/* Super Locksmith Pros — Tactical Dark Theme
   Inspired by Super Lock and Key Tampa aesthetic: dark charcoal base,
   emergency red + electric blue + neon green status, gold stars,
   and subtle tactical/military UI treatments (monospace readouts, glows, pulses). */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root {
  --bg:              #0a0a0a;
  --bg-elev:         #141414;
  --surface:         #1a1a1a;
  --surface-2:       #1f2937;
  --line:            #2a2a2a;
  --border:          #333333;
  --border-soft:     rgba(255,255,255,.08);

  --text:            #e5e7eb;
  --text-soft:       #b3b3b3;
  --text-muted:      #888888;
  --text-dim:        #666666;
  --ink:             #ffffff;

  --red:             #ff4444;
  --red-dark:        #dc2626;
  --red-glow:        rgba(255,68,68,.5);
  --red-soft:        rgba(255,68,68,.12);

  --blue:            #0066ff;
  --blue-bright:     #1a7aff;
  --blue-dark:       #0052cc;
  --blue-glow:       rgba(0,102,255,.45);
  --blue-soft:       rgba(0,102,255,.1);

  --green:           #39ff14;
  --green-dim:       #22c55e;
  --green-glow:      rgba(57,255,20,.55);

  --gold:            #ffd700;
  --gold-soft:       rgba(255,215,0,.15);

  --font-display:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-body:       'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono:       'JetBrains Mono', ui-monospace, 'SF Mono', Consolas, monospace;

  --section-pad:     clamp(56px, 8vw, 96px);
  --container:       1240px;
  --radius:          8px;
  --radius-sm:       6px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.65;overflow-x:hidden;font-size:16px;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:var(--blue-bright);transition:color .2s ease, background .2s ease, border-color .2s ease, transform .2s ease, box-shadow .2s ease}
a:hover{color:var(--blue)}
img{max-width:100%;height:auto;display:block}
section{scroll-margin-top:88px}

.hvz-container{max-width:var(--container);margin:0 auto;padding:0 32px}

.hvz-label{font-family:var(--font-mono);font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.2em;color:var(--red);margin-bottom:12px;display:inline-flex;align-items:center;gap:10px}
.hvz-label::before{content:'//';color:var(--text-muted);font-weight:400}
.hvz-label::after{content:'';width:32px;height:1px;background:linear-gradient(90deg,var(--red),transparent);border-radius:2px}

h1,h2,h3,h4{color:var(--ink);font-family:var(--font-display);font-weight:800;letter-spacing:-0.02em}
p{color:var(--text)}
strong{color:var(--ink)}

/* === STATUS DOT (pulsing, reusable) === */
.hvz-pulse{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em}
.hvz-pulse::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 var(--green-glow);animation:hvz-pulse-green 2s infinite}
.hvz-pulse.hvz-pulse-red{color:var(--red)}
.hvz-pulse.hvz-pulse-red::before{background:var(--red);box-shadow:0 0 0 0 var(--red-glow);animation:hvz-pulse-red 1.6s infinite}
.hvz-pulse.hvz-pulse-green{color:var(--green)}
@keyframes hvz-pulse-green{0%{box-shadow:0 0 0 0 var(--green-glow)}70%{box-shadow:0 0 0 10px rgba(57,255,20,0)}100%{box-shadow:0 0 0 0 rgba(57,255,20,0)}}
@keyframes hvz-pulse-red{0%{box-shadow:0 0 0 0 var(--red-glow)}70%{box-shadow:0 0 0 12px rgba(255,68,68,0)}100%{box-shadow:0 0 0 0 rgba(255,68,68,0)}}

