/* ═══════════════════════════════════════════════════════
   SHIELDWISE CITY PAGE — light professional theme
   100% scoped inside #sv. Reusable across any city page.
   Does NOT touch body, html, .navbar, footer, or any
   Bootstrap class outside this wrapper.
   Usage: <link rel="stylesheet" href="/css/sw-city-page.css">
          then wrap page content in <div id="sv">...</div>
   ═══════════════════════════════════════════════════════ */

/* ── TOKENS — light professional palette: warm white + royal blue + warm gold ── */
#sv {
  --ink:     #ffffff;   /* lightest layer (was the darkest) — now pure white */
  --surface: #fafaf9;   /* page surface — warm off-white, clearly different from dark navbar */
  --card:    #ffffff;   /* card base — clean white */
  --card2:   #f8fafc;   /* secondary card — slight slate tint */
  --blue:    #2563eb;   /* PRIMARY accent — royal blue */
  --blue-lt: #3b82f6;   /* primary accent variant */
  --gold:    #ca8a04;   /* SECONDARY accent — warm gold */
  --gold-lt: #eab308;   /* gold light */
  --white:   #ffffff;   /* kept as white — used where text must stay white on colored buttons/panels */
  --text:    #0f172a;   /* dark slate — readable body/heading text on light bg */
  --off:     #f1f5f9;   /* alternate light background */
  --muted:   #64748b;   /* slate-500 for subtle text */
  --border:  rgba(15,23,42,0.08);
  --r:       12px;
  --r2:      20px;

  font-family: 'Segoe UI', system-ui, -apple-system, 'Helvetica Neue', sans-serif;
  color: var(--text);
  background: var(--surface);
  line-height: 1.65;
  overflow-x: hidden;
  position: relative;
  z-index: 1;
  clear: both;
}
#sv *, #sv *::before, #sv *::after { box-sizing: border-box; }
#sv a { color: var(--blue-lt); text-decoration: none; }
#sv a:hover { text-decoration: underline; color: var(--gold-lt); }
#sv img { max-width: 100%; height: auto; display: block; }
#sv p { margin: 0 0 1rem; }
#sv h1, #sv h2, #sv h3, #sv h4 { margin: 0; line-height: 1.1; font-weight: 900; letter-spacing: -0.03em; }

/* ── SEPARATOR FROM NAVBAR — bold, undeniable break ── */
.sv-topline {
  height: 6px;
  background: linear-gradient(90deg, var(--blue) 0%, var(--gold) 50%, var(--blue) 100%);
  box-shadow: 0 2px 18px rgba(37,99,235,0.35);
}

/* ── BREADCRUMB ── */
.sv-bc {
  background: var(--ink);
  border-bottom: 1px solid var(--border);
  padding: 13px 0;
  font-size: 0.82rem;
  color: var(--muted);
}
.sv-bc ol { list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:8px; align-items:center; }
.sv-bc li + li::before { content:'›'; margin-right:8px; color: var(--muted); }
.sv-bc a { color: var(--muted); }
.sv-bc a:hover { color: var(--gold); text-decoration:none; }
.sv-bc li:last-child { color: var(--gold); font-weight:700; }

/* ── WRAP ── */
.sv-w { width: min(1180px, calc(100% - 40px)); margin: 0 auto; }

