/* ============================================================
   EJL Roofing Residential Ltd - Concept B "Quote First"
   Shared design system. Extracted from b-quote-first.html and
   b-quote-first-roof-repairs.html (templates locked 11 Jun 2026).
   Page-specific CSS (hero background images, one-off layout
   tweaks) stays inline on each page, AFTER this stylesheet.
   ============================================================ */

:root{
  --navy:#1d1e20;
  --navy-2:#292a29;
  --navy-3:#56585e;
  --sky:#f4f4f5;
  --white:#ffffff;
  --line:#e4e4e6;
  --ink:#1d1e20;
  --grey:#56585e;
  --orange:#f16725;
  --orange-d:#d4541a;
  --gold:#f7b32b;
  --font-d:"Archivo",sans-serif;
  --font-x:"Archivo Expanded",sans-serif;
  --font-b:"IBM Plex Sans",sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-b);color:var(--ink);background:var(--white);line-height:1.6;font-size:16px}
img{max-width:100%;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}
h1,h2,h3{font-family:var(--font-d);line-height:1.08;letter-spacing:-.015em}

/* top strip */
.strip{background:var(--orange);color:#fff;font-size:13.5px;font-weight:600;text-align:center;padding:8px 16px}
.strip a{color:#fff}

/* header */
header.site{background:var(--navy);color:#fff;position:sticky;top:0;z-index:60;box-shadow:0 4px 18px rgba(12,12,14,.25)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;min-height:78px;gap:24px}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff}
.logo .logo-img{height:58px;width:auto;display:block}
nav.main{display:flex;gap:24px;font-size:14.5px;font-weight:600}
nav.main a{color:#dfe0e3;text-decoration:none}
nav.main a:hover,nav.main a.on{color:#fff}
.head-phone{display:flex;align-items:center;gap:14px}
.head-phone .num{text-align:right;line-height:1.2}
.head-phone .num small{display:block;font-size:11px;color:#a6a8ad;text-transform:uppercase;letter-spacing:.06em}
.head-phone .num a{color:#fff;font-family:var(--font-x);font-size:19px;text-decoration:none}
.btn{display:inline-block;background:var(--orange);color:#fff;font-weight:700;font-family:var(--font-d);text-decoration:none;padding:13px 24px;border-radius:7px;font-size:15px;border:none;cursor:pointer}
.btn:hover{background:var(--orange-d)}

/* homepage hero */
.hero{background:linear-gradient(rgba(20,21,23,.82),rgba(20,21,23,.9)),url("/assets/img/site/whatsapp-image-2024-09-20-at-13.31.56_5bab0f14-mnlJnOR7w0TNw1lw.jpg") center/cover;color:#fff}
.hero .wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:64px;padding:76px 24px 84px;align-items:center}
.hero h1{font-family:var(--font-x);font-size:clamp(36px,4.4vw,56px);font-weight:800;margin-bottom:18px}
.hero h1 span{color:var(--orange)}
.hero .sub{font-size:17.5px;color:#cdcfd3;max-width:50ch;margin-bottom:28px}
.hero ul.points{list-style:none;display:grid;gap:11px;margin-bottom:34px;font-size:15.5px;font-weight:500}
.hero ul.points li{display:flex;gap:11px;align-items:flex-start}
.hero ul.points svg{flex:none;width:21px;height:21px;color:var(--orange);margin-top:2px}
.hero .or-call{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.hero .or-call .big{font-family:var(--font-x);font-size:26px;color:#fff;text-decoration:none}
.hero .or-call small{color:#a6a8ad}

/* service/location hero (page sets its own background image inline) */
.svc-hero{color:#fff;padding:54px 0 64px}
.crumbs{font-size:13px;color:#a6a8ad;margin-bottom:22px}
.crumbs a{color:#cdcfd3;text-decoration:none}
.crumbs span{margin:0 7px;opacity:.5}
.svc-hero .grid{display:grid;grid-template-columns:1.15fr .85fr;gap:64px;align-items:start}
.svc-hero h1{font-family:var(--font-x);font-size:clamp(32px,4vw,50px);font-weight:800;margin-bottom:16px}
.svc-hero h1 span{color:var(--orange)}
.svc-hero .sub{font-size:17px;color:#cdcfd3;max-width:52ch;margin-bottom:26px}
.svc-hero ul.points{list-style:none;display:grid;gap:11px;margin-bottom:30px;font-size:15.5px;font-weight:500}
.svc-hero ul.points li{display:flex;gap:11px;align-items:flex-start}
.svc-hero ul.points svg{flex:none;width:21px;height:21px;color:var(--orange);margin-top:2px}
.svc-hero .or-call .big{font-family:var(--font-x);font-size:26px;color:#fff;text-decoration:none}
.svc-hero .or-call small{display:block;color:#a6a8ad;margin-top:4px}

/* rating pill */
.ratingline{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:99px;padding:7px 16px;font-size:13.5px;font-weight:600;margin-bottom:20px}
.ratingline .star{color:var(--gold);letter-spacing:1px}

/* quote form card */
.quote-card{background:var(--white);color:var(--ink);border-radius:14px;padding:28px 28px 24px;box-shadow:0 30px 70px -20px rgba(10,10,12,.55)}
.quote-card h2{font-size:21px;margin-bottom:4px}
.quote-card .sub{font-size:13.5px;color:var(--grey);margin-bottom:20px}
.quote-card .sub2{font-size:13.5px;color:var(--grey);margin-bottom:16px}
.quote-card label{display:block;font-size:12.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--grey);margin:13px 0 5px}
.quote-card input,.quote-card select{width:100%;border:1.5px solid var(--line);border-radius:7px;padding:11px 13px;font-size:15px;font-family:var(--font-b);background:var(--sky)}
.quote-card input:focus,.quote-card select:focus{outline:2px solid var(--orange);outline-offset:0;border-color:var(--orange)}
.quote-card .btn{width:100%;margin-top:18px;padding:14px;font-size:15.5px}
.quote-card .privacy{font-size:12px;color:var(--grey);text-align:center;margin-top:12px}
.quote-card .resp{display:flex;align-items:center;gap:8px;justify-content:center;margin-top:13px;font-size:13px;font-weight:600;color:var(--navy)}
.quote-card .resp .dot{width:8px;height:8px;border-radius:50%;background:#2ea35a;animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

/* badges row */
.badges{background:var(--white);border-bottom:1px solid var(--line)}
.badges .wrap{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:18px 24px;flex-wrap:wrap}
.bdg{display:flex;align-items:center;gap:11px;font-size:13.5px;line-height:1.25}
.bdg .sq{width:40px;height:40px;border-radius:9px;display:grid;place-items:center;font-family:var(--font-x);font-weight:800;color:#fff;font-size:13px;flex:none}
.bdg .sq.brand{background:#fff;border:1px solid var(--line)}
.bdg .sq.brand svg{width:24px;height:24px}
.bdg .brand-logo{height:26px;width:auto;flex:none}
.bdg .brand-logo.round{height:40px;width:40px}
.bdg .sq.i{background:var(--navy-3)}
.bdg b{display:block;font-size:14px}
.bdg span{color:var(--grey)}

/* numbers band */
.numbers{background:var(--sky);padding:70px 0}
.numbers .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;text-align:center}
.numb{background:#fff;border:1px solid var(--line);border-radius:12px;padding:30px 18px}
.numb b{font-family:var(--font-x);font-size:42px;color:var(--navy);display:block;line-height:1}
.numb b em{color:var(--orange);font-style:normal}
.numb span{font-size:14px;color:var(--grey);font-weight:500;display:block;margin-top:8px}

/* sections */
section{padding:80px 0}
.sec-head{max-width:720px;margin-bottom:42px}
.sec-head .eyebrow{font-family:var(--font-d);font-weight:700;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--orange);display:block;margin-bottom:10px}
.sec-head h2{font-size:clamp(26px,3vw,38px);font-weight:800;margin-bottom:12px}
.sec-head p{color:var(--grey);font-size:16px}
.sec-head.center{margin:0 auto 42px;text-align:center}

/* full-bleed photo service tiles */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.svc{position:relative;border-radius:12px;overflow:hidden;text-decoration:none;color:#fff;min-height:280px;display:flex;align-items:flex-end}
.svc img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .25s}
.svc:hover img{transform:scale(1.05)}
.svc::after{content:"";position:absolute;inset:0;background:linear-gradient(185deg,rgba(20,21,23,.05) 35%,rgba(20,21,23,.92))}
.svc .body{position:relative;z-index:2;padding:20px}
.svc h3{font-size:18.5px;margin-bottom:5px}
.svc p{font-size:13px;color:#cdcfd3;line-height:1.45}
.svc .go{display:inline-block;margin-top:10px;font-size:13px;font-weight:700;color:var(--orange)}

/* Diagnostic cards (12 Jun 2026): symptom-led replacement for unlinked .fix
   tiles. Two columns of cards, each opened by a soft vector illustration
   that loosely visualises the fault; the explanation carries the weight, so
   cards read as answers rather than navigation. */
.diag{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:24px}
.diag-row{background:#fff;border:1px solid var(--line);border-radius:12px;padding:24px 24px 22px}
.diag-row .ill{display:flex;justify-content:center;margin-bottom:10px}
.diag-row .ill svg{width:170px;height:112px}
.diag-row h3{font-size:17px;margin-bottom:8px}
.diag-row p{font-size:14px;line-height:1.55;color:var(--grey);margin:0 0 7px}
.diag-row p b{color:var(--ink);font-weight:600}
.diag-row .band{display:inline-block;margin-top:5px;font-size:13px;line-height:1.5;background:var(--sky);border:1px solid var(--line);border-radius:14px;padding:6px 14px;color:var(--ink)}
.diag-row .band a{color:var(--ink);font-weight:600;text-decoration:underline;text-underline-offset:2px}
@media(max-width:640px){
  .diag{grid-template-columns:1fr;gap:14px}
}

/* photo fixes grid (service pages); a.fix = linked tile variant */
.fix-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.fix{position:relative;border-radius:12px;overflow:hidden;color:#fff;min-height:240px;display:flex;align-items:flex-end}
a.fix{text-decoration:none}
.fix img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.fix::after{content:"";position:absolute;inset:0;background:linear-gradient(185deg,rgba(20,21,23,.04) 35%,rgba(20,21,23,.92))}
.fix .body{position:relative;z-index:2;padding:18px}
.fix h3{font-size:17.5px;margin-bottom:4px}
.fix p{font-size:13px;color:#cdcfd3;line-height:1.45}

/* dark process steps */
.process{background:var(--navy);color:#fff}
.process .sec-head h2{color:#fff}
.process .sec-head p{color:#a6a8ad}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:step}
.step{background:var(--navy-2);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:24px 20px}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--font-x);font-size:30px;font-weight:800;color:var(--orange);display:block;margin-bottom:12px}
.step h3{font-size:16.5px;margin-bottom:7px}
.step p{font-size:13.5px;color:#b9bbc0}

/* guarantee split (homepage) */
.guarantee .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:stretch}
.guarantee img{border-radius:12px;height:100%;min-height:420px;width:100%;object-fit:cover}

/* cost split (service pages) */
.cost{background:var(--sky)}
.cost .wrap{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.cost img{border-radius:12px;height:380px;width:100%;object-fit:cover}
.sec-head .from-price,.from-price{font-family:var(--font-x);font-weight:800;font-size:clamp(26px,3vw,32px);color:var(--orange);line-height:1;margin:10px 0 2px}
.sec-head .from-price small,.from-price small{font-family:var(--font-b);font-weight:400;font-size:14px;color:var(--grey)}

/* guarantees g-list */
.g-list{display:grid;gap:14px;margin-top:24px}
.g-item{display:flex;gap:15px;background:#fff;border:1px solid var(--line);border-radius:11px;padding:16px 18px}
.g-item .n{flex:none;width:42px;height:42px;border-radius:9px;background:var(--navy);color:var(--orange);font-family:var(--font-x);font-weight:800;display:grid;place-items:center;font-size:14px}
.g-item b{display:block;font-size:15px}
.g-item span{font-size:13.5px;color:var(--grey)}

/* reviews */
.reviews{background:var(--sky)}
.rev-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;max-width:900px;margin:0 auto}
.rev{background:#fff;border:1px solid var(--line);border-radius:12px;padding:24px;display:flex;flex-direction:column}
.rev .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.rev .star{color:var(--gold);letter-spacing:2px;font-size:14px}
.rev .src{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--grey)}
.rev p{font-size:14.5px;flex:1}
.rev .who{margin-top:14px;font-weight:700;font-size:14px}
.rev .who small{display:block;font-weight:400;color:var(--grey)}

/* areas + faq split (homepage) */
.areas-faq .wrap{display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:start}
.area-links{display:flex;flex-wrap:wrap;gap:9px;margin-top:20px}
.area-links a{text-decoration:none;color:var(--navy);background:var(--sky);border:1px solid var(--line);border-radius:7px;padding:8px 15px;font-size:13.5px;font-weight:600}
.area-links a:hover{border-color:var(--orange);color:var(--orange-d)}

/* FAQ accordion */
.faq-wrap{max-width:780px;margin:0 auto}
details{border:1px solid var(--line);border-radius:10px;margin-bottom:10px;background:#fff}
details summary{cursor:pointer;list-style:none;font-family:var(--font-d);font-weight:700;font-size:15.5px;padding:17px 48px 17px 20px;position:relative}
details summary::-webkit-details-marker{display:none}
details summary::after{content:"+";position:absolute;right:18px;top:50%;transform:translateY(-50%);font-size:20px;color:var(--orange)}
details[open] summary::after{content:"\2212"}
details .a{padding:0 20px 18px;color:var(--grey);font-size:14.5px}

/* related services */
.rel-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.rel{background:var(--sky);border:1px solid var(--line);border-radius:11px;padding:20px;text-decoration:none;color:var(--ink)}
.rel:hover{border-color:var(--orange)}
.rel h3{font-size:16px;margin-bottom:6px}
.rel p{font-size:13px;color:var(--grey)}
.rel .go{display:block;margin-top:10px;font-size:13px;font-weight:700;color:var(--orange-d)}

/* dark photo CTA band */
.cta{background:linear-gradient(rgba(20,21,23,.88),rgba(20,21,23,.88)),url("/assets/img/site/chimneyrepairhero-Bj0UvpbnnKulZQ2m.webp") center/cover;color:#fff;text-align:center;padding:84px 0}
.cta h2{font-family:var(--font-x);font-size:clamp(28px,3.4vw,42px);margin-bottom:14px}
.cta p{color:#cdcfd3;max-width:54ch;margin:0 auto 28px}
.cta .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta .btn.alt{background:#fff;color:var(--navy)}

/* footer */
footer{background:#161719;color:#a6a8ad;font-size:14px;padding:56px 0 0}
footer .cols{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px}
footer h4{font-family:var(--font-d);color:#fff;font-size:14px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:15px}
footer ul{list-style:none;display:grid;gap:9px}
footer a{color:#a6a8ad;text-decoration:none}
footer a:hover{color:#fff}
footer .legal{border-top:1px solid rgba(255,255,255,.1);padding:18px 0;display:flex;justify-content:space-between;font-size:12.5px;opacity:.75;flex-wrap:wrap;gap:10px}

/* sticky mobile call bar */
.callbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:90;background:var(--navy);padding:10px 12px;gap:10px;box-shadow:0 -8px 24px rgba(0,0,0,.3)}
.callbar a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;font-weight:700;font-size:15px;padding:13px 6px;border-radius:8px;font-family:var(--font-d)}
.callbar a svg{width:18px;height:18px;flex:none}
.callbar .call{background:var(--orange);color:#fff}
.callbar .wa{background:#25D366;color:#fff}

/* hamburger + mobile nav */
.menu-btn{display:none;width:44px;height:44px;border:1.5px solid rgba(255,255,255,.4);border-radius:8px;background:none;cursor:pointer;flex:none;flex-direction:column;align-items:center;justify-content:center}
.menu-btn span{display:block;width:18px;height:2px;background:#fff;margin:2.5px 0;border-radius:2px}
.mobile-nav{display:none;background:var(--navy-2);border-top:1px solid rgba(255,255,255,.1)}
.mobile-nav.open{display:block}
.mobile-nav a{display:block;padding:15px 24px;text-decoration:none;color:#dfe0e3;font-family:var(--font-d);font-weight:700;font-size:16px;border-bottom:1px solid rgba(255,255,255,.08)}
.mobile-nav a:last-child{color:var(--gold)}

/* responsive */
@media(max-width:1020px){
  .hero .wrap{grid-template-columns:1fr;gap:44px}
  .svc-hero .grid{grid-template-columns:1fr;gap:40px}
  .svc-grid,.steps,.numbers .wrap,.fix-grid,.rel-grid{grid-template-columns:repeat(2,1fr)}
  .rev-grid{grid-template-columns:1fr}
  .guarantee .wrap,.areas-faq .wrap{grid-template-columns:1fr;gap:40px}
  .guarantee img{height:420px;min-height:0}
  .cost .wrap{grid-template-columns:1fr;gap:36px}
  nav.main{display:none}
  .menu-btn{display:flex}
}
/* trust bar: below ~905px the four badges no longer fit one row and
   flex-wrap turns ragged, so switch to an even 2x2 grid for the whole
   tablet and phone range */
@media(max-width:905px){
  .badges .wrap{display:grid;grid-template-columns:1fr 1fr;gap:16px 14px}
}
@media(max-width:640px){
  .svc-grid,.steps,.numbers .wrap,.fix-grid,.rel-grid{grid-template-columns:1fr}
  .head-phone .num{display:none}
  section{padding:58px 0}
  /* trust bar, phones: logo above text and capped logo heights so all
     four badges carry the same visual weight */
  .badges .wrap{gap:18px 14px;padding:16px 24px}
  .bdg{flex-direction:column;align-items:flex-start;gap:9px}
  .bdg .sq{width:36px;height:36px}
  .bdg .brand-logo{height:20px}
  .bdg .brand-logo.round{height:36px;width:36px}
  .callbar{display:flex}
  body{padding-bottom:66px}
  .guarantee img{height:300px}
  .cost img{height:280px}
}
@media(max-width:860px){footer .cols{grid-template-columns:1fr 1fr}}
@media(max-width:560px){footer .cols{grid-template-columns:1fr;gap:28px}}

/* Comparison and pricing tables (added 12 Jun 2026, cost-led SEO pages) */
.tbl-scroll{overflow-x:auto;margin-top:26px;-webkit-overflow-scrolling:touch}
.cmp{width:100%;min-width:560px;border-collapse:separate;border-spacing:0;background:#fff;border:1px solid var(--line);border-radius:11px;overflow:hidden;font-size:14.5px}
.cmp th{font-family:var(--font-d);font-weight:700;text-align:left;background:var(--navy);color:#fff;padding:13px 16px;font-size:13.5px;letter-spacing:.02em}
.cmp td{padding:13px 16px;border-top:1px solid var(--line);vertical-align:top}
.cmp td:first-child{font-weight:600;font-family:var(--font-d)}
.cmp tbody tr:nth-child(even) td{background:var(--sky)}
.tbl-note{font-size:13px;color:var(--grey);margin-top:12px;max-width:72ch}