/* === BUTTONS === */
.hvz-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:.93rem;font-weight:700;padding:14px 24px;border-radius:var(--radius);border:none;cursor:pointer;letter-spacing:0.01em;transition:all .25s cubic-bezier(.4,0,.2,1);font-family:var(--font-body);line-height:1;position:relative;overflow:hidden}
.hvz-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent,rgba(255,255,255,.14),transparent);transform:translateX(-100%);transition:transform .6s ease}
.hvz-btn:hover::before{transform:translateX(100%)}
.hvz-btn-primary{background:linear-gradient(135deg,var(--red) 0%,var(--red-dark) 100%);color:var(--ink);box-shadow:0 6px 18px rgba(255,68,68,.28)}
.hvz-btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(255,68,68,.48);color:var(--ink)}
.hvz-btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--border)}
.hvz-btn-outline:hover{border-color:var(--blue);color:var(--blue-bright);background:var(--blue-soft)}
.hvz-btn-blue{background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%);color:var(--ink);box-shadow:0 6px 18px var(--blue-glow)}
.hvz-btn-blue:hover{transform:translateY(-2px);box-shadow:0 12px 32px var(--blue-glow);color:var(--ink)}
.hvz-btn-white{background:var(--ink);color:var(--red);box-shadow:0 6px 20px rgba(255,255,255,.12)}
.hvz-btn-white:hover{background:#f5f5f5;color:var(--red-dark);transform:translateY(-2px)}
.hvz-btn-ghost{background:transparent;color:var(--ink);border:1.5px solid rgba(255,255,255,.3)}
.hvz-btn-ghost:hover{background:rgba(255,255,255,.08);border-color:var(--ink)}

/* === HEADER === */
.hvz-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,10,10,.85);backdrop-filter:saturate(1.4) blur(12px);-webkit-backdrop-filter:saturate(1.4) blur(12px);border-bottom:1px solid var(--line)}
.hvz-header-inner{max-width:var(--container);margin:0 auto;padding:0 32px;height:76px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.hvz-logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
.hvz-logo-icon{width:38px;height:38px;filter:drop-shadow(0 0 8px rgba(0,102,255,.4))}
.hvz-logo-text{font-family:var(--font-display);font-size:1.35rem;font-weight:900;letter-spacing:-0.02em;color:var(--ink);line-height:1}
.hvz-logo-text span{background:linear-gradient(135deg,var(--blue-bright) 0%,var(--blue) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.hvz-nav{display:flex;align-items:center;gap:2px}
.hvz-nav a{font-size:.88rem;font-weight:600;color:var(--text-soft);padding:10px 14px;border-radius:var(--radius-sm);position:relative}
.hvz-nav a:hover{color:var(--ink);background:rgba(255,255,255,.04)}
.hvz-nav a.active{color:var(--red)}
.hvz-nav a.active::after{content:'';position:absolute;left:14px;right:14px;bottom:4px;height:2px;background:var(--red);border-radius:2px;box-shadow:0 0 8px var(--red-glow)}
.hvz-header-cta{display:flex;align-items:center;gap:14px;flex-shrink:0}
.hvz-phone{font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--ink);letter-spacing:-0.01em}
.hvz-phone:hover{color:var(--red)}

.hvz-mobile-btn{display:none;width:44px;height:44px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.hvz-mobile-btn span{width:22px;height:2px;background:var(--ink);transition:transform .2s ease}
.hvz-mobile-nav{display:none;position:fixed;top:76px;left:0;right:0;background:var(--surface);padding:14px 20px;border-bottom:2px solid var(--red);max-height:calc(100vh - 76px);overflow-y:auto;box-shadow:0 20px 40px rgba(0,0,0,.5)}
.hvz-mobile-nav a{display:block;padding:14px;color:var(--text-soft);font-weight:600;border-bottom:1px solid var(--line);font-size:.95rem}
.hvz-mobile-nav a:hover,.hvz-mobile-nav a.active{color:var(--red)}
.hvz-mobile-phone{padding:14px;display:block;font-family:var(--font-display);font-size:1.2rem;font-weight:800;color:var(--red);text-align:center;border-bottom:1px solid var(--line)}
.hvz-nav-open .hvz-mobile-nav{display:block}
.hvz-nav-open .hvz-mobile-btn span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hvz-nav-open .hvz-mobile-btn span:nth-child(2){opacity:0}
.hvz-nav-open .hvz-mobile-btn span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* === AFFILIATE STRIP === */
.hvz-affiliate-strip{background:linear-gradient(90deg,rgba(255,68,68,.04) 0%,rgba(0,102,255,.04) 100%);border-bottom:1px solid var(--line);padding:10px 0;margin-top:76px;font-size:.8rem;color:var(--text-soft);text-align:center;line-height:1.5}
.hvz-affiliate-strip .hvz-container{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}
.hvz-affiliate-strip strong{color:var(--red);font-family:var(--font-mono);font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:.68rem;padding:3px 10px;background:rgba(255,68,68,.08);border-radius:999px;border:1px solid rgba(255,68,68,.2)}

/* === BREADCRUMBS === */
.hvz-crumbs{background:var(--bg-elev);border-bottom:1px solid var(--line);padding:14px 0;font-size:.82rem;margin-top:0}
.hvz-crumbs ol{max-width:var(--container);margin:0 auto;padding:0 32px;display:flex;align-items:center;flex-wrap:wrap;gap:8px;list-style:none}
.hvz-crumbs li{display:flex;align-items:center;gap:8px;color:var(--text-muted);font-weight:500;font-family:var(--font-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.12em}
.hvz-crumbs li::after{content:'/';color:var(--text-dim);margin-left:8px}
.hvz-crumbs li:last-child::after{display:none}
.hvz-crumbs a{color:var(--blue-bright)}
.hvz-crumbs a:hover{color:var(--ink)}
.hvz-crumbs li[aria-current="page"]{color:var(--ink)}

.hvz-no-crumbs main{padding-top:0}

/* === HERO === */
.hvz-hero{padding:72px 0 64px;position:relative;overflow:hidden;background:var(--bg)}
.hvz-hero.hvz-hero-compact{padding:48px 0 44px}
.hvz-hero::before{content:'';position:absolute;inset:0;background:
  radial-gradient(ellipse 60% 50% at 20% 10%, rgba(255,68,68,.08) 0%, transparent 60%),
  radial-gradient(ellipse 50% 40% at 85% 85%, rgba(0,102,255,.1) 0%, transparent 60%),
  radial-gradient(ellipse 40% 30% at 50% 100%, rgba(57,255,20,.04) 0%, transparent 60%);
  pointer-events:none;z-index:0}
.hvz-hero::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);background-size:40px 40px;background-position:center;mask-image:radial-gradient(ellipse 70% 60% at 50% 40%, #000 0%, transparent 70%);-webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%, #000 0%, transparent 70%);pointer-events:none;z-index:0}
.hvz-hero-inner{max-width:var(--container);margin:0 auto;padding:0 32px;position:relative;z-index:2;text-align:center}
.hvz-hero-tag{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.04);border:1px solid var(--border);padding:8px 18px;border-radius:999px;font-family:var(--font-mono);font-size:.72rem;font-weight:700;color:var(--green);text-transform:uppercase;letter-spacing:.2em;margin-bottom:22px;box-shadow:0 0 0 1px var(--green-glow) inset, 0 0 24px rgba(57,255,20,.08)}
.hvz-hero-tag::before{content:'';width:8px;height:8px;background:var(--green);border-radius:50%;box-shadow:0 0 12px var(--green-glow);animation:hvz-pulse-green 2s infinite}
.hvz-hero h1{font-family:var(--font-display);font-size:clamp(2.2rem, 5.6vw, 4.2rem);font-weight:900;line-height:1.05;letter-spacing:-0.03em;margin-bottom:18px;color:var(--ink);text-shadow:0 2px 20px rgba(0,0,0,.5)}
.hvz-hero h1 span{background:linear-gradient(135deg,var(--blue-bright) 0%,var(--blue) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.hvz-hero h1 em{font-style:normal;color:var(--red);text-shadow:0 0 24px var(--red-glow)}
.hvz-hero-sub{max-width:780px;margin:0 auto 32px;font-size:1.1rem;line-height:1.75;color:var(--text-soft)}
.hvz-hero-btns{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:40px}
.hvz-hero-stats{display:flex;justify-content:center;gap:40px;flex-wrap:wrap;padding-top:30px;border-top:1px solid var(--line)}
.hvz-hero-stat{text-align:center}
.hvz-hero-stat strong{display:block;font-family:var(--font-display);font-size:2rem;font-weight:900;color:var(--ink);line-height:1;margin-bottom:6px;letter-spacing:-0.03em}
.hvz-hero-stat span{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.18em;font-weight:600}

/* Tactical readout strip — for "LAT/LON/STATUS" style decoration */
.hvz-tactical-readout{display:flex;justify-content:center;flex-wrap:wrap;gap:18px;margin-top:18px;font-family:var(--font-mono);font-size:.68rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.18em}
.hvz-tactical-readout span{display:inline-flex;align-items:center;gap:6px}
.hvz-tactical-readout span b{color:var(--green);font-weight:500}
.hvz-tactical-readout span i{font-style:normal;color:var(--text-soft)}

/* === SECTIONS === */
.hvz-section{padding:var(--section-pad) 0;background:var(--bg);position:relative}
.hvz-section.alt{background:var(--bg-elev);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.hvz-section h2{font-family:var(--font-display);font-size:clamp(1.7rem, 3.8vw, 2.6rem);font-weight:800;line-height:1.15;margin-bottom:12px;letter-spacing:-0.02em;color:var(--ink)}
.hvz-section p.lead{font-size:1.05rem;max-width:820px;margin-bottom:24px;color:var(--text-soft);line-height:1.75}

/* === CARDS === */
.hvz-grid{display:grid;gap:18px}
.hvz-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.hvz-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.hvz-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.hvz-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative}
.hvz-card h3{font-family:var(--font-display);font-size:1.08rem;font-weight:800;margin-bottom:8px;color:var(--ink);letter-spacing:-0.01em}
.hvz-card p{font-size:.94rem;line-height:1.7;color:var(--text-soft)}
.hvz-card .mini{margin-top:8px;color:var(--text);font-weight:600;font-size:.88rem}
.hvz-card-link{display:block;text-decoration:none;color:inherit}
.hvz-card-link:hover{border-color:var(--blue);transform:translateY(-3px);box-shadow:0 16px 40px rgba(0,0,0,.4), 0 0 0 1px var(--blue-glow)}
.hvz-card-link:hover h3{color:var(--blue-bright)}
.hvz-card-icon{width:52px;height:52px;margin-bottom:14px;color:var(--red);display:flex;align-items:center;justify-content:center;background:var(--red-soft);border-radius:var(--radius);border:1px solid rgba(255,68,68,.2)}
.hvz-card-icon svg{width:26px;height:26px;display:block}
.hvz-card .hvz-arrow{margin-top:16px;display:inline-flex;align-items:center;gap:6px;color:var(--blue-bright);font-weight:700;font-size:.84rem;transition:gap .2s ease}
.hvz-card-link:hover .hvz-arrow{gap:10px;color:var(--blue)}

.hvz-bullets{margin-top:14px;display:grid;gap:8px}
.hvz-bullets div{background:var(--bg-elev);border:1px solid var(--line);border-left:3px solid var(--red);padding:10px 14px;border-radius:var(--radius-sm);color:var(--text);font-size:.94rem}
.hvz-split{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:start}

/* === NEARBY === */
.hvz-nearby{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.hvz-nearby a{color:var(--blue-bright);padding:0 6px;display:inline-block;line-height:2.1;font-weight:500}
.hvz-nearby a:hover{color:var(--ink);text-decoration:underline;text-decoration-color:var(--blue)}

/* === FAQ === */
.hvz-faq-list{display:flex;flex-direction:column;gap:10px;margin-top:20px}
.hvz-faq-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .2s ease}
.hvz-faq-item[open]{border-color:var(--blue);box-shadow:0 0 0 1px var(--blue-glow)}
.hvz-faq-item summary{padding:18px 20px;font-size:1rem;font-weight:700;color:var(--ink);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.hvz-faq-item summary::-webkit-details-marker{display:none}
.hvz-faq-item summary::after{content:'+';font-size:1.4rem;font-weight:400;color:var(--red);transition:transform .2s ease;flex-shrink:0}
.hvz-faq-item[open] summary::after{transform:rotate(45deg);color:var(--blue-bright)}
.hvz-faq-answer{padding:0 20px 18px;color:var(--text-soft);line-height:1.75}

/* === CTA BANNER === */
.hvz-cta{padding:var(--section-pad) 0;background:linear-gradient(135deg,var(--red) 0%,var(--red-dark) 100%);text-align:center;color:var(--ink);position:relative;overflow:hidden}
.hvz-cta::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);background-size:48px 48px;opacity:.6;mask-image:radial-gradient(ellipse 80% 70% at 50% 50%, #000 0%, transparent 75%);-webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 50%, #000 0%, transparent 75%);pointer-events:none}
.hvz-cta .hvz-container{position:relative;z-index:2}
.hvz-cta h2{font-family:var(--font-display);font-size:clamp(1.8rem, 4vw, 2.8rem);font-weight:900;margin-bottom:12px;color:var(--ink);letter-spacing:-0.02em;text-shadow:0 2px 20px rgba(0,0,0,.3)}
.hvz-cta p{max-width:780px;margin:0 auto 26px;color:rgba(255,255,255,.92);font-size:1.05rem;line-height:1.7}
.hvz-cta-btns{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}

/* === STATE DIRECTORY === */
.hvz-states{display:grid;grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));gap:16px;margin-top:24px}
.hvz-state{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .2s ease}
.hvz-state[open]{border-color:var(--blue);box-shadow:0 0 0 1px var(--blue-glow)}
.hvz-state summary{padding:16px 20px;font-family:var(--font-display);font-weight:800;font-size:1.08rem;color:var(--ink);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px;letter-spacing:-0.01em}
.hvz-state summary::-webkit-details-marker{display:none}
.hvz-state summary::after{content:'+';font-size:1.5rem;font-weight:400;color:var(--red);transition:transform .2s ease}
.hvz-state[open] summary::after{transform:rotate(45deg);color:var(--blue-bright)}
.hvz-state-count{font-family:var(--font-mono);font-size:.68rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.16em}

.hvz-state-cities{padding:0 20px 20px;display:grid;grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));gap:2px 12px;max-height:380px;overflow:hidden;position:relative}
.hvz-state-cities::after{content:'';position:absolute;left:0;right:0;bottom:0;height:56px;background:linear-gradient(180deg, rgba(26,26,26,0) 0%, var(--surface) 100%);pointer-events:none;transition:opacity .2s ease}
.hvz-state-cities.hvz-state-cities--expanded{max-height:none}
.hvz-state-cities.hvz-state-cities--expanded::after{opacity:0}
.hvz-state-cities.hvz-state-cities--short{max-height:none}
.hvz-state-cities.hvz-state-cities--short::after{display:none}
.hvz-state-cities a{color:var(--blue-bright);font-size:.92rem;padding:4px 0;display:block;font-weight:500}
.hvz-state-cities a:hover{color:var(--ink);text-decoration:underline;text-decoration-color:var(--blue)}
.hvz-state-more{padding:0 20px 18px;text-align:center}
.hvz-state-more button{background:transparent;border:1.5px solid var(--blue);color:var(--blue-bright);padding:10px 22px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.88rem;font-weight:700;cursor:pointer;transition:all .2s ease}
.hvz-state-more button:hover{background:var(--blue);color:var(--ink);box-shadow:0 6px 18px var(--blue-glow)}
.hvz-state-more.hvz-state-more--hidden{display:none}

/* === NEAR YOU banner === */
.hvz-near-you{background:linear-gradient(135deg,var(--blue-soft) 0%,transparent 100%);border:1px solid var(--blue);border-radius:var(--radius);padding:16px 22px;margin:20px 0 24px;animation:hvz-slide-in .4s ease;box-shadow:0 0 0 1px var(--blue-glow), 0 0 40px rgba(0,102,255,.15)}
.hvz-near-you[hidden]{display:none}
.hvz-near-you-inner{display:flex;align-items:center;flex-wrap:wrap;gap:14px}
.hvz-near-you-label{font-family:var(--font-mono);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--blue-bright);padding:4px 10px;background:rgba(0,102,255,.15);border-radius:999px;border:1px solid var(--blue)}
.hvz-near-you strong{color:var(--ink);font-weight:800}
.hvz-btn.hvz-btn-sm{padding:9px 16px;font-size:.82rem;margin-left:auto}
@keyframes hvz-slide-in{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

/* === HOMEPAGE === */
.hvz-service-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));gap:16px;margin-top:24px}
.hvz-why{display:grid;grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));gap:18px;margin-top:24px}
.hvz-why-item{text-align:left;padding:22px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:all .2s ease}
.hvz-why-item:hover{border-color:var(--red);transform:translateY(-2px);box-shadow:0 12px 28px rgba(0,0,0,.4)}
.hvz-why-item .num{font-family:var(--font-mono);font-size:2rem;font-weight:700;color:var(--red);line-height:1;margin-bottom:10px;display:block;letter-spacing:-0.02em;text-shadow:0 0 20px var(--red-glow)}
.hvz-why-item h3{font-family:var(--font-display);font-size:1.08rem;font-weight:800;margin-bottom:6px;color:var(--ink)}
.hvz-why-item p{font-size:.92rem;color:var(--text-soft)}

