/* Future of Construction — directory styles (city + contractor profile pages).
   Self-contained; FoC branding (blue #3569b4 / #0177b5, Literata + Muli). */
:root{
  --brand:#0177b5; --brand-dark:#3569b4; --accent:#ec162c;
  --ink:#171716; --muted:#6b7280; --line:#e6e8ec;
  --bg:#fff; --bg-soft:#f5f7fa; --footer:#171716; --star:#f5a623;
  --shadow:0 1px 3px rgba(16,24,40,.06),0 8px 24px rgba(16,24,40,.06);
  --radius:14px; --maxw:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Muli","Source Sans Pro",-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,.serif{font-family:"Literata",Georgia,serif;line-height:1.2;color:var(--ink)}
a{color:var(--brand);text-decoration:none}a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* header */
.site-head{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.95);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;height:72px;gap:20px}
.site-head .logo img{height:44px;width:auto}
.nav{display:flex;align-items:center;gap:26px}
.nav a{color:var(--ink);font-weight:600;font-size:15px}
.nav a:hover{color:var(--brand);text-decoration:none}
.btn{display:inline-flex;align-items:center;gap:8px;border-radius:8px;font-weight:700;
  font-size:15px;padding:11px 20px;cursor:pointer;border:0;transition:.15s;text-decoration:none}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand-dark);text-decoration:none;color:#fff}