/* ── HERO ── */
.sv-hero {
  position: relative;
  background: var(--ink);
  overflow: hidden;
  min-height: 600px;
  display: flex;
  align-items: stretch;
}
.sv-hero__photo {
  position: absolute; inset: 0;
  background: url('/img/California_SecurityGuards.webp') center 30% / cover no-repeat;
  z-index: 0;
}
.sv-hero__photo::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(105deg,
    rgba(9,9,11,0.97) 0%,
    rgba(9,9,11,0.88) 45%,
    rgba(9,9,11,0.3) 100%
  );
}
.sv-hero__inner {
  position: relative; z-index: 2;
  width: min(1180px, calc(100% - 40px)); margin: 0 auto;
  padding: 96px 0 88px;
  display: grid;
  grid-template-columns: minmax(0,1fr) minmax(260px,420px);
  gap: 60px; align-items: center;
}
.sv-hero__badge {
  display: inline-flex; align-items: center; gap: 8px;
  border: 1px solid rgba(202,138,4,0.4);
  background: rgba(202,138,4,0.08);
  border-radius: 999px; padding: 5px 14px 5px 8px;
  font-size: 0.76rem; font-weight: 800; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--gold); margin-bottom: 24px;
}
.sv-hero__badge-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 0 0 rgba(202,138,4,0.4);
  animation: sv-pulse 2s infinite;
  flex-shrink: 0;
}
@keyframes sv-pulse {
  0% { box-shadow: 0 0 0 0 rgba(202,138,4,0.5); }
  70% { box-shadow: 0 0 0 8px rgba(202,138,4,0); }
  100% { box-shadow: 0 0 0 0 rgba(202,138,4,0); }
}
.sv-hero h1 {
  font-size: clamp(2.8rem, 5.5vw, 4.6rem);
  color: var(--white); margin-bottom: 8px;
}
.sv-hero__city {
  display: block;
  background: linear-gradient(90deg, var(--blue-lt) 0%, var(--gold-lt) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.sv-hero__sub {
  font-size: 1.1rem; color: rgba(15,23,42,0.72); max-width: 520px;
  margin: 24px 0 32px; line-height: 1.7;
}
.sv-hero__ctas { display: flex; flex-wrap: wrap; gap: 12px; }
.sv-btn-primary {
  display: inline-flex; align-items: center; gap: 8px; min-height: 52px;
  padding: 13px 26px; border-radius: 8px;
  background: var(--blue); color: var(--white) !important;
  font-size: 1rem; font-weight: 800;
  text-decoration: none !important; border: 2px solid var(--blue);
  transition: background .2s, transform .2s, box-shadow .2s;
  box-shadow: 0 4px 18px rgba(37,99,235,0.4);
}
.sv-btn-primary:hover { background: #1d4ed8; border-color:#1d4ed8; transform:translateY(-2px); box-shadow:0 8px 28px rgba(37,99,235,0.5); }
.sv-btn-gold {
  display: inline-flex; align-items: center; gap: 8px; min-height: 52px;
  padding: 13px 26px; border-radius: 8px;
  background: var(--gold); color: #060f1f !important;
  font-size: 1rem; font-weight: 800;
  text-decoration: none !important; border: 2px solid var(--gold);
  transition: background .2s, transform .2s;
}
.sv-btn-gold:hover { background: var(--gold-lt); border-color:var(--gold-lt); transform:translateY(-2px); }
.sv-btn-ghost {
  display: inline-flex; align-items: center; gap: 8px; min-height: 52px;
  padding: 13px 26px; border-radius: 8px;
  color: rgba(15,23,42,0.85) !important; font-size: 1rem; font-weight: 700;
  text-decoration: none !important; border: 2px solid rgba(255,255,255,0.25);
  transition: border-color .2s, color .2s, transform .2s;
}
.sv-btn-ghost:hover { border-color:var(--gold); color:var(--gold)!important; transform:translateY(-2px); text-decoration:none!important; }

/* Hero side panel */
.sv-hero__panel {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.12);
  border-top: 3px solid var(--blue);
  border-radius: var(--r2);
  padding: 30px;
  backdrop-filter: blur(24px);
}
.sv-hero__panel-label {
  font-size: 0.72rem; font-weight: 800; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--blue-lt); margin-bottom: 14px;
}
.sv-hero__panel h2 { font-size: 1.1rem; color: var(--white); margin-bottom: 18px; }
.sv-hero__panel ul { list-style:none; margin:0 0 24px; padding:0; }
.sv-hero__panel li {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 10px 0; border-bottom: 1px solid var(--border);
  font-size: 0.93rem; color: rgba(15,23,42,0.8);
}
.sv-hero__panel li:last-child { border-bottom:none; }
.sv-panel-icon { color: var(--blue-lt); width: 16px; flex-shrink:0; margin-top:3px; }
.sv-panel-ctas { display: flex; flex-direction: column; gap: 10px; }
.sv-panel-ctas a { justify-content:center; }

/* ── TRUST BAR ── */
.sv-trust-bar {
  background: var(--ink);
  border-bottom: 1px solid var(--border);
  padding: 0;
}
.sv-trust-bar__inner {
  display: grid; grid-template-columns: repeat(5,1fr);
}
.sv-trust-item {
  text-align: center; padding: 22px 16px;
  border-right: 1px solid var(--border);
}
.sv-trust-item:last-child { border-right: none; }
.sv-trust-val {
  font-size: 1.5rem; font-weight: 900; color: var(--blue-lt);
  font-variant-numeric: tabular-nums; letter-spacing: -0.02em;
  line-height: 1; margin-bottom: 5px;
}
.sv-trust-val span { color: var(--gold); }
.sv-trust-lbl { font-size: 0.74rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--muted); }

/* ── SECTION BASE ── */
.sv-sec { padding: 88px 0; }
.sv-sec--dark { background: var(--ink); }
.sv-sec--mid { background: var(--card); }
.sv-sec--light { background: var(--off); }

