/* Consolidated section styles — rebuilt from design files (home, residential, commercial, KC, STL, contact). */

/* ===== BRAND COLOR OVERRIDES — v3 ===== */
:root {
  --sky: #099CF9;
  --sky-700: #0775D4;
  --sky-300: #65C5FC;
  --sky-50: #E8F5FE;
  --charcoal: #2D2D2D;
  --charcoal-2: #383838;
  --charcoal-3: #454545;
  --grey: #6B6B6B;
  --grey-2: #9A9A9A;
  --line: #E2E2E2;
  --bg: #F6F6F6;
}


/* ===== NAV ===== */
.promo-bar { background: var(--green); color: var(--charcoal); text-align: center; padding: 9px 16px; font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; }
.promo-bar a { text-decoration: underline; text-underline-offset: 2px; }
.nav-wrap { position: sticky; top: 0; z-index: 60; background: rgba(45,45,45,.92); backdrop-filter: blur(14px); border-bottom: 1px solid rgba(255,255,255,.06); }
.nav { display: flex; align-items: center; justify-content: space-between; padding: 18px 48px; color: #fff; }
.nav-logo { display: flex; align-items: center; }
.nav-logo img { height: 48px; width: auto; display: block; }
.nav-links { display: flex; align-items: center; gap: 36px; }
.nav-link { position: relative; font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 13px; letter-spacing: .05em; color: #fff; padding: 24px 0; display: inline-flex; align-items: center; gap: 6px; }
.nav-link .caret { font-size: 9px; opacity: .7; transition: transform .2s; }
.nav-item:hover .caret { transform: rotate(180deg); }
.nav-item { position: relative; }
.nav-cta { display: flex; align-items: center; gap: 14px; }
.nav-phone { font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 13px; letter-spacing: .04em; color: #fff; display: flex; align-items: center; gap: 8px; }
.nav-phone .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 0 rgba(0,255,1,.6); animation: pulse 2s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(0,255,1,.6); } 70% { box-shadow: 0 0 0 14px rgba(0,255,1,0); } 100% { box-shadow: 0 0 0 0 rgba(0,255,1,0); } }
.dropdown { position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(8px); min-width: 280px; background: #fff; color: var(--charcoal); border-radius: 18px; padding: 14px; box-shadow: 0 24px 60px -12px rgba(0,0,0,.35); opacity: 0; pointer-events: none; transition: all .2s ease; border: 1px solid var(--line); }
.nav-item:hover .dropdown { opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.dropdown a { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-radius: 10px; font-family: 'Mansfield',sans-serif; font-weight: 500; font-size: 14px; color: var(--charcoal); transition: background .15s; }
.dropdown a:hover { background: var(--bg); }
.dropdown a::after { content: "→"; opacity: 0; transform: translateX(-4px); transition: all .15s; color: var(--sky); }
.dropdown a:hover::after { opacity: 1; transform: translateX(0); }
.dropdown .dd-divider { height: 1px; background: var(--line); margin: 8px 6px; }
.dropdown .dd-feature { display: flex; align-items: center; gap: 12px; padding: 14px 14px; margin: 4px 0 0; background: linear-gradient(135deg,var(--charcoal) 0%,var(--charcoal-2) 100%); border-radius: 12px; color: #fff; font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 13px; transition: transform .15s; }
.dropdown .dd-feature:hover { transform: translateY(-1px); background: linear-gradient(135deg,var(--charcoal-2) 0%,var(--charcoal-3) 100%); }
.dropdown .dd-feature::after { display: none; }
.dropdown .dd-feature .dd-mark { width: 28px; height: 28px; border-radius: 50%; background: var(--green); color: var(--charcoal); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 13px; flex-shrink: 0; }
.dropdown .dd-feature .dd-text { display: flex; flex-direction: column; gap: 1px; }
.dropdown .dd-feature .dd-text span { font-family: 'Poppins',sans-serif; font-weight: 400; font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--green); }
.nav-cta .free-guide { font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 13px; color: rgba(255,255,255,.85); text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(255,255,255,.3); transition: text-decoration-color .15s, color .15s; white-space: nowrap; }
.nav-cta .free-guide:hover { color: #fff; text-decoration-color: var(--green); }

/* ===== HERO ===== */
.hero { position: relative; background: var(--charcoal); color: #fff; padding: 100px 0 120px; overflow: hidden; min-height: 700px; display: flex; align-items: center; }
.hero .sonar-bg { top: -280px; right: -340px; width: 1300px; height: 1300px; color: var(--sky); opacity: .22; }
.hero .sonar-bg-bottomleft { bottom: -380px; left: -380px; width: 760px; height: 760px; color: var(--green); opacity: .13; }
.hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; position: relative; z-index: 2; }
.hero-grid > div:last-child { display: flex; justify-content: center; }
.hero-eyebrow { display: inline-flex; align-items: center; gap: 14px; margin-bottom: 28px; }
.hero-eyebrow .pip { width: 28px; height: 1px; background: var(--green); }
.hero h1 { margin: 0 0 28px; color: #fff; }
.hero h1 .highlight { color: var(--green); font-style: normal; }
.hero-sub { font-size: 19px; line-height: 1.55; color: rgba(255,255,255,.75); max-width: 54ch; margin-bottom: 40px; font-weight: 300; }
.hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 54px; }
.hero-meta { display: flex; gap: 48px; flex-wrap: wrap; }
.hero-meta-item { display: flex; flex-direction: column; gap: 4px; }
.hero-meta-item .num { font-family: 'TBJ Norguba',sans-serif; font-size: 42px; line-height: 1; color: var(--green); }
.hero-meta-item .label { font-family: 'Poppins',sans-serif; font-size: 11px; text-transform: uppercase; letter-spacing: .22em; color: rgba(255,255,255,.6); margin-top: 6px; }
.hero-visual { position: relative; aspect-ratio: 1/1; border-radius: 50%; overflow: hidden; background: #000; width: min(646px,48vw); margin: 48px auto 0; }
.hero-visual img, .hero-visual video { width: 100%; height: 100%; object-fit: cover; display: block; }
.hero-visual::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg,rgba(45,45,45,.05) 0%,rgba(45,45,45,.55) 100%); }
.hero-visual .badge { position: absolute; right: 28px; bottom: 40px; z-index: 2; width: 96px; height: 96px; border-radius: 50%; background: rgba(255,255,255,.94); color: var(--charcoal); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; padding: 0; text-align: center; box-shadow: 0 6px 24px rgba(0,0,0,.18); }
.hero-visual .badge .star { color: var(--sky); font-size: 22px; line-height: 1; }
.hero-visual .badge .badge-name { font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 9px; letter-spacing: .18em; text-transform: uppercase; line-height: 1.2; }
.hero-visual .badge .badge-sub { font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 7.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--grey); line-height: 1.2; }
@media (max-width: 980px) { .hero-grid { grid-template-columns: 1fr; gap: 48px; } .hero { padding: 80px 0 100px; min-height: 0; } .hero-visual { margin-top: 0; width: min(560px,90%); } }

/* ===== MARQUEE ===== */
.marquee { background: var(--bg); padding: 28px 0; border-bottom: 1px solid var(--line); position: relative; overflow: hidden; }
.marquee-label { display: block; margin: 0 0 18px; font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .28em; text-transform: uppercase; color: var(--grey); }
.marquee-viewport { overflow: hidden; -webkit-mask-image: linear-gradient(to right, transparent 0, #000 7%, #000 93%, transparent 100%); mask-image: linear-gradient(to right, transparent 0, #000 7%, #000 93%, transparent 100%); }
.marquee-track { display: flex; gap: 64px; align-items: center; width: max-content; animation: scroll 34s linear infinite; }
.marquee-track img { height: 62px; width: auto; display: block; flex: none; }
@keyframes scroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* ===== SECTION HEAD ===== */
.section-head { display: grid; grid-template-columns: 1fr 1.2fr; gap: 80px; align-items: end; margin-bottom: 64px; }
.section-head h2 { margin: 14px 0 0; }
@media (max-width: 880px) { .section-head { grid-template-columns: 1fr; gap: 24px; } }

/* ===== SERVICES ===== */
.services { background: #fff; }
.svc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; }
.svc-card { position: relative; border-radius: 32px; overflow: hidden; background: var(--charcoal); }
.services .svc-grid .svc-card { aspect-ratio: auto !important; }
.svc-card img { width: 100%; height: 360px; flex: none; object-fit: cover; object-position: center top; display: block; transition: transform .8s ease; }
.svc-card:hover img { transform: scale(1.04); }
.svc-card-inner { margin-top: -66px; position: relative; z-index: 2; display: flex; flex-direction: column; padding: 30px 40px 40px; color: #fff; background: linear-gradient(180deg, rgba(45,45,45,0) 0%, rgba(45,45,45,.55) 34px, var(--charcoal) 66px); }
.svc-card .num { font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .28em; text-transform: uppercase; color: var(--green); margin-bottom: 12px; }
.svc-card h3 { font-family: 'TBJ Norguba',sans-serif; font-size: 48px; text-transform: uppercase; line-height: .92; margin: 0 0 14px; }
.svc-card p { font-size: 15px; color: rgba(255,255,255,.82); margin: 0 0 22px; max-width: 42ch; font-weight: 300; }
.svc-card .text-link { color: #fff; border-bottom: none; text-decoration: underline; text-underline-offset: 4px; padding-bottom: 0; }
@media (max-width: 880px) { .svc-grid { grid-template-columns: 1fr; } }

/* ===== ECOFLOW BAND ===== */
.ecoflow-band { background: var(--charcoal); color: #fff; position: relative; overflow: hidden; }
.ecoflow-band-inner { display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px; align-items: center; position: relative; z-index: 2; }
.ecoflow-band-inner > div:last-child { display: flex; justify-content: center; width: 100%; }
.ecoflow-tag { display: inline-flex; align-items: center; gap: 14px; padding: 8px 16px; border: 1px solid rgba(255,255,255,.18); border-radius: 999px; margin-bottom: 32px; }
.ecoflow-tag .auth { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .28em; text-transform: uppercase; color: var(--green); }
.ecoflow-tag .name { font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 13px; letter-spacing: .04em; }
.ecoflow-band h2 { margin: 0 0 24px; }
.ecoflow-band h2 em { font-style: normal; color: var(--green); }
.ecoflow-band .lede { margin-bottom: 36px; color: rgba(255,255,255,.78); }
.ecoflow-band .lede strong { color: #fff; font-weight: 600; }
.ecoflow-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin: 36px 0 40px; padding: 24px 0; border-top: 1px solid rgba(255,255,255,.12); border-bottom: 1px solid rgba(255,255,255,.12); }
.ecoflow-stat .num { font-family: 'TBJ Norguba',sans-serif; font-size: 42px; line-height: 1; color: var(--sky-300); }
.ecoflow-stat .label { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.65); margin-top: 8px; }
.ecoflow-visual { position: relative; aspect-ratio: 1/1; border-radius: 50%; overflow: hidden; background: #000; width: min(520px,90%); margin: 0 auto; }
.ecoflow-visual img { width: 100%; height: 100%; object-fit: cover; }
.ecoflow-visual::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg,rgba(45,45,45,0) 50%,rgba(45,45,45,.4) 100%); }
@media (max-width: 980px) { .ecoflow-band-inner { grid-template-columns: 1fr; gap: 40px; } }

/* ===== PRODUCTS ===== */
.products { background: var(--bg); }
.prod-tabs { display: flex; flex-wrap: wrap; gap: 8px; margin: 32px 0 48px; padding: 8px; background: #fff; border-radius: 999px; width: fit-content; border: 1px solid var(--line); }
.prod-tab { padding: 12px 22px; border-radius: 999px; font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--grey); transition: all .2s; }
.prod-tab.active { background: var(--charcoal); color: #fff; }
.prod-tab:not(.active):hover { color: var(--charcoal); }
.prod-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.prod-card { background: #fff; border-radius: 28px; overflow: hidden; border: 1px solid var(--line); transition: all .3s; display: flex; flex-direction: column; }
.prod-card:hover { transform: translateY(-4px); box-shadow: 0 24px 60px -24px rgba(45,45,45,.18); }
.prod-card .thumb { aspect-ratio: 4/3; overflow: hidden; background: var(--charcoal); position: relative; }
.prod-card .thumb img, .prod-card .thumb video { width: 100%; height: 100%; object-fit: cover; transition: transform .6s; }
.prod-card:hover .thumb img, .prod-card:hover .thumb video { transform: scale(1.04); }
.prod-card .thumb.thumb-light { background: #fff; }
.prod-card .thumb.thumb-light img { object-fit: cover; object-position: center top; transform: translateY(-6%) scale(1.4); transform-origin: center top; }
.prod-card:hover .thumb.thumb-light img { transform: translateY(-6%) scale(1.44); }
.prod-card .ef-tag { position: absolute; top: 16px; left: 16px; background: var(--charcoal); color: var(--green); font-family: 'Poppins',sans-serif; font-size: 9px; letter-spacing: .22em; text-transform: uppercase; padding: 6px 10px; border-radius: 999px; font-weight: 700; display: inline-flex; align-items: center; gap: 6px; }
.prod-card .ef-tag::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--green); }
.prod-card .ef-tag { transition: opacity .3s ease; }
.prod-card:hover .ef-tag { opacity: 0; pointer-events: none; }
.prod-card .body { padding: 28px 28px 30px; flex: 1; display: flex; flex-direction: column; }
.prod-card .cat { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .28em; text-transform: uppercase; color: var(--sky); margin-bottom: 10px; }
.prod-card h4 { font-family: 'TBJ Norguba',sans-serif; font-size: 30px; text-transform: uppercase; line-height: 1; margin: 0 0 12px; }
.prod-card p { font-size: 14px; color: var(--grey); margin: 0 0 22px; line-height: 1.5; flex: 1; }
.prod-card .text-link { color: var(--charcoal); }
@media (max-width: 980px) { .prod-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px) { .prod-grid { grid-template-columns: 1fr; } }

/* ===== OCEAN FEATURE ===== */
.ocean-feature { background: var(--sky); color: #fff; position: relative; overflow: hidden; }
.ocean-feature .sonar-bg { top: auto; bottom: -300px; right: -200px; color: #fff; opacity: .2; }
.ocean-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 80px; align-items: center; position: relative; z-index: 2; }
.ocean-grid h2 { margin: 18px 0 24px; color: #fff; }
.ocean-grid h2 em { font-style: normal; color: var(--green); }
.ocean-list { list-style: none; padding: 0; margin: 36px 0 40px; display: grid; grid-template-columns: 1fr 1fr; gap: 14px 28px; }
.ocean-list li { display: flex; align-items: flex-start; gap: 12px; font-size: 15px; line-height: 1.45; }
.ocean-list li::before { content: ""; width: 18px; height: 18px; border-radius: 50%; border: 2px solid var(--green); flex: none; margin-top: 2px; background: radial-gradient(circle,var(--green) 0%,var(--green) 35%,transparent 36%); }
.ocean-visual { position: relative; border-radius: 36px; overflow: hidden; aspect-ratio: 1.05/1; background: #000; }
.ocean-visual img { width: 100%; height: 100%; object-fit: cover; }
.ocean-mini { position: absolute; left: 24px; bottom: 24px; background: rgba(255,255,255,.96); color: var(--charcoal); padding: 18px 22px; border-radius: 18px; display: flex; align-items: center; gap: 14px; backdrop-filter: blur(8px); }
.ocean-mini .icon { width: 40px; height: 40px; border-radius: 10px; background: var(--green); display: flex; align-items: center; justify-content: center; font-family: 'TBJ Norguba',sans-serif; color: var(--charcoal); font-size: 24px; }
.ocean-mini .t { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--grey); }
.ocean-mini .v { font-family: 'TBJ Norguba',sans-serif; font-size: 22px; text-transform: uppercase; line-height: 1; margin-top: 2px; }
@media (max-width: 980px) { .ocean-grid { grid-template-columns: 1fr; gap: 48px; } .ocean-list { grid-template-columns: 1fr; } }

/* ===== PROCESS ===== */
.process { background: #fff; }
.proc-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; margin-top: 24px; }
.proc-step { position: relative; padding: 36px 28px; border-radius: 24px; border: 1px solid var(--line); background: #fff; transition: all .3s; }
.proc-step:hover { border-color: var(--charcoal); transform: translateY(-3px); }
.proc-step .step-num { font-family: 'TBJ Norguba',sans-serif; font-size: 14px; letter-spacing: .18em; color: var(--green-dim); margin-bottom: 32px; display: flex; align-items: center; gap: 10px; }
.proc-step .step-num::after { content: ""; flex: 1; height: 1px; background: var(--line); }
.proc-step h4 { font-family: 'TBJ Norguba',sans-serif; font-size: 30px; text-transform: uppercase; line-height: .95; margin: 0 0 14px; }
.proc-step p { font-size: 14px; color: var(--grey); margin: 0; line-height: 1.55; }
.proc-step .icon { width: 48px; height: 48px; border-radius: 50%; background: var(--charcoal); color: var(--green); display: flex; align-items: center; justify-content: center; margin-bottom: 24px; font-family: 'TBJ Norguba',sans-serif; font-size: 22px; }
@media (max-width: 980px) { .proc-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px) { .proc-grid { grid-template-columns: 1fr; } }

/* ===== PROMISE ===== */
.promise { background: var(--charcoal); color: #fff; position: relative; overflow: hidden; }
.promise-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; position: relative; z-index: 2; }
.promise-img { position: relative; border-radius: 36px; overflow: hidden; aspect-ratio: 4/5; background: #000; }
.promise-img img { width: 100%; height: 100%; object-fit: cover; }
.promise-img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg,rgba(45,45,45,.1) 0%,rgba(45,45,45,.55) 100%); }
.promise h2 em { font-style: normal; color: var(--green); }
.promise-points { margin-top: 40px; display: flex; flex-direction: column; gap: 24px; }
.promise-pt { display: grid; grid-template-columns: auto 1fr; gap: 24px; align-items: start; padding-bottom: 24px; border-bottom: 1px solid rgba(255,255,255,.12); }
.promise-pt:last-child { border-bottom: none; }
.promise-pt .n { font-family: 'TBJ Norguba',sans-serif; font-size: 42px; color: var(--sky-300); line-height: .9; width: 60px; }
.promise-pt h4 { font-family: 'TBJ Norguba',sans-serif; font-size: 22px; text-transform: uppercase; line-height: 1; margin: 0 0 8px; }
.promise-pt p { font-size: 14px; color: rgba(255,255,255,.7); margin: 0; font-weight: 300; }
@media (max-width: 980px) { .promise-grid { grid-template-columns: 1fr; } }

/* ===== TESTIMONIALS ===== */
.testimonials { background: var(--bg); }
.test-head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 48px; }
.test-head .right { display: flex; justify-content: flex-end; align-items: center; gap: 16px; }
.t-rating { display: flex; align-items: center; gap: 14px; padding: 14px 22px; background: #fff; border-radius: 999px; border: 1px solid var(--line); }
.t-rating .stars { color: var(--green-dim); font-size: 18px; letter-spacing: 1px; }
.t-rating .v { font-family: 'TBJ Norguba',sans-serif; font-size: 24px; line-height: 1; }
.t-rating .meta { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--grey); }
.t-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.t-card { background: #fff; border-radius: 24px; padding: 36px; border: 1px solid var(--line); display: flex; flex-direction: column; }
.t-card .stars { color: var(--green-dim); font-size: 14px; letter-spacing: 2px; margin-bottom: 18px; }
.t-card .quote { font-family: 'Mansfield',sans-serif; font-size: 17px; line-height: 1.5; color: var(--charcoal); flex: 1; margin-bottom: 24px; }
.t-card .author { display: flex; align-items: center; gap: 14px; border-top: 1px solid var(--line); padding-top: 18px; }
.t-card .avatar { width: 42px; height: 42px; border-radius: 50%; background: var(--charcoal); color: var(--green); display: flex; align-items: center; justify-content: center; font-family: 'TBJ Norguba',sans-serif; font-size: 16px; }
.t-card .who { font-family: 'Mansfield',sans-serif; font-weight: 600; font-size: 14px; }
.t-card .where { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--grey); margin-top: 2px; }
@media (max-width: 980px) { .t-grid { grid-template-columns: 1fr; } .test-head { grid-template-columns: 1fr; } .test-head .right { justify-content: flex-start; } }

/* ===== LOCATIONS ===== */
.locations { background: #fff; }
.loc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.loc-card { position: relative; background: var(--charcoal); color: #fff; border-radius: 32px; padding: 56px 48px; overflow: hidden; min-height: 340px; display: flex; flex-direction: column; justify-content: space-between; }
.loc-card .sonar-bg { top: -120px; right: -160px; width: 520px; height: 520px; color: var(--sky-300); opacity: .2; }
.loc-card.alt { background: var(--sky); }
.loc-card.alt .sonar-bg { color: #fff; opacity: .25; }
.loc-card .city { font-family: 'TBJ Norguba',sans-serif; font-size: 64px; text-transform: uppercase; line-height: .95; margin: 0; position: relative; z-index: 2; }
.loc-card .city em { font-style: normal; color: var(--green); }
.loc-card .meta { display: grid; grid-template-columns: auto auto; gap: 36px; position: relative; z-index: 2; margin-top: 32px; }
.loc-card .meta-item { display: flex; flex-direction: column; }
.loc-card .meta-item .l { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.6); margin-bottom: 8px; }
.loc-card .meta-item .v { font-family: 'TBJ Norguba',sans-serif; font-size: 22px; line-height: 1.05; text-transform: uppercase; }
.loc-card .text-link { color: #fff; border-color: #fff; align-self: flex-start; margin-top: 32px; position: relative; z-index: 2; }
@media (max-width: 880px) { .loc-grid { grid-template-columns: 1fr; } }

/* ===== CERTIFICATIONS ===== */
.certs { background: #fff; border-top: 1px solid var(--line); padding: 60px 0; }
.certs-inner { display: grid; grid-template-columns: auto 1fr; gap: 72px; align-items: center; }
.certs-inner .label { font-family: 'TBJ Norguba',sans-serif; font-size: 24px; text-transform: uppercase; line-height: 1; max-width: 14ch; }
.certs-row { display: flex; flex-wrap: wrap; gap: 48px; align-items: center; justify-content: flex-end; }
.cert-item { display: flex; flex-direction: column; align-items: center; gap: 8px; text-align: center; flex: 1; min-width: 120px; max-width: 180px; }
.cert-item .seal { width: 64px; height: 64px; border-radius: 50%; border: 1.5px solid var(--charcoal); display: flex; align-items: center; justify-content: center; font-family: 'TBJ Norguba',sans-serif; font-size: 11px; text-align: center; line-height: 1; letter-spacing: .05em; }
.cert-item .seal.filled { background: var(--charcoal); color: #fff; }
.cert-item .seal.green { background: var(--green); color: var(--charcoal); border-color: var(--green); }
.cert-item .seal.blue { background: var(--sky); color: #fff; border-color: var(--sky); }
.cert-item .name { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--grey); }
@media (max-width: 880px) { .certs-inner { grid-template-columns: 1fr; gap: 32px; } .certs-row { justify-content: flex-start; } }

/* ===== CTA ===== */
.cta { background: var(--charcoal); color: #fff; position: relative; overflow: hidden; text-align: center; padding: 140px 0; }
.cta .sonar-bg { top: 50%; left: 50%; transform: translate(-50%,-50%); right: auto; width: 1100px; height: 1100px; opacity: .2; }
.cta .eyebrow { margin-bottom: 24px; }
.cta h2 { margin: 0 0 28px; position: relative; z-index: 2; }
.cta h2 em { font-style: normal; color: var(--green); }
.cta .lede { margin: 0 auto 40px; max-width: 54ch; color: rgba(255,255,255,.78); position: relative; z-index: 2; }
.cta-row { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; position: relative; z-index: 2; }

/* ===== FOOTER ===== */
.footer { background: #161F1F; color: #fff; padding: 96px 0 32px; position: relative; }
.foot-grid { display: grid; grid-template-columns: 1.4fr repeat(4,1fr); gap: 48px; }
.foot-brand p { font-size: 14px; color: rgba(255,255,255,.6); max-width: 34ch; line-height: 1.55; font-weight: 300; }
.foot-col h5 { font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .28em; text-transform: uppercase; color: var(--green); margin: 0 0 22px; }
.foot-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.foot-col a { font-family: 'Mansfield',sans-serif; font-size: 14px; color: rgba(255,255,255,.78); transition: color .2s; }
.foot-col a:hover { color: var(--green); }
.foot-bottom { margin-top: 64px; padding-top: 32px; border-top: 1px solid rgba(255,255,255,.1); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px; font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.5); }
.foot-social { display: flex; gap: 12px; }
.foot-social a { width: 36px; height: 36px; border-radius: 50%; border: 1px solid rgba(255,255,255,.15); display: flex; align-items: center; justify-content: center; font-size: 14px; transition: all .2s; }
.foot-social a:hover { background: var(--green); color: var(--charcoal); border-color: var(--green); }
@media (max-width: 980px) { .foot-grid { grid-template-columns: 1fr 1fr; gap: 36px; } }
@media (max-width: 560px) { .foot-grid { grid-template-columns: 1fr; } .nav-links { display: none; } }

/* ===== TWEAKS MOOD OVERRIDES ===== */
body[data-mood="daylight"] { --hero-bg:#F6F7F7; --hero-fg:#2D2D2D; --hero-sub:rgba(45,45,45,.7); --hero-h1-color:#2D2D2D; --hero-em-color:#0775D4; --promo-bg:#2D2D2D; --promo-fg:#00FF01; --nav-bg:rgba(246,247,247,.92); --nav-border:rgba(0,0,0,.06); }
body[data-mood="dusk"] { --hero-bg:#2D2D2D; --hero-fg:#fff; --hero-sub:rgba(255,255,255,.75); --hero-h1-color:#fff; --hero-em-color:#00FF01; --promo-bg:#00FF01; --promo-fg:#2D2D2D; --nav-bg:rgba(45,45,45,.92); --nav-border:rgba(255,255,255,.06); }
body[data-mood="eclipse"] { --hero-bg:#0A0F12; --hero-fg:#F6F7F7; --hero-sub:rgba(255,255,255,.65); --hero-h1-color:#F6F7F7; --hero-em-color:#65C5FC; --promo-bg:#65C5FC; --promo-fg:#0A0F12; --nav-bg:rgba(8,9,11,.92); --nav-border:rgba(255,255,255,.05); }
.hero { background: var(--hero-bg,var(--charcoal)) !important; color: var(--hero-fg,#fff) !important; transition: background .6s, color .6s; }
.hero h1 { color: var(--hero-h1-color,#fff) !important; }
.hero h1 .highlight { color: var(--hero-em-color,var(--green)) !important; }
.hero-sub { color: var(--hero-sub,rgba(255,255,255,.75)) !important; }
.promo-bar { background: var(--promo-bg,var(--green)) !important; color: var(--promo-fg,var(--charcoal)) !important; transition: background .4s, color .4s; }
.nav-wrap { background: var(--nav-bg,rgba(45,45,45,.92)) !important; border-bottom-color: var(--nav-border,rgba(255,255,255,.06)) !important; transition: background .4s; }
body[data-mood="daylight"] .nav-link, body[data-mood="daylight"] .nav-phone { color: #2D2D2D !important; }
body[data-mood="daylight"] .nav-logo img { filter: invert(1) brightness(0); }
body[data-mood="daylight"] .hero-eyebrow .pip { background: #0775D4; }
body[data-mood="daylight"] .eyebrow.light { color: #0775D4; }
body[data-mood="daylight"] .hero-meta-item .num { color: #0775D4; }
body[data-mood="daylight"] .hero-meta-item .label { color: rgba(45,45,45,.55); }
body[data-mood="daylight"] .hero-visual .badge { background: #2D2D2D; color: #fff; }
body[data-mood="daylight"] .hero-visual .badge .star { color: #00CC01; }
body[data-mood="daylight"] .hero-visual .badge .badge-sub { color: rgba(255,255,255,.6); }
body[data-mood="daylight"] .btn-ghost.on-dark { color: #2D2D2D; border-color: #2D2D2D; }
body[data-mood="eclipse"] .hero h1 .highlight, body[data-mood="eclipse"] .hero h1 em { color: #65C5FC !important; }
/* Energy motion */
body[data-energy="calm"] .marquee-track { animation-duration: 56s !important; }
body[data-energy="flow"] .marquee-track { animation-duration: 28s !important; }
body[data-energy="surge"] .marquee-track { animation-duration: 14s !important; }
body[data-energy="calm"] .nav-phone .dot { animation-duration: 4s !important; }
body[data-energy="surge"] .nav-phone .dot { animation-duration: 1s !important; }
body[data-energy="calm"] .flow-stage { filter: saturate(.85); }
body[data-energy="surge"] .flow-stage { filter: saturate(1.15) brightness(1.05); }
/* Voice type */
body[data-voice="warm"] .display { font-family: 'Mansfield','Poppins',sans-serif; font-weight: 700; text-transform: none; letter-spacing: -.015em; line-height: 1.02; }
body[data-voice="bold"] .display { font-family: 'TBJ Norguba','Mansfield',sans-serif; text-transform: uppercase; letter-spacing: .005em; line-height: .92; }
body[data-voice="quiet"] .display { font-family: 'Mansfield',sans-serif; font-weight: 300; text-transform: none; letter-spacing: -.025em; line-height: 1.05; }
body[data-voice="quiet"] .display em, body[data-voice="quiet"] .display em.highlight { font-weight: 500; font-style: italic; }
body[data-voice="warm"] .display em.highlight, body[data-voice="warm"] .display em { font-weight: 900; }

/* ───────────── */

/* ---- Option B: on small windows, shift the hero video to a background
   element — the rounded window stays, enlarged and bleeding off the right
   edge behind the text, with a strengthened scrim for legibility. ---- */
@media (max-width: 980px) {
  .hero { min-height: 560px; }
  .hero-grid { grid-template-columns: 1fr; }
  /* text column sits above the video */
  .hero-grid > div:first-child { position: relative; z-index: 2; }

  /* the circle becomes a background accent, anchored off the right edge */
  .hero-grid > div.hero-visual {
    position: absolute;
    top: 50%;
    right: -26%;
    transform: translateY(-50%);
    width: min(620px, 96%);
    margin: 0;
    z-index: 0;
    opacity: .9;
    pointer-events: none;
  }
  /* darken from the left so the light text stays readable over the video */
  .hero-visual::after {
    background: linear-gradient(100deg,
      rgba(20,24,24,.94) 0%,
      rgba(20,24,24,.78) 42%,
      rgba(20,24,24,.34) 100%) !important;
  }
  /* keep the decorative rings from competing with the video */
  .hero .sonar-bg, .hero .sonar-bg-bottomleft { opacity: .35; }
}

/* On phones, push the circle further off-screen so copy never sits on the
   bright center of the video. */
@media (max-width: 600px) {
  .hero-grid > div.hero-visual { right: -42%; width: min(520px, 118%); opacity: .8; }
}

/* ───────────── */

/* ===== BRAND COLOR OVERRIDES ===== */
:root {
  --sky: #099CF9;
  --sky-700: #0775D4;
  --sky-300: #65C5FC;
  --sky-50: #E8F5FE;
  --charcoal: #2D2D2D;
  --charcoal-2: #383838;
  --charcoal-3: #454545;
  --grey: #6B6B6B;
  --grey-2: #9A9A9A;
  --line: #E2E2E2;
  --bg: #F6F6F6;
}

/* ===== NAV ===== */
.promo-bar { background: var(--green); color: var(--charcoal); text-align: center; padding: 9px 16px; font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; }
.promo-bar a { text-decoration: underline; text-underline-offset: 2px; }
.nav-wrap { position: sticky; top: 0; z-index: 60; background: rgba(45,45,45,.94); backdrop-filter: blur(14px); border-bottom: 1px solid rgba(255,255,255,.06); }
.nav { display: flex; align-items: center; justify-content: space-between; padding: 18px 48px; color: #fff; }
.nav-logo { display: flex; align-items: center; }
.nav-logo img { height: 48px; width: auto; display: block; }
.nav-links { display: flex; align-items: center; gap: 36px; }
.nav-link { font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 13px; letter-spacing: .05em; color: #fff; padding: 24px 0; display: inline-flex; align-items: center; gap: 6px; }
.nav-link .caret { font-size: 9px; opacity: .7; transition: transform .2s; }
.nav-item:hover .caret { transform: rotate(180deg); }
.nav-item { position: relative; }
.nav-cta { display: flex; align-items: center; gap: 14px; }
.nav-phone { font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 13px; color: #fff; display: flex; align-items: center; gap: 8px; }
.nav-phone .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); animation: pulse 2s infinite; }
@keyframes pulse { 0%,100% { box-shadow: 0 0 0 0 rgba(0,255,1,.6); } 70% { box-shadow: 0 0 0 14px rgba(0,255,1,0); } }
.dropdown { position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(8px); min-width: 280px; background: #fff; color: var(--charcoal); border-radius: 18px; padding: 14px; box-shadow: 0 24px 60px -12px rgba(0,0,0,.35); opacity: 0; pointer-events: none; transition: all .2s ease; border: 1px solid var(--line); }
.nav-item:hover .dropdown { opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.dropdown a { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-radius: 10px; font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 14px; color: var(--charcoal); transition: background .15s; }
.dropdown a:hover { background: var(--bg); }
.dropdown a::after { content: "→"; opacity: 0; transform: translateX(-4px); transition: all .15s; color: var(--sky); }
.dropdown a:hover::after { opacity: 1; transform: translateX(0); }
.dropdown .dd-divider { height: 1px; background: var(--line); margin: 8px 6px; }
.dropdown .dd-feature { display: flex; align-items: center; gap: 12px; padding: 14px 14px; margin: 4px 0 0; background: linear-gradient(135deg,var(--charcoal) 0%,var(--charcoal-2) 100%); border-radius: 12px; color: #fff; font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 13px; transition: transform .15s; }
.dropdown .dd-feature:hover { transform: translateY(-1px); background: linear-gradient(135deg,var(--charcoal-2) 0%,var(--charcoal-3) 100%); }
.dropdown .dd-feature::after { display: none; }
.dropdown .dd-feature .dd-mark { width: 28px; height: 28px; border-radius: 50%; background: var(--green); color: var(--charcoal); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 13px; flex-shrink: 0; }
.dropdown .dd-feature .dd-text { display: flex; flex-direction: column; gap: 1px; }
.dropdown .dd-feature .dd-text span { font-family: 'Poppins',sans-serif; font-weight: 400; font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--green); }
.nav-cta .free-guide { font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 13px; color: rgba(255,255,255,.85); text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(255,255,255,.3); transition: text-decoration-color .15s, color .15s; white-space: nowrap; }
.nav-cta .free-guide:hover { color: #fff; text-decoration-color: var(--green); }

/* ===== PAGE HERO ===== */
.page-hero { position: relative; background: var(--charcoal); color: #fff; overflow: hidden; min-height: 620px; display: flex; align-items: center; padding: 100px 0; }
.page-hero .sonar-bg { top: -220px; right: -300px; width: 1100px; height: 1100px; color: var(--sky); opacity: .18; }
.page-hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; position: relative; z-index: 2; }
.page-hero .page-hero-grid { grid-template-rows: auto auto; align-items: start !important; }
.page-hero-grid > div:first-child { grid-column: 1; grid-row: 1; }
.page-hero-img { grid-column: 2; grid-row: 1; align-self: end; }
.page-hero .page-hero-meta { grid-column: 1; grid-row: 2; display: grid; grid-template-columns: 1fr 1fr; gap: 18px 32px; }
.page-hero-img { position: relative; aspect-ratio: 4/3; border-radius: 28px; overflow: hidden; background: var(--charcoal-2); }
.page-hero-img img { width: 100%; height: 100%; object-fit: cover; }
.page-hero-img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg,rgba(45,45,45,0) 50%,rgba(45,45,45,.45) 100%); }
.page-hero-badge { position: absolute; left: 22px; bottom: 22px; display: flex; align-items: center; gap: 12px; padding: 12px 16px; background: rgba(255,255,255,.96); color: var(--charcoal); border-radius: 14px; z-index: 2; }
.page-hero-badge .ico { width: 36px; height: 36px; border-radius: 50%; background: var(--green); color: var(--charcoal); display: flex; align-items: center; justify-content: center; font-weight: 700; font-family: 'Poppins',sans-serif; font-size: 14px; flex-shrink: 0; }
.page-hero-badge .txt { font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 12px; line-height: 1.3; }
.page-hero-badge .txt span { display: block; font-weight: 400; color: var(--grey); font-size: 11px; }
.breadcrumb { font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.55); margin-bottom: 20px; display: flex; align-items: center; gap: 8px; }
.breadcrumb a { color: var(--green); }
.breadcrumb .sep { opacity: .4; }
.page-hero h1 { margin: 0 0 14px; color: #fff; }
.page-hero h1 em { font-style: normal; color: var(--green); }
.page-hero-sub { font-size: 18px; line-height: 1.58; color: rgba(255,255,255,.75); max-width: 50ch; margin-bottom: 20px; font-weight: 300; }
.page-hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 24px; }
.page-hero-meta { display: flex; gap: 40px; flex-wrap: wrap; padding-top: 18px; border-top: 1px solid rgba(255,255,255,.1); }
.hero-stat { display: flex; flex-direction: column; gap: 4px; }
.hero-stat .n { font-family: 'TBJ Norguba',sans-serif; font-size: 36px; line-height: 1; color: var(--green); }
.hero-stat .l { font-family: 'Poppins',sans-serif; font-size: 10px; text-transform: uppercase; letter-spacing: .22em; color: rgba(255,255,255,.55); }
@media (max-width: 980px) {
  .page-hero-grid { grid-template-columns: 1fr; gap: 0; position: static; }
  .page-hero { padding-bottom: 44px; position: relative; overflow: hidden; }
  /* image becomes a full-bleed background behind the text */
  .page-hero .page-hero-img { position: absolute; top: 0; height: 100%; left: 50%; transform: translateX(-50%); width: 100vw; aspect-ratio: auto; border-radius: 0; z-index: 0; margin: 0; }
  .page-hero-img::after { background: linear-gradient(180deg, rgba(20,24,24,.92) 0%, rgba(20,24,24,.74) 48%, rgba(20,24,24,.6) 100%); }
  .page-hero-badge { display: none; }
  .page-hero-grid > div:first-child { position: relative; z-index: 2; }
  .page-hero-meta { position: relative; z-index: 2; }
}

/* ===== TRUST MARQUEE ===== */
.marquee { background: var(--sky); color: #fff; padding: 18px 0; overflow: hidden; }
.marquee-label { display: block; margin: 0 0 10px 28px; font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 10px; letter-spacing: .28em; text-transform: uppercase; color: rgba(255,255,255,.9); }
.marquee-track { display: flex; align-items: center; gap: 28px; animation: marquee-scroll 28s linear infinite; white-space: nowrap; padding-left: 28px; }
.marquee-track span { font-family: 'Mansfield',sans-serif; font-weight: 400; font-size: 17px; letter-spacing: 0; text-transform: none; opacity: .92; white-space: nowrap; }
.marquee-track .dot { width: 4px; height: 4px; border-radius: 50%; background: rgba(255,255,255,.5); flex-shrink: 0; display: inline-block; }
@keyframes marquee-scroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* ===== SECTION PROBLEM ===== */
.prob { background: #fff; }
.prob-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; align-items: stretch; margin-top: 56px; }
.prob-card { background: var(--bg); border-radius: 24px; padding: 32px 30px 34px; border: 1px solid var(--line); display: flex; flex-direction: column; }
.prob-card .ico { width: 52px; height: 52px; border-radius: 14px; background: var(--charcoal); color: var(--green); display: flex; align-items: center; justify-content: center; font-family: 'TBJ Norguba',sans-serif; font-size: 24px; line-height: 1; margin-bottom: 22px; }
.prob-card h3 { font-family: 'TBJ Norguba',sans-serif; font-size: 26px; text-transform: uppercase; line-height: 1; margin: 0 0 12px; }
.prob-card p { font-size: 15px; color: var(--grey); margin: 0 0 16px; line-height: 1.55; }
.prob-card .voice { font-style: italic; font-size: 14px; color: var(--charcoal); border-top: 1px solid var(--line); padding-top: 14px; line-height: 1.5; margin-top: auto; }
.prob-card .voice::before { content: "\201C"; color: var(--sky); font-family: 'TBJ Norguba',sans-serif; font-size: 24px; line-height: 0; vertical-align: -8px; margin-right: 3px; }
.prob-right { display: flex; flex-direction: column; gap: 22px; }
@media (max-width: 980px) { .prob-grid { grid-template-columns: 1fr; } }

/* ===== SECTION BLUE (Guide) ===== */
.blue-section { background: var(--sky); color: #fff; position: relative; overflow: hidden; }
.blue-section .sonar-bg { top: -240px; right: -280px; width: 960px; height: 960px; color: #fff; opacity: .12; }
.blue-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; position: relative; z-index: 2; }
.blue-section h2 { margin: 0 0 22px; color: #fff; }
.blue-section h2 em { font-style: normal; color: var(--charcoal); }
.blue-section .lede { color: rgba(255,255,255,.88); margin: 0 0 28px; }
.blue-section .lede strong { color: #fff; font-weight: 700; }
.guide-creds { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 28px 0 32px; }
.guide-cred { background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.2); border-radius: 14px; padding: 16px 18px; }
.guide-cred .tag { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .26em; text-transform: uppercase; color: var(--green); margin-bottom: 6px; }
.guide-cred .val { font-family: 'TBJ Norguba',sans-serif; font-size: 28px; line-height: 1; color: #fff; }
.guide-cred .sub { font-size: 12px; color: rgba(255,255,255,.75); margin-top: 3px; font-family: 'Poppins',sans-serif; }
.blue-img { position: relative; aspect-ratio: 4/5; border-radius: 28px; overflow: hidden; background: rgba(0,0,0,.2); }
.blue-img img { width: 100%; height: 100%; object-fit: cover; }
.blue-img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg,rgba(9,156,249,0) 50%,rgba(9,156,249,.3) 100%); }
@media (max-width: 980px) { .blue-grid { grid-template-columns: 1fr; } .guide-creds { grid-template-columns: 1fr 1fr; } }

/* ===== INCLUDED SERVICES ===== */
.included { background: #fff; }
.included-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 56px; }
.inc-card { border: 1px solid var(--line); border-radius: 22px; padding: 30px 26px 32px; background: #fff; transition: box-shadow .25s, transform .25s; display: flex; flex-direction: column; }
.inc-card:hover { transform: translateY(-4px); box-shadow: 0 20px 50px -20px rgba(45,45,45,.14); }
.inc-card .num { font-family: 'TBJ Norguba',sans-serif; font-size: 48px; line-height: 1; color: var(--sky); opacity: .18; margin-bottom: 16px; }
.inc-card h4 { font-family: 'TBJ Norguba',sans-serif; font-size: 22px; text-transform: uppercase; line-height: 1; margin: 0 0 12px; color: var(--charcoal); }
.inc-card p { font-size: 14px; color: var(--grey); line-height: 1.55; margin: 0; flex: 1; }
.inc-card .tag { display: inline-flex; align-items: center; gap: 6px; margin-top: 18px; font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--sky-700); padding: 5px 10px; background: var(--sky-50); border-radius: 999px; align-self: flex-start; }
@media (max-width: 980px) { .included-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px) { .included-grid { grid-template-columns: 1fr; } }

/* ===== ECOFLOW BAND ===== */
.ecoflow-band { background: var(--charcoal); color: #fff; position: relative; overflow: hidden; }
.ecoflow-band .sonar-bg { top: -180px; right: -260px; width: 900px; height: 900px; color: var(--sky); opacity: .14; }
.ef-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px; align-items: center; position: relative; z-index: 2; }
.ef-grid > div:last-child { display: flex; justify-content: center; }
.ecoflow-tag { display: inline-flex; align-items: center; gap: 14px; padding: 8px 16px; border: 1px solid rgba(255,255,255,.18); border-radius: 999px; margin-bottom: 28px; }
.ecoflow-tag .auth { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .28em; text-transform: uppercase; color: var(--green); }
.ecoflow-tag .name { font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 13px; }
.ecoflow-band h2 em { font-style: normal; color: var(--green); }
.ecoflow-band .lede { color: rgba(255,255,255,.78); margin: 0 0 28px; }
.ecoflow-band .lede strong { color: #fff; font-weight: 600; }
.ef-features { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 24px 0 32px; }
.ef-feat { display: flex; align-items: flex-start; gap: 12px; }
.ef-feat .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); flex-shrink: 0; margin-top: 6px; }
.ef-feat span { font-size: 14px; color: rgba(255,255,255,.82); line-height: 1.5; }
.ef-visual { position: relative; aspect-ratio: 1/1; border-radius: 50%; overflow: hidden; background: var(--charcoal-2); width: min(460px,90%); }
.ef-visual img { width: 100%; height: 100%; object-fit: cover; }
@media (max-width: 980px) { .ef-grid { grid-template-columns: 1fr; } }

/* ===== PRODUCT OFFERINGS ===== */
.products-section { background: #fff; }
.prod-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 56px; }
.prod-card { background: #fff; border-radius: 24px; overflow: hidden; border: 1px solid var(--line); transition: transform .25s, box-shadow .25s; display: flex; flex-direction: column; }
.prod-card:hover { transform: translateY(-4px); box-shadow: 0 24px 60px -24px rgba(45,45,45,.18); }
.prod-card .thumb { aspect-ratio: 4/3; overflow: hidden; background: var(--charcoal); position: relative; }
.prod-card .thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s; }
.prod-card:hover .thumb img { transform: scale(1.04); }
.prod-card .thumb video { width: 100%; height: 100%; object-fit: cover; transition: transform .6s; }
.prod-card:hover .thumb video { transform: scale(1.04); }
.prod-card .thumb.thumb-light { background: #fff; }
.prod-card .thumb.thumb-light img { object-fit: cover; object-position: center top; transform: translateY(-6%) scale(1.4); transform-origin: center top; }
.prod-card:hover .thumb.thumb-light img { transform: translateY(-6%) scale(1.44); }
.prod-card .ef-tag { transition: opacity .3s ease; }
.prod-card:hover .ef-tag { opacity: 0; pointer-events: none; }
.prod-card .ef-tag { position: absolute; top: 14px; left: 14px; background: var(--charcoal); color: var(--green); font-family: 'Poppins',sans-serif; font-size: 9px; letter-spacing: .22em; text-transform: uppercase; padding: 6px 11px; border-radius: 999px; display: inline-flex; align-items: center; gap: 6px; font-weight: 700; }
.prod-card .ef-tag::before { content: ""; width: 5px; height: 5px; border-radius: 50%; background: var(--green); display: inline-block; }
.prod-card .body { padding: 24px 26px 26px; flex: 1; display: flex; flex-direction: column; }
.prod-card .cat { font-family: 'Poppins',sans-serif; font-size: 9px; letter-spacing: .26em; text-transform: uppercase; color: var(--sky); margin-bottom: 10px; }
.prod-card h4 { font-family: 'TBJ Norguba',sans-serif; font-size: 26px; text-transform: uppercase; line-height: 1; margin: 0 0 10px; color: var(--charcoal); }
.prod-card p { font-size: 13px; color: var(--grey); margin: 0 0 16px; line-height: 1.55; flex: 1; }
.prod-card .text-link { font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .04em; font-weight: 700; color: var(--charcoal); display: inline-flex; align-items: center; gap: 6px; align-self: flex-start; }
.prod-card .text-link::after { content: "→"; color: var(--sky); transition: transform .2s; }
.prod-card .text-link:hover::after { transform: translateX(3px); }
@media (max-width: 980px) { .prod-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px) { .prod-grid { grid-template-columns: 1fr; } }

/* ===== HOW IT WORKS ===== */
.how { background: var(--bg); }
.how-track { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 56px; position: relative; }
.how-track::before { content: ""; position: absolute; top: 32px; left: 10%; right: 10%; height: 2px; background: linear-gradient(90deg,var(--sky) 0%,var(--green) 100%); opacity: .2; }
.how-step { background: #fff; border-radius: 22px; padding: 32px 28px 34px; border: 1px solid var(--line); position: relative; z-index: 1; }
.how-step .num { width: 64px; height: 64px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: 'TBJ Norguba',sans-serif; font-size: 28px; line-height: 1; margin-bottom: 22px; }
.how-step:nth-child(1) .num { background: var(--sky); color: #fff; }
.how-step:nth-child(2) .num { background: var(--green); color: var(--charcoal); }
.how-step:nth-child(3) .num { background: var(--charcoal); color: var(--green); }
.how-step .sub { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .26em; text-transform: uppercase; color: var(--sky-700); margin-bottom: 10px; }
.how-step h4 { font-family: 'TBJ Norguba',sans-serif; font-size: 28px; text-transform: uppercase; line-height: 1; margin: 0 0 14px; }
.how-step p { font-size: 14px; color: var(--grey); margin: 0 0 20px; line-height: 1.55; }
.how-step .micro { display: flex; gap: 18px; padding-top: 16px; border-top: 1px solid var(--line); }
.how-step .micro .it { display: flex; flex-direction: column; gap: 2px; }
.how-step .micro .v { font-family: 'TBJ Norguba',sans-serif; font-size: 20px; line-height: 1; color: var(--charcoal); }
.how-step .micro .l { font-family: 'Poppins',sans-serif; font-size: 9px; letter-spacing: .2em; text-transform: uppercase; color: var(--grey); }
.how-cta { margin-top: 48px; background: #fff; border-radius: 20px; border: 1px solid var(--line); padding: 28px 32px; display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
.how-cta .msg { flex: 1; min-width: 220px; }
.how-cta .msg strong { display: block; font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 15px; color: var(--charcoal); margin-bottom: 4px; }
.how-cta .msg span { font-size: 14px; color: var(--grey); }
@media (max-width: 980px) { .how-track { grid-template-columns: 1fr; } .how-track::before { display: none; } }

/* ===== OUTCOME STRIP ===== */
.outcomes { background: var(--charcoal); color: #fff; padding: 80px 0; }
.outcomes-inner { display: grid; grid-template-columns: 1fr 2fr; gap: 64px; align-items: center; }
.outcomes h2 { margin: 0; color: #fff; }
.outcomes h2 em { font-style: normal; color: var(--green); }
.outcomes-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; }
.outcome-item { padding: 28px 24px; background: rgba(255,255,255,.04); border-right: 1px solid rgba(255,255,255,.08); }
.outcome-item:last-child { border-right: none; }
.outcome-item .val { font-family: 'TBJ Norguba',sans-serif; font-size: 48px; line-height: 1; color: var(--green); margin-bottom: 8px; }
.outcome-item .lbl { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.55); margin-bottom: 8px; }
.outcome-item .desc { font-size: 13px; color: rgba(255,255,255,.65); line-height: 1.5; }
@media (max-width: 980px) { .outcomes-inner { grid-template-columns: 1fr; } .outcomes-grid { grid-template-columns: 1fr 1fr; } }

/* ===== TESTIMONIALS ===== */
.testimonials { background: #fff; }
.test-head { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 48px; flex-wrap: wrap; gap: 24px; }
.test-head h2 { margin: 0; }
.t-rating { display: flex; align-items: center; gap: 16px; }
.t-rating .v { font-family: 'TBJ Norguba',sans-serif; font-size: 44px; line-height: 1; color: var(--charcoal); }
.t-rating .meta { font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--grey); margin-top: 4px; }
.t-rating .stars { font-size: 20px; color: var(--sky); letter-spacing: 2px; }
.right { display: flex; align-items: center; gap: 28px; flex-wrap: wrap; }
.t-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.t-card { background: var(--bg); border: 1px solid var(--line); border-radius: 22px; padding: 28px 24px 30px; }
.t-card .stars { font-size: 16px; color: var(--sky); letter-spacing: 2px; margin-bottom: 16px; }
.t-card .quote { font-size: 15px; color: var(--charcoal); line-height: 1.6; margin: 0 0 22px; font-style: italic; }
.t-card .author { display: flex; align-items: center; gap: 14px; }
.t-card .avatar { width: 42px; height: 42px; border-radius: 50%; background: var(--sky); color: #fff; display: flex; align-items: center; justify-content: center; font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 13px; flex-shrink: 0; }
.t-card .who { font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 13px; color: var(--charcoal); }
.t-card .where { font-family: 'Poppins',sans-serif; font-size: 11px; color: var(--grey); margin-top: 2px; }
@media (max-width: 980px) { .t-grid { grid-template-columns: 1fr; } }

/* ===== CERTS ===== */
.certs { background: var(--bg); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 36px 0; }
.certs-inner { display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.certs-inner .label { font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--grey); white-space: nowrap; }
.certs-row { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.cert-item { display: flex; align-items: center; gap: 10px; }
.cert-item .seal { font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 11px; letter-spacing: .08em; padding: 6px 12px; border-radius: 8px; border: 1.5px solid var(--charcoal); color: var(--charcoal); }
.cert-item .seal.filled { background: var(--charcoal); color: #fff; }
.cert-item .seal.green { background: var(--green); color: var(--charcoal); border-color: var(--green); }
.cert-item .seal.blue { background: var(--sky); color: #fff; border-color: var(--sky); }
.cert-item .name { font-family: 'Poppins',sans-serif; font-size: 11px; color: var(--grey); }

/* ===== CTA ===== */
.cta { background: var(--charcoal); color: #fff; position: relative; overflow: hidden; text-align: center; padding: 120px 0; }
.cta .sonar-bg { top: 50%; left: 50%; transform: translate(-50%,-50%); right: auto; width: 1100px; height: 1100px; opacity: .18; color: var(--green); }
.cta .eyebrow { color: var(--green); }
.cta h2 { color: #fff; margin: 0 0 24px; }
.cta h2 em { font-style: normal; color: var(--green); }
.cta .lede { color: rgba(255,255,255,.72); max-width: 56ch; margin: 0 auto 40px; }
.cta-row { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; }
.cta-note { margin-top: 28px; font-family: 'Poppins',sans-serif; font-size: 12px; letter-spacing: .04em; color: rgba(255,255,255,.45); position: relative; z-index: 2; }

/* ===== FOOTER ===== */
.footer { background: var(--charcoal); color: rgba(255,255,255,.7); border-top: 1px solid rgba(255,255,255,.07); padding: 64px 0 32px; }
.foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 48px; }
.foot-brand p { font-size: 14px; line-height: 1.6; color: rgba(255,255,255,.55); max-width: 28ch; margin-top: 0; }
.foot-col h5 { font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.9); margin: 0 0 18px; }
.foot-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.foot-col ul li a { font-size: 13px; color: rgba(255,255,255,.55); transition: color .15s; }
.foot-col ul li a:hover { color: #fff; }
.foot-bottom { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.07); font-family: 'Poppins',sans-serif; font-size: 12px; color: rgba(255,255,255,.35); }
.foot-social { display: flex; gap: 16px; }
.foot-social a { width: 34px; height: 34px; border-radius: 50%; border: 1px solid rgba(255,255,255,.15); display: flex; align-items: center; justify-content: center; font-size: 12px; color: rgba(255,255,255,.55); transition: all .15s; }
.foot-social a:hover { border-color: var(--green); color: var(--green); }
@media (max-width: 980px) { .foot-grid { grid-template-columns: 1fr 1fr; gap: 32px; } }

/* ───────────── */

/* ===== BRAND COLOR OVERRIDES ===== */
:root {
  --sky: #099CF9;
  --sky-700: #0775D4;
  --sky-300: #65C5FC;
  --sky-50: #E8F5FE;
  --charcoal: #2D2D2D;
  --charcoal-2: #383838;
  --charcoal-3: #454545;
  --grey: #6B6B6B;
  --grey-2: #9A9A9A;
  --line: #E2E2E2;
  --bg: #F6F6F6;
}

/* ===== NAV ===== */
.promo-bar { background: var(--charcoal); color: var(--green); text-align: center; padding: 9px 16px; font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; }
.promo-bar a { text-decoration: underline; text-underline-offset: 2px; color: var(--green); }
.nav-wrap { position: sticky; top: 0; z-index: 60; background: rgba(45,45,45,.94); backdrop-filter: blur(14px); border-bottom: 1px solid rgba(255,255,255,.06); }
.nav { display: flex; align-items: center; justify-content: space-between; padding: 18px 48px; color: #fff; }
.nav-logo { display: flex; align-items: center; }
.nav-logo img { height: 48px; width: auto; display: block; }
.nav-links { display: flex; align-items: center; gap: 36px; }
.nav-link { font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 13px; letter-spacing: .05em; color: #fff; padding: 24px 0; display: inline-flex; align-items: center; gap: 6px; }
.nav-link .caret { font-size: 9px; opacity: .7; transition: transform .2s; }
.nav-item:hover .caret { transform: rotate(180deg); }
.nav-item { position: relative; }
.nav-cta { display: flex; align-items: center; gap: 14px; }
.nav-phone { font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 13px; color: #fff; display: flex; align-items: center; gap: 8px; }
.nav-phone .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); animation: pulse 2s infinite; }
@keyframes pulse { 0%,100% { box-shadow: 0 0 0 0 rgba(0,255,1,.6); } 70% { box-shadow: 0 0 0 14px rgba(0,255,1,0); } }
.dropdown { position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(8px); min-width: 280px; background: #fff; color: var(--charcoal); border-radius: 18px; padding: 14px; box-shadow: 0 24px 60px -12px rgba(0,0,0,.35); opacity: 0; pointer-events: none; transition: all .2s ease; border: 1px solid var(--line); }
.nav-item:hover .dropdown { opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.dropdown a { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-radius: 10px; font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 14px; color: var(--charcoal); transition: background .15s; }
.dropdown a:hover { background: var(--bg); }
.dropdown a::after { content: "→"; opacity: 0; transform: translateX(-4px); transition: all .15s; color: var(--sky); }
.dropdown a:hover::after { opacity: 1; transform: translateX(0); }
.dropdown .dd-divider { height: 1px; background: var(--line); margin: 8px 6px; }
.dropdown .dd-feature { display: flex; align-items: center; gap: 12px; padding: 14px 14px; margin: 4px 0 0; background: linear-gradient(135deg,var(--charcoal) 0%,var(--charcoal-2) 100%); border-radius: 12px; color: #fff; font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 13px; transition: transform .15s; }
.dropdown .dd-feature:hover { transform: translateY(-1px); background: linear-gradient(135deg,var(--charcoal-2) 0%,var(--charcoal-3) 100%); }
.dropdown .dd-feature::after { display: none; }
.dropdown .dd-feature .dd-mark { width: 28px; height: 28px; border-radius: 50%; background: var(--green); color: var(--charcoal); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 13px; flex-shrink: 0; }
.dropdown .dd-feature .dd-text { display: flex; flex-direction: column; gap: 1px; }
.dropdown .dd-feature .dd-text span { font-family: 'Poppins',sans-serif; font-weight: 400; font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--green); }
.nav-cta .free-guide { font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 13px; color: rgba(255,255,255,.85); text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(255,255,255,.3); transition: text-decoration-color .15s, color .15s; white-space: nowrap; }
.nav-cta .free-guide:hover { color: #fff; text-decoration-color: var(--green); }

/* ===== PAGE HERO ===== */
.page-hero { position: relative; background: var(--charcoal); color: #fff; overflow: hidden; min-height: 680px; display: flex; align-items: center; padding: 100px 0; }
.page-hero .sonar-bg { top: -240px; right: -320px; width: 1200px; height: 1200px; color: var(--green); opacity: .1; }
.page-hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; position: relative; z-index: 2; }
.page-hero .page-hero-grid { grid-template-rows: auto auto; align-items: start !important; }
.page-hero-grid > div:first-child { grid-column: 1; grid-row: 1; }
.page-hero-img { grid-column: 2; grid-row: 1; align-self: end; }
.page-hero .page-hero-meta { grid-column: 1; grid-row: 2; display: grid; grid-template-columns: 1fr 1fr; gap: 18px 32px; }
.page-hero-img { position: relative; aspect-ratio: 16/11; border-radius: 28px; overflow: hidden; background: var(--charcoal-2); }
.page-hero-img img { width: 100%; height: 100%; object-fit: cover; }
.page-hero-img::after { content: ""; position: absolute; inset: 0; background: linear-gradient(160deg,rgba(45,45,45,0) 40%,rgba(45,45,45,.55) 100%); }
.hero-pill-row { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; }
.hero-pill { display: inline-flex; align-items: center; gap: 7px; padding: 6px 12px; border: 1px solid rgba(255,255,255,.14); border-radius: 999px; font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .06em; color: rgba(255,255,255,.75); }
.hero-pill .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--green); }
.breadcrumb { font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.45); margin-bottom: 20px; display: flex; align-items: center; gap: 8px; }
.breadcrumb a { color: var(--green); }
.breadcrumb .sep { opacity: .4; }
.page-hero h1 { margin: 0 0 14px; color: #fff; }
.page-hero h1 em { font-style: normal; color: var(--green); }
.page-hero-sub { font-size: 18px; line-height: 1.58; color: rgba(255,255,255,.72); max-width: 50ch; margin-bottom: 20px; font-weight: 300; }
.page-hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 24px; }
.page-hero-meta { display: flex; gap: 40px; flex-wrap: wrap; padding-top: 18px; border-top: 1px solid rgba(255,255,255,.1); }
.hero-stat { display: flex; flex-direction: column; gap: 4px; }
.hero-stat .n { font-family: 'TBJ Norguba',sans-serif; font-size: 36px; line-height: 1; color: var(--green); }
.hero-stat .l { font-family: 'Poppins',sans-serif; font-size: 10px; text-transform: uppercase; letter-spacing: .22em; color: rgba(255,255,255,.5); }
.hero-img-label { position: absolute; right: 20px; bottom: 20px; padding: 10px 16px; background: rgba(0,255,1,.92); color: var(--charcoal); border-radius: 12px; font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 12px; letter-spacing: .04em; z-index: 2; }
@media (max-width: 980px) {
  .page-hero-grid { grid-template-columns: 1fr; gap: 0; position: static; }
  .page-hero { padding-bottom: 44px; position: relative; overflow: hidden; }
  /* image becomes a full-bleed background behind the text */
  .page-hero .page-hero-img { position: absolute; top: 0; height: 100%; left: 50%; transform: translateX(-50%); width: 100vw; aspect-ratio: auto; border-radius: 0; z-index: 0; margin: 0; }
  .page-hero-img::after { background: linear-gradient(180deg, rgba(20,24,24,.92) 0%, rgba(20,24,24,.74) 48%, rgba(20,24,24,.6) 100%); }
  .hero-img-label { display: none; }
  .page-hero-grid > div:first-child { position: relative; z-index: 2; }
  .page-hero-meta { position: relative; z-index: 2; }
}

/* ===== ROI STRIP ===== */
.roi-strip { background: var(--green); color: var(--charcoal); padding: 48px 0; }
.roi-inner { display: grid; grid-template-columns: repeat(4,1fr); gap: 2px; }
.roi-item { text-align: center; padding: 0 24px; border-right: 1px solid rgba(45,45,45,.15); }
.roi-item:last-child { border-right: none; }
.roi-item .val { font-family: 'TBJ Norguba',sans-serif; font-size: 52px; line-height: 1; color: var(--charcoal); margin-bottom: 6px; }
.roi-item .lbl { font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 10px; letter-spacing: .24em; text-transform: uppercase; color: rgba(45,45,45,.65); margin-bottom: 6px; }
.roi-item .desc { font-size: 12px; color: rgba(45,45,45,.7); line-height: 1.45; font-family: 'Poppins',sans-serif; }
@media (max-width: 980px) { .roi-inner { grid-template-columns: 1fr 1fr; gap: 1px; } .roi-item { padding: 20px; border-right: none; border-bottom: 1px solid rgba(45,45,45,.15); } }

/* ===== PROBLEM ===== */
.prob { background: #fff; }
.prob-intro { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; margin-bottom: 56px; align-items: end; }
.prob-intro .lede { color: var(--grey); }
.prob-intro .lede strong { color: var(--charcoal); }
.prob-cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.prob-card { background: var(--bg); border-radius: 22px; padding: 30px 26px 32px; border: 1px solid var(--line); }
.prob-card .ico { width: 50px; height: 50px; border-radius: 14px; background: var(--charcoal); color: var(--green); display: flex; align-items: center; justify-content: center; font-family: 'TBJ Norguba',sans-serif; font-size: 22px; line-height: 1; margin-bottom: 20px; }
.prob-card h4 { font-family: 'TBJ Norguba',sans-serif; font-size: 22px; text-transform: uppercase; line-height: 1.05; margin: 0 0 10px; }
.prob-card p { font-size: 14px; color: var(--grey); margin: 0; line-height: 1.55; }
@media (max-width: 980px) { .prob-intro { grid-template-columns: 1fr; gap: 28px; } .prob-cards { grid-template-columns: 1fr; } }

/* ===== BLUE GUIDE ===== */
.blue-section { background: var(--sky); color: #fff; position: relative; overflow: hidden; }
.blue-section .sonar-bg { top: -200px; right: -260px; width: 960px; height: 960px; color: #fff; opacity: .1; }
.blue-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; position: relative; z-index: 2; }
.blue-section h2 { margin: 0 0 20px; color: #fff; }
.blue-section h2 em { font-style: normal; color: var(--charcoal); }
.blue-section .lede { color: rgba(255,255,255,.88); margin-bottom: 28px; }
.blue-section .lede strong { color: #fff; }
.guide-creds { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 24px 0 32px; }
.guide-cred { background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.2); border-radius: 14px; padding: 16px 18px; }
.guide-cred .tag { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .26em; text-transform: uppercase; color: var(--green); margin-bottom: 6px; }
.guide-cred .val { font-family: 'TBJ Norguba',sans-serif; font-size: 28px; line-height: 1; color: #fff; }
.guide-cred .sub { font-size: 12px; color: rgba(255,255,255,.7); margin-top: 3px; font-family: 'Poppins',sans-serif; }
.blue-img { position: relative; aspect-ratio: 4/3; border-radius: 28px; overflow: hidden; background: rgba(0,0,0,.15); }
.blue-img img { width: 100%; height: 100%; object-fit: cover; }
@media (max-width: 980px) { .blue-grid { grid-template-columns: 1fr; } }

/* ===== INDUSTRIES ===== */
.industries { background: var(--bg); }
.ind-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; margin-top: 56px; }
.ind-card { background: #fff; border: 1px solid var(--line); border-radius: 22px; padding: 28px 22px 30px; transition: transform .25s, box-shadow .25s; display: flex; flex-direction: column; }
.ind-card:hover { transform: translateY(-4px); box-shadow: 0 18px 48px -18px rgba(45,45,45,.14); }
.ind-card .ico-wrap { width: 50px; height: 50px; border-radius: 14px; display: flex; align-items: center; justify-content: center; font-size: 22px; margin-bottom: 18px; }
.ind-card.sky .ico-wrap { background: var(--sky-50); }
.ind-card.green .ico-wrap { background: rgba(0,255,1,.1); }
.ind-card.dark .ico-wrap { background: var(--charcoal); }
.ind-card.line .ico-wrap { background: var(--bg); border: 1px solid var(--line); }
.ind-card h4 { font-family: 'TBJ Norguba',sans-serif; font-size: 20px; text-transform: uppercase; line-height: 1; margin: 0 0 10px; color: var(--charcoal); }
.ind-card p { font-size: 13px; color: var(--grey); margin: 0 0 16px; line-height: 1.55; flex: 1; }
.ind-card .link { font-family: 'Poppins',sans-serif; font-size: 11px; font-weight: 600; letter-spacing: .06em; color: var(--sky-700); display: flex; align-items: center; gap: 5px; }
.ind-card .link::after { content: "→"; }
@media (max-width: 1100px) { .ind-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px) { .ind-grid { grid-template-columns: 1fr; } }

/* ===== FINANCIAL CASE ===== */
.financial { background: var(--charcoal); color: #fff; position: relative; overflow: hidden; }
.financial .sonar-bg { top: -200px; left: -200px; width: 900px; height: 900px; color: var(--sky); opacity: .12; }
.fin-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 72px; align-items: center; position: relative; z-index: 2; }
.financial h2 { margin: 0 0 22px; color: #fff; }
.financial h2 em { font-style: normal; color: var(--green); }
.financial .lede { color: rgba(255,255,255,.75); margin-bottom: 0; }
.fin-items { display: flex; flex-direction: column; gap: 18px; margin: 32px 0 36px; }
.fin-item { display: flex; align-items: flex-start; gap: 18px; padding: 20px 22px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: 16px; }
.fin-item .pill { flex-shrink: 0; padding: 6px 12px; border-radius: 999px; font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 11px; letter-spacing: .06em; }
.fin-item.itc .pill { background: var(--green); color: var(--charcoal); }
.fin-item.roi .pill { background: var(--sky); color: #fff; }
.fin-item.dep .pill { background: rgba(255,255,255,.15); color: #fff; }
.fin-item .body { flex: 1; }
.fin-item .body strong { display: block; font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 14px; color: #fff; margin-bottom: 4px; }
.fin-item .body span { font-size: 13px; color: rgba(255,255,255,.65); line-height: 1.5; }
.fin-visual { position: relative; aspect-ratio: 4/5; border-radius: 28px; overflow: hidden; background: var(--charcoal-2); display: flex; align-items: center; justify-content: center; padding: 40px; }
.fin-visual img { width: 100%; height: 100%; object-fit: cover; border-radius: 20px; }
@media (max-width: 980px) { .fin-grid { grid-template-columns: 1fr; } }

/* ===== PRODUCT OFFERINGS ===== */
.products-section { background: #fff; }
.prod-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 56px; }
.prod-card { background: #fff; border-radius: 24px; overflow: hidden; border: 1px solid var(--line); transition: transform .25s, box-shadow .25s; display: flex; flex-direction: column; }
.prod-card:hover { transform: translateY(-4px); box-shadow: 0 24px 60px -24px rgba(45,45,45,.18); }
.prod-card .thumb { aspect-ratio: 4/3; overflow: hidden; background: var(--charcoal); position: relative; }
.prod-card .thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s; }
.prod-card:hover .thumb img { transform: scale(1.04); }
.prod-card .thumb video { width: 100%; height: 100%; object-fit: cover; transition: transform .6s; }
.prod-card:hover .thumb video { transform: scale(1.04); }
.prod-card .thumb.thumb-light { background: #fff; }
.prod-card .thumb.thumb-light img { object-fit: cover; object-position: center top; transform: translateY(-6%) scale(1.4); transform-origin: center top; }
.prod-card:hover .thumb.thumb-light img { transform: translateY(-6%) scale(1.44); }
.prod-card .ef-tag { transition: opacity .3s ease; }
.prod-card:hover .ef-tag { opacity: 0; pointer-events: none; }
.prod-card .ef-tag { position: absolute; top: 14px; left: 14px; background: var(--charcoal); color: var(--green); font-family: 'Poppins',sans-serif; font-size: 9px; letter-spacing: .22em; text-transform: uppercase; padding: 6px 11px; border-radius: 999px; display: inline-flex; align-items: center; gap: 6px; font-weight: 700; }
.prod-card .ef-tag::before { content: ""; width: 5px; height: 5px; border-radius: 50%; background: var(--green); display: inline-block; }
.prod-card .body { padding: 24px 26px 26px; flex: 1; display: flex; flex-direction: column; }
.prod-card .cat { font-family: 'Poppins',sans-serif; font-size: 9px; letter-spacing: .26em; text-transform: uppercase; color: var(--sky); margin-bottom: 10px; }
.prod-card h4 { font-family: 'TBJ Norguba',sans-serif; font-size: 24px; text-transform: uppercase; line-height: 1; margin: 0 0 10px; color: var(--charcoal); }
.prod-card p { font-size: 13px; color: var(--grey); margin: 0 0 16px; line-height: 1.55; flex: 1; }
.prod-card .text-link { font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .04em; font-weight: 700; color: var(--charcoal); display: inline-flex; align-items: center; gap: 6px; align-self: flex-start; }
.prod-card .text-link::after { content: "→"; color: var(--sky); transition: transform .2s; }
.prod-card .text-link:hover::after { transform: translateX(3px); }
@media (max-width: 980px) { .prod-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px) { .prod-grid { grid-template-columns: 1fr; } }

/* ===== HOW IT WORKS ===== */
.how { background: #fff; }
.how-track { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 56px; position: relative; }
.how-track::before { content: ""; position: absolute; top: 32px; left: 10%; right: 10%; height: 2px; background: linear-gradient(90deg,var(--sky) 0%,var(--green) 100%); opacity: .2; }
.how-step { background: var(--bg); border: 1px solid var(--line); border-radius: 22px; padding: 32px 28px 34px; position: relative; z-index: 1; }
.how-step .num { width: 64px; height: 64px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: 'TBJ Norguba',sans-serif; font-size: 28px; line-height: 1; margin-bottom: 22px; }
.how-step:nth-child(1) .num { background: var(--sky); color: #fff; }
.how-step:nth-child(2) .num { background: var(--green); color: var(--charcoal); }
.how-step:nth-child(3) .num { background: var(--charcoal); color: var(--green); }
.how-step .sub { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .26em; text-transform: uppercase; color: var(--sky-700); margin-bottom: 10px; }
.how-step h4 { font-family: 'TBJ Norguba',sans-serif; font-size: 28px; text-transform: uppercase; line-height: 1; margin: 0 0 14px; }
.how-step p { font-size: 14px; color: var(--grey); margin: 0; line-height: 1.55; }
.how-cta { margin-top: 48px; background: var(--bg); border-radius: 20px; border: 1px solid var(--line); padding: 28px 32px; display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
.how-cta .msg { flex: 1; min-width: 220px; }
.how-cta .msg strong { display: block; font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 15px; color: var(--charcoal); margin-bottom: 4px; }
.how-cta .msg span { font-size: 14px; color: var(--grey); }
@media (max-width: 980px) { .how-track { grid-template-columns: 1fr; } .how-track::before { display: none; } }

/* ===== TESTIMONIALS ===== */
.testimonials { background: var(--bg); }
.test-head { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 48px; flex-wrap: wrap; gap: 24px; }
.test-head h2 { margin: 0; }
.t-rating { display: flex; align-items: center; gap: 16px; }
.t-rating .v { font-family: 'TBJ Norguba',sans-serif; font-size: 44px; line-height: 1; color: var(--charcoal); }
.t-rating .meta { font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--grey); margin-top: 4px; }
.t-rating .stars { font-size: 20px; color: var(--sky); letter-spacing: 2px; }
.right { display: flex; align-items: center; gap: 28px; flex-wrap: wrap; }
.t-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.t-card { background: #fff; border: 1px solid var(--line); border-radius: 22px; padding: 28px 24px 30px; }
.t-card .stars { font-size: 16px; color: var(--sky); letter-spacing: 2px; margin-bottom: 16px; }
.t-card .quote { font-size: 15px; color: var(--charcoal); line-height: 1.6; margin: 0 0 22px; font-style: italic; }
.t-card .author { display: flex; align-items: center; gap: 14px; }
.t-card .avatar { width: 42px; height: 42px; border-radius: 50%; background: var(--charcoal); color: var(--green); display: flex; align-items: center; justify-content: center; font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 13px; flex-shrink: 0; }
.t-card .who { font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 13px; color: var(--charcoal); }
.t-card .where { font-family: 'Poppins',sans-serif; font-size: 11px; color: var(--grey); margin-top: 2px; }
@media (max-width: 980px) { .t-grid { grid-template-columns: 1fr; } }

/* ===== CERTS ===== */
.certs { background: #fff; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 36px 0; }
.certs-inner { display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.certs-inner .label { font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--grey); white-space: nowrap; }
.certs-row { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.cert-item { display: flex; align-items: center; gap: 10px; }
.cert-item .seal { font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 11px; letter-spacing: .08em; padding: 6px 12px; border-radius: 8px; border: 1.5px solid var(--charcoal); color: var(--charcoal); }
.cert-item .seal.filled { background: var(--charcoal); color: #fff; }
.cert-item .seal.green { background: var(--green); color: var(--charcoal); border-color: var(--green); }
.cert-item .seal.blue { background: var(--sky); color: #fff; border-color: var(--sky); }
.cert-item .name { font-family: 'Poppins',sans-serif; font-size: 11px; color: var(--grey); }

/* ===== CTA ===== */
.cta { background: var(--charcoal); color: #fff; position: relative; overflow: hidden; text-align: center; padding: 120px 0; }
.cta .sonar-bg { top: 50%; left: 50%; transform: translate(-50%,-50%); right: auto; width: 1100px; height: 1100px; opacity: .16; color: var(--sky); }
.cta .eyebrow { color: var(--green); }
.cta h2 { color: #fff; margin: 0 0 24px; }
.cta h2 em { font-style: normal; color: var(--green); }
.cta .lede { color: rgba(255,255,255,.7); max-width: 54ch; margin: 0 auto 40px; }
.cta-row { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; }
.cta-note { margin-top: 28px; font-family: 'Poppins',sans-serif; font-size: 12px; letter-spacing: .04em; color: rgba(255,255,255,.4); position: relative; z-index: 2; }

/* ===== FOOTER ===== */
.footer { background: var(--charcoal); color: rgba(255,255,255,.7); border-top: 1px solid rgba(255,255,255,.07); padding: 64px 0 32px; }
.foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 48px; }
.foot-brand p { font-size: 14px; line-height: 1.6; color: rgba(255,255,255,.5); max-width: 28ch; margin-top: 0; }
.foot-col h5 { font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.9); margin: 0 0 18px; }
.foot-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.foot-col ul li a { font-size: 13px; color: rgba(255,255,255,.5); transition: color .15s; }
.foot-col ul li a:hover { color: #fff; }
.foot-bottom { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.07); font-family: 'Poppins',sans-serif; font-size: 12px; color: rgba(255,255,255,.3); }
.foot-social { display: flex; gap: 16px; }
.foot-social a { width: 34px; height: 34px; border-radius: 50%; border: 1px solid rgba(255,255,255,.15); display: flex; align-items: center; justify-content: center; font-size: 12px; color: rgba(255,255,255,.5); transition: all .15s; }
.foot-social a:hover { border-color: var(--green); color: var(--green); }
@media (max-width: 980px) { .foot-grid { grid-template-columns: 1fr 1fr; gap: 32px; } }

/* ───────────── */

:root {
  --sky: #099CF9; --sky-700: #0775D4; --sky-300: #65C5FC; --sky-50: #E8F5FE;
  --charcoal: #2D2D2D; --charcoal-2: #383838; --charcoal-3: #454545;
  --grey: #6B6B6B; --grey-2: #9A9A9A; --line: #E2E2E2; --bg: #F6F6F6;
}

/* ===== NAV ===== */
.promo-bar { background: var(--green); color: var(--charcoal); text-align: center; padding: 9px 16px; font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; }
.promo-bar a { text-decoration: underline; text-underline-offset: 2px; }
.nav-wrap { position: sticky; top: 0; z-index: 60; background: rgba(45,45,45,.94); backdrop-filter: blur(14px); border-bottom: 1px solid rgba(255,255,255,.06); }
.nav { display: flex; align-items: center; justify-content: space-between; padding: 18px 48px; color: #fff; }
.nav-logo img { height: 48px; width: auto; display: block; }
.nav-links { display: flex; align-items: center; gap: 36px; }
.nav-link { font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 13px; letter-spacing: .05em; color: #fff; padding: 24px 0; display: inline-flex; align-items: center; gap: 6px; }
.nav-link .caret { font-size: 9px; opacity: .7; transition: transform .2s; }
.nav-item:hover .caret { transform: rotate(180deg); }
.nav-item { position: relative; }
.nav-cta { display: flex; align-items: center; gap: 14px; }
.nav-phone { font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 13px; color: #fff; display: flex; align-items: center; gap: 8px; }
.nav-phone .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); animation: pulse 2s infinite; }
@keyframes pulse { 0%,100% { box-shadow: 0 0 0 0 rgba(0,255,1,.6); } 70% { box-shadow: 0 0 0 14px rgba(0,255,1,0); } }
.dropdown { position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(8px); min-width: 280px; background: #fff; color: var(--charcoal); border-radius: 18px; padding: 14px; box-shadow: 0 24px 60px -12px rgba(0,0,0,.35); opacity: 0; pointer-events: none; transition: all .2s ease; border: 1px solid var(--line); }
.nav-item:hover .dropdown { opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.dropdown a { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-radius: 10px; font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 14px; color: var(--charcoal); transition: background .15s; }
.dropdown a:hover { background: var(--bg); }
.dropdown a::after { content: "→"; opacity: 0; transform: translateX(-4px); transition: all .15s; color: var(--sky); }
.dropdown a:hover::after { opacity: 1; transform: translateX(0); }
.dropdown .dd-divider { height: 1px; background: var(--line); margin: 8px 6px; }
.dropdown .dd-feature { display: flex; align-items: center; gap: 12px; padding: 14px 14px; margin: 4px 0 0; background: linear-gradient(135deg,var(--charcoal) 0%,var(--charcoal-2) 100%); border-radius: 12px; color: #fff; font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 13px; }
.dropdown .dd-feature::after { display: none; }
.dropdown .dd-feature .dd-mark { width: 28px; height: 28px; border-radius: 50%; background: var(--green); color: var(--charcoal); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 13px; flex-shrink: 0; }
.dropdown .dd-feature .dd-text span { display: block; font-weight: 400; font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--green); }
.nav-cta .free-guide { font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 13px; color: rgba(255,255,255,.85); text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(255,255,255,.3); white-space: nowrap; }
.nav-cta .free-guide:hover { color: #fff; text-decoration-color: var(--green); }

/* ===== HERO ===== */
.page-hero { position: relative; background: var(--charcoal); color: #fff; overflow: hidden; padding: 100px 0; min-height: 620px; display: flex; align-items: center; }
.page-hero .sonar-bg { top: -240px; right: -300px; width: 1200px; height: 1200px; color: var(--sky); opacity: .14; }
.hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; position: relative; z-index: 2; }
.breadcrumb { font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: 20px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.breadcrumb a { color: var(--green); }
.breadcrumb .sep { opacity: .4; }
.city-pill { display: inline-flex; align-items: center; gap: 10px; padding: 8px 16px 8px 8px; border: 1px solid rgba(255,255,255,.18); border-radius: 999px; margin-bottom: 24px; background: rgba(255,255,255,.04); }
.city-pill .dot { width: 12px; height: 12px; border-radius: 50%; background: var(--green); }
.city-pill .txt { font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 12px; letter-spacing: .14em; text-transform: uppercase; }
.page-hero h1 { margin: 0 0 24px; color: #fff; font-family: 'TBJ Norguba',sans-serif; font-weight: 400; font-size: clamp(48px,7vw,108px); line-height: .95; text-transform: uppercase; }
.page-hero h1 em { font-style: normal; color: var(--green); }
.page-hero-sub { font-size: 18px; line-height: 1.55; color: rgba(255,255,255,.75); max-width: 50ch; margin-bottom: 36px; font-weight: 300; }
.page-hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 44px; }
.local-stats { display: flex; flex-wrap: wrap; gap: 24px 48px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.1); }
.local-stat { display: flex; flex-direction: column; gap: 4px; }
.local-stat .n { font-family: 'TBJ Norguba',sans-serif; font-size: 36px; line-height: 1; color: var(--green); }
.local-stat .l { font-family: 'Poppins',sans-serif; font-size: 10px; text-transform: uppercase; letter-spacing: .22em; color: rgba(255,255,255,.55); }

/* ===== MAP ===== */
.map-wrap { position: relative; aspect-ratio: 4/5; border-radius: 28px; overflow: hidden; background: var(--charcoal-2); }
.map-wrap svg { width: 100%; height: 100%; display: block; }
/* v5 hero skyline photo — full-width band, only the top seam feathered into charcoal */
.page-hero { position: relative; overflow: hidden; }
.kc-hero-photo {
  position: absolute; left: 0; right: 0; top: 0; bottom: 0;
  background: url('/wp-content/themes/wp-blocks-shinnova/assets/img/kc-skyline.jpg') center bottom / cover no-repeat;
  z-index: 0;
  pointer-events: none;
}
/* Legibility panel: a filter-blurred grey panel sits behind the text with equal
   left & right insets — soft on every edge (no sharp line) and balanced weight. */
.page-hero .hero-grid > div {
  position: relative; z-index: 2;
}
.kc-hero-scrim {
  position: absolute; z-index: -1;
  top: -260px; bottom: -260px; left: -90px; right: -90px;
  background: rgba(24,28,27,0.88);
  filter: blur(60px);
  pointer-events: none;
}
.page-hero .container { position: relative; z-index: 2; }
.page-hero .map-wrap { display: none; }
.page-hero .hero-grid { grid-template-columns: minmax(0, 660px); }
.map-overlay { position: absolute; top: 24px; left: 24px; right: 24px; display: flex; justify-content: space-between; align-items: flex-start; gap: 14px; }
.map-tag { padding: 10px 16px; background: rgba(45,45,45,.85); color: #fff; backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,.12); border-radius: 12px; font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; font-weight: 700; }
.map-tag.green { background: var(--green); color: var(--charcoal); border-color: var(--green); }
.map-legend { position: absolute; left: 24px; bottom: 24px; right: 24px; padding: 18px 22px; background: rgba(45,45,45,.85); color: #fff; backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,.12); border-radius: 14px; display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }
.map-legend .v { font-family: 'TBJ Norguba',sans-serif; font-size: 28px; line-height: 1; color: var(--green); }
.map-legend .l { font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.7); }
.map-legend .div { width: 1px; height: 28px; background: rgba(255,255,255,.18); }
@media (max-width: 980px) { .hero-grid { grid-template-columns: 1fr; gap: 40px; } .page-hero { padding: 70px 0 80px; min-height: 0; } }

/* ===== SECTION GENERICS ===== */
.section { padding: 110px 0; position: relative; overflow: hidden; }
.section.bg-white { background: #fff; color: var(--charcoal); }
.section.bg-light { background: var(--bg); color: var(--charcoal); }
.section.bg-charcoal { background: var(--charcoal); color: #fff; }
.section.bg-sky { background: var(--sky); color: #fff; }
.section .sonar-bg { opacity: .12; }
.section.bg-charcoal .sonar-bg { color: var(--sky); }
.section.bg-sky .sonar-bg { color: #fff; opacity: .14; }
.section.bg-white .sonar-bg, .section.bg-light .sonar-bg { color: var(--sky); opacity: .06; }
.section-head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; margin-bottom: 64px; align-items: end; }
.section-head .right { font-size: 17px; line-height: 1.6; color: var(--grey); }
.section.bg-charcoal .section-head .right { color: rgba(255,255,255,.78); }
.section.bg-sky .section-head .right { color: rgba(255,255,255,.9); }
.section-head h2 { font-family: 'TBJ Norguba',sans-serif; font-weight: 400; font-size: clamp(40px,5vw,80px); line-height: .95; text-transform: uppercase; margin: 0; }
.section.bg-charcoal h2 em, .section.bg-sky h2 em { font-style: normal; color: var(--green); }
.section.bg-white h2 em, .section.bg-light h2 em { font-style: normal; color: var(--sky); }
.section.bg-sky h2 em { color: var(--charcoal); }
.eyebrow { font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .28em; text-transform: uppercase; color: var(--sky); margin-bottom: 16px; display: inline-block; font-weight: 600; }
.section.bg-charcoal .eyebrow { color: var(--green); }
.section.bg-sky .eyebrow { color: rgba(255,255,255,.9); }
@media (max-width: 980px) { .section-head { grid-template-columns: 1fr; gap: 24px; } }

/* ===== OFFICE BLOCK ===== */
.office-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 56px; align-items: center; }
.office-img { aspect-ratio: 4/3; border-radius: 24px; overflow: hidden; background: var(--charcoal-2); }
.office-img img { width: 100%; height: 100%; object-fit: cover; }
.office-img iframe { width: 100%; height: 100%; border: 0; display: block; }
.office-info h3 { font-family: 'TBJ Norguba',sans-serif; font-weight: 400; font-size: clamp(28px,3.5vw,44px); line-height: .95; text-transform: uppercase; margin: 0 0 18px; color: var(--charcoal); }
.office-info h3 em { font-style: normal; color: var(--sky); }
.office-info p { font-size: 16px; color: var(--grey); line-height: 1.6; margin: 0 0 28px; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.contact-card { padding: 22px 24px; background: var(--bg); border: 1px solid var(--line); border-radius: 16px; }
.contact-card .lab { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--grey); margin-bottom: 8px; font-weight: 700; }
.contact-card .val { font-family: 'TBJ Norguba',sans-serif; font-size: 18px; line-height: 1.15; color: var(--charcoal); }
.contact-card .val.green { color: var(--sky); }
.contact-card .sub { font-size: 12px; color: var(--grey); margin-top: 6px; font-family: 'Poppins',sans-serif; }
@media (max-width: 980px) { .office-grid { grid-template-columns: 1fr; } }

/* ===== AREAS COVERED ===== */
.areas-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; margin-top: 48px; }
.area-col { text-align: center; padding: 0 44px; }
.area-col:first-child { border-right: 1px solid var(--line); }
.area-col ul { text-align: left; }
.area-col h4 { font-family: 'TBJ Norguba',sans-serif; font-size: 18px; text-transform: uppercase; line-height: 1; margin: 0 0 16px; color: var(--charcoal); padding-bottom: 14px; border-bottom: 2px solid var(--green); display: inline-block; }
.area-col ul { list-style: none; padding: 0; margin: 0; columns: 2; column-gap: 28px; }
.area-col li { font-size: 13px; color: var(--grey); font-family: 'Poppins',sans-serif; line-height: 1.4; margin-bottom: 8px; break-inside: avoid; }
.area-col li::before { content: "→ "; color: var(--sky); font-weight: 700; margin-right: 4px; }
@media (max-width: 600px) {
  .areas-grid { grid-template-columns: 1fr; }
  .area-col { padding: 0; }
  .area-col:first-child { border-right: none; border-bottom: 1px solid var(--line); padding-bottom: 28px; margin-bottom: 28px; }
}

/* ===== INSTALL GALLERY ===== */
.gallery-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 48px; }
.gallery-card { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1); border-radius: 18px; overflow: hidden; }
.gallery-card .img { aspect-ratio: 4/3; overflow: hidden; }
.gallery-card .img img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s; }
.gallery-card:hover .img img { transform: scale(1.04); }
.gallery-card .body { padding: 18px 22px 22px; }
.gallery-card .neighborhood { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--green); margin-bottom: 8px; font-weight: 700; }
.gallery-card h4 { font-family: 'TBJ Norguba',sans-serif; font-size: 18px; text-transform: uppercase; line-height: 1.05; margin: 0 0 8px; color: #fff; }
.gallery-card p { font-size: 12px; color: rgba(255,255,255,.7); margin: 0; line-height: 1.5; }
.gallery-card .specs { display: flex; gap: 12px; margin-top: 12px; padding-top: 12px; border-top: 1px solid rgba(255,255,255,.1); }
.gallery-card .specs span { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .14em; color: rgba(255,255,255,.65); }
.gallery-card .specs span strong { color: #fff; font-weight: 700; }
@media (max-width: 980px) { .gallery-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .gallery-grid { grid-template-columns: 1fr; } }

/* ===== UTILITY ===== */
.util-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 56px; align-items: center; }
.util-card { padding: 36px 40px; background: #fff; border: 1px solid var(--line); border-radius: 24px; }
.util-card .logo { padding: 12px 18px; background: var(--charcoal); color: #fff; border-radius: 10px; display: inline-flex; align-items: center; gap: 8px; font-family: 'TBJ Norguba',sans-serif; font-size: 16px; letter-spacing: .04em; margin-bottom: 24px; }
.util-card .logo span { font-family: 'Poppins',sans-serif; font-size: 9px; color: var(--green); letter-spacing: .22em; font-weight: 700; text-transform: uppercase; }
.util-card h4 { font-family: 'TBJ Norguba',sans-serif; font-size: 28px; line-height: 1; text-transform: uppercase; margin: 0 0 14px; color: var(--charcoal); }
.util-card p { font-size: 14px; color: var(--grey); line-height: 1.55; margin: 0 0 22px; }
.util-card p strong { color: var(--charcoal); font-weight: 600; }
.util-facts { display: flex; flex-direction: column; gap: 12px; }
.util-fact { display: flex; gap: 14px; align-items: flex-start; padding: 14px 18px; background: var(--bg); border-radius: 10px; }
.util-fact .ico { flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%; background: var(--green); color: var(--charcoal); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 14px; margin-top: 1px; }
.util-fact .text { font-size: 13px; color: var(--charcoal); line-height: 1.45; }
.util-fact .text strong { display: block; margin-bottom: 2px; color: var(--charcoal); font-weight: 700; font-size: 13px; font-family: 'Poppins',sans-serif; }
@media (max-width: 980px) { .util-grid { grid-template-columns: 1fr; gap: 36px; } }

/* ===== LOCAL REVIEWS ===== */
.local-reviews { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.lr-card { background: #fff; border: 1px solid var(--line); border-radius: 18px; padding: 26px 26px 28px; }
.lr-card .stars { font-size: 16px; color: var(--sky); letter-spacing: 2px; margin-bottom: 16px; }
.lr-card .q { font-size: 14px; color: var(--charcoal); line-height: 1.55; font-style: italic; margin: 0 0 22px; }
.lr-card .who { display: flex; align-items: center; gap: 12px; padding-top: 16px; border-top: 1px solid var(--line); }
.lr-card .av { width: 40px; height: 40px; border-radius: 50%; background: linear-gradient(135deg,var(--sky) 0%,var(--green) 100%); display: flex; align-items: center; justify-content: center; font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 13px; color: #fff; flex-shrink: 0; }
.lr-card .name { font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 13px; color: var(--charcoal); }
.lr-card .neighborhood { font-family: 'Poppins',sans-serif; font-size: 11px; color: var(--grey); margin-top: 2px; }
@media (max-width: 980px) { .local-reviews { grid-template-columns: 1fr; } }

/* ===== CTA + FOOTER ===== */
.cta { background: var(--charcoal); color: #fff; position: relative; overflow: hidden; text-align: center; padding: 120px 0; }
.cta .sonar-bg { top: 50%; left: 50%; transform: translate(-50%,-50%); right: auto; width: 1100px; height: 1100px; opacity: .18; color: var(--green); }
.cta .eyebrow { color: var(--green); }
.cta h2 { color: #fff; margin: 0 0 24px; font-family: 'TBJ Norguba',sans-serif; font-weight: 400; font-size: clamp(48px,7vw,108px); line-height: .95; text-transform: uppercase; }
.cta h2 em { font-style: normal; color: var(--green); }
.cta .lede { color: rgba(255,255,255,.72); max-width: 56ch; margin: 0 auto 40px; font-size: 18px; line-height: 1.55; }
.cta-row { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; position: relative; z-index: 2; }
.cta-note { margin-top: 28px; font-family: 'Poppins',sans-serif; font-size: 12px; letter-spacing: .04em; color: rgba(255,255,255,.45); position: relative; z-index: 2; }

.footer { background: var(--charcoal); color: rgba(255,255,255,.7); border-top: 1px solid rgba(255,255,255,.07); padding: 64px 0 32px; }
.foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 48px; }
.foot-brand p { font-size: 14px; line-height: 1.6; color: rgba(255,255,255,.55); max-width: 28ch; margin-top: 0; }
.foot-col h5 { font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.9); margin: 0 0 18px; }
.foot-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.foot-col ul li a { font-size: 13px; color: rgba(255,255,255,.55); transition: color .15s; }
.foot-col ul li a:hover { color: #fff; }
.foot-bottom { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.07); font-family: 'Poppins',sans-serif; font-size: 12px; color: rgba(255,255,255,.35); }
.foot-social { display: flex; gap: 16px; }
.foot-social a { width: 34px; height: 34px; border-radius: 50%; border: 1px solid rgba(255,255,255,.15); display: flex; align-items: center; justify-content: center; font-size: 12px; color: rgba(255,255,255,.55); }
.foot-social a:hover { border-color: var(--green); color: var(--green); }
@media (max-width: 980px) { .foot-grid { grid-template-columns: 1fr 1fr; gap: 32px; } }
html { scroll-behavior: smooth; scroll-padding-top: 100px; }

/* ───────────── */

:root {
  --sky: #099CF9; --sky-700: #0775D4; --sky-300: #65C5FC; --sky-50: #E8F5FE;
  --charcoal: #2D2D2D; --charcoal-2: #383838; --charcoal-3: #454545;
  --grey: #6B6B6B; --grey-2: #9A9A9A; --line: #E2E2E2; --bg: #F6F6F6;
}

/* ===== NAV ===== */
.promo-bar { background: var(--green); color: var(--charcoal); text-align: center; padding: 9px 16px; font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; }
.promo-bar a { text-decoration: underline; text-underline-offset: 2px; }
.nav-wrap { position: sticky; top: 0; z-index: 60; background: rgba(45,45,45,.94); backdrop-filter: blur(14px); border-bottom: 1px solid rgba(255,255,255,.06); }
.nav { display: flex; align-items: center; justify-content: space-between; padding: 18px 48px; color: #fff; }
.nav-logo img { height: 48px; width: auto; display: block; }
.nav-links { display: flex; align-items: center; gap: 36px; }
.nav-link { font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 13px; letter-spacing: .05em; color: #fff; padding: 24px 0; display: inline-flex; align-items: center; gap: 6px; }
.nav-link .caret { font-size: 9px; opacity: .7; transition: transform .2s; }
.nav-item:hover .caret { transform: rotate(180deg); }
.nav-item { position: relative; }
.nav-cta { display: flex; align-items: center; gap: 14px; }
.nav-phone { font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 13px; color: #fff; display: flex; align-items: center; gap: 8px; }
.nav-phone .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); animation: pulse 2s infinite; }
@keyframes pulse { 0%,100% { box-shadow: 0 0 0 0 rgba(0,255,1,.6); } 70% { box-shadow: 0 0 0 14px rgba(0,255,1,0); } }
.dropdown { position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(8px); min-width: 280px; background: #fff; color: var(--charcoal); border-radius: 18px; padding: 14px; box-shadow: 0 24px 60px -12px rgba(0,0,0,.35); opacity: 0; pointer-events: none; transition: all .2s ease; border: 1px solid var(--line); }
.nav-item:hover .dropdown { opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.dropdown a { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-radius: 10px; font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 14px; color: var(--charcoal); transition: background .15s; }
.dropdown a:hover { background: var(--bg); }
.dropdown a::after { content: "→"; opacity: 0; transform: translateX(-4px); transition: all .15s; color: var(--sky); }
.dropdown a:hover::after { opacity: 1; transform: translateX(0); }
.dropdown .dd-divider { height: 1px; background: var(--line); margin: 8px 6px; }
.dropdown .dd-feature { display: flex; align-items: center; gap: 12px; padding: 14px 14px; margin: 4px 0 0; background: linear-gradient(135deg,var(--charcoal) 0%,var(--charcoal-2) 100%); border-radius: 12px; color: #fff; font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 13px; }
.dropdown .dd-feature::after { display: none; }
.dropdown .dd-feature .dd-mark { width: 28px; height: 28px; border-radius: 50%; background: var(--green); color: var(--charcoal); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 13px; flex-shrink: 0; }
.dropdown .dd-feature .dd-text span { display: block; font-weight: 400; font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--green); }
.nav-cta .free-guide { font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 13px; color: rgba(255,255,255,.85); text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(255,255,255,.3); white-space: nowrap; }
.nav-cta .free-guide:hover { color: #fff; text-decoration-color: var(--green); }

/* ===== HERO ===== */
.page-hero { position: relative; background: var(--charcoal); color: #fff; overflow: hidden; padding: 100px 0; min-height: 620px; display: flex; align-items: center; }
.page-hero .sonar-bg { top: -240px; right: -300px; width: 1200px; height: 1200px; color: var(--sky); opacity: .14; }
.hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; position: relative; z-index: 2; }
.breadcrumb { font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: 20px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.breadcrumb a { color: var(--green); }
.breadcrumb .sep { opacity: .4; }
.city-pill { display: inline-flex; align-items: center; gap: 10px; padding: 8px 16px 8px 8px; border: 1px solid rgba(255,255,255,.18); border-radius: 999px; margin-bottom: 24px; background: rgba(255,255,255,.04); }
.city-pill .dot { width: 12px; height: 12px; border-radius: 50%; background: var(--green); }
.city-pill .txt { font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 12px; letter-spacing: .14em; text-transform: uppercase; }
.page-hero h1 { margin: 0 0 24px; color: #fff; font-family: 'TBJ Norguba',sans-serif; font-weight: 400; font-size: clamp(48px,7vw,108px); line-height: .95; text-transform: uppercase; }
.page-hero h1 em { font-style: normal; color: var(--green); }
.page-hero-sub { font-size: 18px; line-height: 1.55; color: rgba(255,255,255,.75); max-width: 50ch; margin-bottom: 36px; font-weight: 300; }
.page-hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 44px; }
.local-stats { display: flex; flex-wrap: wrap; gap: 24px 48px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.1); }
.local-stat { display: flex; flex-direction: column; gap: 4px; }
.local-stat .n { font-family: 'TBJ Norguba',sans-serif; font-size: 36px; line-height: 1; color: var(--green); }
.local-stat .l { font-family: 'Poppins',sans-serif; font-size: 10px; text-transform: uppercase; letter-spacing: .22em; color: rgba(255,255,255,.55); }

/* ===== MAP ===== */
.map-wrap { position: relative; aspect-ratio: 4/5; border-radius: 28px; overflow: hidden; background: var(--charcoal-2); }
.map-wrap svg { width: 100%; height: 100%; display: block; }
/* v5 hero skyline photo + blurred legibility panel (mirrors KC v5) */
.page-hero { position: relative; overflow: hidden; }
.stl-hero-photo {
  position: absolute; left: 0; right: 0; top: 0; bottom: 0;
  background: url('/wp-content/themes/wp-blocks-shinnova/assets/img/stl-skyline.jpg') center 55% / cover no-repeat;
  z-index: 0;
  pointer-events: none;
}
.page-hero .hero-grid > div { position: relative; z-index: 2; }
.stl-hero-scrim {
  position: absolute; z-index: -1;
  top: -260px; bottom: -260px; left: -90px; right: -90px;
  background: rgba(24,28,27,0.88);
  filter: blur(60px);
  pointer-events: none;
}
.page-hero .container { position: relative; z-index: 2; }
.page-hero .map-wrap { display: none; }
.page-hero .hero-grid { grid-template-columns: minmax(0, 660px); }
.map-overlay { position: absolute; top: 24px; left: 24px; right: 24px; display: flex; justify-content: space-between; align-items: flex-start; gap: 14px; }
.map-tag { padding: 10px 16px; background: rgba(45,45,45,.85); color: #fff; backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,.12); border-radius: 12px; font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; font-weight: 700; }
.map-tag.green { background: var(--green); color: var(--charcoal); border-color: var(--green); }
.map-legend { position: absolute; left: 24px; bottom: 24px; right: 24px; padding: 18px 22px; background: rgba(45,45,45,.85); color: #fff; backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,.12); border-radius: 14px; display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }
.map-legend .v { font-family: 'TBJ Norguba',sans-serif; font-size: 28px; line-height: 1; color: var(--green); }
.map-legend .l { font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.7); }
.map-legend .div { width: 1px; height: 28px; background: rgba(255,255,255,.18); }
@media (max-width: 980px) { .hero-grid { grid-template-columns: 1fr; gap: 40px; } .page-hero { padding: 70px 0 80px; min-height: 0; } }

/* ===== SECTION GENERICS ===== */
.section { padding: 110px 0; position: relative; overflow: hidden; }
.section.bg-white { background: #fff; color: var(--charcoal); }
.section.bg-light { background: var(--bg); color: var(--charcoal); }
.section.bg-charcoal { background: var(--charcoal); color: #fff; }
.section.bg-sky { background: var(--sky); color: #fff; }
.section .sonar-bg { opacity: .12; }
.section.bg-charcoal .sonar-bg { color: var(--sky); }
.section.bg-sky .sonar-bg { color: #fff; opacity: .14; }
.section.bg-white .sonar-bg, .section.bg-light .sonar-bg { color: var(--sky); opacity: .06; }
.section-head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; margin-bottom: 64px; align-items: end; }
.section-head .right { font-size: 17px; line-height: 1.6; color: var(--grey); }
.section.bg-charcoal .section-head .right { color: rgba(255,255,255,.78); }
.section.bg-sky .section-head .right { color: rgba(255,255,255,.9); }
.section-head h2 { font-family: 'TBJ Norguba',sans-serif; font-weight: 400; font-size: clamp(40px,5vw,80px); line-height: .95; text-transform: uppercase; margin: 0; }
.section.bg-charcoal h2 em, .section.bg-sky h2 em { font-style: normal; color: var(--green); }
.section.bg-white h2 em, .section.bg-light h2 em { font-style: normal; color: var(--sky); }
.section.bg-sky h2 em { color: var(--charcoal); }
.eyebrow { font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .28em; text-transform: uppercase; color: var(--sky); margin-bottom: 16px; display: inline-block; font-weight: 600; }
.section.bg-charcoal .eyebrow { color: var(--green); }
.section.bg-sky .eyebrow { color: rgba(255,255,255,.9); }
@media (max-width: 980px) { .section-head { grid-template-columns: 1fr; gap: 24px; } }

/* ===== OFFICE BLOCK ===== */
.office-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 56px; align-items: center; }
.office-img { aspect-ratio: 4/3; border-radius: 24px; overflow: hidden; background: var(--charcoal-2); }
.office-img img { width: 100%; height: 100%; object-fit: cover; }
.office-img iframe { width: 100%; height: 100%; border: 0; display: block; }
.office-info h3 { font-family: 'TBJ Norguba',sans-serif; font-weight: 400; font-size: clamp(28px,3.5vw,44px); line-height: .95; text-transform: uppercase; margin: 0 0 18px; color: var(--charcoal); }
.office-info h3 em { font-style: normal; color: var(--sky); }
.office-info p { font-size: 16px; color: var(--grey); line-height: 1.6; margin: 0 0 28px; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.contact-card { padding: 22px 24px; background: var(--bg); border: 1px solid var(--line); border-radius: 16px; }
.contact-card .lab { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--grey); margin-bottom: 8px; font-weight: 700; }
.contact-card .val { font-family: 'TBJ Norguba',sans-serif; font-size: 18px; line-height: 1.15; color: var(--charcoal); }
.contact-card .val.green { color: var(--sky); }
.contact-card .sub { font-size: 12px; color: var(--grey); margin-top: 6px; font-family: 'Poppins',sans-serif; }
@media (max-width: 980px) { .office-grid { grid-template-columns: 1fr; } }

/* ===== AREAS COVERED ===== */
.areas-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 0; margin-top: 48px; }
.area-col { text-align: center; padding: 0 32px; }
.area-col:not(:last-child) { border-right: 1px solid var(--line); }
.area-col h4 { font-family: 'TBJ Norguba',sans-serif; font-size: 18px; text-transform: uppercase; line-height: 1; margin: 0 0 16px; color: var(--charcoal); padding-bottom: 14px; border-bottom: 2px solid var(--green); display: inline-block; }
.area-col ul { list-style: none; padding: 0; margin: 0; columns: 2; column-gap: 24px; text-align: left; }
.area-col li { font-size: 13px; color: var(--grey); font-family: 'Poppins',sans-serif; line-height: 1.4; margin-bottom: 8px; break-inside: avoid; }
.area-col li::before { content: "→ "; color: var(--sky); font-weight: 700; margin-right: 4px; }
@media (max-width: 900px) {
  .areas-grid { grid-template-columns: 1fr; }
  .area-col { padding: 0; }
  .area-col:not(:last-child) { border-right: none; border-bottom: 1px solid var(--line); padding-bottom: 28px; margin-bottom: 28px; }
}

/* ===== INSTALL GALLERY ===== */
.gallery-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 48px; }
.gallery-card { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1); border-radius: 18px; overflow: hidden; }
.gallery-card .img { aspect-ratio: 4/3; overflow: hidden; }
.gallery-card .img img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s; }
.gallery-card:hover .img img { transform: scale(1.04); }
.gallery-card .body { padding: 18px 22px 22px; }
.gallery-card .neighborhood { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--green); margin-bottom: 8px; font-weight: 700; }
.gallery-card h4 { font-family: 'TBJ Norguba',sans-serif; font-size: 18px; text-transform: uppercase; line-height: 1.05; margin: 0 0 8px; color: #fff; }
.gallery-card p { font-size: 12px; color: rgba(255,255,255,.7); margin: 0; line-height: 1.5; }
.gallery-card .specs { display: flex; gap: 12px; margin-top: 12px; padding-top: 12px; border-top: 1px solid rgba(255,255,255,.1); }
.gallery-card .specs span { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .14em; color: rgba(255,255,255,.65); }
.gallery-card .specs span strong { color: #fff; font-weight: 700; }
@media (max-width: 980px) { .gallery-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .gallery-grid { grid-template-columns: 1fr; } }

/* ===== UTILITY ===== */
.util-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 56px; align-items: center; }
.util-card { padding: 36px 40px; background: #fff; border: 1px solid var(--line); border-radius: 24px; }
.util-card .logo { padding: 12px 18px; background: var(--charcoal); color: #fff; border-radius: 10px; display: inline-flex; align-items: center; gap: 8px; font-family: 'TBJ Norguba',sans-serif; font-size: 16px; letter-spacing: .04em; margin-bottom: 24px; }
.util-card .logo span { font-family: 'Poppins',sans-serif; font-size: 9px; color: var(--green); letter-spacing: .22em; font-weight: 700; text-transform: uppercase; }
.util-card h4 { font-family: 'TBJ Norguba',sans-serif; font-size: 28px; line-height: 1; text-transform: uppercase; margin: 0 0 14px; color: var(--charcoal); }
.util-card p { font-size: 14px; color: var(--grey); line-height: 1.55; margin: 0 0 22px; }
.util-card p strong { color: var(--charcoal); font-weight: 600; }
.util-facts { display: flex; flex-direction: column; gap: 12px; }
.util-fact { display: flex; gap: 14px; align-items: flex-start; padding: 14px 18px; background: var(--bg); border-radius: 10px; }
.util-fact .ico { flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%; background: var(--green); color: var(--charcoal); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 14px; margin-top: 1px; }
.util-fact .text { font-size: 13px; color: var(--charcoal); line-height: 1.45; }
.util-fact .text strong { display: block; margin-bottom: 2px; color: var(--charcoal); font-weight: 700; font-size: 13px; font-family: 'Poppins',sans-serif; }
@media (max-width: 980px) { .util-grid { grid-template-columns: 1fr; gap: 36px; } }

/* ===== LOCAL REVIEWS ===== */
.local-reviews { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.lr-card { background: #fff; border: 1px solid var(--line); border-radius: 18px; padding: 26px 26px 28px; }
.lr-card .stars { font-size: 16px; color: var(--sky); letter-spacing: 2px; margin-bottom: 16px; }
.lr-card .q { font-size: 14px; color: var(--charcoal); line-height: 1.55; font-style: italic; margin: 0 0 22px; }
.lr-card .who { display: flex; align-items: center; gap: 12px; padding-top: 16px; border-top: 1px solid var(--line); }
.lr-card .av { width: 40px; height: 40px; border-radius: 50%; background: linear-gradient(135deg,var(--sky) 0%,var(--green) 100%); display: flex; align-items: center; justify-content: center; font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 13px; color: #fff; flex-shrink: 0; }
.lr-card .name { font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 13px; color: var(--charcoal); }
.lr-card .neighborhood { font-family: 'Poppins',sans-serif; font-size: 11px; color: var(--grey); margin-top: 2px; }
@media (max-width: 980px) { .local-reviews { grid-template-columns: 1fr; } }

/* ===== CTA + FOOTER ===== */
.cta { background: var(--charcoal); color: #fff; position: relative; overflow: hidden; text-align: center; padding: 120px 0; }
.cta .sonar-bg { top: 50%; left: 50%; transform: translate(-50%,-50%); right: auto; width: 1100px; height: 1100px; opacity: .18; color: var(--green); }
.cta .eyebrow { color: var(--green); }
.cta h2 { color: #fff; margin: 0 0 24px; font-family: 'TBJ Norguba',sans-serif; font-weight: 400; font-size: clamp(48px,7vw,108px); line-height: .95; text-transform: uppercase; }
.cta h2 em { font-style: normal; color: var(--green); }
.cta .lede { color: rgba(255,255,255,.72); max-width: 56ch; margin: 0 auto 40px; font-size: 18px; line-height: 1.55; }
.cta-row { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; position: relative; z-index: 2; }
.cta-note { margin-top: 28px; font-family: 'Poppins',sans-serif; font-size: 12px; letter-spacing: .04em; color: rgba(255,255,255,.45); position: relative; z-index: 2; }

.footer { background: var(--charcoal); color: rgba(255,255,255,.7); border-top: 1px solid rgba(255,255,255,.07); padding: 64px 0 32px; }
.foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 48px; }
.foot-brand p { font-size: 14px; line-height: 1.6; color: rgba(255,255,255,.55); max-width: 28ch; margin-top: 0; }
.foot-col h5 { font-family: 'Poppins',sans-serif; font-weight: 700; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.9); margin: 0 0 18px; }
.foot-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.foot-col ul li a { font-size: 13px; color: rgba(255,255,255,.55); transition: color .15s; }
.foot-col ul li a:hover { color: #fff; }
.foot-bottom { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.07); font-family: 'Poppins',sans-serif; font-size: 12px; color: rgba(255,255,255,.35); }
.foot-social { display: flex; gap: 16px; }
.foot-social a { width: 34px; height: 34px; border-radius: 50%; border: 1px solid rgba(255,255,255,.15); display: flex; align-items: center; justify-content: center; font-size: 12px; color: rgba(255,255,255,.55); }
.foot-social a:hover { border-color: var(--green); color: var(--green); }
@media (max-width: 980px) { .foot-grid { grid-template-columns: 1fr 1fr; gap: 32px; } }
html { scroll-behavior: smooth; scroll-padding-top: 100px; }

/* ───────────── */

/* ===== NAV (from Shinnova global) ===== */
.nav-wrap { position: sticky; top: 0; z-index: 60; background: rgba(32,45,45,.92); backdrop-filter: blur(14px); border-bottom: 1px solid rgba(255,255,255,.06); }
.nav { display: flex; align-items: center; justify-content: space-between; padding: 18px 48px; color: #fff; }
.nav-logo { display: flex; align-items: center; }
.nav-logo img { height: 48px; width: auto; display: block; }
.nav-links { display: flex; align-items: center; gap: 36px; }
.nav-link { position: relative; font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 13px; letter-spacing: .05em; color: #fff; padding: 24px 0; display: inline-flex; align-items: center; gap: 6px; }
.nav-link .caret { font-size: 9px; opacity: .7; transition: transform .2s; }
.nav-item:hover .caret { transform: rotate(180deg); }
.nav-item { position: relative; }
.nav-cta { display: flex; align-items: center; gap: 14px; }
.nav-phone { font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 13px; letter-spacing: .04em; color: #fff; display: flex; align-items: center; gap: 8px; }
.nav-phone .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 0 rgba(0,255,1,.6); animation: pulse 2s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(0,255,1,.6); } 70% { box-shadow: 0 0 0 14px rgba(0,255,1,0); } 100% { box-shadow: 0 0 0 0 rgba(0,255,1,0); } }
.dropdown { position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(8px); min-width: 280px; background: #fff; color: var(--charcoal); border-radius: 18px; padding: 14px; box-shadow: 0 24px 60px -12px rgba(0,0,0,.35); opacity: 0; pointer-events: none; transition: all .2s ease; border: 1px solid var(--line); }
.nav-item:hover .dropdown { opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.dropdown a { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-radius: 10px; font-family: 'Mansfield',sans-serif; font-weight: 500; font-size: 14px; color: var(--charcoal); transition: background .15s; }
.dropdown a:hover { background: var(--bg); }
.nav-cta .free-guide { font-family: 'Poppins',sans-serif; font-weight: 500; font-size: 13px; color: rgba(255,255,255,.85); text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(255,255,255,.3); transition: text-decoration-color .15s, color .15s; white-space: nowrap; }
.nav-cta .free-guide:hover { color: #fff; text-decoration-color: var(--green); }

/* ===== PAGE HEADER ===== */
.contact-head { position: relative; background: var(--charcoal); color: #fff; overflow: hidden; padding: 88px 0 64px; }
.contact-head .sonar-bg { top: -320px; right: -300px; width: 1000px; height: 1000px; color: var(--sky); opacity: .2; }
.contact-head .inner { position: relative; z-index: 2; max-width: 720px; }
.contact-head .hero-eyebrow { display: inline-flex; align-items: center; gap: 14px; margin-bottom: 22px; }
.contact-head .hero-eyebrow .pip { width: 28px; height: 1px; background: var(--green); }
.contact-head h1 { margin: 0 0 20px; color: #fff; }
.contact-head h1 em { font-style: normal; color: var(--green); }
.contact-head p { font-size: 18px; line-height: 1.55; color: rgba(255,255,255,.75); max-width: 56ch; font-weight: 300; margin: 0; }

/* ===== CONTACT BODY ===== */
.contact-body { background: var(--bg); padding: 72px 0 96px; }
.contact-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 64px; align-items: start; }

.contact-aside h2 { font-family: 'TBJ Norguba',sans-serif; text-transform: uppercase; font-size: 34px; line-height: .95; margin: 0 0 20px; }
.contact-aside p { color: var(--charcoal-2); font-size: 16px; margin: 0 0 32px; max-width: 40ch; }
.contact-detail { display: flex; flex-direction: column; gap: 24px; }
.cd-item { display: flex; flex-direction: column; gap: 5px; }
.cd-item .l { font-family: 'Poppins',sans-serif; font-size: 10px; letter-spacing: .24em; text-transform: uppercase; color: var(--grey); }
.cd-item .v { font-family: 'Mansfield',sans-serif; font-weight: 600; font-size: 18px; color: var(--charcoal); }
.cd-item .v.sky { color: var(--sky); }

/* Form card */
.form-card { background: #fff; border: 1px solid var(--line); border-radius: 28px; padding: 44px; box-shadow: 0 24px 60px -30px rgba(32,45,45,.25); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px 20px; }
.field { display: flex; flex-direction: column; gap: 8px; }
.field.full { grid-column: 1 / -1; }
.field label { font-family: 'Poppins',sans-serif; font-weight: 600; font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--charcoal-2); }
.field label .req { color: var(--sky); margin-left: 2px; }
.field input, .field select {
  font-family: 'Mansfield','Poppins',sans-serif; font-size: 16px; color: var(--charcoal);
  background: var(--bg); border: 1.5px solid var(--line); border-radius: 12px;
  padding: 14px 16px; width: 100%; transition: border-color .18s, background .18s, box-shadow .18s;
  -webkit-appearance: none; appearance: none;
}
.field select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7777' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 16px center; padding-right: 40px; }
.field input:focus, .field select:focus { outline: none; border-color: var(--sky); background: #fff; box-shadow: 0 0 0 4px rgba(9,144,207,.12); }
.field input::placeholder { color: var(--grey-2); }

.form-foot { margin-top: 30px; display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.form-note { font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .04em; color: var(--grey); max-width: 34ch; line-height: 1.5; }
.submit-btn { border: none; }
.submit-btn:disabled { opacity: .6; cursor: not-allowed; transform: none !important; }

.form-status { display: none; margin-top: 22px; padding: 16px 20px; border-radius: 12px; font-family: 'Poppins',sans-serif; font-size: 13px; font-weight: 500; letter-spacing: .02em; }
.form-status.show { display: block; }
.form-status.ok { background: rgba(0,204,1,.12); color: #0a7d24; border: 1px solid rgba(0,204,1,.4); }
.form-status.err { background: rgba(207,40,40,.1); color: #b3261e; border: 1px solid rgba(207,40,40,.35); }

.form-success { display: none; text-align: center; padding: 24px 12px; }
.form-success.show { display: block; }
.form-success .mark { width: 68px; height: 68px; border-radius: 50%; background: var(--green); color: var(--charcoal); display: flex; align-items: center; justify-content: center; font-size: 34px; margin: 0 auto 22px; }
.form-success h3 { font-family: 'TBJ Norguba',sans-serif; text-transform: uppercase; font-size: 30px; margin: 0 0 12px; }
.form-success p { color: var(--charcoal-2); margin: 0; }

/* ===== FOOTER ===== */
.footer { background: #161F1F; color: #fff; padding: 96px 0 32px; position: relative; }
.foot-grid { display: grid; grid-template-columns: 1.4fr repeat(4,1fr); gap: 48px; }
.foot-brand p { font-size: 14px; color: rgba(255,255,255,.6); max-width: 34ch; line-height: 1.55; font-weight: 300; }
.foot-col h5 { font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .28em; text-transform: uppercase; color: var(--green); margin: 0 0 22px; }
.foot-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.foot-col a { font-family: 'Mansfield',sans-serif; font-size: 14px; color: rgba(255,255,255,.78); transition: color .2s; }
.foot-col a:hover { color: var(--green); }
.foot-bottom { margin-top: 64px; padding-top: 32px; border-top: 1px solid rgba(255,255,255,.1); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px; font-family: 'Poppins',sans-serif; font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.5); }
.foot-social { display: flex; gap: 12px; }
.foot-social a { width: 36px; height: 36px; border-radius: 50%; border: 1px solid rgba(255,255,255,.15); display: flex; align-items: center; justify-content: center; font-size: 14px; transition: all .2s; }
.foot-social a:hover { background: var(--green); color: var(--charcoal); border-color: var(--green); }

@media (max-width: 980px) {
  .contact-grid { grid-template-columns: 1fr; gap: 44px; }
  .foot-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
}
@media (max-width: 620px) {
  .form-card { padding: 28px 22px; }
  .form-grid { grid-template-columns: 1fr; }
  .field.half-sm { grid-column: auto; }
  .foot-grid { grid-template-columns: 1fr; }
}

/* ── sh-block wrapper reset (Group/HTML block wrappers around each section) ── */
.site-content, .site-content > *{ margin:0; }
.sh-block{ margin:0 !important; padding:0; }
.sh-block > .wp-block-html, .sh-block > *{ margin:0; }
.wp-block-group.sh-block{ display:block; }