.btn-ghost{background:#fff;color:var(--brand);border:1.5px solid var(--brand)}
.btn-ghost:hover{background:var(--bg-soft);text-decoration:none}
.btn-block{width:100%;justify-content:center}
@media(max-width:720px){.nav .nav-link{display:none}.site-head .wrap{height:62px}}

/* breadcrumb */
.crumb{font-size:13px;color:var(--muted);padding:16px 0 0}
.crumb a{color:var(--muted)}.crumb a:hover{color:var(--brand)}

/* hero */
.hero{background:linear-gradient(135deg,#0e2a4a,#13365e 60%,#0177b5);color:#fff;padding:54px 0 60px}
.hero h1{color:#fff;font-size:clamp(28px,4.4vw,46px);margin:0 0 14px}
.hero h1 .hl{color:#7fc4ec}
.hero p{color:#d9e6f2;font-size:18px;max-width:680px;margin:0}
.hero .meta{margin-top:18px;display:flex;gap:22px;flex-wrap:wrap;font-size:14px;color:#bcd4e8}
.hero .meta b{color:#fff}

/* intro */
.section{padding:42px 0}
.section.tight{padding:28px 0}
.lead{font-size:17px;color:#374151;max-width:760px}
.section h2{font-size:26px;margin:0 0 6px}
.section .sub{color:var(--muted);margin:0 0 26px}

/* cards grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:22px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);display:flex;flex-direction:column;transition:.18s}
.card:hover{transform:translateY(-3px);box-shadow:0 6px 14px rgba(16,24,40,.1),0 18px 40px rgba(16,24,40,.1)}
.card-photo{position:relative;aspect-ratio:16/10;background:#eef2f7 center/cover no-repeat}
.card-photo.fallback{display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#e8eef6,#dbe6f2)}
.card-photo.fallback svg{width:64px;height:64px;opacity:.5}
.rank-badge{position:absolute;top:12px;left:12px;background:var(--brand-dark);color:#fff;
  font-weight:800;font-size:12px;letter-spacing:.03em;padding:5px 11px;border-radius:20px;
  box-shadow:0 2px 6px rgba(0,0,0,.2)}
.card-body{padding:18px 18px 20px;display:flex;flex-direction:column;flex:1}
.card-name{font-size:19px;margin:0 0 6px}
.card-name a{color:var(--ink)}.card-name a:hover{color:var(--brand)}
.rating{display:flex;align-items:center;gap:7px;font-size:14px;margin:0 0 8px}
.stars{color:var(--star);letter-spacing:1px;font-size:15px}
.rating .num{font-weight:700}.rating .cnt{color:var(--muted)}
.card-loc{font-size:13px;color:var(--muted);margin:0 0 10px;display:flex;align-items:center;gap:6px}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin:0 0 12px}
.tag{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  color:var(--brand-dark);background:#eaf2fb;border-radius:6px;padding:4px 9px}
.excerpt{font-size:14px;color:#4b5563;margin:0 0 16px;flex:1}
.card-actions{display:flex;gap:10px}
.card-actions .btn{flex:1;padding:10px 12px;font-size:14px}

/* profile */
.firm-hero{background:linear-gradient(135deg,#0e2a4a,#13365e 60%,#0177b5);color:#fff;padding:42px 0}
.firm-hero-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:34px;align-items:center}
.firm-hero h1{color:#fff;font-size:clamp(26px,3.6vw,38px);margin:0 0 12px}
.firm-hero .rating{color:#fff}.firm-hero .rating .cnt{color:#bcd4e8}
.firm-hero .addr{color:#d9e6f2;margin:10px 0 18px;display:flex;align-items:center;gap:8px}
.firm-hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.firm-hero-photo{border-radius:var(--radius);overflow:hidden;box-shadow:0 10px 30px rgba(0,0,0,.3);
  aspect-ratio:16/10;background:#0b1f38 center/cover no-repeat}
.firm-hero-photo.fallback{display:flex;align-items:center;justify-content:center}
.firm-hero-photo.fallback svg{width:84px;height:84px;opacity:.4;filter:invert(1)}
@media(max-width:820px){.firm-hero-grid{grid-template-columns:1fr}}

.profile-grid{display:grid;grid-template-columns:1fr 380px;gap:40px;align-items:start;padding:42px 0}
@media(max-width:900px){.profile-grid{grid-template-columns:1fr}}
.prose p{color:#374151;font-size:16px}
.factbox{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:22px 0}
.fact{background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;padding:14px 16px}
.fact .k{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.fact .v{font-size:16px;font-weight:700;margin-top:3px}
.reviews{display:flex;flex-direction:column;gap:16px;margin-top:8px}
.review{border:1px solid var(--line);border-radius:12px;padding:16px 18px;background:#fff}
.review-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.review-author{font-weight:700}.review-when{font-size:13px;color:var(--muted)}
.review-text{color:#4b5563;font-size:15px;margin:0}
.map{margin-top:22px;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.map iframe{display:block;width:100%;height:300px;border:0}

/* lead / contact form (sidebar sticky) */
.lead-box{position:sticky;top:90px;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:24px;background:#fff}
.lead-box h3{font-size:20px;margin:0 0 4px}
.lead-box .hint{color:var(--muted);font-size:14px;margin:0 0 18px}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:700;margin-bottom:5px}
.field input,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:8px;
  padding:11px 13px;font:inherit;font-size:15px;color:var(--ink);background:#fff}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--brand)}
.field textarea{min-height:110px;resize:vertical}
.form-msg{font-size:14px;border-radius:8px;padding:11px 14px;margin-bottom:14px;display:none}
.form-msg.ok{display:block;background:#e7f6ec;color:#176c36;border:1px solid #b6e3c6}
.form-msg.err{display:block;background:#fdecec;color:#9b1c1c;border:1px solid #f4c2c2}
.cf-turnstile{margin-bottom:14px}
.tiny{font-size:12px;color:var(--muted);margin-top:10px}

/* contact page */
.contact-grid{display:grid;grid-template-columns:1fr 420px;gap:40px;padding:42px 0;align-items:start}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}

/* CTA band */
.cta-band{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:40px 0;text-align:center}
.cta-band h2{margin:0 0 10px}
.cta-band p{color:var(--muted);max-width:560px;margin:0 auto 20px}

/* footer */
.site-foot{background:var(--footer);color:#c9ccd1;padding:48px 0 26px;font-size:14px;margin-top:10px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:30px}
.foot-grid h4{color:#fff;font-family:inherit;font-size:13px;text-transform:uppercase;
  letter-spacing:.06em;margin:0 0 14px}
.foot-grid a{color:#c9ccd1;display:block;margin-bottom:8px}
.foot-grid a:hover{color:#fff;text-decoration:none}
.foot-brand img{height:40px;margin-bottom:12px;filter:brightness(0) invert(1)}
.foot-brand p{color:#9aa0a8;max-width:280px}
.foot-contact div{margin-bottom:8px}
.foot-bottom{border-top:1px solid #2a2a29;margin-top:34px;padding-top:18px;color:#8a8f97;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}
.icon{width:1em;height:1em;display:inline-block;vertical-align:-.12em;fill:currentColor}

/* ── city-page filter bar (ported from australianroofers, FoC-toned) ── */
.muted{color:var(--muted)}.muted-label{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.ar-syd-filterbar{background:#fff;border-bottom:1px solid var(--line);padding:14px 0;position:sticky;top:72px;z-index:30;box-shadow:0 2px 8px rgba(16,24,40,.04)}
.ar-syd-filterbar-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.ar-syd-filterbar-spacer{flex-grow:1}
.ar-syd-filtersearch{display:inline-flex;align-items:center;gap:8px;background:var(--bg-soft);border:1px solid var(--line);border-radius:999px;padding:8px 14px;min-width:230px}
.ar-syd-filtersearch:focus-within{border-color:var(--brand);background:#fff}
.ar-syd-filtersearch-icon{width:16px;height:16px;color:var(--muted);flex:none}
.ar-syd-filtersearch input{border:0;background:transparent;outline:none;font:inherit;font-size:14px;width:100%;color:var(--ink)}
.ar-syd-filterdrop{position:relative}
.ar-syd-filterdrop summary{list-style:none;cursor:pointer;padding:8px 14px;background:var(--bg-soft);border:1px solid var(--line);border-radius:999px;font-weight:700;font-size:.85rem;color:var(--ink);display:inline-flex;align-items:center;gap:8px;user-select:none;transition:border-color .12s,background .12s}
.ar-syd-filterdrop summary::-webkit-details-marker{display:none}.ar-syd-filterdrop summary::marker{content:''}
.ar-syd-filterdrop summary:hover{border-color:var(--brand);background:#fff}
.ar-syd-filterdrop[open] summary{border-color:var(--brand);background:#fff;box-shadow:0 0 0 3px rgba(1,119,181,.12)}
.ar-syd-filterdrop-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:var(--brand);color:#fff;border-radius:999px;font-size:.72rem;font-weight:700}
.ar-syd-filterdrop-caret{font-size:.75rem;color:var(--muted);transition:transform .15s}
.ar-syd-filterdrop[open] .ar-syd-filterdrop-caret{transform:rotate(180deg);color:var(--brand)}
.ar-syd-filterdrop-panel{position:absolute;top:calc(100% + 8px);left:0;min-width:260px;max-width:480px;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 12px 32px rgba(16,24,40,.16);padding:16px;z-index:35}
.ar-syd-filterdrop-panel-wide{min-width:300px}
.ar-syd-filterdrop-divider{border:0;border-top:1px solid var(--line);margin:14px 0 12px}
.ar-chips{display:flex;flex-wrap:wrap;gap:8px}
.ar-chip{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);border-radius:999px;padding:7px 13px;font-size:13px;font-weight:600;cursor:pointer;user-select:none;transition:.12s}
.ar-chip:hover{border-color:var(--brand)}
.ar-chip input{accent-color:var(--brand);margin:0}
.ar-chip:has(input:checked){background:#eaf2fb;border-color:var(--brand);color:var(--brand-dark)}
.ar-syd-rating-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}
.ar-syd-rating-headlabel{font-size:13px;font-weight:700;color:var(--ink)}
.ar-syd-rating-value{font-size:13px;font-weight:700;color:var(--brand)}
.ar-syd-rating-value.is-empty{color:var(--muted);font-weight:600}
.ar-syd-rating-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;
  background:linear-gradient(to right,var(--brand) 0%,var(--brand) var(--rating-pct,0%),var(--line) var(--rating-pct,0%),var(--line) 100%);outline:none}
.ar-syd-rating-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--brand);border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.3);cursor:pointer}
.ar-syd-rating-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--brand);border:2px solid #fff;cursor:pointer}
.ar-syd-rating-scale{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-top:6px}
.ar-syd-sort{display:inline-flex;align-items:center;gap:8px}
.ar-syd-sort select{border:1px solid var(--line);border-radius:8px;padding:8px 12px;font:inherit;font-size:14px;background:#fff;color:var(--ink);cursor:pointer}
.ar-syd-filterbar-controls{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:12px;margin-top:12px;border-top:1px dashed var(--line)}
.ar-syd-filter-count{margin:0;color:var(--muted);font-size:14px}
.ar-syd-filter-count strong{color:var(--ink);font-size:1.05rem}
.ar-filter-active-pill a{color:var(--brand);font-weight:700}
.ar-syd-no-results{text-align:center;padding:40px 0;color:var(--muted)}
.ar-syd-no-results p{margin:0 0 14px}
@media(max-width:720px){.ar-syd-filterbar{top:62px}.ar-syd-filterbar-spacer{display:none}.ar-syd-filtersearch{min-width:0;flex:1}}

/* ── multi-operator quote form ── */
.multi-section{padding:38px 0;background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.multi-card{max-width:940px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px}
.multi-head{margin-bottom:16px}
.eyebrow{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--brand);margin:0 0 6px}
.multi-head h2{font-size:24px;margin:0 0 8px}
.multi-head .sub{color:var(--muted);margin:0;font-size:15px}
.multi-firms{margin:18px 0 20px}
.multi-firms-head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.multi-count{color:var(--brand);font-weight:800}
.multi-controls{display:flex;gap:8px;flex-wrap:wrap}
.btn-sm{padding:7px 12px;font-size:13px}
.multi-search{padding:8px 12px;border:1px solid var(--line);border-radius:8px;font:inherit;font-size:14px;min-width:180px}
.multi-search:focus{outline:none;border-color:var(--brand)}
.multi-list{max-height:300px;overflow-y:auto;border:1px solid var(--line);border-radius:10px;background:var(--bg-soft)}
.multi-firmrow{display:flex;gap:11px;align-items:center;padding:10px 14px;border-bottom:1px solid var(--line);cursor:pointer}
.multi-firmrow:last-child{border-bottom:0}
.multi-firmrow:hover{background:#eef4fb}
.multi-firmrow input{accent-color:var(--brand);width:17px;height:17px;flex:none;cursor:pointer;margin:0}
.multi-firmrow-main{font-size:14px}
.multi-fields{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
@media(max-width:600px){.multi-fields{grid-template-columns:1fr}}
.field select{width:100%;border:1.5px solid var(--line);border-radius:8px;padding:11px 13px;font:inherit;font-size:15px;background:#fff;color:var(--ink);cursor:pointer}
.field select:focus{outline:none;border-color:var(--brand)}

.chip-n{color:var(--muted);font-weight:700;font-size:11px;margin-left:2px}
.ar-syd-filterdrop-count[hidden]{display:none}

/* ── homepage ── */
.center{text-align:center}
.btn-lg{padding:14px 26px;font-size:16px}
.btn-light{background:#fff;color:var(--brand-dark)}
.btn-light:hover{background:#eaf2fb;text-decoration:none}
.home-hero{background-size:cover;background-position:center;color:#fff;padding:96px 0 104px}
.home-hero-inner{max-width:760px}
.home-hero h1{color:#fff;font-size:clamp(34px,5.4vw,58px);margin:6px 0 18px;line-height:1.08}
.home-hero h1 .hl{color:#7fc4ec}
.home-hero-sub{color:#dbe8f4;font-size:19px;max-width:620px;margin:0 0 28px}
.home-hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.home-trust{margin-top:26px;font-size:14px;color:#bcd4e8;font-weight:600}
.section h2.serif{font-size:30px}
.section .sub.center{margin-left:auto;margin-right:auto}
/* location browser */
.loc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:28px;margin-top:28px}
.loc-region h3{font-size:18px;margin:0 0 14px;padding-bottom:10px;border-bottom:2px solid var(--brand);display:inline-block}
.loc-links{display:flex;flex-direction:column;gap:8px}
.loc-link{display:flex;justify-content:space-between;align-items:center;padding:13px 16px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--ink);font-weight:600;transition:.15s}
.loc-link:hover{border-color:var(--brand);background:var(--bg-soft);text-decoration:none;transform:translateX(3px)}
.loc-n{background:#eaf2fb;color:var(--brand-dark);font-size:13px;font-weight:800;border-radius:20px;padding:3px 11px}
/* steps */
.home-steps-sec{background:var(--bg-soft)}
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-top:30px}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;text-align:center;box-shadow:var(--shadow)}
.step-ic{width:54px;height:54px;margin:0 auto 16px;border-radius:50%;background:#eaf2fb;color:var(--brand);display:flex;align-items:center;justify-content:center}
.step-ic svg{width:26px;height:26px}
.step h3{font-size:18px;margin:0 0 8px}
.step p{color:var(--muted);font-size:15px;margin:0}
/* picks */
.home-picks-head{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.home-picks-head h2{margin:0}
.picks{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.pick{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;box-shadow:var(--shadow);color:var(--ink);transition:.18s}
.pick:hover{transform:translateY(-3px);box-shadow:0 8px 22px rgba(16,24,40,.12);text-decoration:none}
.pick-photo{aspect-ratio:16/10;background:#eef2f7 center/cover no-repeat}
.pick-photo.fallback{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e8eef6,#dbe6f2)}
.pick-photo.fallback svg{width:54px;height:54px;opacity:.5}
.pick-body{padding:15px 16px 17px}
.pick-name{font-weight:700;font-size:16px;margin-bottom:6px}
.pick-loc{font-size:13px;color:var(--muted);margin-top:4px}
/* values */
.values-sec{background:var(--bg-soft)}
.values{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:28px}
@media(max-width:680px){.values{grid-template-columns:1fr}}
.value{display:flex;gap:16px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.value-ic{flex:none;width:46px;height:46px;border-radius:12px;background:#eaf2fb;color:var(--brand);display:flex;align-items:center;justify-content:center}
.value-ic svg{width:24px;height:24px}
.value h3{font-size:17px;margin:0 0 6px}
.value p{color:var(--muted);font-size:14px;margin:0}

/* ── profile FAQ + questions-to-ask ── */
.faq{display:flex;flex-direction:column;gap:8px;margin:8px 0 10px}
.faq-item{border:1px solid var(--line);border-radius:10px;background:#fff;overflow:hidden}
.faq-item summary{cursor:pointer;padding:14px 16px;font-weight:700;font-size:15px;list-style:none;display:flex;justify-content:space-between;gap:12px;align-items:center}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--brand);font-weight:800;font-size:20px;line-height:1}
.faq-item[open] summary::after{content:"\2013"}
.faq-item[open] summary{border-bottom:1px solid var(--line)}
.faq-a{padding:12px 16px;color:#4b5563;font-size:15px;line-height:1.6}
.qlist{margin:0 0 4px;padding-left:20px;display:flex;flex-direction:column;gap:9px}
.qlist li{color:#374151;font-size:15px;padding-left:4px}
.prose h2{margin-top:30px}
.prose h2:first-child{margin-top:0}