.sv-label {
  font-size: 0.73rem; font-weight: 800; letter-spacing: 0.13em;
  text-transform: uppercase; color: var(--blue-lt);
  display: flex; align-items: center; gap: 8px; margin-bottom: 14px;
}
.sv-label::before { content:''; width:28px; height:2px; background:var(--blue); flex-shrink:0; }
.sv-label--gold { color: var(--gold); }
.sv-label--gold::before { background: var(--gold); }

.sv-head {
  font-size: clamp(2rem, 3.8vw, 3.1rem); color: var(--white);
  margin-bottom: 26px;
}
.sv-head--dark { color: var(--ink); }
.sv-subhead { font-size: 1.05rem; color: var(--muted); max-width: 640px; }

/* ── INTRO: CONTENT + IMAGE ── */
.sv-intro-grid {
  display: grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  gap: 72px; align-items: center;
}
.sv-intro-text p { color: rgba(15,23,42,0.72); margin-bottom: 20px; font-size: 1.02rem; }
.sv-quote {
  margin: 28px 0;
  border-left: 3px solid var(--gold);
  padding: 18px 22px;
  background: rgba(202,138,4,0.06);
  border-radius: 0 var(--r) var(--r) 0;
}
.sv-quote p { color: rgba(15,23,42,0.85); font-style: italic; margin:0 0 8px; }
.sv-quote cite { font-size: 0.82rem; color: var(--gold); font-style: normal; font-weight: 700; }

.sv-img-frame {
  position: relative; border-radius: var(--r2); overflow: hidden;
  box-shadow: 0 40px 100px rgba(0,0,0,0.7);
  margin: 30px 0;
}
.sv-img-frame img { width: 100%; height: 680px; object-fit: cover; }
.sv-img-frame::after {
  content:''; position:absolute; inset:0;
  background: linear-gradient(to bottom right, rgba(37,99,235,0.12) 0%, transparent 55%);
  pointer-events:none;
}
.sv-img-cap {
  position:absolute; bottom:0; left:0; right:0; z-index:2;
  background: linear-gradient(to top, rgba(9,9,11,0.92) 0%, transparent 100%);
  padding: 40px 24px 22px;
}
.sv-img-cap strong { display:block; color:var(--white); font-size:0.95rem; }
.sv-img-cap span { color: var(--blue-lt); font-size:0.82rem; }

/* ── SERVICES ── */
.sv-svc-intro { display:grid; grid-template-columns:1fr auto; gap:32px; align-items:end; margin-bottom:48px; }
.sv-svc-grid {
  display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 16px;
}

/* Full <a> card — entire card is the link */
.sv-svc-card {
  position: relative;
  display: flex; flex-direction: column;
  background: var(--card2);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  padding: 28px;
  text-decoration: none !important;
  transition: transform .28s cubic-bezier(.2,.6,.3,1),
              box-shadow .28s,
              border-color .28s,
              background .28s;
  overflow: hidden;
  color: var(--white) !important;
}
.sv-svc-card::before {
  content: ''; position:absolute; top:0; left:0; right:0; height:2px;
  background: linear-gradient(90deg, var(--blue), var(--blue-lt));
  transform: scaleX(0); transform-origin: left;
  transition: transform .32s cubic-bezier(.2,.6,.3,1);
}
.sv-svc-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 28px 64px rgba(0,0,0,0.6), 0 0 0 1px rgba(37,99,235,0.35);
  border-color: rgba(37,99,235,0.35); background: var(--card);
  text-decoration: none !important; color: var(--white) !important;
}
.sv-svc-card:hover::before { transform: scaleX(1); }

.sv-svc-icon {
  width: 44px; height: 44px; border-radius: 10px;
  background: rgba(37,99,235,0.15); border: 1px solid rgba(37,99,235,0.3);
  display: flex; align-items: center; justify-content: center;
  color: var(--blue-lt); font-size: 1.1rem; margin-bottom: 18px;
  transition: background .28s, box-shadow .28s;
}
.sv-svc-card:hover .sv-svc-icon {
  background: rgba(37,99,235,0.28);
  box-shadow: 0 0 20px rgba(37,99,235,0.25);
}
.sv-svc-card h3 {
  font-size: 1.05rem; color: var(--white); margin: 0 0 10px;
  font-weight: 800; letter-spacing: -0.01em;
}
.sv-svc-card p { font-size: 0.9rem; color: var(--muted); flex: 1; margin: 0 0 20px; line-height: 1.6; }
.sv-svc-arrow {
  display: flex; align-items: center; gap: 6px;
  font-size: 0.82rem; font-weight: 800; color: var(--blue-lt);
  text-decoration: none !important;
  margin-top: auto;
  transition: gap .25s, color .2s;
}
.sv-svc-card:hover .sv-svc-arrow { gap: 12px; color: var(--gold-lt); }
.sv-svc-arrow-icon { transition: transform .25s; }
.sv-svc-card:hover .sv-svc-arrow-icon { transform: translateX(5px); }

