/* ============================================================
   JUNK BRAWLERS — Shared Stylesheet
   Fonts at ../fonts/  |  Images at ../images/
   See DESIGN.md for the full design system reference.
   ============================================================ */

/* ---- FONT FACES ---- */
@font-face{font-family:'Barlow';font-style:normal;font-weight:400;font-display:swap;src:url(../fonts/barlow-400.woff2)format('woff2')}
@font-face{font-family:'Barlow';font-style:normal;font-weight:500;font-display:swap;src:url(../fonts/barlow-500.woff2)format('woff2')}
@font-face{font-family:'Barlow';font-style:normal;font-weight:600;font-display:swap;src:url(../fonts/barlow-600.woff2)format('woff2')}
@font-face{font-family:'Barlow';font-style:normal;font-weight:700;font-display:swap;src:url(../fonts/barlow-700.woff2)format('woff2')}
@font-face{font-family:'Barlow Condensed';font-style:normal;font-weight:600;font-display:swap;src:url(../fonts/barlow-condensed-600.woff2)format('woff2')}
@font-face{font-family:'Barlow Condensed';font-style:normal;font-weight:700;font-display:swap;src:url(../fonts/barlow-condensed-700.woff2)format('woff2')}
@font-face{font-family:'Barlow Condensed';font-style:normal;font-weight:800;font-display:swap;src:url(../fonts/barlow-condensed-800.woff2)format('woff2')}

/* ---- DESIGN TOKENS ---- */
:root{
  /* Purple — shield, brand */
  --color-primary:#7B35D4;--color-primary-dark:#5E22AA;--color-primary-mid:#B584F5;--color-primary-light:#EDE8F8;
  /* Fire Orange — intensity, urgency, action */
  --color-fire:#FF7A00;--color-fire-glow:rgba(255,122,0,0.35);
  /* Steel — precision, used on light section bgs */
  --color-steel-light:#D1D5DB;
  /* Darks — graduated by emotional weight */
  --color-dark-section:#080014;--color-review-bg:#060010;--color-footer:#030006;
  /* Lights */
  --color-warm-lighter:#ffffff;--color-hiw-bg:#f5f5f5;--color-light-alt:#f5f5f5;
  /* Neutrals */
  --color-white:#FFFFFF;--color-dark:#1A1A1A;--color-body:#1C1C2E;--color-border:#E0DDD8;
  /* Typography */
  --font-heading:'Barlow Condensed',sans-serif;
  --font:'Barlow',sans-serif;
  /* Shape & motion */
  --radius-card:6px;--radius-pill:22px;--transition:0.25s ease
}

/* ---- RESET & BASE ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip;background:#030006}
body{font-family:var(--font);color:var(--color-body);background:var(--color-footer);font-size:15px;line-height:1.6;overflow-x:clip;width:100%}
section{overflow-x:clip}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--font-heading);font-weight:800}

/* ---- HEADER ---- */
.site-header{position:sticky;top:0;z-index:1000;background:#000;height:70px;display:flex;align-items:center;padding:0 32px;gap:24px;box-shadow:0 1px 0 rgba(255,255,255,0.08)}
.header-logo{display:flex;align-items:center;gap:10px;flex-shrink:0;text-decoration:none}
.header-logo .logo-text{display:flex;flex-direction:column;line-height:1.1}
.header-logo .logo-name{font-size:20px;font-weight:800;color:var(--color-white);text-transform:uppercase;letter-spacing:1px;font-family:var(--font-heading)}
.header-logo .logo-sub{font-size:10px;font-weight:600;color:rgba(255,255,255,0.8);text-transform:uppercase;letter-spacing:1.5px}
.header-nav{flex:1;display:flex;align-items:center;justify-content:center;gap:8px}
.header-nav a,.header-nav .nav-dropdown>button{color:var(--color-white);font-size:15px;font-weight:600;padding:8px 14px;border-radius:4px;background:none;border:none;cursor:pointer;font-family:var(--font);display:flex;align-items:center;gap:4px;white-space:nowrap}
.header-nav a:hover,.header-nav .nav-dropdown>button:hover{background:rgba(255,255,255,0.15)}
.header-ctas{display:flex;align-items:center;gap:10px;flex-shrink:0}

/* ---- NAV DROPDOWN ---- */
.nav-dropdown{position:relative}
.nav-dropdown>button .arrow{font-size:10px;transition:transform var(--transition)}
.nav-dropdown.open>button .arrow{transform:rotate(180deg)}
.dropdown-menu{display:none;position:absolute;top:calc(100% + 4px);left:0;background:var(--color-white);border:1px solid var(--color-border);border-radius:6px;min-width:220px;box-shadow:0 8px 24px rgba(0,0,0,0.15);z-index:200;overflow:hidden}
.nav-dropdown.open .dropdown-menu{display:block}
.dropdown-menu a{display:block;padding:10px 16px;color:var(--color-body);font-size:14px;font-weight:500}
.dropdown-menu a:hover{background:var(--color-light-alt);color:var(--color-primary)}
.dropdown-menu--locations{min-width:500px}
.dropdown-cities{display:grid;grid-template-columns:1fr 1fr 1fr}
.dropdown-cities a{border-bottom:none}

/* ---- MOBILE NAV ---- */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;margin-left:auto;background:none;border:none}
.hamburger span{display:block;width:26px;height:2px;background:var(--color-white);border-radius:2px;transition:transform var(--transition),opacity var(--transition)}
.mobile-nav{display:none;position:fixed;top:70px;left:0;right:0;background:#07001A;z-index:999;padding:16px 24px 24px;box-shadow:0 8px 16px rgba(0,0,0,0.3);max-height:calc(100vh - 70px);overflow-y:auto}
.mobile-nav.open{display:block}
.mobile-nav a{display:block;color:var(--color-white);font-size:16px;font-weight:500;padding:12px 0;border-bottom:1px solid rgba(255,255,255,0.1)}
.mobile-nav .mobile-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,0.8);padding:16px 0 4px}
.mobile-nav .mobile-ctas{display:flex;flex-direction:column;gap:10px;margin-top:16px}
.mobile-nav .btn-ghost-white,.mobile-nav .btn-phone{text-align:center}

