
:root{--primary:#C0161D;--primaryDark:#8E0F14;--ink:#111111;--bg:#ffffff;--muted:#F5F5F7}
*{box-sizing:border-box}
*,*::before,*::after{border-radius:0 !important}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:"Book Antiqua", Palatino, Georgia, serif;line-height:1.55}


.container{width:min(1140px,92%);margin-inline:auto}
img{max-width:100%;display:block}

.sticky-call{position:fixed;right:16px;bottom:16px;background:var(--primary);color:#fff;text-decoration:none;padding:12px 16px;border-radius:999px;font-weight:700;z-index:90;box-shadow:0 8px 30px rgba(0,0,0,.25)}

.site-header{position:sticky;top:0;z-index:80;background:#151515;color:#fff}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:10px 0 8px;gap:18px}
.brand-block{display:flex;flex-direction:column;gap:4px;align-items:flex-start}
.brand-top{display:flex;align-items:center;gap:10px}
.brand-logo{width:48px;height:48px;border-radius:10px;box-shadow:0 2px 10px rgba(0,0,0,.3)}
.brand-text .brand-title{color:var(--primary);font-weight:700;letter-spacing:.04em;font-size:clamp(1rem,2vw,1.15rem)}
.brand-sub{font-size:.9rem;opacity:.95}
.brand-large{width:150px;height:auto;opacity:.96;filter:drop-shadow(0 4px 16px rgba(0,0,0,.35))}

.nav{display:flex;gap:16px;align-items:center;justify-content:flex-end}
.nav a{color:#fff;text-decoration:none;opacity:.9}
.nav a:hover{opacity:1}
.btn{padding:12px 16px;border-radius:999px;border:1px solid currentColor;text-decoration:none;display:inline-block;transition:.2s ease;white-space:nowrap}
.btn-primary{background:var(--primary);color:#ffffff;border-color:var(--primary)}
.btn-outline{color:#ffffff;border-color:#ffffff}
.btn-outline:hover{background:#ffffff;color:#000000}

h1,h2,h3,.brand-title{font-family:"Book Antiqua", Palatino, Georgia, serif;font-weight:700}
.lead{font-weight:400}

.hero{position:relative;min-height:78vh;display:grid;place-items:center;background:#151515;overflow:hidden}
.hero::before{content:"";position:absolute;inset:-6%;background-image:var(--hero-bg);background-size:cover;background-position:center;opacity:.45;transform:scale(1.1);animation:heroZoom 14s ease-in-out infinite alternate}
@keyframes heroZoom{from{transform:scale(1.1)}to{transform:scale(1.2)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom, rgba(21,21,21,.45), rgba(21,21,21,.25) 40%, rgba(21,21,21,.12))}
.hero-content{position:relative;text-align:center;color:#fff;padding:86px 0}
.hero h1{font-size:clamp(2rem,6vw,3.2rem);margin:8px 0 10px}

.ribbon{background:linear-gradient(90deg, rgba(192,22,29,.08), transparent);padding:18px 0;border-top:1px solid rgba(0,0,0,.06);border-bottom:1px solid rgba(0,0,0,.06)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;text-align:center}
.stats-grid strong{display:block;color:var(--primary);font-size:clamp(1.1rem,2.6vw,1.6rem)}

.section{position:relative;padding:66px 0}
.section-title{font-size:clamp(1.6rem,4vw,2.2rem);margin:0 0 10px}

.kenburns{position:relative;overflow:hidden;color:#fff}
.kenburns .card{color:#111;background:rgba(255,255,255,.9)}
.kenburns .card h3{color:var(--primary)}
.kenburns::before{content:"";position:absolute;inset:-8%;background-image:var(--kb);background-size:cover;background-position:center;filter:brightness(.8);transform:scale(1.08);animation:kb 20s ease-in-out infinite alternate}
@keyframes kb{to{transform:scale(1.16)}}

.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.card{background:rgba(255,255,255,.7);border:1px solid rgba(0,0,0,.08);border-radius:18px;padding:18px;backdrop-filter:blur(4px)}
.card h3{margin-top:0;color:var(--primary)}

.skyline{min-height:44vh;display:grid;place-items:center;text-align:center;color:#fff;background:#151515;position:relative;overflow:hidden}
.skyline::before{content:"";position:absolute;inset:-6%;background-image:var(--skyline);background-size:cover;background-position:center;opacity:.45;transform:scale(1.08);transition:transform 1.6s ease}
.skyline:hover::before{transform:scale(1.12)}

.people-strip{display:grid;grid-template-columns:1fr 1fr}
.people-strip .strip{min-height:42vh;background-image:var(--img);background-size:cover;background-position:center;position:relative;overflow:hidden}
.people-strip .strip::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom, rgba(21,21,21,.25), rgba(21,21,21,.15))}

.testimonials .testimonials-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:start}
.testimonial{background:rgba(255,255,255,.7);border:1px solid rgba(0,0,0,.08);padding:20px;border-radius:16px}
.testimonial cite{display:block;opacity:.8;margin-top:8px}
.video-card .video-wrap{position:relative;border-radius:16px;overflow:hidden;border:1px solid rgba(0,0,0,.08)}
.video-card iframe{width:100%;aspect-ratio:16/9;display:block}
.play-badge{position:absolute;right:10px;bottom:10px;background:var(--primary);color:#fff;text-decoration:none;border-radius:999px;padding:8px 12px;font-weight:700;opacity:.95}

.contact .contact-form{background:rgba(255,255,255,.75);border:1px solid rgba(0,0,0,.12);padding:18px;border-radius:18px}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.form-grid .full{grid-column:1/-1}
label{display:grid;gap:6px;font-size:.95rem}
input,select,textarea{padding:12px 12px;border-radius:12px;border:1px solid rgba(0,0,0,.15);background:rgba(255,255,255,.95);color:#111}

.site-footer{background:#151515;color:#fff;padding:24px 0 8px;margin-top:32px}
.footer-grid{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center}
.brandfoot{display:flex;gap:10px;align-items:center}
.brandfoot img{width:36px;height:36px;border-radius:10px}
.foot-links a{color:#fff;text-decoration:none;opacity:.9;margin-right:10px}
.legal{opacity:.7;text-align:center;border-top:1px solid rgba(255,255,255,.1);padding-top:10px;margin-top:10px}

.reveal-up{opacity:0;transform:translateY(12px);transition:.6s ease}
.reveal-up.in-view{opacity:1;transform:none}

/* Bottom news ticker */
.verdicts-ticker-news{background:#151515;color:#fff;border-top:2px solid var(--primary);overflow:hidden}
.verdicts-ticker-news .track{display:flex;gap:64px;white-space:nowrap;padding:10px 0;animation:ticker 22s linear infinite}
.verdicts-ticker-news span{display:inline-block;opacity:.95}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

@media (max-width: 980px){
  .services-grid{grid-template-columns:1fr 1fr}
  .testimonials .testimonials-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .brand-large{width:120px}
}
@media (max-width: 640px){
  .nav{display:flex;gap:16px;align-items:center;justify-content:flex-end}
  .brand-logo{width:40px;height:40px}
  .brand-large{display:none}
}

.card{color:#111111}
.card p{color:#222}

.brand-top .brand-wordmark{height:38px;width:auto}
@media (max-width:640px){
  .brand-top .brand-wordmark{height:30px}
}

.brand-header-logo{height:46px;width:auto}
@media(max-width:640px){
  .brand-header-logo{height:34px}
}

.site-footer .brand-header-logo{height:64px;width:auto;margin-bottom:10px}
@media(max-width:640px){
  .site-footer .brand-header-logo{height:46px}
}

.site-footer .foot-links{margin-top:-6px}

.site-header .nav{margin-top:-4px}

/* Header logo sizing + alignment */
.site-header .brand-header-logo{height:56px;width:auto}
.site-header .header-inner{align-items:center}
.site-header .nav{margin-top:0;align-items:center}
@media(max-width:640px){
  .site-header .brand-header-logo{height:40px}
}

.site-footer .foot-links{text-align:right;justify-self:end}
.site-footer .foot-links a{margin-left:12px;margin-right:0}

/* Header alignment tweaks */
.site-header .nav{margin-left:auto; justify-content:flex-end; align-items:center}
.site-header .brand-header-logo{height:56px; width:auto; margin-top:4px} /* drop logo a bit */
@media(max-width:640px){
  .site-header .brand-header-logo{height:40px; margin-top:2px}
}

/* Footer alignment + CTA styling to match header */
.site-footer .foot-links{text-align:right; justify-self:end}
.site-footer .foot-cta{justify-self:end}
.site-footer .foot-cta .btn,
.site-footer .btn-outline{background:var(--primary); color:#ffffff; border-color:var(--primary)}
.site-footer .btn-outline:hover{background:#ffffff; color:#000000; border-color:#ffffff}

/* Header logo vertical alignment */
.site-header .brand-header-logo{height:56px;width:auto;margin-top:10px;margin-bottom:6px}
@media(max-width:640px){
  .site-header .brand-header-logo{height:40px;margin-top:6px;margin-bottom:4px}
}

/* Footer grid alignment match header */
.footer-grid{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.footer-grid .brandfoot{flex:0 0 auto}
.footer-grid .foot-links{margin-left:auto;text-align:right}
.footer-grid .foot-cta{margin-left:12px}

/* Match header and footer heights */
.site-header .header-inner,
.site-footer .footer-grid{min-height:80px;align-items:center}
@media(max-width:640px){
  .site-header .header-inner,
  .site-footer .footer-grid{min-height:64px}
}

/* Footer logo consistent with header logo */
.site-footer .brand-header-logo{height:56px;width:auto;margin:0}
@media(max-width:640px){
  .site-footer .brand-header-logo{height:40px;margin:0}
}
img.brand-header-logo{border-radius:0 !important}

/* Align footer CTA on same line as nav links */
.footer-grid{display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap}
.site-footer .foot-links{margin-left:auto;display:flex;align-items:center;gap:16px}
.site-footer .foot-cta{margin-left:16px;display:flex;align-items:center}

/* Footer nav + CTA exact alignment */
.footer-grid{display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap;gap:16px}
.site-footer .foot-links,
.site-footer .foot-cta{display:flex;align-items:center}
.site-footer .foot-links a{display:flex;align-items:center;margin:0 0 0 16px;line-height:1}
.site-footer .foot-cta .btn{display:flex;align-items:center;line-height:1;padding:10px 14px;margin-left:16px}
.site-footer .foot-links a:first-child{margin-left:0}

/* Prevent wrapping that can push CTA down */
.site-footer .foot-links, .site-footer .foot-cta{white-space:nowrap}

/* --- Footer exact nav/CTA alignment to header --- */
.footer-grid{display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap;gap:20px;min-height:80px}
.site-footer .foot-links{display:flex;align-items:center;gap:20px;white-space:nowrap;margin-left:auto}
.site-footer .foot-links a{line-height:1;display:inline-flex;align-items:center}
.site-footer .foot-cta{display:flex;align-items:center;margin-left:16px;white-space:nowrap}

/* Match header .btn-primary metrics */
.site-footer .foot-cta .btn{background:var(--primary);color:#ffffff;border-color:var(--primary);
  padding:12px 16px;border-radius:999px;font-weight:700;line-height:1;display:inline-flex;align-items:center}
.site-footer .foot-cta .btn:hover{background:#ffffff;color:#000000;border-color:#ffffff}

/* Prevent accidental vertical offsets from margins */
.site-footer .foot-cta .btn, .site-footer .foot-links a{margin-top:0;margin-bottom:0}

/* --- Footer identical to header layout --- */
.footer-grid{display:flex;align-items:center;justify-content:space-between;min-height:80px}
.footer-grid .brandfoot{flex:0 0 auto;display:flex;align-items:center}
.footer-grid .foot-links,
.footer-grid .foot-cta{display:flex;align-items:center;gap:20px;margin:0}
.footer-grid .foot-links{margin-right:0}
.footer-grid .foot-cta{margin-left:20px}
.footer-grid .foot-links a{display:inline-flex;align-items:center;line-height:1;margin:0}
.footer-grid .foot-cta .btn{background:var(--primary);color:#fff;border-color:var(--primary);
  padding:12px 16px;border-radius:999px;font-weight:700;line-height:1;display:inline-flex;align-items:center}

/* === FINAL ALIGNMENT PASS (header == footer) === */
.site-header .container, .site-footer .container{width:min(1140px,92%);margin-inline:auto;padding-inline:0}
.site-header .header-inner, .site-footer .footer-grid{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:80px}
.site-header{padding:10px 0 8px}
.site-footer{padding:10px 0 8px}

/* Brand logo sizes identical */
.site-header .brand-header-logo, .site-footer .brand-header-logo{height:56px;width:auto;margin:0}
@media(max-width:640px){
  .site-header .brand-header-logo, .site-footer .brand-header-logo{height:40px}
}

/* Right stacks (nav/links + CTA) share a baseline and never wrap */
.site-header .nav{display:flex;align-items:center;gap:16px;margin-left:auto;white-space:nowrap}
.site-footer .foot-links, .site-footer .foot-cta{display:flex;align-items:center;gap:16px;white-space:nowrap;margin:0}
.site-footer .foot-links{margin-left:auto}
.site-footer .foot-cta .btn{padding:12px 16px;border-radius:999px;font-weight:700;line-height:1;background:var(--primary);color:#fff;border-color:var(--primary)}

/* === BW -> Color hover cards (v35) === */
.practice-bw-section{padding:56px 0}
.practice-bw-section .section-title{font-family:"Book Antiqua", Palatino, Georgia, serif;font-size:2rem;margin:0 0 18px}
.bw-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.bw-grid{grid-template-columns:1fr;gap:14px}}
.bw-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.10);border-radius:14px;overflow:hidden;display:grid;grid-template-rows:220px auto}
.bw-media{background-image:var(--img);background-size:cover;background-position:center;filter:grayscale(100%);transition:filter .35s ease, transform .35s ease}
.bw-card:hover .bw-media{filter:grayscale(0%);transform:scale(1.02)}
.bw-body{padding:16px}
.bw-body h3{margin:0 0 8px 0;font-size:1.15rem}
.bw-body p{margin:0;color:var(--muted);font-size:.98rem;line-height:1.45}

/* v36: Placement, readability, and effect polish */
.practice-bw-section.container{width:min(1140px,92%);margin-inline:auto}
.bw-card{grid-template-rows:260px auto}
.bw-media{filter:grayscale(100%) brightness(.82); transition:filter .4s ease, transform .4s ease}
.bw-card:hover .bw-media{filter:grayscale(0%) brightness(1) saturate(1.15); transform:scale(1.03)}
/* Improve text readability */
.bw-body{background:rgba(0,0,0,0.58); color:#fff; border-top:1px solid rgba(255,255,255,0.12)}
.bw-body p{color:#e6e7ea}
/* Tighten typography */
.bw-body h3{font-weight:700; letter-spacing:.2px}

/* === v37: Transparent overlay + "genie" text reveal, exact skyline width === */
/* Keep section within the same skyline container width */
.practice-bw-section.container{width:min(1140px,92%);margin-inline:auto}

/* Card layout */
.bw-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.bw-grid{grid-template-columns:1fr;gap:14px}}

/* Make image panel responsive and consistent; overlay gradient for readability (transparent feel) */
.bw-card{position:relative;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,0.10);background:transparent}
.bw-media{position:relative;aspect-ratio:16/9;background-image:var(--img);background-size:cover;background-position:center;
  filter:grayscale(100%) brightness(.9);transition:filter .45s ease, transform .45s ease}
/* Gradient overlay (transparent to dark at bottom) to ensure readable text without a solid gray box */
.bw-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to bottom, rgba(0,0,0,0) 45%, rgba(0,0,0,0.35) 75%, rgba(0,0,0,0.6) 100%);
  pointer-events:none}

/* Text overlay sits on top of image, visible in both BW & color */
.bw-body{position:absolute;left:0;right:0;bottom:0;padding:16px 16px 18px;
  color:#fff; text-shadow:0 2px 12px rgba(0,0,0,.45), 0 1px 2px rgba(0,0,0,.6); background:transparent; border-top:none}
.bw-body h3{margin:0 0 6px;font-size:1.15rem;letter-spacing:.2px;font-weight:700}
.bw-body p{margin:0;color:#f1f2f5;font-size:.98rem;line-height:1.45}

/* "Genie" reveal: text subtly materializes upward with de-blur and opacity */
.bw-body h3, .bw-body p{opacity:.85;transform:translateY(6px);filter:blur(1.5px);transition:opacity .45s ease, transform .45s ease, filter .45s ease}
.bw-card:hover .bw-body h3, .bw-card:hover .bw-body p{opacity:1;transform:translateY(0);filter:blur(0)}

/* Hover media effect like Perdue & Kidd */
.bw-card:hover .bw-media{filter:grayscale(0%) brightness(1) saturate(1.15);transform:scale(1.03)}

/* Ensure identical total width to skyline sections: rely on the same container and remove extra margins */
.practice-bw-section{padding:48px 0}

/* v38: switch to <img> based cards */
.bw-media{position:relative;overflow:hidden}
.bw-media img{width:100%;height:100%;object-fit:cover;display:block;
  filter:grayscale(100%) brightness(.9);transition:filter .45s ease, transform .45s ease}
.bw-card:hover .bw-media img{filter:grayscale(0%) brightness(1) saturate(1.15);transform:scale(1.03)}

/* === v39 Triple Feature (Perdue&Kidd-style) === */
.mod_home_triple_feature.container{width:min(1140px,92%);margin-inline:auto;padding:48px 0}
.mod_home_triple_feature .row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:900px){.mod_home_triple_feature .row{grid-template-columns:1fr}}

.mod_home_triple_feature .item{position:relative;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,0.10)}
.mod_home_triple_feature .background img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(100%) brightness(.9);transition:filter .45s ease, transform .45s ease}
.mod_home_triple_feature .item:hover .background img{filter:grayscale(0%) brightness(1) saturate(1.15);transform:scale(1.03)}

/* Content overlay */
.mod_home_triple_feature .content{position:absolute;inset:auto 0 0 0;padding:18px 16px;z-index:2;
  color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.45), 0 1px 2px rgba(0,0,0,.6)}
/* soft gradient for readability without opaque panel */
.mod_home_triple_feature .item::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to bottom, rgba(0,0,0,0) 40%, rgba(0,0,0,0.35) 75%, rgba(0,0,0,0.6) 100%);
  pointer-events:none;z-index:1}

/* Genie reveal */
.mod_home_triple_feature .content h2,
.mod_home_triple_feature .content p,
.mod_home_triple_feature .content .btn{opacity:.85;transform:translateY(6px);filter:blur(1.5px);
  transition:opacity .45s ease, transform .45s ease, filter .45s ease}
.mod_home_triple_feature .item:hover .content h2,
.mod_home_triple_feature .item:hover .content p,
.mod_home_triple_feature .item:hover .content .btn{opacity:1;transform:translateY(0);filter:blur(0)}

/* Logo icon */
.mod_home_triple_feature .logo img{width:112px;height:112px;display:block;margin:0 0 6px}

/* Button style to match site */
.white.alt.btn{display:inline-block;padding:10px 14px;border-radius:999px;border:1px solid #fff;color:#fff;text-decoration:none;font-weight:700}
.white.alt.btn:hover{background:#fff;color:#000}

/* === v40: Bigger/wider triple feature, no icon, full-bleed picture === */
.mod_home_triple_feature.container{width:min(1280px,92%);margin-inline:auto;padding:56px 0}
.mod_home_triple_feature .row{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:1024px){.mod_home_triple_feature .row{grid-template-columns:1fr 1fr}}
@media(max-width:720px){.mod_home_triple_feature .row{grid-template-columns:1fr;gap:16px}}

.mod_home_triple_feature .item{position:relative;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,0.10);
  min-height:520px}
@media(max-width:1024px){.mod_home_triple_feature .item{min-height:460px}}
@media(max-width:720px){.mod_home_triple_feature .item{min-height:380px}}

.mod_home_triple_feature .background{position:absolute;inset:0;z-index:0}
.mod_home_triple_feature .background img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;
  filter:grayscale(100%) brightness(.9);transition:filter .45s ease, transform .45s ease}
.mod_home_triple_feature .item:hover .background img{filter:grayscale(0%) brightness(1) saturate(1.15);transform:scale(1.03)}

/* Content overlay stays on top */
.mod_home_triple_feature .content{position:absolute;inset:auto 0 0 0;padding:22px 18px;z-index:2;
  color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.45), 0 1px 2px rgba(0,0,0,.6)}
/* Transparent gradient for readability */
.mod_home_triple_feature .item::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(to bottom, rgba(0,0,0,0) 42%, rgba(0,0,0,0.35) 76%, rgba(0,0,0,0.62) 100%)}

/* Genie reveal */
.mod_home_triple_feature .content h2,
.mod_home_triple_feature .content p,
.mod_home_triple_feature .content .btn{opacity:.88;transform:translateY(6px);filter:blur(1.2px);
  transition:opacity .45s ease, transform .45s ease, filter .45s ease}
.mod_home_triple_feature .item:hover .content h2,
.mod_home_triple_feature .item:hover .content p,
.mod_home_triple_feature .item:hover .content .btn{opacity:1;transform:translateY(0);filter:blur(0)}

/* === v40 full-bleed tweak (no spacing, edge-to-edge) === */
.mod_home_triple_feature.container{
  width:100vw;
  margin-left:calc(50% - 50vw);
  padding:0;
}
.mod_home_triple_feature .row{gap:0}
.mod_home_triple_feature .item{
  border:none;
  border-radius:0;
  min-height:520px;
}
.mod_home_triple_feature .background{position:absolute;inset:0}
.mod_home_triple_feature .background img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
}
/* tighten content padding so the overlay sits nicely on full-bleed */
.mod_home_triple_feature .content{padding:22px 24px}

/* === v46 Reese Red theme accents === */
:root{
  --rlf-red:#C3202F;
  --rlf-red-dark:#8F1520;
}

/* Global CTA buttons */
.btn, .tbtn, .kbtn, .rlf-cta {
  background: var(--rlf-red);
  color:#fff;
  border:none;
  font-weight:700;
  border-radius:999px;
  padding:10px 16px;
  display:inline-block;
  text-decoration:none;
  transition:all .25s ease;
}
.btn:hover, .tbtn:hover, .kbtn:hover, .rlf-cta:hover {
  background:#fff;
  color:var(--rlf-red);
  border:2px solid var(--rlf-red);
  transform:translateY(-1px);
}

/* Outlined alt buttons (if any) */
.white.alt.btn, .white.alt.kbtn, .white.alt.tbtn {
  background:transparent;
  border:2px solid #fff;
  color:#fff;
}
.white.alt.btn:hover, .white.alt.kbtn:hover, .white.alt.tbtn:hover {
  background:#fff;
  color:#111;
  border-color:#fff;
}

/* Section title accent underline */
.section-title{position:relative}
.section-title::after{
  content:"";
  display:block;
  width:64px;
  height:4px;
  margin-top:8px;
  background:linear-gradient(90deg, var(--rlf-red) 0%, var(--rlf-red-dark) 100%);
  border-radius:2px;
}

/* Optional: subtle red tint on image overlays */
.kcard::after, .tcard::after, .svc-card::after {
  background:linear-gradient(to bottom, rgba(195,32,47,0.05) 0%, rgba(0,0,0,0.55) 80%, rgba(0,0,0,0.78) 100%);
}


/* Minimal add: red CTA variant */
.btn-red { background:#d60000 !important; color:#fff !important; border-color:#d60000 !important; }
.btn-red:hover, .btn-red:focus { filter:brightness(0.92); color:#fff !important; }

/* Minimal sticky call bar */
#sticky-bar { position:fixed; bottom:14px; left:50%; transform:translateX(-50%); background:#ffffffee; padding:8px 14px; border-radius:999px; box-shadow:0 6px 24px rgba(0,0,0,0.15); z-index:9999; }
#sticky-bar a { text-decoration:none; font-weight:700; }

/* Subline style inspired by reference image */
.hero-subline { letter-spacing: 0.1em; text-transform: uppercase; opacity: 0.9; font-weight: 600; }

/* Testimonial cards */
.testimonial-card { margin:1rem 0; padding:1rem 1.25rem; background:#fff; border:1px solid #eee; border-left:4px solid #d60000; border-radius:10px; }
.testimonial-card cite { display:block; margin-top:0.5rem; font-style:normal; color:#555; }


.sub-hero img { width:100%; height:auto; display:block; border-radius:12px; }
.content h1 { margin-top:0.25rem; }
.content h2 { margin-top:1rem; font-size:1.25rem; }
.content p, .content li { line-height:1.6; }


/* --- Services pages visual upgrades (scoped) --- */
.service-page .hero-banner { position: relative; min-height: 56vh; display:flex; align-items:center; justify-content:center; border-radius: 0 0 18px 18px; overflow:hidden; }
.service-page .hero-banner::before { content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.35) 40%, rgba(0,0,0,0.55) 100%); }
.service-page .hero-banner .hero-bg { position:absolute; inset:0; background-size: cover; background-position: center; transform: scale(1.03); }
.service-page .hero-banner .hero-content { position:relative; z-index:1; text-align:center; padding: 2rem 1rem; color:#fff; max-width: 900px; }
.service-page .hero-banner .hero-title { font-size: clamp(2rem, 5vw, 3rem); line-height:1.1; margin:0; }
.service-page .hero-banner .hero-sub { margin-top: 0.5rem; letter-spacing: 0.05em; text-transform: none; opacity:0.95; font-weight:600; }

/* Section flow with white cards and subtle separators */
.service-page main { background: #f7f7f9; }
.service-page .section { background:#fff; padding: clamp(1rem, 2vw, 1.75rem); border-radius: 14px; box-shadow: 0 4px 24px rgba(0,0,0,0.06); margin: 1rem auto; max-width: 1100px; }
.service-page .section + .section { margin-top: 1rem; }
.service-page .slice { height: 28px; }

/* Typographic polish */
.service-page .section h1 { margin:0 0 0.5rem 0; font-size: clamp(1.6rem, 3.8vw, 2.2rem); }
.service-page .section h2 { margin-top:1rem; font-size: clamp(1.2rem, 2.2vw, 1.5rem); }
.service-page .section p, .service-page .section li { line-height:1.7; }

/* Keep sticky CTA consistent */
.service-page #sticky-bar a.btn.btn-red { display:inline-block; }


/* --- About page polish --- */
.about-page .hero-banner { position:relative; min-height: 60vh; display:flex; align-items:center; justify-content:center; overflow:hidden; border-radius: 0 0 18px 18px; }
.about-page .hero-banner::before { content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0.55) 100%); }
.about-page .hero-banner .hero-bg { position:absolute; inset:0; background-size: cover; background-position: center; transform: scale(1.04); }
.about-page .hero-banner .hero-content { position:relative; z-index:1; text-align:center; color:#fff; padding: 2rem 1rem; max-width: 900px; }
.about-page .hero-title { font-size: clamp(2rem, 5vw, 3rem); margin:0; line-height:1.1; }
.about-page .hero-sub { margin-top: .5rem; letter-spacing:.05em; text-transform: none; opacity:.95; font-weight:600; }

.about-page main { background:#f7f7f9; }
.about-page .section { background:#fff; padding: clamp(1rem, 2vw, 1.75rem); border-radius:14px; box-shadow: 0 4px 24px rgba(0,0,0,0.06); margin: 1rem auto; max-width: 1100px; }
.about-page .bio { display:grid; grid-template-columns: 160px 1fr; gap:1rem; align-items:center; }
.about-page .bio img { width:160px; height:160px; border-radius:9999px; object-fit:cover; box-shadow: 0 6px 22px rgba(0,0,0,0.12); }
.about-page .cta-card { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:.75rem; padding:1rem 1.25rem; border:1px solid #eee; border-left:4px solid #d60000; border-radius:12px; }
.about-page .cta-card .actions a { margin-right:.5rem; }
@media (max-width: 640px) {
  .about-page .bio { grid-template-columns: 1fr; text-align:center; }
}


/* --- Uniform red accent across cards/sections --- */
.service-page .section, .about-page .section { border-left: 4px solid #d60000; }
.service-page .section h2, .about-page .section h2 { position: relative; padding-bottom: .25rem; }
.service-page .section h2::after, .about-page .section h2::after {
  content:""; position:absolute; left:0; bottom:0; width:56px; height:3px; background:#d60000;
}


.about-page .team { display:grid; grid-template-columns: repeat(3, 1fr); gap:1rem; }
.about-page .team .card { background:#fff; border-radius:14px; box-shadow:0 4px 24px rgba(0,0,0,0.06); overflow:hidden; border-left:4px solid #d60000; }
.about-page .team img { width:100%; height:240px; object-fit:cover; display:block; }
.about-page .team .meta { padding:0.75rem 1rem; }
.about-page .team .meta h3 { margin:0 0 .25rem 0; font-size:1.1rem; }
.about-page .team .meta p { margin:0; color:#444; }
@media (max-width: 980px) { .about-page .team { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .about-page .team { grid-template-columns: 1fr; } }


/* --- Simple entrance animation like home --- */
@keyframes fadeUp { from { opacity:0; transform: translateY(16px);} to { opacity:1; transform:none;} }
.hero-banner .hero-content, .section { animation: fadeUp .8s ease-out both; }


/* --- Uniform tinted hero overlay for service pages --- */
.service-page .hero-banner::before { content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,0.4) 0%, rgba(0,0,0,0.45) 40%, rgba(0,0,0,0.6) 100%); }
.service-page .hero-banner .hero-title, .service-page .hero-banner .hero-sub { color:#fff; }


/* --- Bio image fix for Rabbiyah Reese --- */
.about-page .bio img {
  width: 220px;
  height: auto;
  max-height: 320px;
  border-radius: 20px; /* oval corners instead of circle */
  object-fit: contain;
  background:#fff;
  padding:4px;
}
@media (max-width:640px){
  .about-page .bio img { width: 80%; height:auto; max-height:none; }
}


/* --- Team image oval styling (uniform) --- */
.about-page .team img {
  width: 100%;
  height: 260px;
  object-fit: cover;
  border-radius: 20px;
  background: #fff;
  padding: 4px;
}


/* --- Hero tint overlay for service page banners --- */
.service-page .hero-banner::before {
  content:"";
  position:absolute;
  inset:0;
  background: rgba(0,0,0,0.45);
  mix-blend-mode: multiply;
}
.service-page .hero-banner .hero-title,
.service-page .hero-banner .hero-sub {
  color:#fff;
}


/* --- Sticky header with solid background on scroll --- */
header.site-header { position: sticky; top: 0; z-index: 1000; transition: background-color .25s ease, box-shadow .25s ease; }
header.site-header.is-scrolled { background: rgba(255,255,255,0.92); box-shadow: 0 6px 22px rgba(0,0,0,0.08); backdrop-filter: saturate(1.1) blur(6px); }
header.site-header .nav a { color: inherit; }


/* --- Sticky header contrast polish --- */
header.site-header .nav a { transition: color .22s ease, opacity .22s ease; }
header.site-header:not(.is-scrolled) .nav a { color:#fff; text-shadow:0 1px 6px rgba(0,0,0,.25); }
header.site-header.is-scrolled .nav a { color:#111; text-shadow:none; }

/* CTA button behavior in header */
header.site-header .nav .btn { border-radius:9999px; padding: .5rem .9rem; transition: background-color .22s ease, color .22s ease, border-color .22s ease, box-shadow .22s ease; }
header.site-header:not(.is-scrolled) .nav .btn { background:transparent; color:#fff; border:1px solid rgba(255,255,255,.85); box-shadow:0 1px 6px rgba(0,0,0,.25) inset; }
header.site-header:not(.is-scrolled) .nav .btn:hover { background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.95); }

header.site-header.is-scrolled .nav .btn { background:#d60000; color:#fff; border:1px solid #d60000; box-shadow:none; }
header.site-header.is-scrolled .nav .btn:hover { filter:brightness(.95); box-shadow:0 6px 18px rgba(214,0,0,.25); }

/* Practice Areas dropdown: adapt colors with header state */
.site-header .nav .nav-submenu { background: rgba(0,0,0,0.92); border:1px solid rgba(255,255,255,0.08); }
.site-header .nav .nav-submenu a { color:#fff; }
header.site-header:not(.is-scrolled) .nav .nav-submenu a { color:#fff; }
header.site-header:not(.is-scrolled) .nav .nav-submenu { background: rgba(0,0,0,0.92); border:1px solid rgba(255,255,255,0.08); }
header.site-header.is-scrolled .nav .nav-submenu { background:#ffffff; border:1px solid rgba(0,0,0,0.08); }
header.site-header.is-scrolled .nav .nav-submenu a { color:#111 !important; }
header.site-header.is-scrolled .nav .nav-submenu a:hover { background: rgba(0,0,0,0.06); }
header.site-header:not(.is-scrolled) .nav .nav-submenu a:hover { background: rgba(255,255,255,0.08); }

/* Header contact strip: sync colors with header state */
header.site-header:not(.is-scrolled) .header-contacts,
header.site-header:not(.is-scrolled) .header-contacts .item,
header.site-header:not(.is-scrolled) .header-contacts .item span { color:#fff; text-shadow:0 1px 2px rgba(0,0,0,.35); }
header.site-header.is-scrolled .header-contacts,
header.site-header.is-scrolled .header-contacts .item,
header.site-header.is-scrolled .header-contacts .item span { color:#111; text-shadow:none; }


/* --- Always red CTAs --- */
a.btn.btn-red, .btn.red {
  background:#d60000 !important;
  color:#fff !important;
  border:1px solid #d60000 !important;
}
a.btn.btn-red:hover, .btn.red:hover {
  filter:brightness(.95);
  box-shadow:0 6px 18px rgba(214,0,0,.25);
}


/* --- Centered Free Case Review button on homepage footer --- */
.footer-review-btn {
  display:block;
  margin: 1rem auto;
  text-align:center;
  width: fit-content;
}


/* --- Fixed bottom sticky Free Case Review bar (homepage only) --- */
#sticky-bar{
  position: fixed;
  left: 0; right: 0; bottom: 0;
  display: flex;
  justify-content: center;
  padding: .5rem 1rem calc(.5rem + env(safe-area-inset-bottom));
  z-index: 2000;
  pointer-events: none; /* so only the button captures clicks */
}
#sticky-bar .btn{
  pointer-events: auto;
  border-radius: 9999px;
  box-shadow: 0 8px 24px rgba(0,0,0,.25);
}
/* Avoid overlap with cookie banners etc. �?" feel free to adjust if needed */
body { } /* ensures content isn't hidden behind sticky button */


/* --- Sticky Bar: pill with thick white ring (homepage) --- */
#sticky-bar{
  position: fixed;
  left: 0; right: 0; bottom: 8px;
  display: flex;
  justify-content: center;
  padding: .25rem 1rem calc(.25rem + env(safe-area-inset-bottom));
  z-index: 2000;
  pointer-events: none;
}
#sticky-bar .btn{
  pointer-events: auto;
  background:#d60000;
  color:#fff;
  border-radius: 9999px;
  padding: .65rem 1.25rem;
  border: 2px solid #ffffff;
  box-shadow:
    0 0 0 10px rgba(255,255,255,0.92),
    0 10px 24px rgba(0,0,0,.28);
  font-weight: 700;
}
/* keep content from being hidden behind the sticky CTA */
body { }


/* --- Sticky bottom CTA (homepage only) --- */
#sticky-bar{
  position:fixed;
  left:0; right:0; bottom:12px;
  display:flex !important;
  align-items:center; justify-content:center;
  margin:0; padding:0;
  z-index:9999;
}
#sticky-bar .btn{
  background:#d60000; color:#fff; border-radius:9999px;
  padding:.65rem 1.25rem;
  border:2px solid #fff;
  box-shadow:0 0 0 10px rgba(255,255,255,.92), 0 10px 24px rgba(0,0,0,.28);
  font-weight:700;
}


/* --- Brand text contrast --- */
header.site-header .brand-name { transition:color .22s ease, text-shadow .22s ease; }
header.site-header:not(.is-scrolled) .brand-name { color:#fff; text-shadow:0 1px 6px rgba(0,0,0,.25); }
header.site-header.is-scrolled .brand-name { color:#111; text-shadow:none; }


/* --- Always red buttons --- */
.btn.red, a.btn.btn-red { background:#d60000 !important; color:#fff !important; border:1px solid #d60000 !important; }
.btn.red:hover, a.btn.btn-red:hover { filter:brightness(.95); box-shadow:0 6px 18px rgba(214,0,0,.25); }

html, body { overflow-x: hidden; }


/* --- Harden sticky header: fixed when scrolled --- */
header.site-header.fixed { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; }


/* --- Typeface update --- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600&family=Lora:wght@400;600;700&display=swap');
body { font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; }
h1, h2, h3, .hero-title { font-family: Lora, Georgia, 'Times New Roman', serif; letter-spacing: .3px; }


/* --- Neutral buttons (no red) --- */
.btn, a.btn { background: #111; color: #fff; border: 1px solid #111; border-radius: 9999px; }
.btn:hover, a.btn:hover { filter: brightness(.96); box-shadow: 0 6px 18px rgba(0,0,0,.18); }
.btn.red, a.btn.btn-red, .btn.btn-primary.red { background:#111 !important; border-color:#111 !important; color:#fff !important; }
header.site-header .nav .btn { background:#111 !important; border-color:#111 !important; color:#fff !important; }
#sticky-bar .btn { background:#111 !important; border-color:#fff !important; } /* keeps white ring if present */


/* --- Hamburger navigation --- */
header.site-header .nav { display:none; } /* hide full menu; use drawer */
.hamburger { margin-left: auto; width: 38px; height: 28px; position: relative; cursor: pointer; background: none; border: 0; }
.hamburger span { position:absolute; left:0; right:0; height:2px; background: currentColor; transition: transform .2s ease, top .2s ease, opacity .2s ease; }
.hamburger span:nth-child(1){ top:0; }
.hamburger span:nth-child(2){ top:13px; }
.hamburger span:nth-child(3){ top:26px; }
header.site-header:not(.is-scrolled) .hamburger { color:#fff; }
header.site-header.is-scrolled .hamburger { color:#111; }

.drawer { position: fixed; inset:0 0 0 40%; background:#000; box-shadow: -12px 0 40px rgba(0,0,0,.18); transform: translateX(100%); transition: transform .25s ease; z-index: 1200; }
.drawer.open { transform: translateX(0); }
.drawer .drawer-content { padding: 24px; display:flex; flex-direction:column; gap: 12px;}
.drawer a { color:#111; text-decoration:none; padding: 10px 0; border-bottom:1px solid #eee; }
.drawer a:last-child { border-bottom: none; }

/* Work link on the left of header */
.work-link { margin-left: 16px; }
header.site-header:not(.is-scrolled) .work-link { color:#fff; }
header.site-header.is-scrolled .work-link { color:#111; }

@media (max-width: 800px){
  .drawer { inset:0 0 0 25%; }
}


/* Tiered hero headline */
.hero-headline{ text-transform:uppercase; color:#fff; text-shadow:0 2px 18px rgba(0,0,0,.45); letter-spacing:.08em; }
.hero-kicker{ font-size:clamp(12px,2vw,18px); font-weight:600; opacity:.9; margin-bottom:.25rem; }
.hero-title{ font-size:clamp(36px,7vw,96px); line-height:.95; margin:.1rem 0 .35rem; font-weight:800; letter-spacing:.06em; }
.hero-sub{ font-size:clamp(12px,2vw,16px); font-weight:600; opacity:.95; }


/* Drawer overlay refined */
.drawer-overlay{ position:fixed; inset:0; background:rgba(0,0,0,.35); opacity:0; pointer-events:none; transition:opacity .2s; z-index:1190; }
.drawer-overlay.open{ opacity:1; pointer-events:auto; }
.drawer{ position:fixed; top:0; right:0; height:100vh;  max- background:#000; backdrop-filter:blur(8px) saturate(1.1); transform:translateX(100%); transition:transform .25s; z-index:1200; box-shadow:-12px 0 40px rgba(0,0,0,.18); }
.drawer.open{ transform:translateX(0); }
.drawer .drawer-content{ padding:24px; display:flex; flex-direction:column; gap:12px; }
.drawer a{ color:#111; text-decoration:none; padding:12px 0; border-bottom:1px solid rgba(0,0,0,.06); }
.drawer a:last-child{ border-bottom:none; }
.drawer .drawer-close{ display:block; position:absolute; top:14px; right:16px; background:none; border:0; font-size:24px; line-height:1; color:#111; cursor:pointer; }
@media (max-width:800px){ .drawer{  max- background:#000; } }
header .nav{ display:none !important; }
footer nav, footer .foot-links, footer .foot-cta{ display:none !important; }
a.btn, .btn, #sticky-bar{ display:none !important; }


/* --- Header & Hamburger refinement --- */
header.site-header{ display:flex; align-items:center; }
button.hamburger{ margin-left:auto; width:40px; height:32px; background:transparent; border:0; position:relative; cursor:pointer; }
button.hamburger span{ position:absolute; left:0; right:0; height:2px; background: currentColor; transition:transform .2s, top .2s, opacity .2s; }
button.hamburger span:nth-child(1){ top:4px; }
button.hamburger span:nth-child(2){ top:15px; }
button.hamburger span:nth-child(3){ top:26px; }
header.site-header:not(.is-scrolled) button.hamburger{ color:#fff; }
header.site-header.is-scrolled button.hamburger{ color:#111; }


/* --- Dark transparent drawer (desktop narrow, mobile full) --- */
.drawer-overlay{ position:fixed; inset:0; background:rgba(0,0,0,.45); opacity:0; pointer-events:none; transition:opacity .2s; z-index:1190; }
.drawer-overlay.open{ opacity:1; pointer-events:auto; }
.drawer{ position:fixed; top:0; right:0; height:100vh;  max- 
  background:#000; color:#fff; backdrop-filter: blur(8px) saturate(1.1);
  transform:translateX(100%); transition:transform .25s; z-index:1200; box-shadow:-14px 0 44px rgba(0,0,0,.35); border-left:1px solid rgba(255,255,255,.08); }
.drawer.open{ transform:translateX(0); }
.drawer .drawer-content{ padding:26px; display:flex; flex-direction:column; gap:14px; }
.drawer a{ color:#fff; text-decoration:none; padding:12px 0; border-bottom:1px solid rgba(255,255,255,.08); }
.drawer a:last-child{ border-bottom:none; }
.drawer .drawer-close{ position:absolute; top:14px; right:16px; background:none; border:0; font-size:26px; line-height:1; color:#fff; cursor:pointer; }
@media (max-width:800px){ .drawer{  max- background:#000;} }


/* --- Hero overlay text positioning over background image --- */
.mod_home_hero, .hero, section.hero { position:relative; }
.mod_home_hero::after{ content:''; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.35) 0%, rgba(0,0,0,.25) 40%, rgba(0,0,0,.35) 100%);
  pointer-events:none; z-index:0; }
.mod_home_hero .content, .hero .content, section.hero .content{ position:relative; z-index:1; min-height:48vh; display:flex; flex-direction:column; justify-content:flex-end; padding-bottom:min(10vh,120px); }
.hero-headline{ max-width:min(90vw, 960px); }

/* Center hero content vertically */
.mod_home_hero, .hero, section.hero { position: relative; }
.mod_home_hero .content, .hero .content, section.hero .content{
  position: relative; z-index: 1; min-height: 60vh;
  display: flex; flex-direction: column; justify-content: center; align-items: flex-start;
  padding-top: 10vh; padding-bottom: 14vh;
}
.hero-headline{ max-width: min(90vw, 980px); }


/* --- Defensive: drawer closed by default, overlay hidden --- */
.drawer {
  transform: translateX(100%) !important;
  visibility: hidden !important;
}
.drawer.open {
  transform: translateX(0) !important;
  visibility: visible !important;
}
.drawer-overlay {
  opacity: 0 !important;
  pointer-events: none !important;
}
.drawer-overlay.open {
  opacity: 1 !important;
  pointer-events: auto !important;
}


/* Position headline over the hero overlay */
.mod_home_hero, section.hero, .hero { position: relative; }
.hero-overlay { position: absolute; inset: 0; z-index: 0; }
.hero-headline {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -38%);
  z-index: 1; text-align: center; width: min(92vw, 1100px);
  pointer-events: none;
}
/* Inset the hamburger so it doesn't hug the screen edge */
header.site-header button.hamburger { margin-right: clamp(12px, 2vw, 24px); }

/* v46.46 Drawer: right pane ~= 25% of screen on desktop */
@media (min-width: 801px){
  .drawer{  min- max-width: 480px; }
}

/* v46.46 Hero scale-up & drama */
.hero-headline{ letter-spacing: .10em; }
.hero-kicker{ font-size: clamp(14px, 2.4vw, 22px); }
.hero-title{ font-size: clamp(48px, 9vw, 140px); letter-spacing: .10em; font-weight: 900; }
.hero-headline:after{
  content:''; display:block; width: 72px; height: 2px; margin: .5rem auto 0;
  background: rgba(255,255,255,.85);
  box-shadow: 0 2px 16px rgba(0,0,0,.45);
}
/* Slightly raise headline to feel more hero */
.hero-headline{ transform: translate(-50%, -42%); }


/* v46.47: Ensure drawer anchored to right edge */
.drawer {
  right: 0;
  left: auto;
  transform: translateX(100%);
}
.drawer.open {
  transform: translateX(0);
}






/* Collapsible submenu under Services */
.drawer-group { position: relative; }
.drawer-group .drawer-link { display: inline-block; padding-right: 28px; }
.drawer-subtoggle {
  position: absolute; right: 0; top: 0; background: none; border: 0; color: inherit; cursor: pointer;
  font-size: 18px; line-height: 1; padding: 8px 0;
}
.drawer-submenu { display: none; padding: 4px 0 6px 14px; opacity: .96; }
.drawer-group.open .drawer-submenu { display: block; }
.drawer-submenu a { display:block; padding: 8px 0; border-bottom: 1px solid rgba(255,255,255,.08); }
.drawer-submenu a:last-child { border-bottom: none; }


/* v46.56: Brand text color toggle (no DOM changes) */
header.site-header :where(.brand-text, .brand-name, .brand-title, .brand-label) {
  color: #fff;
  transition: color .25s ease;
}
header.site-header.is-scrolled :where(.brand-text, .brand-name, .brand-title, .brand-label) {
  color: #111;
}
/* If brand text has no class but is inside a .brand container, affect direct text elements */
header.site-header .brand > :where(span, a, strong, em) {
  color: inherit;
}


/* v46.56: Remove red ::after bars on Orlando/Atlanta office sections */
#orlando::after, #atlanta::after,
.section-orlando::after, .section-atlanta::after,
.mod_home_offices #orlando::after, .mod_home_offices #atlanta::after {
  content: none !important;
  display: none !important;
}


/* v46.57: Services tile links styled white */
.mod_home_triple_feature .item h2 a {
  color: #fff !important;
  text-decoration: none;
}
.mod_home_triple_feature .item h2 a:hover {
  text-decoration: underline;
}


/* v46.58: Remove red horizontal line (::after) for Orlando & Atlanta office areas */
#orlando::after, #atlanta::after,
.section-orlando::after, .section-atlanta::after,
.mod_home_offices #orlando::after, .mod_home_offices #atlanta::after {
  content: none !important;
  display: none !important;
}


/* v46.59: Remove ticker and red horizontal bar in footer */
footer::after, .site-footer::after {
  content: none !important;
  display: none !important;
}


/* v46.60: Kill-switch to hide any residual ticker/sticky footer elements */
#sticky-bar, #stickyBar, #footer-sticky-original, #footerTicker, .sticky-bar, .stickyFooter, .footer-sticky, .footerTicker, .ticker, .sticky-ticker, .sticky-call {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}


/* v48.1b: Mobile-only fixed CTA bar */
.fixed-cta {
  position: fixed; bottom:0; left:0; right:0;
  display:flex; gap:8px; justify-content:center; align-items:center;
  background:#0f0f10; padding:10px 12px; z-index:9999;
}
.fixed-cta .btn {
  background:#111; color:#fff; border:1px solid #111;
  padding:10px 14px; border-radius:6px; text-decoration:none; font-weight:600;
  flex:1; text-align:center;
}
@media (min-width:769px){ .fixed-cta{display:none;} }
@media (max-width:768px){ body{padding-bottom:64px;} }


/* v48.2: Mobile CTA visibility & brand red accent */
:root { --brand-red: #c1121f; }

.fixed-cta {
  position: fixed; bottom:0; left:0; right:0;
  display:flex; gap:10px; justify-content:center; align-items:center;
  background:#0f0f10; padding:12px 14px; 
  z-index: 2147483647; /* ensure on top */
}

/* Buttons use brand red */
.fixed-cta .btn {
  background: var(--brand-red) !important;
  border: 1px solid var(--brand-red) !important;
  color:#fff !important;
  padding:12px 16px; border-radius:999px; text-decoration:none; font-weight:700;
  flex:1; text-align:center;
}

/* Force show on common mobile widths; hide on desktop */
@media (min-width: 821px){
  .fixed-cta{ display:none !important; }
}
@media (max-width: 820px){
  .fixed-cta{ display:flex !important; }
  html, body{ padding-bottom:80px !important; }
}


/* v48.3: Force CTA bar visibility and square buttons */
:root { --brand-red: #c1121f; }

@media (max-width: 820px){
  .fixed-cta{
    position: fixed !important; bottom:0 !important; left:0 !important; right:0 !important;
    display: flex !important; gap:10px !important; justify-content:center !important; align-items:center !important;
    background: #111 !important; /* solid dark background so it doesn't appear white */
    padding: 12px 14px !important; z-index: 2147483647 !important;
    box-shadow: 0 -2px 12px rgba(0,0,0,.25) !important;
  }
  .fixed-cta .btn{
    background: var(--brand-red) !important; border: 1px solid var(--brand-red) !important; color:#fff !important;
    padding: 12px 14px !important; border-radius: 6px !important; text-decoration: none !important; font-weight: 700 !important;
    display: inline-flex !important; align-items: center !important; justify-content: center !important;
    flex: 1 1 auto !important; text-align: center !important; min-height: 40px !important;
  }
  /* ensure the number span inherits white */
  .fixed-cta .ppc-number{ color:#fff !important; }
  html, body{ padding-bottom: 86px !important; }
}
@media (min-width: 821px){
  .fixed-cta{ display: none !important; }
}


/* v48.4: Sleek modern mobile CTA bar */
@media (max-width: 820px){
  .fixed-cta{
    position: fixed; bottom:0; left:0; right:0;
    display:flex !important; justify-content:stretch; align-items:stretch;
    background:#1c1c1e; /* dark slate background */
    padding:0; margin:0;
    z-index:2147483647; box-shadow:0 -2px 8px rgba(0,0,0,.2);
  }
  .fixed-cta .btn{
    background:#0077cc; border:none; color:#fff;
    padding:14px 0; margin:0; border-radius:0;
    font-weight:600; flex:1; text-align:center; font-size:0.9em;
  }
  .fixed-cta .btn:hover, .fixed-cta .btn:active{
    background:#005fa3; color:#fff;
  }
  html, body{ padding-bottom:56px !important; }
}
@media (min-width: 821px){
  .fixed-cta{ display:none !important; }
}


/* v48.5: Slide-in animation for mobile CTA (respects reduced motion) */
@media (max-width: 820px){
  @keyframes ctaSlideIn {
    from { transform: translateY(100%); opacity: 0; }
    to   { transform: translateY(0);    opacity: 1; }
  }
  .fixed-cta{
    transform: translateY(100%);
    animation: ctaSlideIn .35s ease-out .10s forwards;
    will-change: transform, opacity;
  }
}
@media (prefers-reduced-motion: reduce){
  .fixed-cta{ animation: none !important; transform: none !important; }
}


/* v48.6: Snappier spring-like slide-in animation for mobile CTA */
@media (max-width: 820px){
  @keyframes ctaSlideInSnappy {
    0%   { transform: translateY(100%); opacity: 0; }
    60%  { transform: translateY(-6%);  opacity: 1; }
    80%  { transform: translateY(3%);   }
    100% { transform: translateY(0);    }
  }
  .fixed-cta{
    animation: ctaSlideInSnappy .25s cubic-bezier(0.25, 1.25, 0.5, 1) forwards;
    will-change: transform, opacity;
  }
}
@media (prefers-reduced-motion: reduce){
  .fixed-cta{ animation: none !important; transform: none !important; }
}


/* v48.7: Fade-out slide when user at top */
@media (max-width: 820px){
  .fixed-cta.hide-top{
    animation: ctaSlideOut .25s ease forwards;
  }
  @keyframes ctaSlideOut {
    from { transform: translateY(0); opacity:1; }
    to   { transform: translateY(100%); opacity:0; }
  }
}


/* v48.10: Apply Oswald font site-wide */
body, h1, h2, h3, h4, h5, h6, nav, footer, button, input, textarea {
  font-family: 'Oswald', sans-serif !important;
}

/* v51.6 - Header desktop nav uses Bebas Neue (override Oswald) */
header.site-header nav.nav,
header.site-header nav.nav > a,
header.site-header nav.nav .nav-parent,
header.site-header nav.nav .nav-submenu a {
  font-family:'Bebas Neue', Helvetica, Arial, sans-serif !important;
  font-size:17px !important;
  font-weight:700;
  letter-spacing:.08em;
}


/* v48.11: Drawer submenu indent under Services */
.drawer-submenu { padding-left: 18px; margin-bottom: 8px; }
.drawer-submenu a { display:block; padding:6px 0; font-size: 0.95em; }


/* === Readability override: light sections use dark text, dark sections use white === */
.section:not(.bg-dark):not(.dark):not(.black),
.section:not(.bg-dark):not(.dark):not(.black) *,
.content:not(.bg-dark):not(.dark):not(.black),
.content:not(.bg-dark):not(.dark):not(.black) * {
  color: #101828 !important;
}
.section:not(.bg-dark):not(.dark):not(.black) a,
.content:not(.bg-dark):not(.dark):not(.black) a {
  color: #0f172a !important;
  text-decoration: underline;
}
.section.bg-dark, .bg-dark, .dark, .black,
.section.bg-dark *, .bg-dark *, .dark *, .black * {
  color: #fff !important;
}


/* === Enforce white text on dark sections === */
.section.bg-dark, .bg-dark, .dark, .black, .parallax, .statement-band { color:#fff !important; }
.section.bg-dark *, .bg-dark *, .dark *, .black *, .parallax *, .statement-band * { color:#fff !important; }
.section.bg-dark a, .bg-dark a, .dark a, .black a, .parallax a, .statement-band a { color:#fff !important; text-decoration: underline; }


/* === Ensure light sections (NOT dark) use dark text === */
.section:not(.bg-dark):not(.dark):not(.black), .content:not(.bg-dark):not(.dark):not(.black) { color:#101828 !important; }
.section:not(.bg-dark):not(.dark):not(.black) a, .content:not(.bg-dark):not(.dark):not(.black) a { color:#101828 !important; text-decoration: underline; }


/* Home dark band specific reinforcement */
.statement-band .inner, .statement-band .inner * { color:#fff !important; }


/* Optional: visual overlay layer managed by the menu itself */
/* === Sitewide Bebas Neue font (global override) === */

:root { --font-sans: Bebas Neue, Impact, "Helvetica Neue", Arial, sans-serif; }
html, body { font-family: var(--font-sans) !important; }
h1,h2,h3,h4,h5,h6,p,a,li,button,label,input,textarea,select,small,strong,em,blockquote,figcaption {
  font-family: var(--font-sans) !important;
}


/* === Hamburger: old side-drawer style (from v48.22r-locations-header-matched-to-home) === */
/* --- Free Case Evaluation spacing tweaks --- */
section.free-eval { padding: 56px 0 76px; }
.free-eval .container.free-eval { padding: 16px 20px; }
.free-eval .contact-form { padding: 22px 22px; border-radius: 14px; }
.free-eval .form-grid { gap: 14px; }

/* Click-away hint (optional cursor) */
/* Ensure hamburger is always clickable above content */
header.site-header .hamburger { position: relative; z-index: 3000; pointer-events: auto; }
/* Avoid stray clicks blocking interaction when hidden */
@media (max-width: 820px) {
  header.site-header .nav { display: none !important; }
  header.site-header .hamburger { display: inline-flex !important; }
}
@media (min-width: 821px) {
  header.site-header .hamburger { display: none !important; }
  header.site-header .nav { display: flex !important; }
}


/* Drawer look & behavior */
/* Keep hamburger clickable above content */
header.site-header .hamburger{ position:relative; z-index:3000; pointer-events:auto; }


/* === DONOR drawer from v48.22n (style only) === */
.drawer { position: fixed; inset:0 0 0 40%; background:#000; box-shadow: -12px 0 40px rgba(0,0,0,.18); transform: translateX(100%); transition: transform .25s ease; z-index: 1200; }
.drawer.open { transform: translateX(0); }
.drawer-overlay { position:fixed; inset:0; background:rgba(0,0,0,.35); opacity:0; pointer-events:none; transition:opacity .2s; z-index:1190; }
.drawer-overlay.open { opacity:1; pointer-events:auto; }
/* Keep hamburger clickable above all */
header.site-header .hamburger { position:relative; z-index:2200; }
/* Hide horizontal nav per request */
header.site-header .nav { display:none !important; }


/* Force hamburger visible on all sizes; hide horizontal nav */
header.site-header .nav { display: none !important; }
header.site-header .hamburger { display: inline-flex !important; position: relative; z-index: 2300; cursor: pointer; }
/* Icon bars (in case theme doesn't style them) */
header.site-header .hamburger span { display:block; width:24px; height:2px; background:#fff; margin:4px 0; border-radius:2px; }

/* Overlay: full-viewport, dark transparent, clickable */
.drawer-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.72); opacity: 0; pointer-events: none; transition: opacity .28s ease; z-index: 2200; }
.drawer-overlay.open { opacity: 1; pointer-events: auto; }

/* Drawer panel stays above overlay */
.drawer { z-index: 2305; }


/* Drawer width: narrower on desktop so it doesn't reach the middle */





/* Genie-effect tight drawer widths (anchored right) */
@media (min-width: 1200px) {
  .drawer { width: 300px; right: 0; left: auto; }
}
@media (min-width: 900px) and (max-width: 1199px) {
  .drawer { width: 320px; right: 0; left: auto; }
}
@media (max-width: 899px) {
  .drawer { width: 86%; max-width: 420px; right: 0; left: auto; }
}



/* link-cover overlay */
.link-cover{position:absolute; inset:0; z-index:3;}
.card, .panel{position:relative;}


/* no-underline helper */
.no-underline, .no-underline:hover{ text-decoration:none !important; }


/* ORL/ATL heading links: force pure white & no underline in all states */
#orlando h2 a.no-underline,
#atlanta h2 a.no-underline,
#orlando h2 a.no-underline:visited,
#atlanta h2 a.no-underline:visited,
#orlando h2 a.no-underline:hover,
#atlanta h2 a.no-underline:hover,
#orlando h2 a.no-underline:focus,
#atlanta h2 a.no-underline:focus,
#orlando h2 a.no-underline:active,
#atlanta h2 a.no-underline:active{
  color:#FFFFFF !important;
  text-decoration:none !important;
}


/* Free Case Evaluation: soften typed text color */
.free-eval input,
.free-eval textarea,
.free-eval select{
  color:#222222 !important;
}


/* Free Case Evaluation: bottom-right SUBMIT button */
.free-eval .form-actions{
  display:flex;
  justify-content:flex-end;
  margin-top:16px;
}
.free-eval .submit-cta{
  appearance:none;
  -webkit-appearance:none;
  font-family: "Bebas Neue", Helvetica, Arial, sans-serif, Impact, "Helvetica Neue", Arial, sans-serif;
  text-transform: uppercase;
  letter-spacing:.6px;
  background: transparent;
  color:#FFFFFF;
  border:1.5px solid #FFFFFF;
  padding:12px 22px;
  border-radius:10px;
  cursor:pointer;
  transition:all .18s ease;
}
.free-eval .submit-cta:hover,
.free-eval .submit-cta:active{
  background:#FFFFFF;
  color:#000000;
}


/* Free Case Evaluation: bottom-right SUBMIT button (v2) */
.free-eval .form-actions{
  display:flex;
  justify-content:flex-end;
  margin-top:18px;
}

.free-eval .submit-cta{
  appearance:none;
  -webkit-appearance:none;
  font-family: "Bebas Neue", Helvetica, Arial, sans-serif, Impact, "Helvetica Neue", Arial, sans-serif;
  text-transform: uppercase;
  letter-spacing:.7px;
  background: transparent;
  color:#FFFFFF;
  border:2px solid #FFFFFF;
  padding:14px 28px;
  font-size:18px;
  border-radius:12px;
  cursor:pointer;
  transition:all .18s ease;
  line-height:1;
}

/* ensure text flips to black whenever background is white */
.free-eval .submit-cta:hover,
.free-eval .submit-cta:active,
.free-eval .submit-cta:focus,
.free-eval .submit-cta:focus-visible{
  background:#FFFFFF !important;
  color:#000000 !important;
  outline:none;
}

.fce-msg{margin-top:10px;color:#e9ecf1}


/* === Reese: desktop contact strip (hidden on mobile) === */
.site-header { position: relative; }
.header-contacts{
  position: absolute;
  right: clamp(12px, 3vw, 24px);
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  gap: clamp(10px, 1.6vw, 18px);
  align-items: center;
  font-weight: 600;
  color: #fff;
  text-shadow: 0 1px 2px rgba(0,0,0,.35);
  z-index: 3000;
}
.header-contacts .item{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  color: inherit;
  opacity: .95;
}
.header-contacts .item:hover{ opacity: 1; }
.header-contacts svg{ width: 16px; height: 16px; display: block; }
@media (max-width: 899.98px){
  .header-contacts{ display: none !important; }
}




/* === Reese v51.3: hide hamburger + drawer on desktop to avoid overlap with contact strip === */
@media (min-width: 900px){
  .hamburger,
  .menu-toggle,
  .nav-toggle,
  .drawer-toggle,
  button[aria-label*="menu" i]{
    display: none !important;
  }
  .menu-drawer,
  .nav-drawer,
  .drawer,
  .dropdown-menu{
    display: none !important;
  }
}




/* === Reese v51.4: remove ALL hamburger visuals on desktop (>=900px) === */
@media (min-width: 900px){
  /* Common containers */
  .hamburger, .menu-toggle, .nav-toggle, .drawer-toggle,
  .menu-btn, .menu-button, .navbar-toggler, .header__toggle, .header-toggle,
  .nav__toggle, .nav__btn, .menu-icon, .icon-menu,
  [aria-label*="menu" i], [aria-controls*="menu" i],
  [class*="hamburger" i], [class*="toggler" i], [class*="menu-btn" i], [class*="menu-toggle" i]{
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  /* Spans/bars within the toggles */
  .hamburger span, .menu-toggle span, .nav-toggle span, .drawer-toggle span,
  .menu-icon span, .navbar-toggler span,
  [class*="hamburger" i] span, [class*="menu" i] span, [class*="toggle" i] span{
    display: none !important;
  }

  /* Pseudo-elements (common "three lines") */
  .hamburger::before, .hamburger::after,
  .menu-toggle::before, .menu-toggle::after,
  .navbar-toggler::before, .navbar-toggler::after,
  [class*="hamburger" i]::before, [class*="hamburger" i]::after,
  [class*="menu" i]::before, [class*="menu" i]::after{
    content: none !important;
    display: none !important;
  }

  /* Icon fonts / SVGs */
  .fa-bars, .fa-bars::before,
  svg[class*="menu" i], svg[class*="hamburger" i]{
    display: none !important;
    visibility: hidden !important;
  }
}



/* v37: card video grayscale->color on hover/playing */
video.service-thumb{
  filter: grayscale(100%) contrast(1.05);
  transition: filter .28s ease, opacity .2s ease;
}
.item:hover video.service-thumb,
video.service-thumb.playing{
  filter: grayscale(0%);
}

/* === Contact form select dropdown: dark menu (options only) === */
/* Hint browsers to render dark dropdown UI without changing the field */
.section.contact select,
.fce-dark select,
.contact-form select,
.free-eval select{
  color-scheme: dark;
}

/* Dropdown list options in common contact contexts */
.section.contact select option,
.section.contact select optgroup,
.fce-dark select option,
.fce-dark select optgroup,
.contact-form select option,
.contact-form select optgroup,
.free-eval select option,
.free-eval select optgroup{
  background-color: #0b0b0f !important; /* site bg */
  color: #eef2f6 !important;            /* readable text */
}
/* Selected/hovered option emphasis (where supported) */
.section.contact select option:checked,
.section.contact select option:hover,
.fce-dark select option:checked,
.fce-dark select option:hover,
.contact-form select option:checked,
.contact-form select option:hover,
.free-eval select option:checked,
.free-eval select option:hover{
  background-color: #161a20 !important; /* match var(--input) */
  color: #ffffff !important;
}
/* --- Footer phone row line placement override --- */
.home-footer .phone-numbers{
  border-top: 0 !important;
  padding-top: 0 !important;
  margin-top: 0 !important;
  border-bottom: 1px solid rgba(255,255,255,.18) !important;
  padding-bottom: 10px !important;
  margin-bottom: 8px !important;
}
.page-centered:not(.page-locations) main h1,
.page-centered:not(.page-locations) main h2,
.page-centered:not(.page-locations) main h3,
.page-centered:not(.page-locations) main h4{font-family:'Bebas Neue',Helvetica,Arial,sans-serif;text-transform:none !important;letter-spacing:.12em;text-align:center;display:block;position:relative;margin:0 auto 18px;}
.page-centered:not(.page-locations) main h1::after,
.page-centered:not(.page-locations) main h2::after,
.page-centered:not(.page-locations) main h3::after,
.page-centered:not(.page-locations) main h4::after{content:"";display:block;width:74px;height:4px;margin:10px auto 0;background:linear-gradient(90deg,#C3202F 0%,#8F1520 100%);}
.page-centered:not(.page-locations) main p,
.page-centered:not(.page-locations) main li{font-family:Georgia,'Times New Roman',Times,serif !important;text-transform:none !important;letter-spacing:normal;}


body.page-centered:not(.page-locations) .sections .section{ text-align:center; }
body.service-page main .section{ text-align:left; }
body.service-page main .section h2,
body.service-page main .section h3{ text-align:center; }
body.service-page main .section p{ font-family:Georgia,'Times New Roman',Times,serif; text-transform:none; }

/* Ensure header contact icons + numbers stay visible on service pages */
body.service-page .header-contacts,
body.service-page .header-contacts .item{color:#ffffff;}
body.service-page .header-contacts svg{color:#ffffff;}

/* Switch header contact icon/text to dark when header bar turns white */
header.site-header.is-scrolled .header-contacts,
header.site-header.is-scrolled .header-contacts .item,
header.site-header.is-scrolled .header-contacts svg,
header.site-header.fixed .header-contacts,
header.site-header.fixed .header-contacts .item,
header.site-header.fixed .header-contacts svg{
  color:#0f131a !important;
}

.about-page .credential strong{display:block;text-align:center;font-family:'Bebas Neue',Helvetica,Arial,sans-serif;text-transform:uppercase;letter-spacing:.12em;position:relative;padding-bottom:.2rem;}
.about-page .credential strong::after{content:"";display:block;width:54px;height:4px;margin:10px auto 12px;background:linear-gradient(90deg,#C3202F 0%,#8F1520 100%);}
.about-page .credential .bullets{padding-left:20px;margin:0;text-align:left;list-style:disc;}
.about-page .credential .bullets li{margin:6px 0;}







.about-card{position:relative;margin:clamp(24px,4vw,48px) auto;background:rgba(255,255,255,.9);color:#111;border:1px solid rgba(0,0,0,.12);padding:clamp(26px,4vw,42px);max-width:1100px;box-shadow:0 24px 48px rgba(8,10,16,.2);}
.about-card::before{content:"";position:absolute;left:0;top:-1px;bottom:-1px;width:6px;background:linear-gradient(180deg,#C3202F 0%,#8F1520 100%);}
.about-card h1,.about-card h2,.about-card h3,.about-card h4{font-family:'Bebas Neue',Helvetica,Arial,sans-serif;text-transform:uppercase;letter-spacing:.12em;color:#0f131a;text-align:center;margin:0 auto 14px;display:inline-block;position:relative;}
.about-card h1::after,.about-card h2::after,.about-card h3::after,.about-card h4::after{content:"";display:block;width:72px;height:4px;margin:10px auto 0;background:linear-gradient(90deg,#C3202F 0%,#8F1520 100%);}
.about-card p{font-family:Georgia,'Times New Roman',Times,serif;line-height:1.65;color:#1f2730;margin:0 auto 18px;text-align:justify;}
.about-card p:last-child{margin-bottom:0;}

.page-heading{font-family:'Bebas Neue',Helvetica,Arial,sans-serif;text-transform:uppercase;letter-spacing:.12em;text-align:center;display:block;position:relative;margin:0 auto clamp(32px,5vw,44px);}
.page-heading::after{content:'';display:block;width:74px;height:4px;margin:10px auto 0;background:linear-gradient(90deg,#C3202F 0%,#8F1520 100%);}
.page-subheading{font-family:'Bebas Neue',Helvetica,Arial,sans-serif;text-transform:none;letter-spacing:.08em;text-align:center;display:inline-block;position:relative;margin:0 auto clamp(28px,4.5vw,40px);}
.page-subheading::after{content:'';display:block;width:64px;height:4px;margin:10px 0 0;background:linear-gradient(90deg,#C3202F 0%,#8F1520 100%);}
.card-heading{font-family:'Bebas Neue',Helvetica,Arial,sans-serif;text-transform:none;letter-spacing:.08em;text-align:center;display:inline-block;position:relative;margin:0 auto clamp(32px,5vw,44px);}
.card-heading::after{content:'';display:block;width:60px;height:4px;margin:10px auto 0;background:linear-gradient(90deg,#C3202F 0%,#8F1520 100%);}
.page-paragraph{font-family:Georgia,'Times New Roman',Times,serif;font-size:1rem;line-height:1.7;color:#161b24;text-align:justify;margin:12px auto;}
.page-paragraph.centered{text-align:center;}
body.home-page .page-paragraph,
body.page-locations .page-paragraph,
body.contact-page .page-paragraph,
main.contact-page .page-paragraph{ text-align:left; }

body:not(.home-page):not(.page-locations):not(.contact-page) .page-paragraph + .page-heading,
body:not(.home-page):not(.page-locations):not(.contact-page) .page-paragraph + .card-heading,
body:not(.home-page):not(.page-locations):not(.contact-page) .page-paragraph + .page-subheading,
body:not(.home-page):not(.page-locations):not(.contact-page) .page-list + .page-heading,
body:not(.home-page):not(.page-locations):not(.contact-page) .page-list + .card-heading,
body:not(.home-page):not(.page-locations):not(.contact-page) .page-list + .page-subheading{margin-top:clamp(48px,6vw,72px);}

.page-list,
.credential .bullets,
.about-card ul,
.cause-list{list-style:none;padding-left:1.5rem;margin:12px auto;text-align:left;}
.page-list li,
.credential .bullets li,
.about-card ul li,
.cause-list li{margin:6px 0;}

main.contact-page .page-paragraph{ text-align:left; }
main.contact-page .page-list{ padding-left:1.5rem; margin-left:0; }
main.contact-page .page-list li{ text-align:left; }/* v51.7 - Only add bottom padding when fixed CTA exists */
@media (max-width: 820px){
  html, body { padding-bottom: 0 !important; }
  html.has-fixed-cta, body.has-fixed-cta { padding-bottom: 64px !important; }
}

/* v51.8 - Footer office headings in Bebas + white */
.site-footer .office-heading, .home-footer .office-heading{
  font-family:'Bebas Neue', Helvetica, Arial, sans-serif !important;
  text-transform:uppercase; letter-spacing:.08em;
  color:#fff !important;
}
/* v51.9 - Ensure footer isn't covered by mobile CTA */
@media (max-width: 820px){
  html.has-fixed-cta, body.has-fixed-cta{
    padding-bottom: calc(96px + env(safe-area-inset-bottom, 0px)) !important;
  }
  .fixed-cta{
    padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px)) !important;
  }
}
/* Footer banner heading: match home hero font and add red underline */
.site-footer .footer-banner h3{
  font-family: 'Bebas Neue', Impact, 'Helvetica Neue', Arial, sans-serif;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.site-footer .footer-banner h3::after{
  content: '';
  display: block;
  width: 72px;
  height: 4px;
  margin: 10px auto 0;
  border-radius: 2px;
  background: linear-gradient(90deg,#C3202F 0%, #8F1520 100%);
}