/* ── PROPERTY TYPES + IMAGE ── */
.sv-prop-grid {
  display: grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  gap: 72px; align-items: center;
}
.sv-prop-list { list-style:none; padding:0; margin:24px 0 32px; }
.sv-prop-list li {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 0; border-bottom: 1px solid var(--border);
  font-size: 0.97rem; color: rgba(15,23,42,0.82);
}
.sv-prop-list li:last-child { border-bottom:none; }
.sv-prop-icon {
  width: 36px; height: 36px; flex-shrink: 0; border-radius: 8px;
  background: rgba(202,138,4,0.1); border: 1px solid rgba(202,138,4,0.25);
  display: flex; align-items: center; justify-content: center;
  color: var(--gold); font-size: 0.85rem;
}
.sv-prop-right { display:flex; flex-direction:column; gap:0; }
.sv-prop-right strong { color:var(--white); font-size:0.97rem; }
.sv-prop-right span { color:var(--muted); font-size:0.83rem; }

.sv-img-frame2 {
  position:relative; border-radius:var(--r2); overflow:hidden;
  box-shadow: 0 40px 100px rgba(0,0,0,0.65);
}
.sv-img-frame2 img { width:100%; height:740px; object-fit:cover; }
.sv-img-frame2::before {
  content:''; position:absolute; inset:0; z-index:1;
  background: linear-gradient(to bottom, transparent 50%, rgba(9,9,11,0.75) 100%);
}

/* ── WHY CHOOSE — asymmetric 2-col ── */
.sv-why-grid {
  display: grid; grid-template-columns: minmax(0,1.15fr) minmax(0,0.85fr); gap: 56px; align-items: start;
}
.sv-why-feature {
  background: linear-gradient(140deg, var(--blue) 0%, #1e40af 100%);
  border-radius: var(--r2); padding: 44px; position:relative; overflow:hidden;
}
.sv-why-feature::before {
  content:''; position:absolute; top:-40px; right:-40px;
  width:200px; height:200px; border-radius:50%;
  background: rgba(255,255,255,0.05); pointer-events:none;
}
.sv-why-feature h2 { font-size:1.9rem; color:var(--white); margin-bottom:16px; }
.sv-why-feature p { color:rgba(15,23,42,0.8); font-size:1rem; margin-bottom:22px; }
.sv-why-creds { display:flex; flex-direction:column; gap:12px; margin-top:24px; }
.sv-why-cred {
  display: flex; align-items: center; gap: 12px;
  background: rgba(255,255,255,0.1); border-radius: 10px; padding: 13px 16px;
}
.sv-why-cred-icon { color:var(--gold-lt); width:18px; flex-shrink:0; }
.sv-why-cred-text strong { display:block; color:var(--white); font-size:0.92rem; }
.sv-why-cred-text span { color:rgba(15,23,42,0.65); font-size:0.8rem; }

.sv-why-stack { display:flex; flex-direction:column; gap:14px; }
.sv-why-card {
  background: var(--card2); border: 1px solid var(--border);
  border-radius: var(--r); padding: 22px;
  transition: border-color .2s, background .2s;
}
.sv-why-card:hover { border-color:rgba(37,99,235,0.3); background:var(--card); }
.sv-why-card h3 { font-size:0.97rem; font-weight:800; color:var(--white); margin:0 0 7px; }
.sv-why-card p { font-size:0.88rem; color:var(--muted); margin:0; }

/* ── PROCESS ── */
.sv-process-grid {
  display: grid; grid-template-columns: repeat(5,minmax(0,1fr)); gap:0; position:relative;
}
.sv-process-grid::before {
  content:''; position:absolute; top:26px; left:calc(10% + 10px); right:calc(10% + 10px);
  height:1px; background:linear-gradient(90deg,var(--blue) 0%,var(--gold) 100%);
}
.sv-step { text-align:center; padding:0 10px; position:relative; }
.sv-step-n {
  width:52px; height:52px; border-radius:50%;
  background:var(--blue); color:var(--white);
  font-size:1.1rem; font-weight:900;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 20px;
  box-shadow:0 0 0 5px rgba(37,99,235,0.15), 0 8px 20px rgba(37,99,235,0.3);
  position:relative; z-index:1;
}
.sv-step h3 { font-size:0.92rem; font-weight:800; color:var(--white); margin:0 0 7px; }
.sv-step p { font-size:0.8rem; color:var(--muted); margin:0; }

/* ── FAQ — two-panel ── */
.sv-faq-grid {
  display: grid; grid-template-columns: minmax(240px,0.7fr) minmax(0,1fr); gap:0;
  background: var(--card2); border: 1px solid var(--border); border-radius:var(--r2);
  overflow:hidden;
}
.sv-faq-list { border-right:1px solid var(--border); }
.sv-faq-btn {
  width:100%; background:none; border:none; border-bottom:1px solid var(--border);
  text-align:left; padding:20px 24px; cursor:pointer;
  font-family:inherit; font-size:0.93rem; font-weight:600;
  color:rgba(15,23,42,0.65);
  display:flex; align-items:center; gap:10px;
  transition:background .2s, color .2s;
}
.sv-faq-btn:hover { background:rgba(255,255,255,0.04); color:var(--white); }
.sv-faq-btn.sv-active {
  background:rgba(37,99,235,0.12);
  color:var(--blue-lt);
  border-left:3px solid var(--blue);
}
.sv-faq-btn-num {
  width:26px; height:26px; border-radius:6px; flex-shrink:0;
  background:rgba(255,255,255,0.06); font-size:0.78rem;
  display:flex; align-items:center; justify-content:center; font-weight:800;
  color:var(--muted);
}
.sv-faq-btn.sv-active .sv-faq-btn-num { background:rgba(37,99,235,0.3); color:var(--blue-lt); }
.sv-faq-panel { padding:40px; }
.sv-faq-answer { display:none; }
.sv-faq-answer.sv-visible { display:block; }
.sv-faq-answer h3 { font-size:1.25rem; color:var(--white); margin-bottom:16px; font-weight:800; }
.sv-faq-answer p { color:rgba(15,23,42,0.72); font-size:0.97rem; line-height:1.75; }
.sv-faq-answer a { color:var(--blue-lt); }

/* ── FINAL CTA ── */
.sv-cta-block {
  position:relative; overflow:hidden;
  background:linear-gradient(120deg, var(--card) 0%, var(--off) 50%, var(--card) 100%);
  border-radius:var(--r2); padding:64px;
  border:1px solid rgba(37,99,235,0.2);
  box-shadow:0 40px 100px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.05);
}
.sv-cta-block::before {
  content:''; position:absolute; top:-80px; right:-80px;
  width:360px; height:360px; border-radius:50%;
  background:radial-gradient(circle, rgba(37,99,235,0.08) 0%, transparent 70%);
  pointer-events:none;
}
.sv-cta-block::after {
  content:''; position:absolute; bottom:-60px; left:40%;
  width:280px; height:280px; border-radius:50%;
  background:radial-gradient(circle, rgba(202,138,4,0.05) 0%, transparent 70%);
  pointer-events:none;
}
.sv-cta-inner {
  position:relative; z-index:1;
  display:grid; grid-template-columns:1fr auto; gap:48px; align-items:center;
}
.sv-cta-block h2 { font-size:clamp(1.9rem,3.5vw,3rem); color:var(--white); margin-bottom:14px; }
.sv-cta-block p { color:rgba(15,23,42,0.65); font-size:1.02rem; margin-bottom:0; }
.sv-cta-block address {
  font-style:normal; font-size:0.85rem; color:rgba(15,23,42,0.45);
  margin-top:16px; line-height:1.6;
}
.sv-cta-block address a { color:rgba(15,23,42,0.55); }
.sv-cta-btns { display:flex; flex-direction:column; gap:10px; min-width:200px; }
.sv-cta-btns a { justify-content:center; }