/* === LEAD FORM === */
.hvz-lead-section{padding:56px 0;background:var(--bg-elev);border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.hvz-lead-section::before{content:'';position:absolute;inset:0;background:
  radial-gradient(ellipse 40% 60% at 10% 50%, rgba(255,68,68,.06) 0%, transparent 60%),
  radial-gradient(ellipse 40% 60% at 90% 50%, rgba(0,102,255,.06) 0%, transparent 60%);pointer-events:none}
.hvz-lead-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;max-width:var(--container);margin:0 auto;padding:0 32px;position:relative;z-index:2}
.hvz-lead-intro h2{font-family:var(--font-display);font-size:clamp(1.7rem, 3.4vw, 2.4rem);font-weight:800;line-height:1.12;margin-bottom:12px;color:var(--ink);letter-spacing:-0.02em}
.hvz-lead-intro p.lead{font-size:1rem;color:var(--text-soft);line-height:1.75;margin-bottom:20px}
.hvz-lead-badges{display:grid;gap:10px;margin-top:20px;padding:0;list-style:none}
.hvz-lead-badges li{display:flex;align-items:flex-start;gap:12px;color:var(--text);font-size:.94rem;line-height:1.55;font-weight:500}
.hvz-lead-badges li::before{content:'\2713';flex-shrink:0;width:22px;height:22px;background:linear-gradient(135deg,var(--green-dim) 0%,var(--green-dim) 100%);border-radius:50%;color:var(--bg);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:.74rem;margin-top:1px;box-shadow:0 0 12px rgba(34,197,94,.35)}

