
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0} :root{--navy:#1e2d5a;--navy-dark:#16234a;--navy-light:#2a3d78;--red:#c0392b;--red-dark:#a93226;--white:#fff;--off-white:#f4f5f8;--text:#222233;--muted:#5a5f72;--border:#d8dce8;--shadow:0 12px 30px rgba(22,35,74,.14);--nav-h:72px} html{scroll-behavior:smooth} body{font-family:Arial,Helvetica,sans-serif;color:var(--text);background:var(--white);line-height:1.65} h1,h2,h3,h4,.btn,.nav-links a,.eyebrow,.section-label{font-family:Arial,Helvetica,sans-serif} a{color:inherit}.container{max-width:1120px;margin:0 auto;padding:0 2rem}.top-alert{background:var(--red);color:#fff;text-align:center;padding:.45rem 1rem;font-size:.86rem;font-weight:700}.top-alert a{text-decoration:none}nav{position:sticky;top:0;z-index:1000;background:var(--navy-dark);min-height:var(--nav-h);display:flex;align-items:center;padding:0 2rem;gap:1.5rem;box-shadow:0 2px 12px rgba(0,0,0,.35)}.nav-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:#fff}.logo-mark{width:50px;height:50px;border:2px solid rgba(255,255,255,.3);border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--navy-light),var(--navy-dark));font-weight:900;letter-spacing:-.08em}.logo-text{line-height:1}.logo-text strong{display:block;text-transform:uppercase;letter-spacing:.08em;font-size:.92rem}.logo-text span{font-size:.72rem;color:#aeb8d6;text-transform:uppercase;letter-spacing:.12em}.nav-links{display:flex;align-items:center;gap:.1rem;list-style:none;margin-left:auto}.nav-links a{color:#c8cde0;text-decoration:none;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;padding:.45rem .7rem;border-radius:2px;transition:color .2s,background .2s}.nav-links a:hover{color:#fff;background:rgba(255,255,255,.05)}.nav-dropdown{position:relative}.nav-dropdown>a::after{content:' ▾';font-size:.55rem;opacity:.7}.dropdown-menu{display:none;position:absolute;top:100%;left:0;background:var(--navy);min-width:300px;border-top:3px solid var(--red);padding:.5rem 0;z-index:999;box-shadow:0 8px 24px rgba(0,0,0,.3)}.nav-dropdown:hover .dropdown-menu{display:block}.dropdown-menu a{display:block;padding:.65rem 1.25rem;font-size:.78rem;color:#b0b8d0;text-transform:none;letter-spacing:.02em;border-radius:0}.dropdown-see-all{border-top:1px solid rgba(255,255,255,.12)!important;margin-top:.25rem!important;padding-top:.85rem!important;color:var(--red)!important;font-weight:900!important;text-transform:uppercase!important;letter-spacing:.06em!important;font-size:.72rem!important}.dropdown-see-all:hover{color:#fff!important;background:var(--red)!important}.nav-cta{background:var(--red)!important;color:#fff!important;padding:.55rem 1.1rem!important;border-radius:3px;font-weight:900!important;white-space:nowrap;margin-left:.5rem}.nav-cta:hover{background:var(--red-dark)!important}.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0;padding:4px;margin-left:auto}.hamburger span{display:block;width:24px;height:2px;background:#fff}.mobile-menu{display:none;background:var(--navy);padding:1rem 1.5rem 1.5rem;flex-direction:column}.mobile-menu a{display:block;color:#c8cde0;text-decoration:none;font-size:.88rem;padding:.65rem 0;border-bottom:1px solid rgba(255,255,255,.08);text-transform:uppercase;letter-spacing:.06em;font-weight:700}.mobile-menu.open{display:flex}.hero{position:relative;min-height:78vh;display:flex;align-items:center;overflow:hidden;background:var(--navy-dark)}.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(105deg,rgba(22,35,74,.88) 0%,rgba(22,35,74,.75) 42%,rgba(192,57,43,.42) 100%),url('hero-bridge.svg');background-size:cover;background-position:center;opacity:1}.hero-content{position:relative;z-index:2;max-width:760px;padding:5rem 2rem 5rem 8vw}.eyebrow,.section-label{font-size:.76rem;font-weight:900;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:1rem;display:flex;align-items:center;gap:.55rem}.eyebrow::before,.section-label::before{content:'';width:28px;height:2px;background:var(--red)}.hero h1{font-size:clamp(2.35rem,5vw,4.25rem);font-weight:900;line-height:1.05;color:#fff;text-transform:uppercase;letter-spacing:.02em;margin-bottom:1.15rem}.hero h1 span{color:var(--red)}.hero-sub{color:rgba(255,255,255,.82);font-size:1.08rem;max-width:590px;margin-bottom:2rem}.hero-btns,.cta-row{display:flex;gap:1rem;flex-wrap:wrap}.btn{display:inline-block;text-decoration:none;text-transform:uppercase;letter-spacing:.1em;font-size:.88rem;font-weight:900;border-radius:3px;padding:.9rem 1.6rem;transition:.2s}.btn-red{background:var(--red);color:#fff}.btn-red:hover{background:var(--red-dark)}.btn-outline{border:2px solid rgba(255,255,255,.55);color:#fff}.btn-outline:hover{border-color:var(--red);color:#fff;background:rgba(192,57,43,.18)}.btn-navy{background:var(--navy);color:#fff}.btn-navy:hover{background:var(--navy-light)}.intro-strip{background:var(--navy);padding:1.4rem 2rem;text-align:center}.intro-strip h2{font-size:clamp(1.05rem,2.4vw,1.55rem);text-transform:uppercase;letter-spacing:.06em;color:#fff}.intro-strip span{color:var(--red)}section{padding:5rem 0}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.card{background:#fff;padding:2rem;border-top:4px solid var(--red);box-shadow:var(--shadow)}.card.dark{background:var(--navy-light);border-left:4px solid var(--red);border-top:0;color:#fff}.card h3{color:var(--navy);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.7rem;font-size:1.05rem}.card.dark h3{color:#fff}.card p,.card li{color:var(--muted);font-size:.94rem}.card.dark p,.card.dark li{color:#c8cde0}.card ul{padding-left:1.15rem}.center{text-align:center}.center .section-label{justify-content:center}.center .section-label::before{display:none}.section-title{font-size:clamp(1.75rem,3.2vw,2.55rem);font-weight:900;line-height:1.15;text-transform:uppercase;letter-spacing:.03em;color:var(--navy);margin-bottom:1.2rem}.lead{font-size:1.05rem;color:var(--muted);max-width:820px;margin:0 auto 2rem;line-height:1.85}.off{background:var(--off-white)}.navy-section{background:var(--navy);color:#fff}.navy-section .section-title{color:#fff}.navy-section .lead{color:#c8cde0}.split{display:grid;grid-template-columns:1fr 1fr;min-height:500px;padding:0}.split-img{background:url('truck-yard.svg') center/cover no-repeat;min-height:380px}.split-text{background:var(--navy-dark);padding:4rem 3.5rem;display:flex;flex-direction:column;justify-content:center}.split-text h2{font-size:clamp(1.6rem,2.6vw,2.3rem);font-weight:900;text-transform:uppercase;color:#fff;line-height:1.2;margin-bottom:1.2rem}.split-text p{color:#aeb8d6;margin-bottom:1.8rem}.page-hero{background:linear-gradient(105deg,rgba(22,35,74,.96),rgba(30,45,90,.84)),url('hero-bridge.svg') center/cover;min-height:350px;display:flex;align-items:center;color:#fff}.page-hero .container{padding-top:3rem;padding-bottom:3rem}.page-hero h1{font-size:clamp(2rem,4.8vw,3.6rem);text-transform:uppercase;line-height:1.08;margin-bottom:1rem}.page-hero p{max-width:760px;color:#d8dce8;font-size:1.05rem}.content{max-width:900px;margin:0 auto}.content h2{font-size:1.7rem;text-transform:uppercase;color:var(--navy);margin:2rem 0 .75rem}.content h3{color:var(--navy);margin:1.5rem 0 .5rem}.content p{margin:.85rem 0;color:var(--muted)}.content ul{padding-left:1.3rem;color:var(--muted);margin:.8rem 0}.cta-band{background:var(--red);color:#fff;text-align:center;padding:4rem 2rem}.cta-band h2{font-size:clamp(1.55rem,3vw,2.35rem);text-transform:uppercase;margin-bottom:.4rem}.cta-band p{color:rgba(255,255,255,.85);margin-bottom:1.6rem}.related{background:var(--off-white);padding:3rem 0}.related h2{font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);margin-bottom:1.1rem}.related-links{display:flex;flex-wrap:wrap;gap:.6rem}.related-links a{display:inline-block;color:var(--navy);text-decoration:none;font-size:.86rem;border:1px solid var(--border);padding:.5rem .9rem;background:#fff}.related-links a:hover{border-color:var(--red);color:var(--red)}.blog-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}.post-card{background:#fff;border:1px solid var(--border);box-shadow:var(--shadow);padding:1.4rem;text-decoration:none}.post-card span{font-size:.8rem;color:var(--red);font-weight:800}.post-card h3{color:var(--navy);margin:.3rem 0 .5rem}.post-card p{color:var(--muted);font-size:.93rem}.faq-item{border-bottom:1px solid var(--border);padding:1.3rem 0}.faq-item h3{color:var(--navy);font-size:1.05rem}.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem}.contact-box{background:var(--off-white);padding:2rem;border-left:4px solid var(--red)}.contact-box a{display:block;color:var(--navy);font-weight:800;text-decoration:none;margin:.45rem 0}.form-mock input,.form-mock textarea{width:100%;padding:.85rem;border:1px solid var(--border);margin-bottom:.8rem;font:inherit}.form-mock textarea{min-height:140px}.form-mock button{border:0}.service-area-list{columns:2;list-style:none;padding:0!important}.service-area-list li{padding:.15rem 0}.service-area-list li::before{content:'✓ ';color:var(--red);font-weight:900}footer{background:var(--navy-dark);color:#8a96b8;padding:4rem 0 1.5rem}.footer-top{display:flex;align-items:center;gap:1rem;padding-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:2rem}.footer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.4rem;padding-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.08)}.footer-col h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;color:#fff;margin-bottom:1rem}.footer-col ul{list-style:none}.footer-col li,.footer-col p{font-size:.9rem;color:#7a86a8}.footer-col a{display:block;color:#8a96b8;text-decoration:none;margin:.25rem 0}.footer-col a:hover{color:#fff}.footer-bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:1.3rem;font-size:.78rem;color:#4a5270}.mini-ctas{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1rem}.mini-ctas a{background:var(--red);color:#fff!important;font-weight:900;text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;padding:.48rem .9rem;border-radius:2px;margin:0}.photos-row{display:grid;grid-template-columns:1fr 1fr;height:310px;padding:0}.photo1{background:url('engine.svg') center/cover}.photo2{background:url('generator.svg') center/cover}.notice{background:#fff8e8;border-left:4px solid #d19700;padding:1rem;margin:1.2rem 0;color:#5c4a13}@media(max-width:980px){.nav-links{display:none}.hamburger{display:flex}.cards{grid-template-columns:1fr}.blog-list,.contact-grid,.split{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr 1fr}.split-img{min-height:280px}.photos-row{height:220px}}@media(max-width:680px){nav{padding:0 1rem}.container{padding:0 1.3rem}.hero-content{padding:3.5rem 1.3rem}.footer-grid{grid-template-columns:1fr}.footer-top,.footer-bottom{align-items:flex-start;flex-direction:column}.photos-row{grid-template-columns:1fr;height:auto}.photo1,.photo2{height:190px}.service-area-list{columns:1}.split-text{padding:2.5rem 1.3rem}}

/* Logo integration */
.nav-logo-icon{height:48px;width:48px;object-fit:contain;background:#fff;border-radius:8px;padding:4px;box-shadow:0 2px 8px rgba(0,0,0,.22)}
.hero-logo-panel{position:absolute;right:6vw;top:50%;transform:translateY(-50%);z-index:2;width:min(340px,28vw);background:rgba(255,255,255,.96);border-radius:14px;padding:1.2rem;box-shadow:0 18px 50px rgba(0,0,0,.32);border:1px solid rgba(255,255,255,.7)}
.hero-logo-panel img{width:100%;height:auto;display:block}
.footer-logo-full{width:min(330px,100%);height:auto;background:#fff;border-radius:10px;padding:.8rem;box-shadow:0 10px 28px rgba(0,0,0,.22)}
.footer-tagline{font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:#c8cde0;font-size:.88rem}
@media(max-width:1180px){.hero-logo-panel{display:none}.hero-content{max-width:850px}}
@media(max-width:680px){.nav-logo-icon{height:42px;width:42px}.logo-text strong{font-size:.78rem}.logo-text span{font-size:.62rem}.footer-logo-full{width:260px}}


/* --- Humanized Lowcountry Diagnostics adjustments --- */
:root{
  --paper:#f7f5f0;
  --ink:#1f2430;
  --steel:#343b4d;
  --sand:#e9e2d6;
}
body{
  background:var(--paper);
  color:var(--ink);
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.06;
  background-image:
    linear-gradient(90deg, rgba(30,45,90,.35) 1px, transparent 1px),
    linear-gradient(rgba(30,45,90,.35) 1px, transparent 1px);
  background-size:42px 42px;
  z-index:-1;
}
.top-alert{
  background:#b72a22;
  font-size:.82rem;
  letter-spacing:.02em;
}
nav{
  background:#121b38;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.logo-text strong{letter-spacing:.045em}
.logo-text span{letter-spacing:.08em}
.nav-links a{letter-spacing:.045em}
.hero{
  min-height:72vh;
  border-bottom:8px solid #b72a22;
}
.hero::before{
  background:
    linear-gradient(98deg,rgba(18,27,56,.94) 0%,rgba(18,27,56,.84) 48%,rgba(18,27,56,.35) 100%),
    url('hero-bridge.svg');
  background-size:cover;
  background-position:center;
}
.hero h1,.page-hero h1{
  letter-spacing:-.015em;
  text-transform:none;
}
.hero h1 span,.intro-strip span{color:#d23b31}
.hero-sub{
  font-size:1.02rem;
  line-height:1.75;
}
.hero-logo-panel{
  width:min(255px,22vw);
  border-radius:4px;
  padding:.75rem;
  transform:translateY(-50%) rotate(-1deg);
  box-shadow:0 12px 30px rgba(0,0,0,.25);
}
.btn{
  border-radius:2px;
  letter-spacing:.055em;
}
.card{
  border-top:0;
  border-left:5px solid var(--red);
  box-shadow:0 8px 22px rgba(22,35,74,.09);
  background:#fffdfa;
}
.card h3{
  text-transform:none;
  letter-spacing:0;
  color:#172449;
}
.card p,.content p,.page-hero p{color:#51586b}
.navy-section{
  background:#172449;
}
.navy-section .card.dark{
  background:#223466;
  border-left-color:#d23b31;
}
.split-text{
  background:#121b38;
}
.split-img,.photo1,.photo2{
  filter:saturate(.85) contrast(.96);
}
.page-hero{
  min-height:315px;
  background:
    linear-gradient(100deg,rgba(18,27,56,.95),rgba(18,27,56,.78)),
    url('hero-bridge.svg') center/cover;
  border-bottom:6px solid #b72a22;
}
.section-title{
  text-transform:none;
  letter-spacing:-.02em;
}
.eyebrow,.section-label{
  letter-spacing:.12em;
}
.service-note{
  background:#fff;
  border:1px solid #d8d0c3;
  border-left:7px solid #b72a22;
  padding:2rem;
  box-shadow:0 10px 28px rgba(22,35,74,.08);
  position:relative;
}
.service-note::after{
  content:"service note";
  position:absolute;
  right:1rem;
  top:1rem;
  color:rgba(30,45,90,.18);
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.72rem;
}
.service-note h2{
  margin-bottom:.75rem;
  color:#172449;
  font-size:clamp(1.45rem,3vw,2.15rem);
}
.service-note p{color:#4d5568;max-width:880px}
.check-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
  margin-top:1.2rem;
}
.check-row div{
  background:#f7f5f0;
  border:1px solid #e3dccf;
  padding:.95rem;
  font-size:.92rem;
  font-weight:700;
  color:#29334f;
}
.local-strip{
  background:#fffdfa;
  border-top:1px solid #e5ded2;
  border-bottom:1px solid #e5ded2;
  padding:1.4rem 0;
}
.local-strip p{
  margin:0;
  color:#37405a;
}
.real-copy{
  font-size:1.04rem;
  line-height:1.85;
}
.footer-logo-full{
  border-radius:3px;
  padding:.65rem;
}
footer{
  background:#10182f;
}
@media(max-width:980px){
  .check-row{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .hero h1,.page-hero h1{text-transform:none}
  .check-row{grid-template-columns:1fr}
  .service-note{padding:1.4rem}
}





/* --- Clean Ravenel Bridge photo homepage hero --- */
.home-bridge-hero{
  min-height:84vh;
  text-align:left;
  justify-content:flex-start;
  background:#111827;
}
.home-bridge-hero::before{
  background:
    linear-gradient(90deg, rgba(9,14,32,.86) 0%, rgba(9,14,32,.68) 36%, rgba(9,14,32,.28) 68%, rgba(9,14,32,.36) 100%),
    linear-gradient(180deg, rgba(9,14,32,.04), rgba(9,14,32,.64)),
    url('home-bridge-background.webp') center center / cover no-repeat;
}
.home-bridge-hero .hero-content{
  margin:0;
  margin-left:min(7vw,96px);
  max-width:760px;
  padding:5.5rem 2rem;
  background:linear-gradient(90deg, rgba(7,12,29,.62), rgba(7,12,29,.20), rgba(7,12,29,0));
  border-left:6px solid #b72a22;
}
.home-bridge-hero .eyebrow,
.home-bridge-hero .hero-btns,
.hero-quick-points{
  justify-content:flex-start;
}
.home-bridge-hero h1,
.home-bridge-hero .hero-sub{
  margin-left:0;
  margin-right:0;
}
.home-bridge-hero h1{
  max-width:720px;
  text-transform:none;
  font-size:clamp(2.75rem,5.4vw,5rem);
  line-height:.98;
  letter-spacing:-.035em;
  color:#fff;
  text-shadow:0 4px 22px rgba(0,0,0,.72);
}
.home-bridge-hero .hero-sub{
  max-width:650px;
  color:rgba(255,255,255,.92);
}
@media(max-width:680px){
  .home-bridge-hero{
    min-height:78vh;
  }
  .home-bridge-hero::before{
    background:
      linear-gradient(90deg, rgba(9,14,32,.88), rgba(9,14,32,.55)),
      linear-gradient(180deg, rgba(9,14,32,.08), rgba(9,14,32,.76)),
      url('home-bridge-background.webp') center center / cover no-repeat;
  }
  .home-bridge-hero .hero-content{
    margin-left:0;
    border-left:4px solid #b72a22;
    padding:4.5rem 1.3rem;
    background:rgba(7,12,29,.48);
  }
}


/* --- Remove faint text/tags below homepage buttons --- */
.hero-quick-points{
  display:none !important;
}
.home-bridge-hero .hero-btns{
  margin-top:1.6rem;
  margin-bottom:0;
}
.home-bridge-hero .hero-content{
  padding-bottom:5rem;
}


/* --- Homepage heavy truck repair section whitespace fix --- */
.truck-repair-band{
  padding:5rem 0;
  background:
    linear-gradient(100deg, rgba(18,27,56,.94), rgba(18,27,56,.82)),
    url('truck-yard.svg') center / cover no-repeat;
}
.truck-repair-card{
  max-width:760px;
  background:rgba(18,27,56,.88);
  border-left:6px solid #b72a22;
  padding:2.4rem;
  color:#fff;
  box-shadow:0 18px 45px rgba(0,0,0,.22);
}
.truck-repair-card .section-label{
  margin-bottom:.7rem;
}
.truck-repair-card h2{
  font-size:clamp(1.9rem,4vw,3.1rem);
  line-height:1.05;
  letter-spacing:-.025em;
  margin-bottom:1rem;
  color:#fff;
}
.truck-repair-card p{
  max-width:650px;
  margin-bottom:1.5rem;
  color:rgba(255,255,255,.84);
  font-size:1.03rem;
  line-height:1.75;
}
@media(max-width:680px){
  .truck-repair-band{
    padding:3rem 0;
  }
  .truck-repair-card{
    padding:1.6rem;
    border-left:4px solid #b72a22;
  }
}


/* --- Final readability, visibility, and SEO cleanup pass --- */
body{
  font-size:16px;
}
h1,h2,h3,h4,p,li,a,span{
  text-rendering:optimizeLegibility;
}
.hero h1,
.home-bridge-hero h1,
.page-hero h1,
.truck-repair-card h2,
.split-text h2{
  color:#ffffff;
  text-shadow:0 3px 18px rgba(0,0,0,.72);
}
.hero-sub,
.home-bridge-hero .hero-sub,
.page-hero p,
.split-text p,
.truck-repair-card p{
  color:rgba(255,255,255,.93);
  text-shadow:0 2px 12px rgba(0,0,0,.62);
}
.card p,
.card li,
.content p,
.content li,
.contact-box p,
.contact-box a,
.footer-col p,
.footer-col li,
.footer-col a{
  color:#3f4658;
}
.navy-section .card.dark p,
.navy-section .card.dark li{
  color:#dfe5f4;
}
.navy-section .card.dark h3,
.navy-section h2,
.navy-section .lead{
  color:#ffffff;
}
.footer-col p,
.footer-col li,
.footer-col a{
  color:#c6cee4;
}
.footer-bottom{
  color:#aeb7d3;
}
.btn{
  min-height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.btn-red{
  background:#b72a22;
  color:#fff;
}
.btn-red:hover{
  background:#941f19;
}
.btn-outline{
  color:#fff;
}
.service-detail-list{
  background:#f7f5f0;
  padding:4rem 0 1.5rem;
}
.service-detail-list .card h2{
  font-size:1.35rem;
  color:#172449;
  margin-bottom:.85rem;
}
.service-detail-list ul{
  padding-left:1.2rem;
}
.service-detail-list li{
  margin:.35rem 0;
}
.page-hero{
  position:relative;
}
.page-hero::after,
.home-bridge-hero::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.18));
  z-index:1;
}
.page-hero .container,
.home-bridge-hero .hero-content{
  position:relative;
  z-index:2;
}
.service-note h2,
.card h2,
.card h3,
.content h2,
.content h3{
  color:#172449;
}
.service-note p,
.real-copy{
  color:#37405a;
}
img{
  max-width:100%;
  height:auto;
}
@media(max-width:680px){
  body{
    font-size:16px;
  }
  .card{
    padding:1.45rem;
  }
  .page-hero p,
  .home-bridge-hero .hero-sub{
    font-size:1rem;
  }
}


/* --- SEO/internal link and readability final polish --- */
.related-seo-links{
  background:#f7f5f0;
  padding:3rem 0;
  border-top:1px solid #e3dccf;
}
.related-seo-links h2{
  font-size:1.35rem;
  color:#172449;
  margin-bottom:1rem;
}
.related-seo-links .related-links{
  display:flex;
  flex-wrap:wrap;
  gap:.7rem;
}
.related-seo-links .related-links a{
  background:#fffdfa;
  border:1px solid #d8d0c3;
  color:#172449;
  padding:.65rem .9rem;
  text-decoration:none;
  font-weight:700;
}
.related-seo-links .related-links a:hover{
  border-color:#b72a22;
  color:#b72a22;
}
[aria-current="page"]{
  color:#fff !important;
}
main a:not(.btn), .content a:not(.btn), .card a:not(.btn){
  text-decoration-thickness:2px;
  text-underline-offset:3px;
}

/* Footer logo cleanup: remove white card/background behind the transparent logo */
.footer-logo-full{
  background:transparent !important;
  box-shadow:none !important;
  padding:0 !important;
  border-radius:0 !important;
}


/* Clear communication section */
.communication-section{padding:2.5rem 0;background:#f7f8fb;}
.communication-note{border-left:4px solid var(--red);}
.communication-note h2{margin-bottom:.5rem;}


/* Clean footer brand: avoid blurry full-logo image on dark footer */
.footer-brand-clean{
  align-items:center;
  gap:1rem;
}
.footer-logo-icon{
  width:96px;
  height:96px;
  object-fit:contain;
  flex:0 0 auto;
  background:transparent;
  border-radius:0;
  box-shadow:none;
}
.footer-brand-text strong{
  display:block;
  color:#fff;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:1.2rem;
  line-height:1.15;
}
.footer-brand-text span{
  display:block;
  color:#c8cde0;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.78rem;
  font-weight:800;
  margin-top:.25rem;
}
.footer-brand-text p{
  color:#aeb8d6;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.11em;
  font-size:.78rem;
  margin-top:.7rem;
  max-width:540px;
}
@media(max-width:680px){
  .footer-logo-icon{width:76px;height:76px;}
  .footer-brand-text strong{font-size:1rem;}
  .footer-brand-text span,.footer-brand-text p{font-size:.68rem;}
}


/* Google Business Profile live feed section */
.google-proof-section{
  background:#f4f7fb;
  padding:72px 0;
  overflow:hidden;
}
.proof-header{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:24px;
  margin-bottom:28px;
}
.proof-header .lead{
  max-width:780px;
  margin-bottom:0;
}
.proof-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:24px;
}
.live-feed-card{
  background:#fff;
  border:1px solid rgba(22,35,74,.12);
  border-radius:22px;
  box-shadow:0 18px 45px rgba(22,35,74,.10);
  padding:24px;
  overflow:hidden;
}
.feed-title-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  margin-bottom:18px;
}
.feed-title-row h3{
  margin:0;
  color:var(--navy);
}
.feed-title-row span{
  color:var(--red);
  font-size:.82rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.live-widget-slot{
  min-height:260px;
  position:relative;
  overflow:hidden;
  border-radius:16px;
  background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
}
.scroll-track{
  display:flex;
  gap:16px;
  width:max-content;
  animation:scroll-feed 28s linear infinite;
  padding:8px 0;
}
.live-widget-slot:hover .scroll-track{
  animation-play-state:paused;
}
.review-placeholder,
.post-placeholder{
  width:260px;
  min-height:210px;
  border:1px solid rgba(22,35,74,.12);
  border-radius:18px;
  padding:20px;
  background:#fff;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.review-placeholder strong,
.post-placeholder strong{
  color:var(--navy);
  font-size:1.05rem;
  margin-bottom:10px;
}
.review-placeholder p,
.post-placeholder p{
  color:#4b5563;
  line-height:1.55;
  margin:0;
}
.proof-note{
  margin:18px 0 0;
  color:#64748b;
  font-size:.92rem;
}
@keyframes scroll-feed{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}
@media(max-width:850px){
  .proof-header{display:block;}
  .proof-header .btn{margin-top:18px;}
  .proof-grid{grid-template-columns:1fr;}
  .review-placeholder,.post-placeholder{width:235px;}
}


/* Common Ninja Google Reviews visibility fix */
.google-proof-featured{
  padding:56px 0;
}
.proof-header-centered{
  align-items:center;
}
.reviews-widget-card{
  max-width:1100px;
  margin:0 auto;
}
.commonninja-review-slot{
  min-height:420px;
  height:auto;
  overflow:visible;
  background:#fff;
}
.commonninja-review-slot .commonninja_component,
#google-reviews-live .commonninja_component{
  display:block;
  width:100%;
  min-height:380px;
}
@media (max-width: 720px){
  .proof-header-centered{display:block;}
  .proof-header-centered .btn{margin-top:18px;}
  .commonninja-review-slot{min-height:500px;}
}

/* Shapo reviews widget visibility fix */
.google-proof-featured {
  position: relative;
  z-index: 2;
}
.reviews-widget-card {
  overflow: visible !important;
}
.shapo-review-slot,
#shapo-widget-d8df53beeffabacd6f34 {
  display: block;
  width: 100%;
  min-height: 360px;
  overflow: visible !important;
}
.shapo-review-slot {
  padding: 10px 0 0;
}
@media (max-width: 700px) {
  .shapo-review-slot,
  #shapo-widget-d8df53beeffabacd6f34 {
    min-height: 460px;
  }
}

/* Shapo reviews widget size refinement */
.google-proof-featured{
  padding:44px 0;
}
.google-proof-featured .proof-header{
  margin-bottom:18px;
}
.reviews-widget-card{
  max-width:820px;
  padding:18px;
}
.shapo-review-slot,
#shapo-widget-d8df53beeffabacd6f34{
  min-height:260px;
}
.shapo-review-slot{
  padding-top:0;
}
@media (max-width:700px){
  .google-proof-featured{
    padding:36px 0;
  }
  .reviews-widget-card{
    max-width:100%;
    padding:14px;
  }
  .shapo-review-slot,
  #shapo-widget-d8df53beeffabacd6f34{
    min-height:340px;
  }
}


/* Repair photo gallery */
.repair-gallery-section{
  padding:4.5rem 0;
}
.repair-gallery-section .container{
  margin-bottom:1.75rem;
}
.repair-gallery-wrap{
  overflow:hidden;
  padding:0 0 0 2rem;
}
.repair-gallery-track{
  display:flex;
  gap:18px;
  width:max-content;
  animation:scroll-repair-gallery 65s linear infinite;
  padding:8px 2rem 10px 0;
}
.repair-gallery-section:hover .repair-gallery-track{
  animation-play-state:paused;
}
.repair-slide{
  width:320px;
  flex:0 0 320px;
  border-radius:18px;
  overflow:hidden;
  background:#fff;
  border:1px solid rgba(22,35,74,.10);
  box-shadow:0 14px 30px rgba(22,35,74,.10);
}
.repair-slide img{
  width:100%;
  height:245px;
  display:block;
  object-fit:cover;
  background:#eaeef5;
}
.repair-slide-copy{
  padding:16px 18px 18px;
}
.repair-slide-copy h3{
  margin:0 0 8px;
  color:var(--navy);
  font-size:1rem;
  text-transform:uppercase;
  letter-spacing:.03em;
}
.repair-slide-copy p{
  margin:0;
  color:var(--muted);
  font-size:.93rem;
  line-height:1.55;
}
@keyframes scroll-repair-gallery{
  from{transform:translateX(0);}
  to{transform:translateX(calc(-50% - 9px));}
}
@media(max-width:980px){
  .repair-gallery-wrap{padding-left:1.3rem;}
  .repair-slide,
  .repair-slide{width:290px;flex-basis:290px;}
  .repair-slide img{height:220px;}
}
@media(max-width:700px){
  .repair-gallery-section{padding:3.5rem 0;}
  .repair-gallery-wrap{
    overflow-x:auto;
    padding:0 1rem 0 1rem;
    -webkit-overflow-scrolling:touch;
  }
  .repair-gallery-track{
    animation:none;
    padding:8px 0 10px;
  }
  .repair-slide{width:265px;flex-basis:265px;}
  .repair-slide img{height:205px;}
}

/* Makes We Work On page */
.make-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1.25rem;
  margin:2.5rem 0;
}
.make-card{
  background:#fff;
  border-top:4px solid var(--red);
  box-shadow:var(--shadow);
  padding:1.5rem;
}
.make-card h3{
  color:var(--navy);
  text-transform:uppercase;
  font-size:.98rem;
  letter-spacing:.04em;
  margin-bottom:.75rem;
}
.make-card ul{
  list-style:none;
  padding:0;
  margin:0;
}
.make-card li{
  color:var(--muted);
  padding:.28rem 0;
  border-bottom:1px solid rgba(22,35,74,.07);
  font-size:.93rem;
}
.make-card li:last-child{
  border-bottom:0;
}
.makes-note{
  margin-top:2rem;
}
@media(max-width:980px){
  .make-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:620px){
  .make-grid{grid-template-columns:1fr;}
}

/* Live contact form */
.contact-form-live label{
  display:block;
  color:var(--navy);
  font-weight:800;
  font-size:.84rem;
  text-transform:uppercase;
  letter-spacing:.06em;
  margin:.7rem 0 .25rem;
}
.contact-form-live select{
  width:100%;
  padding:.85rem;
  border:1px solid var(--border);
  margin-bottom:.8rem;
  font:inherit;
  background:#fff;
  color:var(--text);
}
.contact-form-live button{
  margin-top:.4rem;
  border:0;
  cursor:pointer;
}

/* Facebook feed + reviews two-column layout */
.proof-columns{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.5rem;
  align-items:start;
}
.proof-columns .reviews-widget-card{
  max-width:none;
}
.facebook-feed-card .fb_iframe_widget,
.facebook-feed-card .fb_iframe_widget span,
.facebook-feed-card .fb_iframe_widget span iframe{
  width:100%!important;
  max-width:100%!important;
}
@media(max-width:860px){
  .proof-columns{
    grid-template-columns:1fr;
  }
}