/* ── NEARBY ── */
.sv-nearby {
  background: var(--ink); border-top:1px solid var(--border); padding:60px 0;
}
.sv-nearby-hd { text-align:center; margin-bottom:36px; }
.sv-nearby-hd h2 { font-size:1.65rem; font-weight:900; color:var(--white); margin:10px 0 12px; }
.sv-nearby-sub { color:var(--muted); font-size:0.97rem; max-width:560px; margin:0 auto; }
.sv-nearby-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(190px,1fr));
  gap:14px;
  margin-bottom:32px;
}
.sv-nearby-card {
  display:flex; flex-direction:column; align-items:center; gap:8px;
  background:var(--card2); border:1px solid var(--border);
  border-radius:14px; padding:22px 16px;
  text-decoration:none !important;
  transition:all .22s; position:relative; overflow:hidden;
}
.sv-nearby-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--blue),var(--gold));
  transform:scaleX(0); transform-origin:left; transition:transform .22s;
}
.sv-nearby-card:hover { transform:translateY(-4px); border-color:var(--blue); box-shadow:0 12px 32px rgba(37,99,235,0.12); }
.sv-nearby-card:hover::after { transform:scaleX(1); }
.sv-nc-icon { font-size:1.4rem; color:var(--blue); line-height:1; }
.sv-nc-name { font-size:0.97rem; font-weight:800; color:var(--white); text-align:center; }
.sv-nc-tag { font-size:0.72rem; font-weight:600; text-transform:uppercase; letter-spacing:0.06em; color:var(--muted); }
.sv-nearby-cta-row { display:flex; justify-content:center; margin-top:8px; }
/* keep old .sv-nearby-wrap for backwards compat with other pages */
.sv-nearby-wrap { display:flex; flex-wrap:wrap; gap:10px; }

