/* ============================================
   OSUNA ROOFING & CONSTRUCTION — Master CSS
   Theme: Dark / Blue / Orange · Anton + Manrope
   ============================================ */
*{margin:0;padding:0;box-sizing:border-box}
:root{
--blue:#2B7FFF;--blue-d:#1458CC;--blue-dk:#0D3B94;--blue-pale:#EBF3FF;--blue-mid:#B8D4FF;--blue-glow:rgba(43,127,255,.18);
--baby:#7DB8F7;--orange:#FF6B1A;--orange-d:#E5570E;
--white:#fff;--off:#F5F8FF;--surface:#EEF4FF;
--dark:#0D1117;--dark2:#111820;--dark3:#162235;--dark-card:rgba(255,255,255,.05);
--ink:#0D1117;--mid:#3D546E;--muted:#6B82A0;
--border-l:#D0DFF5;--border-d:rgba(255,255,255,.08);
--disp:'Anton',display;--sans:'Manrope',sans-serif
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);overflow-x:hidden;-webkit-font-smoothing:antialiased;color:var(--ink)}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--disp);letter-spacing:.02em;text-transform:uppercase;line-height:.9}
h1 .ac,h2 .ac{color:var(--blue)}
h1 .ac-o,h2 .ac-o{color:var(--orange)}