.hvz-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:0 20px 60px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.02);position:relative}
.hvz-form::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--red) 0%,var(--blue) 100%);border-radius:var(--radius) var(--radius) 0 0}
.hvz-form .urgency-label{font-family:var(--font-mono);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:var(--text-muted);margin-bottom:10px;display:block}
.hvz-form .urgency-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:18px}
.hvz-form .urgency-row label{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 10px;background:var(--bg-elev);border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:.82rem;font-weight:700;color:var(--text);transition:all .2s ease;text-align:center}
.hvz-form .urgency-row input[type=radio]{position:absolute;opacity:0;pointer-events:none}
.hvz-form .urgency-row label:hover{border-color:var(--blue);color:var(--blue-bright)}
.hvz-form .urgency-row label:has(input:checked){background:var(--blue-soft);border-color:var(--blue);color:var(--blue-bright)}
.hvz-form .urgency-row label:first-child:has(input:checked){background:var(--red-soft);border-color:var(--red);color:var(--red);box-shadow:0 0 20px var(--red-glow)}
.hvz-form .field{margin-bottom:14px}
.hvz-form label.field-label{display:block;font-family:var(--font-mono);font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);margin-bottom:6px}
.hvz-form label.field-label .req{color:var(--red)}
.hvz-form input[type=text],
.hvz-form input[type=tel],
.hvz-form input[type=email],
.hvz-form select,
.hvz-form textarea{width:100%;padding:13px 14px;background:var(--bg-elev);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--ink);font-family:var(--font-body);font-size:.95rem;transition:all .2s ease}
.hvz-form input::placeholder,.hvz-form textarea::placeholder{color:var(--text-dim)}
.hvz-form input:focus,.hvz-form select:focus,.hvz-form textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft), 0 0 20px var(--blue-glow)}
.hvz-form textarea{min-height:80px;resize:vertical}
.hvz-form select{cursor:pointer;appearance:none;-webkit-appearance:none;padding-right:44px}
.hvz-form .select-wrap{position:relative}
.hvz-form .select-wrap::after{content:'';position:absolute;right:18px;top:50%;width:8px;height:8px;border-right:2px solid var(--blue-bright);border-bottom:2px solid var(--blue-bright);transform:translateY(-70%) rotate(45deg);pointer-events:none}
.hvz-form button[type=submit]{width:100%;padding:16px 22px;background:linear-gradient(135deg,var(--red) 0%,var(--red-dark) 100%);color:var(--ink);border:none;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.98rem;font-weight:800;cursor:pointer;transition:all .25s ease;margin-top:6px;letter-spacing:0.01em;box-shadow:0 8px 24px rgba(255,68,68,.35);position:relative;overflow:hidden}
.hvz-form button[type=submit]::before{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent,rgba(255,255,255,.18),transparent);transform:translateX(-100%);transition:transform .6s ease}
.hvz-form button[type=submit]:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(255,68,68,.55)}
.hvz-form button[type=submit]:hover::before{transform:translateX(100%)}
.hvz-form-honeypot{position:absolute;left:-9999px;opacity:0;pointer-events:none}
.hvz-form-consent{margin-top:16px;padding-top:16px;border-top:1px solid var(--line);font-size:.74rem;color:var(--text-muted);line-height:1.65}
.hvz-form-consent a{color:var(--blue-bright)}
.hvz-form-consent a:hover{color:var(--ink);text-decoration:underline}
.hvz-form-consent .no-sell{display:flex;align-items:center;gap:8px;margin-top:10px;color:var(--text);font-weight:700}
.hvz-form-consent .no-sell::before{content:'\1F6E1';font-size:1rem}
.hvz-form .phone-fallback{margin-top:16px;padding-top:14px;border-top:1px solid var(--line);text-align:center;font-size:.9rem;color:var(--text-muted)}
.hvz-form .phone-fallback a{color:var(--red);font-family:var(--font-display);font-size:1.2rem;font-weight:800;letter-spacing:-0.01em}
.hvz-form .phone-fallback a:hover{color:var(--ink);text-shadow:0 0 12px var(--red-glow)}