/* ── NEARBY COUNTIES ── */
.sv-nearby-counties-wrap { margin:36px 0 28px; }
.sv-nearby-divider {
  display:flex; align-items:center; gap:12px;
  margin-bottom:18px;
}
.sv-nearby-divider::before,
.sv-nearby-divider::after {
  content:''; flex:1; height:1px; background:var(--border);
}
.sv-nearby-divider span {
  font-size:0.75rem; font-weight:700; text-transform:uppercase;
  letter-spacing:0.09em; color:var(--muted);
  white-space:nowrap; display:flex; align-items:center; gap:6px;
}
.sv-county-row {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(200px,1fr));
  gap:12px;
}
.sv-county-chip {
  display:flex; align-items:center; gap:10px;
  background:transparent;
  border:1px solid var(--border);
  border-radius:10px; padding:14px 16px;
  text-decoration:none !important;
  transition:all .2s; position:relative; overflow:hidden;
}
.sv-county-chip i {
  font-size:1.1rem; color:var(--gold); flex-shrink:0;
}
.sv-county-name {
  font-size:0.9rem; font-weight:700; color:var(--white);
  display:block; line-height:1.2;
}
.sv-county-dist {
  font-size:0.68rem; font-weight:600; text-transform:uppercase;
  letter-spacing:0.06em; color:var(--muted); display:block;
}
.sv-county-chip:hover {
  border-color:var(--gold);
  background:rgba(202,138,4,0.07);
  transform:translateY(-2px);
}
.sv-county-chip:hover .sv-county-name { color:var(--gold); }

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .sv-hero__inner { grid-template-columns:1fr; gap:36px; padding:72px 0 64px; }
  .sv-hero__panel { display:none; }
  .sv-intro-grid, .sv-prop-grid { grid-template-columns:1fr; gap:40px; }
  .sv-svc-grid { grid-template-columns:repeat(2,1fr); }
  .sv-why-grid { grid-template-columns:1fr; }
  .sv-process-grid { grid-template-columns:repeat(3,1fr); gap:28px; }
  .sv-process-grid::before { display:none; }
  .sv-faq-grid { grid-template-columns:1fr; }
  .sv-faq-list { border-right:none; border-bottom:1px solid var(--border); }
  .sv-cta-inner { grid-template-columns:1fr; gap:32px; }
  .sv-cta-block { padding:40px; }
  .sv-trust-bar__inner { grid-template-columns:repeat(3,1fr); }
  .sv-trust-item:nth-child(3) { border-right:none; }
  .sv-trust-item:nth-child(4) { border-top:1px solid var(--border); }
  .sv-trust-item:nth-child(5) { border-top:1px solid var(--border); border-right:none; }
  .sv-svc-intro { grid-template-columns:1fr; }
}
@media(max-width:640px){
  .sv-svc-grid { grid-template-columns:1fr; }
  .sv-process-grid { grid-template-columns:repeat(2,1fr); }
  .sv-trust-bar__inner { grid-template-columns:repeat(3,1fr); }
  .sv-hero h1 { font-size:2.5rem; }
  .sv-cta-btns { flex-direction:row; flex-wrap:wrap; }
  .sv-hero__ctas { flex-direction:column; }
  .sv-img-frame img, .sv-img-frame2 img { height:440px; }
  .sv-img-frame { margin: 16px 0; }
}

/* ═══════════════════════════════════════════════════════
   LIGHT-THEME OVERRIDES — appended last so they win.
   Fixes contrast on the new light palette while keeping
   structure / layout / content untouched.
   ═══════════════════════════════════════════════════════ */

/* Headings & cards: dark slate text on the light page */
#sv .sv-hero h1,
#sv .sv-hero__panel h2,
#sv .sv-head,
#sv .sv-svc-card,
#sv .sv-svc-card h3,
#sv .sv-prop-right strong,
#sv .sv-why-card h3,
#sv .sv-step h3,
#sv .sv-faq-answer h3,
#sv .sv-cta-block h2,
#sv .sv-nearby h2 { color: var(--text) !important; }
#sv .sv-faq-btn:hover { color: var(--text) !important; background: var(--off) !important; }

/* Subtle hover/border tints replace old white-on-dark tints */
#sv .sv-faq-btn-num { background: rgba(15,23,42,0.06); }
#sv .sv-prop-list li,
#sv .sv-hero__panel li,
#sv .sv-bc { border-color: var(--border); }