/* ---- BUTTONS ---- */
.btn-primary{display:inline-block;padding:13px 28px;background:var(--color-primary);color:var(--color-white);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;border-radius:4px;border:none;cursor:pointer;transition:opacity var(--transition),transform var(--transition);font-family:var(--font);position:relative;overflow:hidden;box-shadow:0 4px 20px rgba(123,53,212,0.4)}
.btn-primary:hover{opacity:0.88;box-shadow:0 4px 14px rgba(0,0,0,0.3)}
.btn-fire{display:inline-block;padding:13px 28px;background:#C05000;color:var(--color-white);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;border-radius:4px;border:none;cursor:pointer;transition:opacity var(--transition);font-family:var(--font);box-shadow:0 2px 8px rgba(0,0,0,0.25)}
.btn-fire:hover{opacity:0.88}
.btn-ghost-white{padding:9px 18px;border:2px solid var(--color-white);color:var(--color-white);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;border-radius:4px;white-space:nowrap;transition:background var(--transition),color var(--transition)}
.btn-ghost-white:hover{background:var(--color-white);color:var(--color-primary-dark)}
.btn-phone{padding:9px 18px;background:#C05000;color:var(--color-white);font-size:13px;font-weight:700;border-radius:4px;transition:opacity var(--transition);white-space:nowrap}
.btn-phone:hover{opacity:0.88}

/* ---- SECTION UTILITIES ---- */
.section-heading{font-size:clamp(28px,3.5vw,42px);font-weight:800;color:var(--color-body);margin-bottom:12px;line-height:1.1;font-family:var(--font-heading)}
.section-heading-accent{width:80px;height:5px;background:var(--color-primary);margin-bottom:32px;border-radius:3px}
.section-heading-accent.centered{margin-left:auto;margin-right:auto}
.section-bridge{font-family:var(--font-heading);font-size:clamp(26px,3.5vw,48px);font-style:italic;font-weight:700;text-align:center;text-decoration:underline;text-decoration-color:var(--color-fire);text-underline-offset:6px;text-decoration-thickness:2px;letter-spacing:-0.01em;margin:0;display:block;padding:72px 32px 80px}
.section-bridge--light{color:rgba(0,0,0,0.65)}
.section-bridge--dark{color:rgba(255,255,255,0.9)}
.section-bridge--xl{font-size:clamp(30px,4.5vw,60px)}
.section-bridge--final{padding-top:120px;padding-bottom:20px}
.h2-bridge{font-family:var(--font-heading);font-size:clamp(26px,3.5vw,48px);font-style:italic;font-weight:700;text-align:center;text-decoration:underline;text-decoration-color:var(--color-fire);text-underline-offset:6px;text-decoration-thickness:2px;letter-spacing:-0.01em;line-height:1.15;margin:0 0 20px;display:block}
.h2-bridge--light{color:rgba(0,0,0,0.65)}
.h2-bridge--dark{color:rgba(255,255,255,0.9)}
.heading-eyebrow{font-family:var(--font-heading);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2.5px;color:var(--color-primary);margin-bottom:8px;display:block}

/* ---- HERO ---- */
.hero{position:relative;min-height:calc(100vh - 70px);background:#0A000F;display:flex;align-items:stretch;overflow:hidden;padding:0}
.hero-left{flex:0 0 55%;max-width:55%;display:flex;align-items:flex-start;padding:72px 60px 56px 80px;position:relative;z-index:1}
.hero-right{position:absolute;left:0;right:0;top:0;bottom:0;overflow:hidden;padding:0}
.hero-right::before{content:'';position:absolute;inset:0;background:linear-gradient(to right,#0A000F 0%,#0A000F 8%,rgba(10,0,15,0.96) 22%,rgba(10,0,15,0.88) 42%,rgba(10,0,15,0.72) 52%,rgba(10,0,15,0.3) 65%,rgba(10,0,15,0.05) 80%,transparent 92%);pointer-events:none}
.hero-content{position:relative;z-index:1;max-width:640px;text-align:left}
.hero-badge{display:inline-flex;align-items:center;gap:10px;background:rgba(6,0,20,0.6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.15);border-radius:8px;padding:12px 20px;margin-bottom:32px;box-shadow:0 2px 12px rgba(0,0,0,0.3)}
.hero-stars{color:#FFD700;font-size:18px;letter-spacing:2px}
.hero-badge-text{color:rgba(255,255,255,0.9);font-size:14px;font-weight:600;white-space:nowrap}
.hero-badge-text strong{color:#fff}
.hero-tagline{font-family:var(--font-heading);font-size:clamp(2.25rem,4vw,4.5rem);font-weight:900;color:var(--color-white);line-height:1.05;margin-bottom:30px;text-transform:none;text-shadow:0 2px 8px rgba(0,0,0,0.6)}
.hero-tagline .hero-em{color:var(--color-fire);display:block;font-size:clamp(2.875rem,5.2vw,6rem);line-height:1.02;text-shadow:0 0 40px var(--color-fire-glow),0 2px 8px rgba(0,0,0,0.5)}
.hero-pullquote{border-left:3px solid var(--color-fire);padding:8px 0 8px 14px;margin-bottom:16px}
.hero-pullquote p{font-size:15px;color:rgba(255,255,255,0.92);font-style:italic;line-height:1.45;margin-bottom:3px}
.hero-pullquote cite{font-size:11px;color:rgba(255,255,255,0.5);font-style:normal;font-weight:600;text-transform:uppercase;letter-spacing:1px}
.hero-content p.hero-sub{font-size:15px;color:rgba(255,255,255,0.78);margin-bottom:40px;max-width:480px;line-height:1.55;text-shadow:0 1px 4px rgba(0,0,0,0.85)}
.hero-buttons{display:flex;gap:14px;flex-wrap:wrap;justify-content:flex-start}
/* Homepage hero is the tallest (pullquote + badge/tagline/sub) — pull it up on desktop so the CTA stays above the fold */
@media(min-width:901px){body.page-home .hero-left{padding-top:24px;padding-bottom:40px}}
/* Short desktop viewports (e.g. 1080p at 150% Windows scaling = 720px tall): compress the stack so the CTA never clips below the fold */
@media(min-width:901px) and (max-height:820px){
  body.page-home .hero-left{padding-top:14px;padding-bottom:24px}
  body.page-home .hero-badge{margin-bottom:18px}
  body.page-home .hero-tagline{margin-bottom:18px}
  body.page-home .hero-content p.hero-sub{margin-bottom:20px}
  body.page-home .hero-pullquote{margin-bottom:12px}
}

/* ---- TRUST TICKER ---- */
.trust-ticker{background:linear-gradient(180deg,#110018 0%,#080012 100%);box-shadow:0 6px 20px rgba(0,0,0,0.5),inset 0 1px 0 rgba(255,255,255,0.07)}
.trust-ticker-wrap{overflow:hidden}
.trust-ticker-track{display:flex;align-items:center;flex-wrap:nowrap;padding:28px 0;width:max-content;will-change:transform;animation:ticker-scroll 160s linear infinite}
@keyframes ticker-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.t-item{display:flex;align-items:center;gap:9px;color:rgba(255,255,255,0.82);font-size:15px;font-weight:600;white-space:nowrap;padding:0 30px}
.t-icon{width:19px;height:19px;flex-shrink:0;color:var(--color-steel-light);display:flex;align-items:center;justify-content:center}
.t-icon svg{width:100%;height:100%}
.t-sep{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,0.25);flex-shrink:0;margin:0 4px}

/* ---- PAIN SECTION ---- */
.pain-section{background:linear-gradient(to bottom,#09000F 0%,#150028 18%,#2d0065 42%,#3a0078 54%,#2d0065 66%,#7b35d4 76%,#ffffff 92%);padding:40px 32px 56px;border-top:none;border-bottom:none}
.pain-inner{max-width:720px;margin:0 auto}
.pain-paragraph{list-style:none;padding:0;color:rgba(255,255,255,0.87);font-size:clamp(17px,2vw,20px);font-weight:500;line-height:1.7;margin-bottom:8px}
.pain-paragraph li{padding-left:1.4em;position:relative;margin-bottom:4px}
.pain-paragraph li::before{content:"•";position:absolute;left:0;color:var(--color-fire)}
.pain-pivot-accent{width:48px;height:3px;background:var(--color-fire);border-radius:2px;margin:64px auto 68px}
.pain-close{font-family:var(--font-heading);font-size:clamp(24px,2.8vw,36px);font-weight:500;color:rgba(255,255,255,0.88);padding:0 32px 52px;line-height:1.3;text-align:center;max-width:780px;margin:0 auto;display:block;letter-spacing:-0.02em}
.pain-close strong{color:var(--color-fire);font-weight:900;letter-spacing:-0.01em}
.pain-contrasts{margin-top:28px;display:flex;flex-direction:column;gap:20px}
.pain-pair{border-left:2px solid rgba(255,255,255,0.15);padding-left:16px}
.pain-answer{font-size:clamp(17px,2vw,20px);font-weight:700;color:var(--color-fire);margin:0;padding-left:1.6em;position:relative}
.pain-answer::before{content:"✓";position:absolute;left:0;color:#fff;font-weight:900}


/* ---- OWNER / MEET TONY ---- */
.owner-section{background:#07001A;padding:80px 32px;overflow:hidden;position:relative;z-index:1}
.owner-section::before{content:'';position:absolute;bottom:20px;left:50%;transform:translateX(-50%);width:520px;height:520px;background:url('../images/logo.webp') no-repeat center/contain;opacity:0.08;mix-blend-mode:screen;pointer-events:none;user-select:none}
.owner-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:max-content 1fr;grid-template-areas:"head photo" "body photo";gap:20px 56px;align-items:start;position:relative;z-index:1}
.owner-head{grid-area:head}
.owner-photo-wrap{grid-area:photo;position:relative}
.owner-body{grid-area:body}
.owner-photo-wrap img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:2px;box-shadow:0 24px 60px rgba(0,0,0,0.18)}
.owner-badge{position:absolute;bottom:-16px;right:-16px;background:linear-gradient(135deg,#9B00FF,#5200A0);border-radius:2px;padding:12px 16px;box-shadow:0 4px 16px rgba(0,0,0,0.35)}
.owner-badge-score{display:block;font-family:var(--font-heading);font-weight:800;color:#FFD700;font-size:20px;line-height:1}
.owner-badge-label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,0.8);margin-top:4px}
.owner-text-head{display:flex;align-items:flex-start;gap:20px;margin-bottom:0}
.owner-accent-bar{width:4px;min-height:72px;flex-shrink:0;background:linear-gradient(180deg,#8000FF 0%,transparent 100%);border-radius:2px;margin-top:4px}
.owner-section h2{font-family:var(--font-heading);font-size:clamp(26px,3.2vw,42px);font-weight:800;color:#ffffff;line-height:1;margin:0}
.owner-section p{font-size:15px;color:rgba(255,255,255,0.7);line-height:1.7;margin-bottom:16px}
.owner-stats{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid rgba(255,255,255,0.12);border-bottom:1px solid rgba(255,255,255,0.12);padding:20px 0;margin-bottom:28px}
.owner-stat{padding:0 16px}
.owner-stat:first-child{padding-left:0}
.owner-stat+.owner-stat{border-left:1px solid rgba(17,17,17,0.08)}
.owner-stat .stat-val{display:block;font-family:var(--font-heading);font-size:36px;font-weight:800;color:#111;line-height:1;margin-bottom:4px}
.owner-stat .stat-val.fire{color:var(--color-fire)}
.owner-stat .stat-lbl{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:rgba(255,255,255,0.5)}

/* ---- SERVICES SECTION ---- */
.svc-section{background:var(--color-dark-section);padding:calc(80px + 6vw) 32px 0;position:relative;z-index:10;box-shadow:inset 0 8px 60px rgba(255,100,0,0.05);margin-top:-6vw;clip-path:polygon(0 6vw,100% 0%,100% 100%,0% 100%)}
.svc-section::after{content:'';position:absolute;bottom:0;left:0;right:0;height:260px;background:var(--color-hiw-bg);z-index:0}
.svc-inner{max-width:1100px;margin:0 auto}
.svc-section h2{font-family:var(--font-heading);font-size:clamp(28px,3.5vw,44px);font-weight:800;color:#fff;text-align:center;margin-bottom:14px}
.svc-accent{width:56px;height:4px;background:#8000FF;border-radius:9px;margin:0 auto 44px}
.svc-intro{max-width:660px;margin:0 auto 48px;text-align:center}
.svc-intro p{color:rgba(255,255,255,0.65);font-size:15px;line-height:1.7;margin-bottom:16px;text-align:center}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;position:relative;z-index:1}
.svc-card{position:relative;overflow:hidden;border-radius:4px;min-height:340px;display:block;text-decoration:none;box-shadow:0 24px 64px rgba(0,0,0,0.5)}
.svc-card-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;pointer-events:none;display:block}
.svc-card-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,0,24,0.05) 0%,rgba(10,0,24,0.72) 70%)}
.svc-card-body{position:absolute;bottom:0;left:0;right:0;padding:20px;z-index:1}
.svc-card-body h3{font-family:var(--font-heading);font-weight:800;text-transform:uppercase;color:#fff;font-size:22px;margin-bottom:6px;line-height:1.1;text-align:center;text-decoration:underline;text-decoration-color:var(--color-fire);text-underline-offset:5px;text-decoration-thickness:2px}
.svc-card-body p{color:rgba(255,255,255,0.7);font-size:13px;line-height:1.6;text-align:center}
.svc-card-hover{position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,0,18,0.96) 0%,rgba(10,0,24,0.98) 100%);padding:28px 28px 24px;display:flex;flex-direction:column;justify-content:center;transform:translateY(100%);transition:transform 0.38s cubic-bezier(0.25,0.46,0.45,0.94);z-index:3}
.svc-card:hover .svc-card-hover{transform:translateY(0)}
.svc-card-hover h3{font-family:var(--font-heading);font-weight:800;text-transform:uppercase;color:#fff;font-size:20px;margin-bottom:16px;text-align:center;letter-spacing:0.5px}
.svc-card-hover ul{list-style:none;padding:0;margin:0 0 18px;flex:1}
.svc-card-hover ul li{color:rgba(255,255,255,0.85);font-size:14px;line-height:1.75;text-align:center;padding:1px 0}
.svc-card-hover ul li::before{content:"✓  ";color:var(--color-fire);font-weight:700}
.svc-card-hover-cta{display:block;text-align:center;color:var(--color-fire);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;padding-top:14px;border-top:1px solid rgba(255,255,255,0.12)}
.svc-cta-row{text-align:center;padding:40px 0 80px;position:relative;z-index:1}
.bento-section{background:var(--color-light-alt);padding:72px 32px 0}
.bento-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:280px 280px 280px;gap:12px;grid-template-areas:"a a b" "c d b" "e e f";text-align:left}
.bento-grid>.svc-card{min-height:0}
.bento-grid>.svc-card:nth-child(1){grid-area:a}
.bento-grid>.svc-card:nth-child(2){grid-area:b}
.bento-grid>.svc-card:nth-child(3){grid-area:c}
.bento-grid>.svc-card:nth-child(4){grid-area:d}
.bento-grid>.svc-card:nth-child(5){grid-area:e}
.bento-grid>.svc-card:nth-child(6){grid-area:f}
@media(max-width:900px){.bento-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:200px 200px 200px 200px;grid-template-areas:"a a" "b c" "d e" "f f"}}
@media(max-width:640px){.bento-grid{grid-template-columns:1fr;grid-template-rows:repeat(6,220px);grid-template-areas:"a" "b" "c" "d" "e" "f"}}

/* ---- HOW IT WORKS ---- */
.hiw-section{background:#ffffff;padding:80px 32px 72px;position:relative;overflow:hidden}
.hiw-dotgrid{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(0,0,0,0.06) 1px,transparent 1px);background-size:32px 32px;opacity:0.6;mask-image:linear-gradient(to bottom,transparent 0%,black 28%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 28%);pointer-events:none}
.hiw-inner{max-width:900px;margin:0 auto;text-align:center;position:relative}
.hiw-section h2{font-family:var(--font-heading);font-size:clamp(28px,3.5vw,44px);font-weight:800;color:#111;margin-bottom:14px}
.hiw-accent{width:56px;height:4px;background:#8000FF;border-radius:9px;margin:0 auto 44px}
.hiw-steps{display:grid;grid-template-columns:repeat(3,1fr);position:relative}
.hiw-connector{position:absolute;top:32px;left:calc(33.33% - 24px);right:calc(33.33% - 24px);height:1px;background:rgba(128,0,255,0.45);z-index:0}
.hiw-step{display:flex;flex-direction:column;align-items:center;padding:32px 24px;position:relative;z-index:1}
.hiw-step:not(:last-child){border-right:1px solid rgba(17,17,17,0.08)}
.hiw-num{width:64px;height:64px;border-radius:50%;border:2px solid var(--color-fire);background:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:24px;flex-shrink:0;position:relative;z-index:1;box-shadow:0 2px 8px rgba(0,0,0,0.12)}
.hiw-num span{font-family:var(--font-heading);font-size:26px;font-weight:800;color:var(--color-fire)}
.hiw-step h3{font-family:var(--font-heading);font-size:clamp(22px,2.2vw,30px);font-weight:800;color:#111;margin-bottom:12px}
.hiw-step p{color:rgba(17,17,17,0.6);font-size:15px;line-height:1.7}
.hiw-cta{margin-top:48px}
/* ---- PRICING SECTION ---- */
.pricing-section{background:var(--color-hiw-bg);padding:80px 32px 80px;clip-path:polygon(0 48px,100% 0,100% 100%,0 100%);position:relative}
.pricing-section::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(0,0,0,0.05) 1px,transparent 1px);background-size:32px 32px;opacity:0.5;mask-image:linear-gradient(to bottom,transparent 0%,black 25%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 25%);pointer-events:none;z-index:0}
.pricing-inner{max-width:960px;margin:0 auto;text-align:center;position:relative;z-index:1}
.pricing-intro{color:rgba(17,17,17,0.62);font-size:clamp(16px,1.8vw,19px);max-width:580px;margin:0 auto 48px;line-height:1.65}
.pricing-trucks{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:36px}
.pricing-tier{background:#fff;border-radius:8px;box-shadow:0 2px 16px rgba(0,0,0,0.07);padding:24px 16px 22px;display:flex;flex-direction:column;align-items:center;border-top:3px solid transparent;transition:transform .2s,box-shadow .2s}
.pricing-tier:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,0.11)}
.pricing-tier.tier-highlight{border-top:3px solid var(--color-fire)}
.truck-svg-wrap{width:100%;max-width:170px;margin:0 auto 16px}
.tier-name{font-family:var(--font-heading);font-size:clamp(17px,1.6vw,20px);font-weight:800;color:#111;margin:0 0 2px}
.tier-price{font-family:var(--font-heading);font-size:clamp(24px,2.4vw,30px);font-weight:800;color:var(--color-fire);margin:4px 0 4px;letter-spacing:-0.5px}
.tier-desc{font-size:13px;color:rgba(17,17,17,0.5);margin:0;line-height:1.5}
.tier-badge{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--color-fire);background:rgba(255,122,0,0.08);border:1px solid rgba(255,122,0,0.25);border-radius:20px;padding:3px 10px;margin-top:8px}
.pricing-note{background:rgba(123,53,212,0.05);border:1px solid rgba(123,53,212,0.15);border-radius:6px;padding:18px 24px;max-width:580px;margin:0 auto 36px;font-size:15px;color:rgba(17,17,17,0.72);line-height:1.65;text-align:left}
.pricing-note strong{color:#111;display:block;margin-bottom:4px}
.truck-fill{transform-box:fill-box;transform-origin:50% 100%}


/* ---- TRUST QUOTES ---- */
.trust-quotes{background:var(--color-review-bg);padding:96px 32px}
.trust-quotes-inner{max-width:1100px;margin:0 auto}
.trust-quotes-heading{font-family:var(--font-heading);font-size:clamp(26px,3.5vw,42px);font-weight:800;color:var(--color-white);line-height:1.1;margin-bottom:14px;text-wrap:balance}
.trust-quotes-accent{width:56px;height:4px;background:var(--color-primary);border-radius:9px;margin-bottom:52px}
.trust-quotes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.tq-card{background:rgba(128,0,255,0.1);border:1px solid rgba(128,0,255,0.25);border-top:3px solid var(--color-fire);border-radius:6px;padding:28px 24px;display:flex;flex-direction:column}
.tq-stars{color:#FFD700;font-size:17px;letter-spacing:2px;margin-bottom:16px}
.tq-text{color:rgba(255,255,255,0.88);font-size:15px;font-style:italic;line-height:1.75;flex:1;margin-bottom:20px}
.tq-author{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,0.55)}

/* ---- REVIEW WIDGETS ---- */
.rw-mini{display:flex;flex-direction:column;gap:6px;padding:16px 20px;border-left:3px solid var(--color-fire);background:rgba(255,255,255,0.06);border-radius:0 4px 4px 0;margin-top:28px}
.rw-mini--light{background:rgba(17,17,17,0.04);border-left-color:var(--color-primary)}
.rw-mini-stars{color:#FFB800;font-size:13px;letter-spacing:2px}
.rw-mini-text{color:rgba(255,255,255,0.9);font-size:15px;font-style:normal;line-height:1.65;margin:0}
.rw-mini--light .rw-mini-text{color:rgba(17,17,17,0.75)}
.rw-mini-author{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,0.45)}
.rw-mini--light .rw-mini-author{color:rgba(17,17,17,0.45)}
.proof-connector{font-size:13px;font-style:italic;font-weight:500;color:rgba(17,17,17,0.45);margin:16px 0 0;letter-spacing:0}
.owner-section .proof-connector{color:rgba(255,255,255,0.65)}
.owner-section .rw-mini--light{background:rgba(255,255,255,0.06);border-left-color:var(--color-fire)}
.owner-section .rw-mini--light .rw-mini-text{color:rgba(255,255,255,0.85)}
.owner-section .rw-mini--light .rw-mini-author{color:rgba(255,255,255,0.45)}
/* light variant — homepage only */
.owner-section--light{background:#ffffff;margin-top:0;padding-top:40px;transform:translateZ(0)}
.owner-section--light::before{mix-blend-mode:multiply;opacity:0.04}
.owner-section--light h2{color:#111}
.owner-section--light p{color:rgba(17,17,17,0.7)}
.owner-section--light{padding-top:32px}
.owner-section--light .owner-stats{border-top-color:rgba(17,17,17,0.12);border-bottom-color:rgba(17,17,17,0.12)}
.owner-section--light .owner-stat+.owner-stat{border-left-color:rgba(17,17,17,0.12)}
.owner-section--light .stat-lbl{color:rgba(17,17,17,0.5)}
.owner-section--light .proof-connector{color:rgba(17,17,17,0.45)}
.owner-section--light .rw-mini--light{background:rgba(17,17,17,0.04);border-left-color:var(--color-fire)}
.owner-section--light .rw-mini--light .rw-mini-text{color:rgba(17,17,17,0.75)}
.owner-section--light .rw-mini--light .rw-mini-author{color:rgba(17,17,17,0.45)}

/* ---- FAQ chapter intro band ---- */
.faq-chapter-intro{background:var(--color-review-bg);padding:52px 32px 0;text-align:center}
.faq-chapter-label{font-family:var(--font-heading);font-size:clamp(24px,3vw,40px);font-weight:700;font-style:italic;letter-spacing:-0.01em;color:rgba(255,255,255,0.9);text-decoration:underline;text-decoration-color:var(--color-fire);text-underline-offset:6px;text-decoration-thickness:2px;display:inline-block}
/* ---- FAQ ---- */
.faq-section{background:var(--color-review-bg);padding:80px 32px 80px;position:relative}
.faq-inner{max-width:820px;margin:0 auto;text-align:center}
.faq-list{margin:36px 0;text-align:left}
.faq-item{border-bottom:1px solid rgba(255,255,255,0.1)}
.faq-question{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 0;cursor:pointer;color:rgba(255,255,255,0.9);font-size:16px;font-weight:600;gap:16px;user-select:none;font-family:var(--font)}
.faq-num{font-family:var(--font-heading);font-size:18px;font-weight:800;color:var(--color-fire);flex-shrink:0;width:28px}
.faq-text{flex:1}
.faq-question:hover{color:var(--color-primary-mid)}
.faq-toggle{flex-shrink:0;width:30px;height:30px;border:2px solid rgba(255,255,255,0.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;color:rgba(255,255,255,0.9);transition:transform var(--transition)}
.faq-item.open .faq-toggle{background:var(--color-primary);border-color:var(--color-primary);color:#fff;transform:rotate(45deg)}
.faq-answer{display:none;padding:0 0 24px 44px;color:rgba(255,255,255,0.6);font-size:14px;line-height:1.8}
.faq-item.open .faq-answer{display:block}

/* ---- RESULTS / BEFORE-AFTER ---- */
.results-section{background:var(--color-dark-section);padding:80px 32px 72px;position:relative;text-align:center}
.results-inner{max-width:1100px;margin:0 auto}
.results-accent{width:56px;height:4px;background:var(--color-primary);border-radius:9px;margin:0 auto 40px}
.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:40px}
.ba-slider{position:relative;overflow:hidden;aspect-ratio:4/3;width:100%;border-radius:8px;border:2px solid rgba(255,255,255,0.13);box-shadow:0 0 0 1px rgba(123,53,212,0.35),0 20px 60px rgba(0,0,0,0.65),inset 0 1px 0 rgba(255,255,255,0.1)}
.ba-after,.ba-before{position:absolute;inset:0}
.ba-after img,.ba-before img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
@keyframes ba-reveal{0%,15%{opacity:1}45%,70%{opacity:0}90%,100%{opacity:1}}
@keyframes ba-reveal-inv{0%,15%{opacity:0}45%,70%{opacity:1}90%,100%{opacity:0}}
/* Before layer "wipes" away with a soft feathered diagonal edge — the junk clears
   across the frame to reveal the clean after-shot underneath, instead of a flat fade. */
@keyframes ba-wipe{0%,15%{-webkit-mask-position:0% 0;mask-position:0% 0}50%,72%{-webkit-mask-position:100% 0;mask-position:100% 0}90%,100%{-webkit-mask-position:0% 0;mask-position:0% 0}}
.ba-before{opacity:1;-webkit-mask-image:linear-gradient(105deg,#000 40%,rgba(0,0,0,0) 62%);mask-image:linear-gradient(105deg,#000 40%,rgba(0,0,0,0) 62%);-webkit-mask-size:220% 100%;mask-size:220% 100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:0% 0;mask-position:0% 0}
.ba-slider.ba-animate .ba-before{animation:ba-wipe 6s ease-in-out infinite}
.ba-caption{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);z-index:4;background:rgba(123,53,212,0.88);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:8px 22px 9px;border-radius:40px;text-align:center;pointer-events:none;white-space:nowrap;border:1px solid rgba(255,255,255,0.15)}
.ba-caption-state{display:block;font-family:var(--font-heading);font-size:20px;font-weight:800;text-transform:uppercase;letter-spacing:2px;color:#fff;line-height:1.1}
.ba-caption-brand{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:rgba(255,255,255,0.6);margin-top:2px}
.ba-caption--after{opacity:0}
.ba-slider.ba-animate .ba-caption--before{animation:ba-reveal 6s ease-in-out infinite}
.ba-slider.ba-animate .ba-caption--after{animation:ba-reveal-inv 6s ease-in-out infinite}

/* ---- LOCATIONS HUB ---- */
.locations-hub{background:var(--color-light-alt);padding:52px 32px;}
.locations-hub-inner{max-width:1100px;margin:0 auto;text-align:center}
.locations-intro{color:#666666;font-size:15px;max-width:560px;margin:0 auto 24px;line-height:1.65}
/* ---- Legacy locations layout (still used by service + city pages until rollout) ---- */
.locations-layout{display:grid;grid-template-columns:1fr 280px;gap:0;border-radius:8px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,0.1);border:1px solid var(--color-border)}
#map-container{position:relative}
#service-map-svg{display:block;width:100%;cursor:pointer}
#service-map{height:480px;display:none;background:#f2f0eb}
#map-activate-btn{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);background:var(--color-primary);color:#fff;border:none;padding:7px 22px;border-radius:20px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;font-family:var(--font);letter-spacing:.5px;box-shadow:0 2px 12px rgba(123,53,212,.3)}
#map-activate-btn:hover{background:var(--color-primary-dark)}
.locations-sidebar{background:var(--color-white);padding:20px;border-left:1px solid var(--color-border);text-align:left}
.locations-sidebar-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--color-primary);margin-bottom:14px}
.location-pills{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-start}
.location-pill{display:inline-block;padding:8px 16px;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-pill);font-size:13px;font-weight:600;color:var(--color-body);cursor:pointer;transition:none}
.location-pill:hover,.location-pill.active{background:var(--color-primary);color:var(--color-white);border-color:var(--color-primary)}
.location-pill--cta{background:var(--color-primary);color:var(--color-white);border-color:var(--color-primary);margin-top:8px}
.location-pill--cta:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark)}

/* ---- Premium coverage-zone map (homepage; scoped via .locations-layout--zones) ---- */
.locations-layout--zones{display:block;border-radius:12px;box-shadow:0 18px 50px -12px rgba(91,34,170,0.28),0 4px 14px rgba(0,0,0,0.08)}
.locations-layout--zones #service-map{display:block;height:520px;background:#eef0ea;z-index:1}
/* soft lift under the whole coverage shape */
.locations-layout--zones .leaflet-overlay-pane svg{filter:drop-shadow(0 8px 18px rgba(91,34,170,.22))}
.locations-layout--zones .leaflet-interactive{cursor:pointer;transition:fill-opacity .18s ease}
/* city dot + name label, pinned at each city point */
.jb-label{pointer-events:none;white-space:nowrap}
.jb-dot{position:absolute;left:-5px;top:-5px;width:10px;height:10px;border-radius:50%;background:var(--color-primary);border:2px solid #fff;box-shadow:0 1px 3px rgba(0,0,0,.4)}
.jb-dot--home{left:-8px;top:-8px;width:16px;height:16px;background:var(--color-fire);border:3px solid #fff;box-shadow:0 0 0 5px rgba(255,122,0,.22),0 1px 4px rgba(0,0,0,.4)}
.jb-city{position:absolute;left:8px;top:-9px;font-family:var(--font-heading);font-weight:700;font-size:13px;letter-spacing:.3px;color:#1c1c2e;text-shadow:0 0 3px #fff,0 0 3px #fff,0 0 6px #fff,0 1px 2px #fff}
.jb-city--home{left:11px;top:-13px;font-size:16px;color:var(--color-primary-dark)}
.jb-city--home em{display:block;font-style:normal;font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--color-fire)}
/* premium hover tooltip */
.jb-tip{background:#1c1c2e;color:#fff;border:none;font-family:var(--font);font-weight:600;font-size:12px;padding:5px 11px;border-radius:6px;box-shadow:0 4px 14px rgba(0,0,0,.3)}
.jb-tip::before{border-top-color:#1c1c2e}
#service-map .leaflet-control-attribution{font-size:10px;background:rgba(255,255,255,.82)}
#service-map .leaflet-control-attribution a{color:var(--color-primary)}
/* slim, secondary city links below the map (crawlable + non-JS fallback) */
.locations-arealist-label{margin:22px 0 10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--color-primary)}
.locations-arealist{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:4px 0;max-width:760px;margin:0 auto}
.area-link{font-size:14px;font-weight:600;color:var(--color-body);text-decoration:none;padding:3px 12px;border-radius:4px;position:relative;transition:color .15s ease,background .15s ease}
.area-link:not(:last-child)::after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px;height:13px;background:var(--color-border)}
.area-link:hover,.area-link--hot{color:var(--color-primary-dark);background:var(--color-primary-light)}
.area-link--cta{color:var(--color-primary);font-weight:700}
.area-link--cta::after{display:none}

/* ---- FINAL CTA ---- */
.cta-final{background:#0D0010;padding:80px 32px;text-align:center;position:relative;overflow:hidden}
.cta-final::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(128,0,255,0.06) 1px,transparent 1px);background-size:28px 28px;pointer-events:none}
.cta-final-content{max-width:600px;margin:0 auto;position:relative}
.cta-final h2{font-family:var(--font-heading);font-size:clamp(28px,4vw,44px);font-weight:800;color:#fff;margin-bottom:20px;letter-spacing:1px}
.cta-final-phone{display:block;font-family:var(--font-heading);font-weight:800;color:var(--color-fire);line-height:1;letter-spacing:-2px;margin-bottom:6px;transition:opacity var(--transition),transform var(--transition);font-size:clamp(52px,9vw,88px);text-shadow:0 0 48px var(--color-fire-glow)}
.cta-final-phone:hover{opacity:0.82;transform:scale(1.02)}
.cta-final-tap{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:rgba(255,255,255,0.62);margin-bottom:32px;display:block}
.cta-final-sub{font-size:14px;color:rgba(255,255,255,0.55);margin-top:20px}

/* ---- FOOTER ---- */
.site-footer{background:var(--color-footer);padding:64px 32px 0;color:rgba(255,255,255,0.72)}
.footer-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:52px}
.footer-brand .footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.footer-brand p{font-size:13px;line-height:1.7;margin-bottom:8px}
.footer-brand .footer-phone{font-size:17px;font-weight:700;color:var(--color-white);display:block;margin-top:14px}
.footer-brand .footer-hours{font-size:12px;color:var(--color-primary-mid);margin-top:6px;display:block}
.footer-col h3{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--color-white);margin-bottom:16px}
.footer-col ul li{margin-bottom:8px}
.footer-col ul a{font-size:13px;color:rgba(255,255,255,0.62)}
.footer-col ul a:hover{color:var(--color-primary-mid)}
.social-icons{display:flex;gap:10px;margin-top:4px}
.social-icon{width:36px;height:36px;border:1px solid rgba(255,255,255,0.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;color:rgba(255,255,255,0.7)}
.social-icon:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.07);padding:20px 32px;text-align:center;font-size:12px;color:rgba(255,255,255,0.65)}
.footer-bottom a{color:rgba(255,255,255,0.75);text-decoration:underline}
.footer-bottom a:hover{color:var(--color-primary-mid)}


/* ---- SERVICE PAGE HERO ---- */
.sp-breadcrumb{font-size:12px;font-weight:600;color:rgba(255,255,255,0.65);text-transform:uppercase;letter-spacing:1px;margin-bottom:32px;display:flex;align-items:center;gap:8px}
.sp-breadcrumb a{color:rgba(255,255,255,0.65);transition:color .2s}
.sp-breadcrumb a:hover{color:rgba(255,255,255,0.85)}
.sp-breadcrumb span{color:rgba(255,255,255,0.4)}

/* ---- RESPONSIVE ---- */
@media(max-width:900px){
  .hero{flex-direction:column;align-items:stretch;position:relative;min-height:calc(100dvh - 70px)}
  .hero-left{flex:none;max-width:100%;width:100%;padding:56px 28px 48px;position:relative;z-index:1}
  .hero-right{position:absolute;inset:0;width:100%;height:100%}
  .hero-right img{object-position:center center}
  .hero-right::before{background:linear-gradient(180deg,rgba(10,0,15,0.88) 0%,rgba(10,0,15,0.62) 45%,rgba(10,0,15,0.82) 100%)}
  .hero-content{text-align:center}
  .hero-pullquote{text-align:left}
  .hero-buttons{justify-content:center}
  .owner-inner{grid-template-columns:1fr;grid-template-rows:none;grid-template-areas:"head" "photo" "body";gap:32px}
  .owner-section--light{margin-top:0;padding-top:52px}
  .owner-badge{bottom:-12px;right:4px}
}
@media(max-width:768px){
  .header-nav,.header-ctas{display:none}
  .hamburger{display:flex}
  .site-header{padding:0 20px}
  .footer-inner{grid-template-columns:1fr;gap:28px}
  .svc-section{padding:calc(52px + 6vw) 20px 0}
  .svc-grid{grid-template-columns:repeat(2,1fr);margin-bottom:-80px}
  .hiw-section{padding-top:160px}
  .svc-card{min-height:180px}
  .svc-card-body p{display:none}
  .svc-grid .svc-card:last-child{grid-column:span 2;min-height:160px}
  .svc-card-hover{display:none}
  .svc-cta-row{display:none}
  .pain-section{padding:52px 20px 0}
  .pain-close{padding:0 20px 28px}
  .pain-bridge{padding-bottom:36px}
  .pain-pivot-accent{margin:28px auto 32px}
  .pain-close br{display:none}
  .section-bridge{padding:48px 20px 56px}
  .section-bridge--final{padding-top:48px;padding-bottom:56px}
  .trust-ticker-track{padding:16px 0}
  .trust-quotes-grid{grid-template-columns:1fr;gap:14px}
  .trust-quotes{padding:52px 20px}
  .hiw-section + .trust-quotes{padding-top:calc(40px + 6vw)}
  .pricing-trucks{grid-template-columns:repeat(2,1fr);gap:12px}
  .pricing-section{padding:52px 20px 60px}
  .truck-svg-wrap{max-width:140px}
}
@media(max-width:640px){
  .ba-grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  .hiw-steps{grid-template-columns:1fr}
  .hiw-connector{display:none}
  .hiw-step:not(:last-child){border-right:none;border-bottom:1px solid rgba(17,17,17,0.08)}
  .results-section{padding:52px 20px 40px}
}
@media(max-width:480px){
  .hero-buttons{flex-direction:column}
  .hero-buttons .btn-fire{text-align:center}
}
@media(max-width:860px){
  /* legacy pages */
  .locations-layout{grid-template-columns:1fr}
  #service-map{height:360px}
  .locations-sidebar{max-height:none;border-left:none;border-top:1px solid var(--color-border);text-align:center}
  .locations-sidebar .location-pills{justify-content:center}
  /* zones map */
  .locations-layout--zones #service-map{height:420px}
  .jb-city{font-size:12px}
}
@media(max-width:480px){
  #service-map{height:300px}
  .locations-hub{padding:40px 16px}
  .locations-layout--zones #service-map{height:360px}
  .jb-city{font-size:11px}
  .jb-city--home{font-size:13px}
  .area-link{font-size:13px;padding:3px 9px}
}


/* ---- PAIN SECTION — restructured layout (problems, pivot, solutions) ---- */
.pain-solutions{list-style:none;padding:0;display:flex;flex-direction:column;gap:10px;margin-top:0}
.pain-solutions .pain-answer{margin:0}
.pain-pivot{font-family:var(--font-heading);font-size:clamp(18px,2vw,26px);font-weight:800;color:var(--color-fire);text-align:left;display:block;padding:12px 0 20px;margin-top:0;letter-spacing:-0.01em}

/* ---- STICKY MOBILE CALL BAR ---- */
.sticky-call-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:950;background:#07001A;border-top:1px solid rgba(255,122,0,0.25);padding:10px 14px;padding-bottom:calc(10px + env(safe-area-inset-bottom));gap:10px;box-shadow:0 -4px 24px rgba(0,0,0,0.45)}
.sticky-call-bar__phone{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;background:#C05000;color:#fff;font-family:var(--font);font-size:15px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;padding:12px 14px;border-radius:4px;text-decoration:none;box-shadow:0 2px 8px rgba(255,122,0,0.3)}
.sticky-call-bar__quote{flex-shrink:0;padding:12px 14px;border:2px solid rgba(255,255,255,0.25);color:rgba(255,255,255,0.85);font-family:var(--font);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;border-radius:4px;text-decoration:none;white-space:nowrap;display:flex;align-items:center}
@media(max-width:768px){
  .sticky-call-bar{display:flex}
  body{padding-bottom:72px}
  #wg-trigger{bottom:84px !important}
}

/* ---- SECTION TRANSITIONS (city page flow) ---- */
/* Dark enters from RIGHT. Light enters from LEFT. Never consciously seen — only felt. */

/* T1: Owner → HIW — light opens from the left */
.owner-section + .hiw-section{clip-path:polygon(0 0,100% 5vw,100% 100%,0 100%);margin-top:-5vw;padding-top:calc(80px + 5vw);z-index:11;position:relative}

/* T2: HIW → Reviews — darkness descends from the right */
.hiw-section + .trust-quotes{clip-path:polygon(0 6vw,100% 0,100% 100%,0 100%);margin-top:-6vw;padding-top:calc(96px + 6vw);z-index:12;position:relative}
.hiw-section:has(+ .trust-quotes){padding-bottom:calc(72px + 6vw)}

/* T3: Reviews → Locations — light re-emerges gently from the left */
.trust-quotes + .locations-hub{clip-path:polygon(0 0,100% 4vw,100% 100%,0 100%);margin-top:-4vw;padding-top:calc(52px + 4vw);z-index:13;position:relative}

/* T4: Locations → FAQ — darkness drops decisively from the right */
.locations-hub + .faq-section{clip-path:polygon(0 6vw,100% 0,100% 100%,0 100%);margin-top:-6vw;padding-top:calc(80px + 6vw);z-index:14;position:relative}
.locations-hub:has(+ .faq-section){padding-bottom:calc(52px + 6vw)}

/* T5: FAQ → Final CTA — heat line, not a diagonal */
.faq-section + .cta-final{position:relative}
.faq-section + .cta-final::before{content:'';display:block;position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0%,var(--color-fire) 30%,var(--color-fire) 70%,transparent 100%);opacity:0.6}

/* ---- NEARBY / SERVICE-CITIES SECTION ---- */
.nearby-section{background:var(--color-light-alt);padding:40px 32px;border-top:1px solid var(--color-border)}
.nearby-section-inner{max-width:820px;margin:0 auto}
.nearby-section-label{font-family:var(--font);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:rgba(0,0,0,0.4);margin:0 0 14px;display:block}
.nearby-section + .cta-final{position:relative}
.nearby-section + .cta-final::before{content:'';display:block;position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0%,var(--color-fire) 30%,var(--color-fire) 70%,transparent 100%);opacity:0.6}
@media(max-width:768px){.nearby-section{padding:32px 20px}}

/* ---- JB SHARED FORM + QUOTE MODAL ---- */
.jb-form-row{display:flex;gap:14px}
.jb-form-group{display:flex;flex-direction:column;flex:1;margin-bottom:11px}
.jb-form-group label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,0.45);margin-bottom:6px}
.jb-form-group input{padding:12px 14px;background:rgba(255,255,255,0.06);border:1.5px solid rgba(255,255,255,0.12);border-radius:4px;font-family:var(--font);font-size:15px;color:#fff;transition:border-color .2s,box-shadow .2s}
.jb-form-group input::placeholder{color:rgba(255,255,255,0.25)}
.jb-form-group input:focus{outline:none;border-color:var(--color-fire);box-shadow:0 0 0 3px rgba(255,122,0,0.18)}
.jb-form-submit{display:block;width:100%;margin-top:24px;padding:15px 28px;background:#C05000;color:#fff;font-family:var(--font-heading);font-size:17px;font-weight:800;text-transform:uppercase;letter-spacing:0.5px;border:none;border-radius:4px;cursor:pointer;transition:opacity .2s;box-shadow:0 4px 20px rgba(255,122,0,0.35);text-align:center}
.jb-form-submit:hover{opacity:.9}
.jb-form-submit:disabled{opacity:.55;cursor:not-allowed}
.jb-form-status{margin-top:12px;font-size:14px;font-weight:600;display:none}
.jb-form-status.success{color:#22c55e;display:block}
.jb-optional{font-weight:400;color:rgba(255,255,255,0.4);font-size:.85em;text-transform:none;letter-spacing:0}
.jb-toggle{display:flex;width:100%;border:1px solid rgba(255,255,255,0.18);border-radius:8px;overflow:hidden}
.jb-toggle input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}
.jb-toggle label{flex:1;margin:0;padding:11px 0;text-align:center;font-size:14px;font-weight:700;letter-spacing:.3px;text-transform:none;color:rgba(255,255,255,0.6);cursor:pointer;transition:background .15s,color .15s}
.jb-toggle label:first-of-type{border-right:1px solid rgba(255,255,255,0.14)}
.jb-toggle input:checked+label{background:#C05000;color:#fff}
.jb-toggle input:focus-visible+label{outline:2px solid var(--color-fire);outline-offset:2px}
/* Centered info-page hero with branded-truck backdrop + gradient overlay (faq, service-areas) */
.hero.hero--info{position:relative;overflow:hidden;min-height:auto;background:#07001A}
.hero--info .hero-bg-media{position:absolute;inset:0;z-index:0;margin:0;display:block}
.hero--info .hero-bg-media img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero.hero--info::before{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(ellipse at 22% 12%,rgba(123,53,212,0.28) 0%,transparent 55%),radial-gradient(ellipse at 88% 108%,rgba(255,122,0,0.13) 0%,transparent 45%),radial-gradient(ellipse at center,rgba(7,0,26,0.45) 0%,transparent 72%),linear-gradient(180deg,rgba(7,0,26,0.90) 0%,rgba(7,0,26,0.80) 48%,rgba(7,0,26,0.95) 100%)}
.hero--info>div{position:relative;z-index:2}
.hero--info .hero-centered{text-shadow:0 2px 20px rgba(7,0,26,0.65)}
.hero--info .hero-sub{color:rgba(255,255,255,0.82);margin-bottom:40px}
.hero--info .hero-centered h1{color:rgba(255,255,255,0.78)}
.jb-form-status.error{color:#ff6b6b;display:block}
.jb-form-group input.jb-input-error{border-color:#ff6b6b !important;box-shadow:0 0 0 3px rgba(255,107,107,0.18) !important}
.jb-modal-overlay{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,0.75);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .25s ease}
.jb-modal-overlay.open{opacity:1;pointer-events:all}
.jb-modal-card{background:#080014;border-radius:8px;padding:44px 40px 40px;max-width:460px;width:100%;position:relative;transform:translateY(20px);transition:transform .25s ease;border-top:3px solid var(--color-fire);max-height:90vh;overflow-y:auto}
.jb-modal-overlay.open .jb-modal-card{transform:translateY(0)}
.jb-modal-close{position:absolute;top:14px;right:16px;background:none;border:none;cursor:pointer;color:rgba(255,255,255,0.35);font-size:28px;line-height:1;padding:4px 8px;font-family:var(--font);transition:color .2s}
.jb-modal-close:hover{color:#fff}
.jb-modal-logo{height:44px;width:auto;margin-bottom:20px;display:block}
.jb-modal-heading{font-family:var(--font-heading);font-size:28px;font-weight:800;font-style:italic;color:#fff;line-height:1.1;margin-bottom:6px;text-decoration:underline;text-decoration-color:var(--color-fire);text-underline-offset:5px;text-decoration-thickness:2px}
.jb-modal-sub{font-size:14px;color:rgba(255,255,255,0.45);margin-bottom:24px}
@media(max-width:540px){
  .jb-modal-overlay{align-items:flex-end;padding:0}
  .jb-modal-card{border-radius:16px 16px 0 0;padding:26px 18px 24px;max-height:92vh}
  .jb-form-row{gap:10px}
  .jb-modal-logo{height:38px;margin-bottom:12px}
  .jb-modal-heading{font-size:24px;margin-bottom:4px}
  .jb-modal-sub{margin-bottom:14px}
  .jb-form-group{margin-bottom:9px}
  .jb-form-submit{margin-top:14px}
}
.zip-check-hint{display:block;font-size:12px;font-weight:600;margin-top:5px;min-height:16px}
.zip-check-hint--ok{color:var(--color-fire)}
.zip-check-hint--warn{color:#FFA040}

/* ---- LOCATION PAGE TEMPLATE ---- */
body.page-location .hero{position:relative;z-index:10}
body.page-location .trust-ticker{position:relative;z-index:10}
body.page-location .svc-section::after{display:none}
body.page-location .svc-section{clip-path:none;margin-top:0;padding-top:56px;padding-bottom:72px;box-shadow:none;z-index:auto}
body.page-location .svc-section h2.h2-bridge--light{color:rgba(0,0,0,0.65)}
body.page-location .svc-card--wide{grid-column:span 2}
body.page-location .svc-card--tall{grid-row:span 2}
body.page-location .faq-section .section-bridge{padding-top:0;padding-bottom:16px}
@media(min-width:769px){body.page-location .svc-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:769px){body.page-location .svc-grid.svc-grid--4col{grid-template-columns:repeat(4,1fr);grid-auto-flow:dense}}
@media(max-width:768px){
  body.page-location .svc-grid{grid-auto-flow:row dense}
  body.page-location .svc-card--wide{min-height:150px}
  body.page-location .svc-section .svc-grid{margin-bottom:0}
  body.page-location .svc-grid .svc-card:last-child{grid-column:span 1;min-height:auto}
}