/* === LEGAL === */
.hvz-legal{padding:56px 0 72px;background:var(--bg)}
.hvz-legal-inner{max-width:780px;margin:0 auto;padding:0 32px}
.hvz-legal h1{font-family:var(--font-display);font-size:clamp(2rem, 4.6vw, 2.8rem);font-weight:900;line-height:1.08;margin-bottom:8px;color:var(--ink);letter-spacing:-0.02em}
.hvz-legal .effective{color:var(--text-muted);font-size:.9rem;font-style:italic;margin-bottom:24px;font-family:var(--font-mono)}
.hvz-legal h2{font-family:var(--font-display);font-size:1.35rem;font-weight:800;color:var(--ink);margin-top:28px;margin-bottom:12px;letter-spacing:-0.01em}
.hvz-legal h3{font-family:var(--font-body);font-weight:800;font-size:1rem;color:var(--ink);margin-top:18px;margin-bottom:6px}
.hvz-legal p{color:var(--text);line-height:1.75;margin-bottom:12px;font-size:.98rem}
.hvz-legal ul,.hvz-legal ol{margin:10px 0 12px 22px;color:var(--text);line-height:1.75}
.hvz-legal li{margin-bottom:6px}
.hvz-legal strong{color:var(--ink)}
.hvz-legal a{color:var(--blue-bright)}
.hvz-legal a:hover{color:var(--ink);text-decoration:underline}
.hvz-legal .toc{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 22px;margin:18px 0 26px}
.hvz-legal .toc h2{margin-top:0;font-size:1rem;margin-bottom:8px}
.hvz-legal .toc ul{margin:0;list-style:none;padding-left:0}
.hvz-legal .toc li{margin-bottom:4px}