/* Hero photo overlay — LIGHT gradient so page reads as light */
#sv .sv-hero__photo::after {
  background: linear-gradient(105deg,
    rgba(250,250,249,0.97) 0%,
    rgba(250,250,249,0.86) 45%,
    rgba(250,250,249,0.15) 100%) !important;
}

/* Hero side panel — clean white card on the light hero */
#sv .sv-hero__panel {
  background: #ffffff !important;
  border: 1px solid var(--border) !important;
  border-top: 3px solid var(--blue) !important;
  backdrop-filter: none !important;
  box-shadow: 0 18px 50px rgba(15,23,42,0.08) !important;
}
#sv .sv-hero__panel h2 { color: var(--text) !important; }

/* Ghost button — readable dark outline on light bg */
#sv .sv-btn-ghost {
  color: var(--text) !important;
  border-color: rgba(15,23,42,0.25) !important;
}
#sv .sv-btn-ghost:hover {
  color: var(--blue) !important;
  border-color: var(--blue) !important;
}

/* Cards & sections: light layered backgrounds + soft shadow */
#sv .sv-svc-card,
#sv .sv-why-card,
#sv .sv-nearby-wrap a {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  box-shadow: 0 4px 14px rgba(15,23,42,0.04);
}
#sv .sv-svc-card:hover {
  background: var(--card) !important;
  border-color: var(--blue) !important;
  box-shadow: 0 24px 50px rgba(37,99,235,0.18), 0 0 0 1px rgba(37,99,235,0.25) !important;
}
#sv .sv-why-card:hover {
  background: var(--card) !important;
  border-color: var(--blue) !important;
}
#sv .sv-faq-grid {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  box-shadow: 0 8px 28px rgba(15,23,42,0.05);
}
#sv .sv-faq-list { border-right-color: var(--border) !important; }
#sv .sv-faq-btn { border-bottom-color: var(--border) !important; }

/* Section variants on light theme */
#sv .sv-sec--dark { background: var(--surface) !important; }
#sv .sv-sec--mid { background: var(--off) !important; }
#sv .sv-bc { background: var(--off) !important; }
#sv .sv-trust-bar { background: var(--card) !important; border-bottom: 1px solid var(--border) !important; }
#sv .sv-trust-item { border-right-color: var(--border) !important; }
#sv .sv-nearby { background: var(--off) !important; border-top: 1px solid var(--border) !important; }
#sv .sv-nearby-hd h2 { color: var(--text) !important; }
#sv .sv-nearby-sub { color: rgba(15,23,42,0.6) !important; }
#sv .sv-nearby-card {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  box-shadow: 0 2px 8px rgba(15,23,42,0.05);
}
#sv .sv-nearby-card:hover {
  border-color: var(--blue) !important;
  box-shadow: 0 12px 32px rgba(37,99,235,0.10) !important;
}
#sv .sv-nc-icon { color: var(--blue) !important; }
#sv .sv-nc-name { color: var(--text) !important; }
#sv .sv-nc-tag { color: rgba(15,23,42,0.45) !important; }

/* County chips — light theme */
#sv .sv-nearby-divider span { color: rgba(15,23,42,0.45) !important; }
#sv .sv-nearby-divider::before,
#sv .sv-nearby-divider::after { background: var(--border) !important; }
#sv .sv-county-chip {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
}
#sv .sv-county-chip i { color: var(--gold) !important; }
#sv .sv-county-name { color: var(--text) !important; }
#sv .sv-county-dist { color: rgba(15,23,42,0.4) !important; }
#sv .sv-county-chip:hover { border-color: var(--gold) !important; background: rgba(202,138,4,0.06) !important; }
#sv .sv-county-chip:hover .sv-county-name { color: #92660a !important; }

/* Quote — softer warm-gold tint on light bg */
#sv .sv-quote {
  background: rgba(202,138,4,0.08) !important;
  border-left-color: var(--gold) !important;
}
#sv .sv-quote p { color: var(--text) !important; }
#sv .sv-quote cite { color: #92660a !important; }

/* Service card icon — keep blue tint but visible on light bg */
#sv .sv-svc-icon {
  background: rgba(37,99,235,0.08) !important;
  border-color: rgba(37,99,235,0.2) !important;
}
#sv .sv-prop-icon {
  background: rgba(202,138,4,0.1) !important;
  border-color: rgba(202,138,4,0.25) !important;
}

/* Final CTA — light gradient panel instead of dark */
#sv .sv-cta-block {
  background: linear-gradient(120deg, var(--card) 0%, var(--off) 60%, var(--card) 100%) !important;
  border: 1px solid var(--border) !important;
  box-shadow: 0 24px 60px rgba(15,23,42,0.08), inset 0 1px 0 rgba(255,255,255,0.6) !important;
}
#sv .sv-cta-block p { color: var(--text) !important; opacity: 0.78; }
#sv .sv-cta-block address { color: var(--muted) !important; }
#sv .sv-cta-block address a { color: var(--blue) !important; }

