:root{
  --max:1140px;
  --pad:18px;
  --r:18px;
  --r2:24px;
  --shadow:0 22px 60px rgba(2,6,23,.14);
  --shadow2:0 14px 34px rgba(2,6,23,.12);
  --line:rgba(15,23,42,.10);
  --text:#0b1220;
  --muted:rgba(2,6,23,.72);
  --accent:#0f766e;
  --accent2:#111827;
  --bg:#ffffff;
  --bg2:#f8fafc;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.55;
  color:var(--text);
  background:
    radial-gradient(900px 420px at 15% 0%, rgba(34,197,94,.18), rgba(15,118,110,.10) 40%, rgba(15,23,42,0) 70%),
    radial-gradient(760px 360px at 90% 10%, rgba(56,189,248,.16), rgba(59,130,246,.08) 45%, rgba(15,23,42,0) 75%),
    linear-gradient(180deg,var(--bg2),#fff 35%);
}
a{color:inherit}
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
header{
  position:sticky;top:0;z-index:10;
  background:rgba(255,255,255,.72);
  backdrop-filter: blur(16px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;gap:14px;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;gap:10px;align-items:center;text-decoration:none}
.logo{
  width:44px;height:44px;border-radius:16px;
  background:radial-gradient(120% 120% at 20% 10%, #22c55e 0%, #0f766e 45%, #111827 100%);
  color:#fff;display:grid;place-items:center;font-weight:900;letter-spacing:.5px;
  box-shadow:var(--shadow2);
}
.brand b{font-size:18px}
.brand small{display:block;font-size:12px;opacity:.75;margin-top:-2px}
.links{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.links a{opacity:.86;text-decoration:none;padding:8px 10px;border-radius:12px}
.links a:hover{background:rgba(2,6,23,.04);opacity:1}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--accent2);color:#fff;text-decoration:none;
  border-radius:14px;padding:10px 14px;font-weight:800;
  box-shadow:var(--shadow2);
  border:1px solid rgba(255,255,255,.10);
  transition:transform .12s ease, filter .12s ease;
}
.btn:hover{transform:translateY(-1px);filter:brightness(1.03)}
.btn:active{transform:translateY(0)}
.btn.alt{background:var(--accent)}
.btn.ghost{background:rgba(255,255,255,.68);color:var(--accent2);border:1px solid var(--line);box-shadow:none}
.btn.small{padding:8px 10px;border-radius:12px;font-weight:750}
.hero{padding:52px 0 26px}
.grid{display:grid;gap:18px}
.heroGrid{grid-template-columns:1.25fr .75fr}
@media (max-width:900px){.heroGrid{grid-template-columns:1fr}}
.card{
  border:1px solid var(--line);
  border-radius:var(--r2);
  background:rgba(255,255,255,.82);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.card .p{padding:20px}
.cardGlass{
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.72));
}
h1{font-size:46px;line-height:1.05;margin:0 0 12px;letter-spacing:-.03em}
@media (max-width:600px){h1{font-size:36px}}
h2{font-size:22px;margin:0 0 10px;letter-spacing:-.01em}
p{margin:0 0 12px;color:var(--muted)}
.badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.badge{
  border:1px solid var(--line);
  border-radius:999px;
  padding:8px 12px;
  font-size:13px;
  color:rgba(2,6,23,.78);
  background:rgba(255,255,255,.72);
}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px}
.kpi{
  border:1px solid var(--line);
  border-radius:16px;
  padding:12px 12px;
  background:linear-gradient(180deg,#fff,rgba(2,6,23,.02));
}
.kpi b{font-size:18px;color:var(--text)}
.small{font-size:12px;opacity:.78}
section{padding:24px 0}
.sectionTitle{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:12px}
.sectionTitle h2{margin:0}
.cols{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:900px){.cols{grid-template-columns:1fr}}
.featureGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media (max-width:900px){.featureGrid{grid-template-columns:1fr}}
.feature{
  border:1px solid var(--line);
  border-radius:18px;
  padding:14px 14px;
  background:rgba(255,255,255,.70);
  box-shadow:0 10px 24px rgba(2,6,23,.06);
}
.feature b{display:block;margin-bottom:6px}
.icon{
  width:38px;height:38px;border-radius:14px;
  display:grid;place-items:center;margin-bottom:10px;
  background:rgba(15,118,110,.12);
  border:1px solid rgba(15,118,110,.18);
}
.form{display:grid;gap:10px}
.form input,.form textarea,.form select{
  border:1px solid var(--line);border-radius:16px;padding:12px 14px;
  font-size:14px;background:#fff;box-shadow:0 10px 22px rgba(2,6,23,.06)
}
.form textarea{min-height:110px;resize:vertical}
hr{border:none;border-top:1px solid var(--line);margin:14px 0}
.callout{
  border:1px dashed rgba(15,118,110,.35);
  background:rgba(15,118,110,.08);
  border-radius:16px;padding:12px 14px
}
.search{display:flex;gap:10px}
.search input{
  flex:1;border:1px solid var(--line);border-radius:16px;padding:12px 14px;
  font-size:14px;background:#fff;box-shadow:0 10px 22px rgba(2,6,23,.06)
}
.table{
  border:1px solid var(--line);
  border-radius:var(--r2);
  overflow:hidden;
  background:rgba(255,255,255,.86);
  box-shadow:var(--shadow);
}
.table .row{display:grid;grid-template-columns:1.35fr .9fr .75fr;gap:0;border-top:1px solid var(--line)}
@media (max-width:800px){.table .row{grid-template-columns:1.2fr .8fr} .table .row .cell:last-child{display:none}}
.table .row:first-child{border-top:none}
.table .cell{padding:12px 14px}
.table .head{background:rgba(2,6,23,.03);font-weight:900}
.pills{display:flex;gap:8px;flex-wrap:wrap}
.pill{border:1px solid var(--line);border-radius:999px;padding:6px 10px;font-size:12px;opacity:.92;background:rgba(255,255,255,.68)}
.footer{
  border-top:1px solid var(--line);
  padding:30px 0;
  margin-top:24px;
  background:linear-gradient(180deg,rgba(2,6,23,.02),transparent);
}
.fab{
  position:fixed;right:16px;bottom:16px;z-index:50;
  display:flex;flex-direction:column;gap:10px;
}
.fab a{
  border-radius:16px;
  padding:12px 14px;
  box-shadow:var(--shadow2);
  text-decoration:none;
}
.fab .call{background:var(--accent);color:#fff;font-weight:900}
.fab .loc{background:rgba(255,255,255,.82);border:1px solid var(--line);color:var(--accent2);font-weight:850}
.faq button{
  width:100%;
  text-align:left;
  border:1px solid var(--line);
  background:rgba(255,255,255,.72);
  border-radius:16px;
  padding:12px 14px;
  font-weight:900;
  cursor:pointer;
}
.faq .a{
  display:none;
  padding:10px 14px 0 14px;
  color:var(--muted);
}
.faq .item{margin:10px 0}
.logo-img{height:42px}
.ba-wrap{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.ba{position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.ba img{width:100%;display:block}
.ba .tag{position:absolute;top:12px;left:12px;padding:6px 10px;border-radius:999px;font-weight:800;color:#fff}
.ba .before{background:#f97316}
.ba .after{background:#22c55e}
@media (max-width:900px){.ba-wrap{grid-template-columns:1fr}}

.callOnly{
  border:1px solid var(--line);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(15,118,110,.10), rgba(255,255,255,.82));
  padding:14px 14px;
  box-shadow:0 10px 24px rgba(2,6,23,.08);
}
.callOnly .big{
  font-size:22px;
  font-weight:950;
  letter-spacing:-.02em;
  margin:2px 0 10px;
}
.callOnly .meta{color:var(--muted);font-size:13px;line-height:1.5}


/* ===== SoCal Roofing: Awesome UI Override ===== */
:root{
  --line2: rgba(15,23,42,.10);
  --shadow2: 0 18px 50px rgba(2,6,23,.18);
  --shadow3: 0 10px 30px rgba(2,6,23,.14);
}
body{
  background:
    radial-gradient(900px 420px at 18% 10%, rgba(34,197,94,.14), transparent 60%),
    radial-gradient(820px 380px at 84% 6%, rgba(59,130,246,.14), transparent 60%),
    radial-gradient(980px 520px at 50% 92%, rgba(249,115,22,.10), transparent 60%),
    linear-gradient(180deg, rgba(248,250,252,.94), rgba(248,250,252,.98));
}
.wrap{max-width:1120px}
header{
  position:sticky; top:0; z-index:40;
  backdrop-filter:saturate(1.2) blur(10px);
  background:rgba(255,255,255,.72);
  border-bottom:1px solid var(--line2);
}
.nav a{font-weight:700}
.logoRow{display:flex;align-items:center;gap:10px}
.logo-img{height:44px;width:auto}
.brandTitle{font-weight:950;letter-spacing:-.02em}
.brandSub{font-size:12px;color:var(--muted);margin-top:-2px}

.hero{padding:28px 0 18px}
.heroGrid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:18px;
  align-items:start;
}
@media (max-width: 980px){.heroGrid{grid-template-columns:1fr}}

.card, .cardGlass{
  border:1px solid var(--line2) !important;
  box-shadow: var(--shadow3) !important;
  background: rgba(255,255,255,.78) !important;
}
.cardGlass{background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.74)) !important;}
.card .p, .cardGlass .p{padding:18px !important}

.badge{
  border:1px solid rgba(15,23,42,.12) !important;
  background: rgba(255,255,255,.72) !important;
}
.btn{border-radius:14px !important;font-weight:900 !important;padding:12px 14px !important}
.btn.alt{
  background: linear-gradient(135deg, rgba(15,118,110,1), rgba(34,197,94,1)) !important;
  box-shadow: 0 14px 28px rgba(16,185,129,.22) !important;
}
.btn.ghost{
  border:1px solid rgba(15,23,42,.16) !important;
  background: rgba(255,255,255,.62) !important;
}
hr{
  border:none !important;height:1px !important;
  background: linear-gradient(90deg, transparent, rgba(15,23,42,.14), transparent) !important;
  margin:18px 0 !important;
}

/* Call-only card */
.callOnly{
  background: linear-gradient(180deg, rgba(240,253,250,.95), rgba(255,255,255,.85)) !important;
  border:1px solid rgba(16,185,129,.24) !important;
  box-shadow: var(--shadow2) !important;
  padding:16px 16px !important;
}
.callOnly .big a.btn.alt{
  display:inline-flex;gap:10px;align-items:center;justify-content:center;
  width:100%;font-size:18px;
}
.callOnly .meta b{color: rgba(2,6,23,.88)}
.callOnly .meta a{font-weight:800}

.sidebarStack{display:flex;flex-direction:column;gap:14px}

section{padding:18px 0}
ul{padding-left:18px}
li{margin:8px 0}
.callout{
  border:1px solid rgba(59,130,246,.18) !important;
  background: rgba(239,246,255,.78) !important;
}
footer{border-top:1px solid var(--line2);background: rgba(255,255,255,.7)}
.nav .cta{background: rgba(15,23,42,.06) !important;border:1px solid rgba(15,23,42,.12) !important;}


/* ===== HERO ALIGNMENT FIX ===== */
.heroGrid{
  align-items:stretch !important;
}
.heroGrid > *{
  width:100% !important;
}
.hero .card,
.hero .cardGlass{
  max-width:none !important;
  width:100% !important;
}
.heroLeft, .heroRight{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.sidebarStack{
  width:100%;
}


/* ===== LOCATION HERO 2-COLUMN FIX ===== */
.heroLeft, .heroRight{width:100%}
.heroLeft{display:flex;flex-direction:column;gap:16px}
.heroRight{display:flex;flex-direction:column;gap:14px}


/* ===== Location Page Layout Hardening ===== */
.heroGrid{align-items:start !important;}
.heroLeft,.heroRight{min-width:0;}
.heroLeft .card, .heroLeft .cardGlass, .heroRight .card, .heroRight .cardGlass{width:100%;}