/* === FOOTER === */
.hvz-footer{background:var(--bg);border-top:1px solid var(--line);padding:56px 0 24px;color:var(--text-soft);position:relative}
.hvz-footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--red),var(--blue),transparent)}
.hvz-footer a{color:var(--text-soft)}
.hvz-footer a:hover{color:var(--ink)}
.hvz-footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:36px;max-width:var(--container);margin-left:auto;margin-right:auto;padding:0 32px}
.hvz-footer-brand .hvz-logo{margin-bottom:14px}
.hvz-footer-brand p{font-size:.9rem;max-width:360px;line-height:1.75;color:var(--text-muted)}
.hvz-footer h4{font-family:var(--font-mono);font-size:.74rem;font-weight:700;color:var(--red);margin-bottom:14px;text-transform:uppercase;letter-spacing:.16em}
.hvz-footer h4::before{content:'//';color:var(--text-dim);margin-right:6px;font-weight:400}
.hvz-footer ul{list-style:none;display:grid;gap:8px;padding:0}
.hvz-footer ul a{font-size:.92rem;font-weight:500}
.hvz-footer ul a:hover{color:var(--blue-bright)}
.hvz-footer-bottom{border-top:1px solid var(--line);padding-top:22px;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;max-width:var(--container);margin:0 auto;padding-left:32px;padding-right:32px}
.hvz-footer-bottom p{font-size:.78rem;color:var(--text-dim);font-weight:500;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.12em}
.hvz-footer-phone{font-family:var(--font-display);font-size:1.2rem;font-weight:800;color:var(--ink);letter-spacing:-0.01em}
.hvz-footer-phone:hover{color:var(--red);text-shadow:0 0 12px var(--red-glow)}