/* Image frame 2 — remove dark bottom gradient (was for dark theme) */
#sv .sv-img-frame2::before { display: none !important; }
#sv .sv-img-frame,
#sv .sv-img-frame2 { box-shadow: 0 24px 60px rgba(15,23,42,0.12) !important; }

/* Process line connector — visible on light bg */
#sv .sv-process-grid::before {
  background: linear-gradient(90deg, var(--blue) 0%, var(--gold) 100%);
  opacity: 0.35;
}

/* Step number circle — keep white number on blue circle */
#sv .sv-step-n { color: #ffffff !important; }

/* ════ INSIDE .sv-why-feature (royal-blue gradient panel) ════
   This panel stays colored — text inside MUST remain white. */
#sv .sv-why-feature {
  background: linear-gradient(140deg, var(--blue) 0%, #1e40af 100%) !important;
  box-shadow: 0 24px 60px rgba(37,99,235,0.25);
}
#sv .sv-why-feature h2,
#sv .sv-why-cred-text strong { color: #ffffff !important; }
#sv .sv-why-feature p { color: rgba(255,255,255,0.88) !important; }
#sv .sv-why-feature .sv-label,
#sv .sv-why-feature .sv-label[style] { color: rgba(255,255,255,0.75) !important; }
#sv .sv-why-feature .sv-label::before { background: rgba(255,255,255,0.6) !important; }
#sv .sv-why-cred {
  background: rgba(255,255,255,0.12) !important;
  border: 1px solid rgba(255,255,255,0.08);
}
#sv .sv-why-cred-text span { color: rgba(255,255,255,0.78) !important; }
#sv .sv-why-feature::before { background: rgba(255,255,255,0.08) !important; }
#sv .sv-why-card i { color: var(--blue) !important; }

/* Buttons — primary stays white-on-blue; gold stays dark-on-gold */
#sv .sv-btn-primary { color: #ffffff !important; }
#sv .sv-btn-gold { color: #0f172a !important; }

/* Image caption — KEEP dark gradient ONLY on the photo for legibility */
#sv .sv-img-cap {
  background: linear-gradient(to top, rgba(15,23,42,0.88) 0%, transparent 100%) !important;
}
#sv .sv-img-cap strong { color: #ffffff !important; }
#sv .sv-img-cap span { color: rgba(255,255,255,0.85) !important; }

/* Trust bar accent numbers stay colored — readable on white */
#sv .sv-trust-val { color: var(--blue) !important; }
#sv .sv-trust-val span { color: var(--gold) !important; }

/* Stronger topline so navbar-to-page break is undeniable on light */
#sv .sv-topline {
  height: 8px !important;
  background: linear-gradient(90deg, var(--blue) 0%, var(--gold) 50%, var(--blue) 100%) !important;
  box-shadow: 0 4px 22px rgba(37,99,235,0.35) !important;
}

/* Mirror separator just before the dark footer — fade light page to dark navy */
#sv .sv-bottomline {
  height: 64px;
  background: linear-gradient(180deg, var(--surface) 0%, #e7eaf0 55%, #1a2642 100%);
  position: relative;
}
#sv .sv-bottomline::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 8px;
  background: linear-gradient(90deg, var(--blue) 0%, var(--gold) 50%, var(--blue) 100%);
  box-shadow: 0 -4px 22px rgba(37,99,235,0.35);
}

/* Subhead muted text — slate */
#sv .sv-subhead,
#sv .sv-intro-text p,
#sv .sv-hero__sub { color: var(--muted) !important; }

/* Nearby city pills */
#sv .sv-nearby-wrap a { color: var(--text) !important; }
#sv .sv-nearby-wrap a:hover {
  background: rgba(37,99,235,0.06) !important;
  border-color: rgba(37,99,235,0.35) !important;
  color: var(--blue) !important;
}

/* Breadcrumb on light */
#sv .sv-bc a { color: var(--muted) !important; }
#sv .sv-bc a:hover { color: var(--blue) !important; }
#sv .sv-bc li:last-child { color: var(--blue) !important; }

/* FAQ active question — blue tint on light */
#sv .sv-faq-btn.sv-active {
  background: rgba(37,99,235,0.08) !important;
  color: var(--blue) !important;
  border-left: 3px solid var(--blue);
}
#sv .sv-faq-btn.sv-active .sv-faq-btn-num {
  background: rgba(37,99,235,0.15);
  color: var(--blue);
}
#sv .sv-faq-answer p { color: var(--text) !important; opacity: 0.82; }