/* TOPBAR (DARK → white) */
.topbar{background:var(--dark);padding:9px 5vw;display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap}
.tb-l{display:flex;gap:20px;flex-wrap:wrap}
.tb-i{font-size:.73rem;font-weight:700;color:#fff;display:flex;align-items:center;gap:5px}
.tb-i a{color:var(--baby);text-decoration:none}
.tb-badge{background:var(--orange);color:#fff;padding:5px 14px;border-radius:20px;font-size:.71rem;font-weight:800;text-decoration:none}

/* NAV (WHITE → black) */
.site-nav{background:var(--white);border-bottom:1px solid var(--border-l);box-shadow:0 2px 16px rgba(43,127,255,.07);padding:0 5vw;min-height:72px;display:flex;align-items:center;justify-content:space-between;gap:16px;position:sticky;top:0;z-index:200}
.nav-logo{font-family:var(--disp);font-size:1.35rem;letter-spacing:.04em;text-transform:uppercase;color:#000;text-decoration:none;display:flex;align-items:center;gap:10px}
.nav-logo-sq{width:38px;height:38px;background:var(--blue);border-radius:7px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px var(--blue-glow)}
.nav-logo-sq svg{width:20px;height:20px;fill:#fff}
.nav-logo em{color:var(--blue);font-style:normal}
.nav-links{display:flex;gap:2px;align-items:center}
.nav-links>a,.nav-item>a{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#000;text-decoration:none;padding:8px 11px;border-radius:7px;transition:all .2s;display:flex;align-items:center;gap:5px;cursor:pointer}
.nav-links>a:hover,.nav-item>a:hover{color:var(--blue);background:var(--blue-pale)}
.nav-end{display:flex;gap:10px;align-items:center}
.nav-ph{font-weight:800;font-size:.88rem;color:#000;text-decoration:none;white-space:nowrap}
.nav-ph:hover{color:var(--blue)}
.nav-cta{background:var(--blue);color:#fff;padding:10px 20px;border-radius:7px;font-weight:700;font-size:.81rem;text-decoration:none;text-transform:uppercase;letter-spacing:.04em;transition:all .2s;box-shadow:0 4px 14px var(--blue-glow)}
.nav-cta:hover{background:var(--blue-d);transform:translateY(-1px)}

/* NAV DROPDOWNS (WHITE → black) */
.nav-item{position:relative}
.nav-chevron{width:10px;height:10px;transition:transform .25s;stroke:currentColor;fill:none;stroke-width:2.5}
.nav-item.open>a .nav-chevron{transform:rotate(180deg)}
.nav-item.open>a{color:var(--blue);background:var(--blue-pale)}
.dropdown{display:none;position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%);background:var(--white);border:1px solid var(--border-l);border-radius:12px;box-shadow:0 20px 60px rgba(13,17,23,.15),0 4px 14px var(--blue-glow);padding:22px;z-index:600;width:640px}
.nav-item.open .dropdown{display:block;animation:ddFade .2s ease}
@keyframes ddFade{from{opacity:0;transform:translateX(-50%) translateY(-6px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.dropdown::before{content:'';position:absolute;top:-7px;left:50%;width:13px;height:13px;background:var(--white);border-left:1px solid var(--border-l);border-top:1px solid var(--border-l);transform:translateX(-50%) rotate(45deg)}
.dd-grid{display:grid;gap:0}
.dd-col{padding:0 12px 0 0;border-right:1px solid var(--border-l)}
.dd-col:last-child{border-right:none;padding-right:0;padding-left:12px}
.dd-col-header{font-family:var(--disp);font-size:.72rem;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:var(--orange);margin-bottom:10px;padding:0 10px}
.dd-link{display:block;padding:8px 10px;font-size:.82rem;font-weight:700;color:#000;text-decoration:none;border-radius:6px;transition:all .15s;text-transform:none;letter-spacing:0}
.dd-link:hover{background:var(--blue-pale);color:var(--blue);transform:translateX(2px)}
.dd-footer{margin-top:18px;padding-top:14px;border-top:1px solid var(--border-l);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.dd-footer-text{font-size:.76rem;color:#000;font-weight:600}
.dd-footer-link{font-size:.76rem;font-weight:800;color:var(--orange);text-decoration:none;text-transform:uppercase;letter-spacing:.05em}
.dd-footer-link:hover{color:var(--orange-d)}

/* HAMBURGER + MOBILE NAV (WHITE → black) */
.ham{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;background:none;border:none}
.ham span{display:block;width:22px;height:2px;background:#000;border-radius:2px}
.mob-overlay{display:none;position:fixed;inset:0;background:var(--white);z-index:700;flex-direction:column;padding:80px 6vw 40px;overflow-y:auto}
.mob-overlay.is-open{display:flex}
.mob-x{position:absolute;top:22px;right:6vw;font-size:1.8rem;color:#000;cursor:pointer;background:none;border:none;font-weight:300}
.mob-phone{font-size:1rem;font-weight:700;color:#000;padding:16px 0;border-bottom:1px solid var(--border-l);margin-bottom:6px}
.mob-phone a{color:var(--blue);text-decoration:none}
.mob-overlay a.mob-link{font-family:var(--disp);font-size:2rem;letter-spacing:.04em;text-transform:uppercase;color:#000;text-decoration:none;padding:14px 0;border-bottom:1px solid var(--border-l);display:block;transition:color .2s}
.mob-overlay a.mob-link:hover{color:var(--blue)}
.mob-sect{border-bottom:1px solid var(--border-l)}
.mob-sect-head{font-family:var(--disp);font-size:2rem;letter-spacing:.04em;text-transform:uppercase;color:#000;padding:14px 0;display:flex;justify-content:space-between;align-items:center;cursor:pointer;background:none;border:none;width:100%}
.mob-sect-head svg{width:18px;height:18px;transition:transform .25s;stroke:currentColor;fill:none;stroke-width:2.5}
.mob-sect.open .mob-sect-head svg{transform:rotate(180deg)}
.mob-sub{display:none;padding:0 0 14px 8px;flex-direction:column;gap:2px}
.mob-sect.open .mob-sub{display:flex}
.mob-sub a{font-size:.95rem;font-weight:700;color:#000;text-decoration:none;padding:8px 0;transition:color .2s}
.mob-sub a:hover{color:var(--blue)}
.mob-cta-btn{margin-top:28px;background:var(--orange);color:#fff;padding:18px;border-radius:10px;text-align:center;font-weight:800;font-size:1rem;text-decoration:none;display:block;text-transform:uppercase;letter-spacing:.05em}
@media(max-width:980px){.nav-links,.nav-end{display:none!important}.ham{display:flex!important}}

/* HERO */
.hero{display:grid;grid-template-columns:1fr 1fr;min-height:88vh;background:var(--white)}
.hero-l{background:var(--dark);padding:80px 5vw;display:flex;flex-direction:column;justify-content:space-between;clip-path:polygon(0 0,100% 0,90% 100%,0 100%);position:relative;overflow:hidden}
.hero-l::before{content:"OSUNA";font-family:var(--disp);font-size:18vw;color:rgba(255,255,255,.008);position:absolute;bottom:-2vw;left:-1vw;pointer-events:none;line-height:1}
.hero-l-inner{position:relative;z-index:1}
.hl-tag{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--baby);display:flex;align-items:center;gap:8px;margin-bottom:24px}
.hl-tag::before{content:"";width:18px;height:2px;background:var(--blue)}
h1{font-size:clamp(3.8rem,7vw,8.5rem);color:#fff;margin-bottom:22px}
.hero-sub{font-size:.95rem;line-height:1.75;color:#fff;max-width:38ch;margin-bottom:32px}
.hero-sub strong{color:var(--orange)}
.btn-blue{background:var(--blue);color:#fff;padding:14px 28px;border-radius:7px;font-weight:700;font-size:.87rem;text-decoration:none;text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;gap:8px;transition:all .25s;box-shadow:0 4px 18px var(--blue-glow)}
.btn-blue:hover{background:var(--blue-d);transform:translateY(-2px)}
.btn-orange{background:var(--orange);color:#fff;padding:14px 26px;border-radius:7px;font-weight:700;font-size:.87rem;text-decoration:none;text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;gap:8px;transition:all .25s;box-shadow:0 4px 14px rgba(255,107,26,.28)}
.btn-orange:hover{background:var(--orange-d);transform:translateY(-2px)}
.btn-outline-l{color:var(--blue);padding:13px 22px;border-radius:7px;font-weight:700;font-size:.87rem;text-decoration:none;border:2px solid var(--blue-mid);transition:all .2s;text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;gap:8px}
.btn-outline-l:hover{background:var(--blue-pale);border-color:var(--blue)}
.btn-white{background:#fff;color:#000;padding:14px 28px;border-radius:7px;font-weight:700;font-size:.87rem;text-decoration:none;text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;gap:8px;transition:all .25s}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.15)}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:0}
.hero-stats-row{display:flex;gap:24px;padding-top:28px;border-top:1px solid rgba(255,255,255,.15);flex-wrap:wrap}
.hs-n{font-family:var(--disp);font-size:1.8rem;color:#fff;letter-spacing:.02em;line-height:1}
.hs-n .cb{color:var(--blue)}
.hs-n .co{color:var(--orange)}
.hs-l{font-size:.61rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.08em;margin-top:2px}
.hero-r{position:relative;overflow:visible}
.hero-r img{width:100%;height:100%;object-fit:cover}
.hero-r-overlay{position:absolute;inset:0;background:linear-gradient(to left,transparent 55%,rgba(13,17,23,.3));z-index:1}
.hero-form-float{position:absolute;bottom:28px;right:24px;width:292px;background:var(--white);border-radius:14px;padding:22px 20px;box-shadow:0 16px 48px rgba(0,0,0,.18);border-top:4px solid var(--orange);z-index:10}
.hff-sub{font-size:.71rem;color:#000;font-weight:500;margin-bottom:13px}
.hfi,.hfs{width:100%;background:var(--off);border:1.5px solid var(--border-l);border-radius:7px;padding:10px 12px;font-family:var(--sans);font-size:.84rem;color:#000;outline:none;transition:border-color .2s;margin-bottom:8px;appearance:none}
.hfs{margin-bottom:10px;cursor:pointer}
.hfi:focus,.hfs:focus{border-color:var(--blue)}
.hfb{width:100%;background:var(--blue);color:#fff;font-family:var(--disp);font-size:.88rem;letter-spacing:.06em;text-transform:uppercase;padding:11px;border-radius:7px;border:none;cursor:pointer;transition:all .2s;box-shadow:0 4px 14px var(--blue-glow)}
.hfb:hover{background:var(--blue-d)}
@media(max-width:900px){
   .hero-r{height:auto;display:flex;flex-direction:column;overflow:visible;background:var(--dark)}

.hero{display:flex;flex-direction:column;min-height:auto;overflow:visible}
.hero-l{clip-path:none;padding:60px 5vw}
.hero-r img{display:none}
.hero-r{height:auto;display:flex;flex-direction:column;overflow:visible}
.hero-r img{height:180px;flex-shrink:0;width:100%;object-fit:cover}
.hero-form-float{position:relative;width:calc(100% - 10vw);margin:24px auto 24px;max-width:420px;left:auto;right:auto;bottom:auto}

}

/* INSURANCE SLIDER (WHITE → black) */
.isl{background:var(--white);border-top:1px solid var(--border-l);border-bottom:1px solid var(--border-l)}
.isl-hdr{text-align:center;padding:22px 5vw 12px;border-bottom:1px solid var(--border-l)}
.isl-ttl{font-family:var(--disp);font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;color:#000;display:flex;align-items:center;justify-content:center;gap:12px}
.isl-ttl::before,.isl-ttl::after{content:"";flex:1;max-width:56px;height:1px;background:var(--border-l)}
.isl-wrap{overflow:hidden;padding:16px 0;position:relative}
.isl-wrap::before,.isl-wrap::after{content:"";position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.isl-wrap::before{left:0;background:transparent}
.isl-wrap::after{right:0;background:transparent}
.isl-track{display:flex;animation:islScroll 24s linear infinite;width:max-content}

@keyframes islScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.isl-card{display:flex;align-items:center;gap:9px;padding:11px 20px;background:var(--surface);border:2px solid var(--border-l);border-radius:10px;margin:0 6px;transition:all .25s;width:180px;flex-shrink:0;justify-content:center;text-decoration:none;overflow:hidden}
.isl-card:hover{border-color:var(--blue);background:var(--blue-pale);transform:translateY(-2px);box-shadow:0 4px 16px var(--blue-glow)}
.isl-logo{width:44px;height:44px;object-fit:contain;border-radius:8px;flex-shrink:0;background:#fff;padding:4px;border:1px solid #e8eef8}
.isl-name{font-family:var(--disp);font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;color:#000}
.isl-disclaimer{text-align:center;padding:9px 5vw 16px;font-size:.7rem;font-weight:600;color:#000;max-width:680px;margin:0 auto;line-height:1.6}
.isl-disclaimer a{color:var(--orange);text-decoration:none;font-weight:800}

/* PROOF BAR (DARK → white) */
.proof-bar{background:var(--dark2);display:grid;grid-template-columns:repeat(4,1fr)}
.pb{padding:22px 16px;text-align:center;border-right:1px solid var(--border-d)}
.pb:last-child{border-right:none}
.pb-n{font-family:var(--disp);font-size:2rem;color:var(--blue);letter-spacing:.02em;line-height:1}
.pb:nth-child(even) .pb-n{color:var(--orange)}
.pb-l{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:#fff;margin-top:3px}
@media(max-width:640px){.proof-bar{grid-template-columns:repeat(2,1fr)}.pb:nth-child(2){border-right:none}.pb:nth-child(-n+2){border-bottom:1px solid var(--border-d)}}

/* SECTION HELPERS */
.sec-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--blue);display:flex;align-items:center;gap:8px;margin-bottom:10px}
.sec-label::before{content:"";width:16px;height:2px;background:var(--blue)}
h2{font-size:clamp(2.2rem,4.5vw,4.5rem);margin-bottom:14px;color:#000}

/* PROCESS (WHITE → black, feat card DARK → white) */
.process-section{padding:88px 5vw;background:var(--white)}
.proc-top{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:44px;flex-wrap:wrap}
.proc-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:44px}
.ps{background:var(--surface);border:1px solid var(--border-l);border-radius:14px;padding:28px 22px;position:relative;transition:all .25s}
.ps:hover{transform:translateY(-4px);border-color:var(--blue);box-shadow:0 12px 32px var(--blue-glow)}
.ps.feat{background:var(--dark);color:#fff;border-color:var(--dark)}
.ps.feat h3{color:#fff}
.ps.feat p{color:#fff}
.ps-n{font-family:var(--disp);font-size:2.6rem;color:var(--blue);letter-spacing:.02em;line-height:1;margin-bottom:14px}
.ps.feat .ps-n{color:var(--orange)}
.ps h3{font-size:1.15rem;letter-spacing:.03em;margin-bottom:9px;color:#000}
.ps p{font-size:.84rem;line-height:1.65;color:#000}
.proc-cta{background:var(--dark);border-radius:14px;padding:28px 32px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.proc-cta-txt{font-family:var(--disp);font-size:1.2rem;letter-spacing:.03em;text-transform:uppercase;color:#fff}
.proc-cta-txt em{color:var(--orange);font-style:normal}
@media(max-width:900px){.proc-steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.proc-steps{grid-template-columns:1fr}}

/* SERVICES (DARK → white) */
.svcs-section{background:var(--dark);padding:88px 5vw;position:relative;overflow:hidden}
.svcs-section::before{content:"ROOFING";font-family:var(--disp);font-size:20vw;color:rgba(255,255,255,.007);position:absolute;top:-4vw;right:-2vw;pointer-events:none;line-height:1}
.svcs-wrap{position:relative;z-index:1;max-width:1400px;margin:0 auto}
.svcs-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:40px;flex-wrap:wrap}
.svcs-head h2{color:#fff}
.svc-alt{display:grid;grid-template-columns:1fr 1fr;background:var(--dark2);border:1px solid var(--border-d);border-radius:14px;overflow:hidden;transition:all .3s}
.svc-alt.feat-svc{border-color:rgba(255,107,26,.35)}
.svc-alt:hover{border-color:var(--blue);transform:translateY(-2px)}
.svc-alt.rev{direction:rtl}
.svc-alt.rev>*{direction:ltr}
.svc-alt-img{position:relative;min-height:280px}
.svc-alt-img img{width:100%;height:100%;object-fit:cover}
.svc-label{position:absolute;top:16px;left:16px;padding:6px 14px;border-radius:20px;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#fff}
.svc-label.orange{background:var(--orange)}
.svc-label.blue{background:var(--blue)}
.svc-alt-body{padding:36px 32px;display:flex;flex-direction:column;justify-content:center}
.svc-tag{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--baby);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.svc-tag::before{content:"";width:14px;height:2px;background:var(--blue)}
.svc-alt-body h3{font-size:clamp(1.6rem,2.5vw,2.4rem);letter-spacing:.03em;color:#fff;margin-bottom:14px}
.svc-alt-body p{font-size:.93rem;line-height:1.7;color:#fff;margin-bottom:20px}
.svc-sm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;margin-top:3px}
.svc-sm{background:var(--dark2);border:1px solid var(--border-d);border-radius:10px;overflow:hidden;transition:all .25s}
.svc-sm:hover{border-color:var(--blue);transform:translateY(-3px)}
.svc-sm img{width:100%;height:160px;object-fit:cover}
.svc-sm-body{padding:20px 18px}
.svc-sm-tag{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--orange);margin-bottom:6px}
.svc-sm-body h3{font-family:var(--disp);font-size:1.05rem;letter-spacing:.03em;color:#fff;text-transform:uppercase}
@media(max-width:900px){.svc-alt,.svc-alt.rev{grid-template-columns:1fr;direction:ltr}.svc-sm-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.svc-sm-grid{grid-template-columns:1fr}}

/* SERVICE AREAS (LIGHT → black) */
.areas-section{background:var(--off);border-top:1px solid var(--border-l);border-bottom:1px solid var(--border-l);padding:88px 5vw;position:relative;overflow:hidden}
.areas-section::before{content:"OKC";font-family:var(--disp);font-size:22vw;color:var(--blue);opacity:.012;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;line-height:1;letter-spacing:.04em}
.areas-wrap{max-width:1280px;margin:0 auto;position:relative;z-index:1}
.areas-head{text-align:center;margin-bottom:48px}
.areas-sub{font-size:1rem;line-height:1.75;color:#000;max-width:60ch;margin:14px auto 0}
.cities-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.city-card{background:var(--white);border:1.5px solid var(--border-l);border-radius:12px;padding:26px 22px;text-decoration:none;transition:all .3s;position:relative;overflow:hidden;display:flex;flex-direction:column}
.city-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--blue);transform:translateY(-3px);transition:transform .25s}
.city-card:hover{border-color:var(--blue);transform:translateY(-4px);box-shadow:0 12px 32px var(--blue-glow)}
.city-card:hover::before{transform:translateY(0)}
.city-card.feat::before{background:var(--orange);transform:translateY(0)}
.city-card.feat{border-color:rgba(255,107,26,.3)}
.city-pin{width:38px;height:38px;border-radius:9px;background:var(--blue-pale);color:var(--blue);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.city-card.feat .city-pin{background:rgba(255,107,26,.12);color:var(--orange)}
.city-pin svg{width:20px;height:20px}
.city-name{font-family:var(--disp);font-size:1.15rem;letter-spacing:.03em;text-transform:uppercase;color:#000;margin-bottom:6px;line-height:1}
.city-zip{font-size:.68rem;font-weight:700;letter-spacing:.08em;color:#000;text-transform:uppercase;margin-bottom:12px}
.city-desc{font-size:.82rem;line-height:1.7;color:#000;margin-bottom:16px;flex:1}
.city-cta{font-size:.74rem;font-weight:800;color:var(--blue);text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:5px}
.city-card.feat .city-cta{color:var(--orange)}
.city-cta svg{width:12px;height:12px;transition:transform .2s}
.city-card:hover .city-cta svg{transform:translateX(3px)}
.areas-foot{text-align:center;margin-top:36px;font-size:.88rem;color:#000}
.areas-foot strong{color:#000}
.areas-foot a{color:var(--orange);text-decoration:none;font-weight:800}
@media(max-width:900px){.cities-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.cities-grid{grid-template-columns:1fr}}

/* REVIEWS (WHITE → black) */
.rv-section{padding:88px 5vw;background:var(--white)}
.rv-head{text-align:center;margin-bottom:44px}
.rv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1280px;margin:0 auto}
.rv-item{background:var(--surface);border:1px solid var(--border-l);border-radius:14px;padding:26px 24px;transition:all .25s}
.rv-item:hover{transform:translateY(-4px);border-color:var(--blue);box-shadow:0 12px 32px var(--blue-glow)}
.rv-stars{color:var(--orange);font-size:.95rem;margin-bottom:12px;letter-spacing:2px}
.rv-text{font-size:.9rem;line-height:1.7;color:#000;margin-bottom:16px}
.rv-author{font-family:var(--disp);font-size:.92rem;letter-spacing:.04em;color:#000;text-transform:uppercase}
.rv-meta{font-size:.7rem;font-weight:600;color:#000;margin-top:2px}
@media(max-width:900px){.rv-grid{grid-template-columns:1fr}}

/* STORM CTA (DARK → white) */
.storm-section{position:relative;padding:100px 5vw;background:#000;overflow:hidden;color:#fff}
.storm-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:0}
.storm-inner{position:relative;z-index:2;max-width:1000px;margin:0 auto;text-align:center}
.storm-inner h2{color:#fff}
.storm-inner p{font-size:1.05rem;line-height:1.7;color:#fff;max-width:60ch;margin:18px auto 28px}

/* FAQ (LIGHT → black) */
.faq-section{padding:88px 5vw;background:var(--off)}
.faq-wrap{max-width:860px;margin:0 auto}
.faq-head{text-align:center;margin-bottom:40px}
.fq{background:var(--white);border:1px solid var(--border-l);border-radius:12px;margin-bottom:10px;overflow:hidden;transition:all .2s}
.fq:hover{border-color:var(--blue-mid)}
.fq summary{list-style:none;padding:20px 22px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:14px;font-family:var(--disp);font-size:1.02rem;letter-spacing:.03em;color:#000;text-transform:uppercase}
.fq summary::-webkit-details-marker{display:none}
.fq summary::after{content:"+";font-family:var(--sans);font-size:1.6rem;font-weight:300;color:var(--blue);transition:transform .25s;flex-shrink:0}
.fq[open] summary::after{transform:rotate(45deg)}
.fq-body{padding:0 22px 20px;font-size:.92rem;line-height:1.75;color:#000}

/* CONTACT (DARK → white · WHITE form → black) */
.ct-section{background:var(--dark);padding:88px 5vw;color:#fff;position:relative;overflow:hidden}
.ct-section::before{display:none}
.ct-wrap{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:56px;position:relative;z-index:1}
.ct-l h2{color:#fff;margin-bottom:18px}
.ct-l p{font-size:1rem;line-height:1.7;color:#fff;margin-bottom:30px;max-width:40ch}
.ct-info{display:flex;flex-direction:column;gap:18px}
.ct-info-item{display:flex;gap:14px;align-items:flex-start}
.ct-info-ic{width:40px;height:40px;border-radius:8px;background:rgba(43,127,255,.15);color:var(--blue);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ct-info-lab{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#fff;margin-bottom:3px}
.ct-info-val{font-size:.95rem;font-weight:700;color:#fff}
.ct-info-val a{color:#fff;text-decoration:none}
.ct-info-val a:hover{color:var(--blue)}
.ct-form{background:var(--white);border-radius:14px;padding:34px 30px;border-top:4px solid var(--orange)}
.ct-form h3{font-size:1.5rem;letter-spacing:.03em;color:#000;margin-bottom:22px}
.ct-form label{display:block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#000;margin-bottom:6px;margin-top:12px}
.ct-form label:first-of-type{margin-top:0}
.ct-form input,.ct-form select,.ct-form textarea{width:100%;background:var(--off);border:1.5px solid var(--border-l);border-radius:7px;padding:11px 14px;font-family:var(--sans);font-size:.88rem;color:#000;outline:none;transition:border-color .2s;appearance:none}
.ct-form textarea{resize:vertical;min-height:90px}
.ct-form input:focus,.ct-form select:focus,.ct-form textarea:focus{border-color:var(--blue)}
.ct-form button{margin-top:18px;width:100%;background:var(--blue);color:#fff;font-family:var(--disp);font-size:1rem;letter-spacing:.06em;text-transform:uppercase;padding:14px;border-radius:7px;border:none;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px var(--blue-glow)}
.ct-form button:hover{background:var(--blue-d)}
@media(max-width:900px){.ct-wrap{grid-template-columns:1fr;gap:40px}}

/* ============================================
   STORM FOOTER — dark bg, rain+lightning canvas
   ============================================ */
footer{position:relative;overflow:hidden;background:#1a1e24;padding:0;color:#fff}
footer #stormCanvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;display:block}
.ft-wrap{position:relative;z-index:2}
.ft-alert{background:rgba(255,200,0,.12);border-bottom:1px solid rgba(255,200,0,.25);padding:14px 5vw;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.ft-alert-txt{font-size:.85rem;font-weight:700;color:#FFD600;display:flex;align-items:center;gap:10px;letter-spacing:.02em}
.ft-alert-bolt{font-size:1.2rem}
.ft-alert-cta{background:rgba(255,200,0,.15);border:1.5px solid rgba(255,214,0,.55);color:#FFD600;padding:9px 20px;border-radius:6px;font-weight:800;font-size:.78rem;text-decoration:none;letter-spacing:.05em;text-transform:uppercase;transition:all .2s;white-space:nowrap}
.ft-alert-cta:hover{background:rgba(255,200,0,.3);color:#fff}
.ft-body{max-width:1200px;margin:0 auto;padding:52px 5vw 44px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
.ft-brand-name{font-size:1.05rem;font-weight:900;text-transform:uppercase;letter-spacing:.05em;color:#fff;margin-bottom:10px}
.ft-brand-name em{color:#FFD600;font-style:normal}
.ft-brand-desc{font-size:.82rem;color:#fff;line-height:1.78;max-width:24ch;margin-bottom:22px}
.ft-brand-phone{display:flex;flex-direction:column;gap:6px}
.ft-brand-phone a{font-size:1.25rem;font-weight:900;color:#fff;text-decoration:none;letter-spacing:-.01em;transition:color .2s}
.ft-brand-phone a:hover{color:#FFD600}
.ft-brand-phone span{font-size:.7rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.07em}
.ft-social{margin-top:14px}
.ft-social-link{display:inline-flex;align-items:center;gap:8px;color:#fff;text-decoration:none;font-size:.82rem;font-weight:700;background:rgba(255,255,255,.08);padding:8px 16px;border-radius:7px;transition:all .2s}
.ft-social-link:hover{background:#1877F2;color:#fff}
.ft-col-s h5{font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:#FFD600;margin-bottom:14px}
.ft-col-s a{display:block;font-size:.81rem;color:#fff;text-decoration:none;margin-bottom:9px;transition:color .2s}
.ft-col-s a:hover{color:#FFD600}
.ft-bar{border-top:1px solid rgba(255,255,255,.12);padding:16px 5vw;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.ft-bar-copy{font-size:.71rem;color:#fff}
.ft-bar-badges{display:flex;gap:10px;flex-wrap:wrap}
.ft-bar-badge{font-size:.67rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.06em;padding:4px 10px;border:1px solid rgba(255,255,255,.5);border-radius:20px}
@media(max-width:900px){.ft-body{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:520px){.ft-body{grid-template-columns:1fr}}


/* ===== VERSION OVERRIDES ===== */

/* Version A: Compact — 2 rows on mobile, 1 on desktop */
.isl-track-2{display:none}
@media(max-width:768px){
  .topbar{padding:6px 4vw;gap:4px;font-size:.68rem;flex-wrap:nowrap}
  .topbar .tb-l{gap:6px;justify-content:center;width:100%;flex-wrap:nowrap}
  .topbar .tb-i{font-size:.6rem;gap:2px}
  .topbar .tb-badge{display:none}
  .isl-track-2{display:flex !important;animation:islScroll 24s linear infinite;width:max-content;margin-top:6px}
  .isl-card{width:130px;padding:8px 14px;flex-shrink:0}
  .isl-logo{width:32px;height:32px}
  .isl-name{font-size:.72rem}
  .isl-hdr{padding:16px 5vw 10px}
  .isl-ttl{font-size:.68rem}
  .isl-wrap{display:flex;flex-direction:column;gap:6px;padding:10px 0}
  .isl-track-1{animation:islScroll 24s linear infinite}
}