/* === PER-SERVICE VISUAL VARIATION ===
   Each service page body gets a data-svc attribute that shifts the hero
   gradient, status-tag color, section-label accent, and pulse color.
   Keeps the base dark tactical theme consistent, varies the accent. */

body[data-svc="emergency"] .hvz-hero::before{background:
  radial-gradient(ellipse 60% 50% at 20% 10%, rgba(255,68,68,.14) 0%, transparent 60%),
  radial-gradient(ellipse 50% 40% at 85% 85%, rgba(255,68,68,.08) 0%, transparent 60%),
  radial-gradient(ellipse 40% 30% at 50% 100%, rgba(0,102,255,.04) 0%, transparent 60%)}
body[data-svc="emergency"] .hvz-hero-tag{color:var(--red);box-shadow:0 0 0 1px var(--red-glow) inset, 0 0 30px rgba(255,68,68,.12)}
body[data-svc="emergency"] .hvz-hero-tag::before{background:var(--red);box-shadow:0 0 12px var(--red-glow);animation:hvz-pulse-red 1.4s infinite}
body[data-svc="emergency"] .hvz-label{color:var(--red)}
body[data-svc="emergency"] .hvz-label::after{background:linear-gradient(90deg,var(--red),transparent)}

body[data-svc="auto"] .hvz-hero::before{background:
  radial-gradient(ellipse 60% 50% at 15% 15%, rgba(0,102,255,.14) 0%, transparent 60%),
  radial-gradient(ellipse 50% 40% at 90% 90%, rgba(26,122,255,.1) 0%, transparent 60%),
  radial-gradient(ellipse 35% 25% at 50% 100%, rgba(57,255,20,.04) 0%, transparent 60%)}
body[data-svc="auto"] .hvz-hero-tag{color:var(--blue-bright);box-shadow:0 0 0 1px var(--blue-glow) inset, 0 0 30px rgba(0,102,255,.12)}
body[data-svc="auto"] .hvz-hero-tag::before{background:var(--blue-bright);box-shadow:0 0 12px var(--blue-glow);animation:hvz-pulse-blue 2s infinite}
body[data-svc="auto"] .hvz-label{color:var(--blue-bright)}
body[data-svc="auto"] .hvz-label::after{background:linear-gradient(90deg,var(--blue-bright),transparent)}
@keyframes hvz-pulse-blue{0%{box-shadow:0 0 0 0 rgba(0,102,255,.5)}70%{box-shadow:0 0 0 12px rgba(0,102,255,0)}100%{box-shadow:0 0 0 0 rgba(0,102,255,0)}}

body[data-svc="residential"] .hvz-hero::before{background:
  radial-gradient(ellipse 60% 50% at 20% 15%, rgba(245,158,11,.12) 0%, transparent 60%),
  radial-gradient(ellipse 50% 40% at 85% 85%, rgba(245,158,11,.06) 0%, transparent 60%),
  radial-gradient(ellipse 35% 25% at 50% 100%, rgba(0,102,255,.04) 0%, transparent 60%)}
