/*
Theme Name: Sparks Contractors
Theme URI: https://sparkscontractors.com/
Author: Rose-Tech, LLC
Author URI: https://rosetechllc.com/
Description: Custom industrial theme for Sparks Contractors, Inc. — specialized general contracting, crane service, and trucking.
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: sparks
*/

/* ============================================================
   Sparks Contractors, Inc. — Shared Stylesheet
   Ford-inspired premium industrial theme · by Rose-Tech, LLC
   ============================================================ */
:root{
  --navy:#00142E;
  --navy-2:#041d3d;
  --blue:#00306b;
  --blue-2:#0a3f86;
  --oval:#1660c4;
  --gold:#c6a667;
  --gold-soft:#d9c193;
  --platinum:#eef1f5;
  --paper:#f6f8fa;
  --white:#ffffff;
  --ink:#0c1726;
  --muted:#5a6678;
  --line:#e2e7ee;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Archivo',sans-serif;font-weight:800;line-height:1.08;letter-spacing:-0.015em}
.container{max-width:1200px;margin:0 auto;padding:0 26px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.accent{color:var(--gold)}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:700;letter-spacing:.26em;
  text-transform:uppercase;color:var(--gold);margin-bottom:18px;font-family:'Inter',sans-serif;
}
.eyebrow::before{content:"";width:28px;height:1.5px;background:var(--gold);display:inline-block}
.eyebrow.center{justify-content:center}

/* ===== Top bar ===== */
.topbar{background:var(--navy);color:#aeb9cc;font-size:13px;border-bottom:1px solid rgba(255,255,255,.06)}
.topbar .container{display:flex;justify-content:space-between;align-items:center;height:44px;gap:16px}
.topbar .left{display:flex;gap:26px;align-items:center}
.topbar .left span{display:flex;align-items:center;gap:8px}
.topbar .icn{color:var(--gold);display:inline-flex}
.topbar .icn svg{width:14px;height:14px;display:block}
.topbar a{color:#aeb9cc;transition:color .2s}
.topbar a:hover{color:#fff}
.topbar .right{letter-spacing:.04em}
@media(max-width:760px){.topbar .left span.loc,.topbar .right{display:none}}

/* ===== Header ===== */
header.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav .container{display:flex;align-items:center;justify-content:space-between;height:84px;gap:20px}
.brand{display:flex;align-items:center;gap:14px}
.brand .mark{
  width:50px;height:50px;border-radius:11px;
  background:linear-gradient(145deg,var(--oval),var(--blue));color:#fff;
  display:grid;place-items:center;font-family:'Archivo';font-weight:900;font-size:23px;
  box-shadow:0 6px 18px rgba(0,48,107,.35);border:1px solid rgba(255,255,255,.15)
}
.brand .txt b{display:block;font-family:'Archivo';font-size:19px;font-weight:900;letter-spacing:.02em;line-height:1;color:var(--navy)}
.brand .txt small{font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);font-weight:600}
nav.menu{display:flex;gap:34px;align-items:center}
nav.menu a{font-weight:600;font-size:14.5px;color:var(--ink);transition:color .2s;position:relative;padding:4px 0}
nav.menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--gold);transition:width .25s}
nav.menu a:hover,nav.menu a.active{color:var(--blue)}
nav.menu a:hover::after,nav.menu a.active::after{width:100%}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  background:linear-gradient(145deg,var(--oval),var(--blue));color:#fff;font-weight:700;font-family:'Inter';
  padding:14px 28px;border-radius:9px;font-size:14.5px;letter-spacing:.01em;
  transition:transform .18s,box-shadow .2s,filter .2s;border:none;cursor:pointer;
  box-shadow:0 8px 22px rgba(0,48,107,.28)
}
.btn:hover{transform:translateY(-2px);filter:brightness(1.08);box-shadow:0 12px 28px rgba(0,48,107,.36)}
.btn.gold{background:linear-gradient(145deg,var(--gold-soft),var(--gold));color:var(--navy);box-shadow:0 8px 22px rgba(198,166,103,.4)}
.btn.ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4);box-shadow:none}
.btn.ghost:hover{background:#fff;color:var(--navy);border-color:#fff}
/* Sparks oval emblem, redrawn as a clean scalable vector */
.brand-logo{display:block;height:54px;width:135px;
  background:url('brand/sparks-emblem.svg') left center / contain no-repeat}
@media(max-width:520px){.brand-logo{height:44px;width:110px}}
.brand-logo--footer{display:block;height:50px;width:125px;
  background:url('brand/sparks-emblem-dark.svg') left center / contain no-repeat}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.menu-toggle span{width:26px;height:3px;background:var(--navy);border-radius:2px;transition:.25s}
.mobile-menu{display:none;flex-direction:column;background:#fff;border-bottom:1px solid var(--line)}
.mobile-menu a{padding:15px 26px;font-weight:600;border-top:1px solid var(--line);color:var(--ink)}
.mobile-menu.open{display:flex}
@media(max-width:920px){nav.menu,.nav .btn{display:none}.menu-toggle{display:flex}}

/* ===== Hero (home) ===== */
.hero{position:relative;color:#fff;overflow:hidden;background:var(--navy)}
.hero .bg{
  position:absolute;inset:0;
  background:
    linear-gradient(110deg,rgba(0,12,28,.96) 0%,rgba(0,20,46,.88) 40%,rgba(0,30,68,.55) 100%),
    url('https://sparkscontractors.com/wp-content/uploads/2021/10/IMG_1929-scaled-1000x550.jpg') center/cover;
}
.hero .glow{position:absolute;top:-20%;right:-10%;width:540px;height:540px;border-radius:50%;
  background:radial-gradient(circle,rgba(22,96,196,.45),transparent 65%);filter:blur(20px)}
.hero .stripe{position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(var(--gold),transparent)}
.hero .container{position:relative;padding:108px 26px 116px}
.hero h1{font-size:clamp(38px,5.8vw,74px);max-width:15ch;margin-bottom:24px;font-weight:900;letter-spacing:-0.02em}
.hero p.lead{font-size:clamp(17px,1.9vw,21px);max-width:58ch;color:#cdd6e4;margin-bottom:38px;line-height:1.7}
.hero .cta{display:flex;gap:16px;flex-wrap:wrap}
.hero .badges{display:flex;gap:0;flex-wrap:wrap;margin-top:60px;padding-top:34px;border-top:1px solid rgba(255,255,255,.14)}
.hero .badge{padding-right:48px;margin-right:48px;border-right:1px solid rgba(255,255,255,.12)}
.hero .badge:last-child{border-right:none}
.hero .badge b{display:block;font-family:'Archivo';font-size:40px;font-weight:900;color:#fff;line-height:1;margin-bottom:4px}
.hero .badge b .accent{color:var(--gold)}
.hero .badge span{font-size:13px;color:#9fabbf;letter-spacing:.03em}
@media(max-width:620px){.hero .badge{padding-right:26px;margin-right:26px}}

/* ===== Page hero (interior) ===== */
.page-hero{position:relative;color:#fff;overflow:hidden;background:var(--navy)}
.page-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(0,12,28,.95),rgba(0,30,68,.62))}
.page-hero .stripe{position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(var(--gold),transparent);z-index:2}
.page-hero .container{position:relative;z-index:2;padding:84px 26px}
.page-hero .crumbs{font-size:13px;color:#9fabbf;margin-bottom:16px;letter-spacing:.04em}
.page-hero .crumbs a:hover{color:var(--gold)}
.page-hero h1{font-size:clamp(32px,4.6vw,56px);max-width:18ch;font-weight:900}
.page-hero p{margin-top:16px;max-width:60ch;color:#cdd6e4;font-size:18px}

/* ===== Sections ===== */
section{padding:96px 0}
.section-head{max-width:720px;margin-bottom:54px}
.section-head.center{margin:0 auto 54px;text-align:center}
.section-head h2{font-size:clamp(30px,3.8vw,46px);margin-bottom:16px;font-weight:800}
.section-head p{color:var(--muted);font-size:17.5px}

/* ===== Services cards ===== */
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px}
@media(max-width:820px){.svc-grid{grid-template-columns:1fr}}
.svc{
  position:relative;border-radius:18px;overflow:hidden;min-height:460px;display:flex;flex-direction:column;
  justify-content:flex-end;color:#fff;box-shadow:0 24px 60px rgba(0,20,46,.22);border:1px solid rgba(255,255,255,.06)
}
.svc .img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .8s ease}
.svc:hover .img{transform:scale(1.07)}
.svc::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,12,28,.96) 8%,rgba(0,20,46,.4) 52%,rgba(0,30,68,.12) 100%)}
.svc .body{position:relative;padding:38px}
.svc .tag{display:inline-block;background:rgba(198,166,103,.16);color:var(--gold-soft);border:1px solid rgba(198,166,103,.4);font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:6px 13px;border-radius:50px;margin-bottom:16px}
.svc h3{font-size:28px;margin-bottom:12px;font-weight:800}
.svc p{color:#cfd6e2;font-size:15.5px;margin-bottom:20px;line-height:1.65}
.svc .more{font-weight:700;color:#fff;display:inline-flex;align-items:center;gap:9px;font-size:14.5px}
.svc .more .arr{color:var(--gold);transition:transform .25s}
.svc:hover .more .arr{transform:translateX(6px)}
.svc-a .img{background-image:url('https://sparkscontractors.com/wp-content/uploads/2021/10/IMG_0551-scaled-1000x550.jpg')}
.svc-b .img{background-image:url('https://sparkscontractors.com/wp-content/uploads/2021/10/20170508_165555-scaled-1000x550.jpg')}

/* ===== Industries ===== */
.industries{background:var(--white)}
.ind-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
@media(max-width:900px){.ind-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.ind-grid{grid-template-columns:1fr}}
.ind{border:1px solid var(--line);border-radius:16px;padding:30px 26px;background:var(--white);transition:transform .25s,box-shadow .25s,border-color .25s}
.ind:hover{transform:translateY(-6px);box-shadow:0 22px 50px rgba(0,20,46,.12);border-color:transparent}
.ind .ic{width:52px;height:52px;border-radius:12px;background:linear-gradient(145deg,var(--oval),var(--blue));color:#fff;display:grid;place-items:center;margin-bottom:18px;box-shadow:0 8px 18px rgba(0,48,107,.25)}
.ind .ic svg{width:27px;height:27px}
.ind h3{font-size:18px;margin-bottom:9px;color:var(--navy)}
.ind p{color:var(--muted);font-size:14.5px;line-height:1.6}

/* ===== About ===== */
.about{background:var(--paper)}
.about .grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
@media(max-width:900px){.about .grid{grid-template-columns:1fr;gap:40px}}
.about h2{font-size:clamp(30px,3.8vw,46px);margin-bottom:20px}
.about p{color:var(--muted);font-size:16.5px;margin-bottom:18px}
.about .quote{border-left:3px solid var(--gold);padding:6px 0 6px 22px;font-family:'Archivo';font-weight:700;font-size:19px;color:var(--navy);margin:26px 0;line-height:1.4}
.about .photo-wrap{position:relative}
.about .photo{border-radius:18px;overflow:hidden;box-shadow:0 30px 70px rgba(0,20,46,.28);aspect-ratio:4/3;background:#222 center/cover url('https://sparkscontractors.com/wp-content/uploads/2025/10/image-49.png')}
.about .photo-wrap::after{content:"";position:absolute;right:-14px;bottom:-14px;width:120px;height:120px;border:2px solid var(--gold);border-radius:18px;z-index:-1}

/* ===== Prose (interior body copy) ===== */
.prose{max-width:760px}
.prose p{color:var(--muted);font-size:17px;margin-bottom:20px}
.prose h3{font-size:24px;margin:34px 0 14px;color:var(--navy)}
.prose .quote{border-left:3px solid var(--gold);padding:6px 0 6px 22px;font-family:'Archivo';font-weight:700;font-size:20px;color:var(--navy);margin:28px 0;line-height:1.4}
.prose .check{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:12px 28px;margin:20px 0}
@media(max-width:620px){.prose .check{grid-template-columns:1fr}}
.prose .check li{display:flex;align-items:center;gap:12px;font-weight:600;color:var(--ink)}
.prose .check li svg{width:20px;height:20px;color:var(--gold);flex:none}

/* ===== Equipment ===== */
.equip{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.equip .glow{position:absolute;bottom:-30%;left:-8%;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(22,96,196,.3),transparent 65%);filter:blur(10px)}
.equip .container{position:relative}
.equip .section-head h2{color:#fff}
.equip .section-head p{color:#9fabbf}
.eq-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
@media(max-width:900px){.eq-grid{grid-template-columns:repeat(2,1fr)}}
.eq{background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.09);border-radius:14px;padding:30px 22px;transition:transform .25s,border-color .25s,background .25s}
.eq:hover{transform:translateY(-6px);border-color:var(--gold);background:rgba(198,166,103,.06)}
.eq .ic{width:50px;height:50px;border-radius:11px;background:linear-gradient(145deg,rgba(22,96,196,.3),rgba(0,48,107,.3));color:var(--gold);display:grid;place-items:center;margin-bottom:18px;border:1px solid rgba(255,255,255,.08)}
.eq .ic svg{width:27px;height:27px}
.eq b{display:block;font-family:'Archivo';font-size:16.5px;margin-bottom:6px}
.eq span{font-size:13px;color:#93a0b5}
.equip .note{margin-top:38px;text-align:center;color:#9fabbf;font-size:15px}
.equip .note b{color:var(--gold)}

/* ===== Gallery ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:820px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
.gallery-grid .g{aspect-ratio:1/1;border-radius:12px;background-size:cover;background-position:center;box-shadow:0 8px 22px rgba(0,20,46,.12);transition:transform .35s,box-shadow .35s;position:relative;overflow:hidden}
.gallery-grid .g::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,20,46,.35),transparent 60%);opacity:0;transition:opacity .3s}
.gallery-grid .g:hover{transform:scale(1.04);box-shadow:0 16px 38px rgba(0,20,46,.26)}
.gallery-grid .g:hover::after{opacity:1}

/* ===== CTA strip ===== */
.cta-strip{background:linear-gradient(120deg,var(--navy) 0%,var(--blue) 60%,var(--blue-2) 100%);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-strip .glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:700px;height:300px;background:radial-gradient(ellipse,rgba(198,166,103,.18),transparent 70%)}
.cta-strip .container{position:relative}
.cta-strip h2{font-size:clamp(28px,3.6vw,44px);margin-bottom:16px;color:#fff}
.cta-strip p{font-size:18px;color:#cdd6e4;margin-bottom:32px}

/* ===== Contact ===== */
.contact .grid{display:grid;grid-template-columns:1fr 1fr;gap:52px}
@media(max-width:820px){.contact .grid{grid-template-columns:1fr}}
.contact .info-card{background:linear-gradient(160deg,var(--navy),var(--blue));color:#fff;border-radius:18px;padding:42px;box-shadow:0 24px 60px rgba(0,20,46,.25);border:1px solid rgba(255,255,255,.08)}
.contact .info-card h3{font-size:25px;margin-bottom:8px}
.contact .info-card .sub{color:#9fabbf;margin-bottom:28px;font-size:14.5px}
.contact .row{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-top:1px solid rgba(255,255,255,.1)}
.contact .row .ic{color:var(--gold);margin-top:2px}
.contact .row .ic svg{width:21px;height:21px;display:block}
.contact .row b{display:block;font-size:16px;font-family:'Archivo'}
.contact .row a{color:#fff}
.contact .row a:hover{color:var(--gold)}
.contact .row span{color:#9fabbf;font-size:14px}
form{display:flex;flex-direction:column;gap:18px}
form label{font-weight:600;font-size:13.5px;margin-bottom:-10px;color:var(--ink)}
form input,form textarea{
  border:1.5px solid var(--line);border-radius:10px;padding:14px 16px;font-size:15px;font-family:inherit;transition:border-color .2s,box-shadow .2s;background:var(--paper)
}
form input:focus,form textarea:focus{outline:none;border-color:var(--oval);box-shadow:0 0 0 3px rgba(22,96,196,.12);background:#fff}
form textarea{min-height:140px;resize:vertical}
.form-note{font-size:13px;color:var(--muted)}

/* ===== Footer ===== */
footer{background:#000c1c;color:#9fabbf;padding:60px 0 30px}
footer .grid{display:flex;justify-content:space-between;gap:34px;flex-wrap:wrap;margin-bottom:40px}
footer .brand .mark{box-shadow:none}
footer .brand .txt b{color:#fff}
footer .col h4{color:#fff;font-family:'Archivo';font-size:13px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:16px}
footer .col a{display:block;color:#9fabbf;margin-bottom:10px;font-size:14.5px;transition:color .2s}
footer .col a:hover{color:var(--gold)}
footer .bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:24px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:13px}
footer .bottom a{color:var(--gold)}