body[data-svc="residential"] .hvz-hero-tag{color:#fbbf24;box-shadow:0 0 0 1px rgba(245,158,11,.4) inset, 0 0 30px rgba(245,158,11,.12)}
body[data-svc="residential"] .hvz-hero-tag::before{background:#fbbf24;box-shadow:0 0 12px rgba(245,158,11,.5);animation:hvz-pulse-amber 2s infinite}
body[data-svc="residential"] .hvz-label{color:#fbbf24}
body[data-svc="residential"] .hvz-label::after{background:linear-gradient(90deg,#fbbf24,transparent)}
@keyframes hvz-pulse-amber{0%{box-shadow:0 0 0 0 rgba(245,158,11,.5)}70%{box-shadow:0 0 0 12px rgba(245,158,11,0)}100%{box-shadow:0 0 0 0 rgba(245,158,11,0)}}

body[data-svc="commercial"] .hvz-hero::before{background:
  radial-gradient(ellipse 60% 50% at 20% 15%, rgba(139,92,246,.12) 0%, transparent 60%),
  radial-gradient(ellipse 50% 40% at 85% 85%, rgba(168,85,247,.08) 0%, transparent 60%),
  radial-gradient(ellipse 35% 25% at 50% 100%, rgba(0,102,255,.04) 0%, transparent 60%)}
body[data-svc="commercial"] .hvz-hero-tag{color:#c084fc;box-shadow:0 0 0 1px rgba(139,92,246,.4) inset, 0 0 30px rgba(139,92,246,.12)}
body[data-svc="commercial"] .hvz-hero-tag::before{background:#c084fc;box-shadow:0 0 12px rgba(139,92,246,.5);animation:hvz-pulse-purple 2s infinite}
body[data-svc="commercial"] .hvz-label{color:#c084fc}
body[data-svc="commercial"] .hvz-label::after{background:linear-gradient(90deg,#c084fc,transparent)}
@keyframes hvz-pulse-purple{0%{box-shadow:0 0 0 0 rgba(139,92,246,.5)}70%{box-shadow:0 0 0 12px rgba(139,92,246,0)}100%{box-shadow:0 0 0 0 rgba(139,92,246,0)}}

/* Tactical readout under hero — service-colored coordinates/status strip */
.hvz-tactical{display:flex;justify-content:center;flex-wrap:wrap;gap:22px;margin-top:20px;padding:12px 20px;background:rgba(255,255,255,.02);border:1px solid var(--line);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.16em;max-width:820px;margin-left:auto;margin-right:auto}
.hvz-tactical span{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.hvz-tactical b{font-weight:500;color:var(--text-soft)}
body[data-svc="emergency"] .hvz-tactical b{color:var(--red)}
body[data-svc="auto"] .hvz-tactical b{color:var(--blue-bright)}
body[data-svc="residential"] .hvz-tactical b{color:#fbbf24}
body[data-svc="commercial"] .hvz-tactical b{color:#c084fc}
.hvz-tactical i{font-style:normal;color:var(--green);font-weight:500}

/* === RESPONSIVE === */
@media (max-width:1100px){
  .hvz-nav{display:none}
  .hvz-phone{display:none}
  .hvz-mobile-btn{display:flex}
  .hvz-grid.cols-4{grid-template-columns:repeat(2,1fr)}
  .hvz-grid.cols-3{grid-template-columns:1fr}
  .hvz-grid.cols-2{grid-template-columns:1fr}
  .hvz-split{grid-template-columns:1fr}
  .hvz-footer-grid{grid-template-columns:1fr 1fr}
  .hvz-lead-grid{grid-template-columns:1fr;gap:26px}
  .hvz-header-cta .hvz-btn{display:none}
}
@media (max-width:768px){
  .hvz-header-inner{padding:0 18px;height:68px}
  .hvz-affiliate-strip{margin-top:68px}
  .hvz-mobile-nav{top:68px}
  .hvz-hero-inner{padding:0 18px}
  .hvz-container{padding:0 18px}
  .hvz-crumbs ol{padding:0 18px}
  .hvz-hero-stats{gap:22px}
  .hvz-hero-stat strong{font-size:1.6rem}
  .hvz-grid.cols-4{grid-template-columns:1fr}
  .hvz-footer-grid{grid-template-columns:1fr;gap:28px;padding:0 18px}
  .hvz-footer-bottom{flex-direction:column;text-align:center;padding:22px 18px 0}
  .hvz-form .urgency-row{grid-template-columns:1fr}
  .hvz-state-cities{grid-template-columns:1fr}
}

/* === REDUCED MOTION === */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
}
