/* ============================================================
   Blue Raider Roofing LLC — shared stylesheet (styles.css)
   ============================================================ */
:root{
  --navy:#16233f; --navy-deep:#0f1a30; --navy-soft:#243758;
  --copper:#c98a4b; --copper-bright:#dba163;
  --cream:#f7f2e9; --cream-deep:#efe7d7; --paper:#fffdf8;
  --ink:#1c2433; --ink-soft:#4a5468; --line:#e3d9c6;
  --shadow:0 20px 50px -25px rgba(16,26,48,.45);
  --shadow-sm:0 6px 22px -12px rgba(16,26,48,.35);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{font-family:'Mulish',-apple-system,sans-serif;color:var(--ink);background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;line-height:1.12;font-weight:600;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.skip{position:absolute;left:-999px;top:0;background:var(--navy);color:#fff;padding:12px 18px;z-index:999;border-radius:0 0 8px 0}
.skip:focus{left:0}

.topbar{background:var(--navy-deep);color:#cdd6e6;font-size:.82rem;font-weight:600}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:18px;height:38px;flex-wrap:wrap}
.topbar a{color:#e7ecf5;transition:color .2s}
.topbar a:hover{color:var(--copper-bright)}
.topbar .tb-left{display:flex;gap:22px;align-items:center}
.topbar .tb-left span{display:inline-flex;align-items:center;gap:7px}
.topbar svg{width:14px;height:14px;stroke:var(--copper-bright)}

header.nav{position:sticky;top:0;z-index:100;background:rgba(247,242,233,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:72px;gap:20px}
.brand{display:flex;align-items:center;gap:12px}
.brand .mark{width:42px;height:42px;background:var(--navy);border-radius:9px;display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.brand .mark svg{width:26px;height:26px}
.brand .bt{font-family:'Fraunces',serif;font-weight:700;font-size:1.18rem;color:var(--navy);line-height:1.05}
.brand .bt small{display:block;font-family:'Mulish',sans-serif;font-weight:700;font-size:.6rem;letter-spacing:.18em;color:var(--copper);text-transform:uppercase}
.navlinks{display:flex;gap:28px;align-items:center;font-weight:700;font-size:.92rem}
.navlinks a{position:relative;color:var(--navy);padding:6px 0;transition:color .2s}
.navlinks a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--copper);transition:width .25s}
.navlinks a:hover,.navlinks a.active{color:var(--copper)}
.navlinks a:hover::after,.navlinks a.active::after{width:100%}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:.95rem;padding:13px 24px;border-radius:9px;transition:transform .18s,box-shadow .25s,background .25s;cursor:pointer;border:none;font-family:'Mulish',sans-serif}
.btn-primary{background:var(--copper);color:#fff;box-shadow:0 10px 24px -10px rgba(201,138,75,.7)}
.btn-primary:hover{background:var(--copper-bright);transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(201,138,75,.8)}
.btn-ghost{background:transparent;color:var(--navy);border:1.5px solid var(--navy)}
.btn-ghost:hover{background:var(--navy);color:#fff}
.btn-light{background:#fff;color:var(--navy)}
.btn-light:hover{background:var(--cream-deep);transform:translateY(-2px)}
.nav-cta{display:flex;gap:12px;align-items:center}
.menu-btn{display:none;background:none;border:none;cursor:pointer;padding:8px}
.menu-btn svg{width:28px;height:28px;stroke:var(--navy)}

.hero{position:relative;background:radial-gradient(120% 80% at 80% -10%, rgba(201,138,75,.14), transparent 55%),linear-gradient(160deg,var(--navy) 0%,var(--navy-deep) 100%);color:#fff;overflow:hidden}
.hero::before,.page-hero::before,.process::before{content:"";position:absolute;inset:0;opacity:.5;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='30' viewBox='0 0 60 30'%3E%3Cpath d='M0 30 L30 4 L60 30' fill='none' stroke='%23ffffff' stroke-opacity='0.04' stroke-width='1.5'/%3E%3C/svg%3E");background-size:60px 30px}
.process::before{opacity:.4}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;padding:74px 24px 86px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;background:rgba(201,138,75,.16);border:1px solid rgba(219,161,99,.4);color:var(--copper-bright);font-weight:800;font-size:.74rem;letter-spacing:.13em;text-transform:uppercase;padding:8px 15px;border-radius:50px;margin-bottom:22px}
.eyebrow svg{width:14px;height:14px;stroke:var(--copper-bright)}
.hero h1{font-size:clamp(2.5rem,5.2vw,4rem);color:#fff;margin-bottom:20px}
.hero h1 em{font-style:italic;color:var(--copper-bright)}
.hero p.lead{font-size:1.18rem;color:#cdd6e6;max-width:540px;margin-bottom:30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.hero-trust{display:flex;gap:26px;flex-wrap:wrap;font-size:.86rem;color:#aebbd2;font-weight:600}
.hero-trust span{display:inline-flex;align-items:center;gap:8px}
.hero-trust svg{width:18px;height:18px;stroke:var(--copper-bright)}
.stars{color:var(--copper-bright);letter-spacing:2px}

.page-hero{position:relative;background:radial-gradient(120% 90% at 85% -20%, rgba(201,138,75,.16), transparent 55%),linear-gradient(160deg,var(--navy) 0%,var(--navy-deep) 100%);color:#fff;overflow:hidden}
.page-hero .wrap{position:relative;padding:54px 24px 64px;max-width:840px}
.page-hero h1{font-size:clamp(2.1rem,4.4vw,3.3rem);color:#fff;margin-bottom:16px}
.page-hero h1 em{font-style:italic;color:var(--copper-bright)}
.page-hero p{font-size:1.15rem;color:#cdd6e6;max-width:620px;margin-bottom:26px}
.page-hero .hero-cta{margin-bottom:0}

.crumbs{background:var(--cream-deep);font-size:.82rem;font-weight:600}
.crumbs .wrap{padding:12px 24px;color:var(--ink-soft)}
.crumbs a{color:var(--navy)}.crumbs a:hover{color:var(--copper)}
.crumbs span{margin:0 8px;color:var(--copper)}

.quote-card{background:var(--paper);color:var(--ink);border-radius:18px;padding:30px;box-shadow:var(--shadow);border:1px solid var(--line)}
.quote-card h3{font-size:1.45rem;color:var(--navy);margin-bottom:6px}
.quote-card .sub{font-size:.9rem;color:var(--ink-soft);margin-bottom:20px}
.field{margin-bottom:14px}
.field label{display:block;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:9px;font-family:inherit;font-size:.95rem;background:#fff;transition:border-color .2s,box-shadow .2s}
.field textarea{resize:vertical;min-height:120px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--copper);box-shadow:0 0 0 3px rgba(201,138,75,.16)}
.quote-card .btn{width:100%;justify-content:center;margin-top:4px}
.quote-card .fineprint{font-size:.74rem;color:var(--ink-soft);text-align:center;margin-top:12px}

.trust-strip{background:var(--navy-deep);color:#fff}
.trust-strip .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:34px 24px}
.tstat{text-align:center;border-right:1px solid rgba(255,255,255,.1)}
.tstat:last-child{border:none}
.tstat .n{font-family:'Fraunces',serif;font-size:2.3rem;font-weight:700;color:var(--copper-bright);line-height:1}
.tstat .l{font-size:.82rem;color:#aebbd2;font-weight:600;margin-top:6px}

section{padding:86px 0}
.sec-head{max-width:680px;margin-bottom:50px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.kicker{display:inline-block;font-weight:800;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--copper);margin-bottom:14px}
.sec-head h2{font-size:clamp(2rem,3.6vw,2.85rem);color:var(--navy);margin-bottom:16px}
.sec-head p{font-size:1.08rem;color:var(--ink-soft)}

.content-grid{display:grid;grid-template-columns:1.5fr .9fr;gap:48px;align-items:start}
.prose{max-width:760px}
.prose h2{font-size:clamp(1.7rem,3vw,2.3rem);color:var(--navy);margin:42px 0 14px}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:1.3rem;color:var(--navy);margin:28px 0 10px}
.prose p{font-size:1.05rem;color:var(--ink-soft);margin-bottom:16px}
.prose ul{list-style:none;margin:0 0 20px;display:grid;gap:11px}
.prose ul li{position:relative;padding-left:30px;color:var(--ink-soft);font-size:1.03rem}
.prose ul li::before{content:"";position:absolute;left:0;top:7px;width:16px;height:16px;background:var(--copper);-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='3'%3E%3Cpath d='m5 13 4 4L19 7'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='3'%3E%3Cpath d='m5 13 4 4L19 7'/%3E%3C/svg%3E") center/contain no-repeat}
.prose strong{color:var(--ink)}
.sidebar-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:26px;box-shadow:var(--shadow-sm);position:sticky;top:96px}
.sidebar-card h3{font-size:1.25rem;color:var(--navy);margin-bottom:6px}
.sidebar-card p{font-size:.92rem;color:var(--ink-soft);margin-bottom:16px}
.sidebar-card .npill{display:flex;align-items:center;gap:9px;font-weight:700;color:var(--navy);font-size:1.05rem;margin-bottom:10px}
.sidebar-card .npill svg{width:18px;height:18px;stroke:var(--copper);flex:none}
.sidebar-card .btn{width:100%;justify-content:center}

.services{background:var(--paper)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc{background:var(--cream);border:1px solid var(--line);border-radius:16px;padding:30px;transition:transform .25s,box-shadow .25s,border-color .25s}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--copper)}
.svc .ic{width:56px;height:56px;border-radius:13px;background:var(--navy);display:grid;place-items:center;margin-bottom:18px}
.svc .ic svg{width:30px;height:30px;stroke:var(--copper-bright);fill:none}
.svc h3{font-size:1.3rem;color:var(--navy);margin-bottom:10px}
.svc p{font-size:.96rem;color:var(--ink-soft);margin-bottom:14px}
.svc a.more{font-weight:800;font-size:.88rem;color:var(--copper);display:inline-flex;align-items:center;gap:6px}
.svc a.more svg{width:15px;height:15px;stroke:var(--copper);transition:transform .2s}
.svc:hover a.more svg{transform:translateX(4px)}

.why{background:var(--cream)}
.why .wrap{display:grid;grid-template-columns:.95fr 1.05fr;gap:54px;align-items:center}
.why-visual{position:relative}
.why-visual .panel{background:linear-gradient(155deg,var(--navy),var(--navy-deep));border-radius:20px;padding:42px;color:#fff;box-shadow:var(--shadow)}
.why-visual .panel .roofsvg{width:100%;height:auto;margin-bottom:22px}
.why-visual .badge{position:absolute;bottom:-22px;right:-14px;background:var(--copper);color:#fff;border-radius:14px;padding:18px 22px;box-shadow:var(--shadow-sm);text-align:center}
.why-visual .badge .b1{font-family:'Fraunces',serif;font-size:1.9rem;font-weight:700;line-height:1}
.why-visual .badge .b2{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-top:3px}
.why-list{list-style:none;margin-top:26px;display:grid;gap:18px}
.why-list li{display:flex;gap:15px;align-items:flex-start}
.why-list .chk{flex:none;width:30px;height:30px;border-radius:8px;background:rgba(201,138,75,.14);display:grid;place-items:center;margin-top:2px}
.why-list .chk svg{width:17px;height:17px;stroke:var(--copper)}
.why-list h4{font-size:1.08rem;color:var(--navy);font-family:'Mulish';font-weight:800;margin-bottom:3px}
.why-list p{font-size:.93rem;color:var(--ink-soft)}

.process{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.process .wrap{position:relative}
.process .sec-head h2{color:#fff}.process .sec-head p{color:#cdd6e6}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step}
.step{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:15px;padding:28px 24px}
.step .num{counter-increment:step;font-family:'Fraunces',serif;font-size:2.6rem;font-weight:700;color:var(--copper-bright);line-height:1;margin-bottom:12px}
.step .num::before{content:"0" counter(step)}
.step h4{color:#fff;font-family:'Mulish';font-weight:800;font-size:1.08rem;margin-bottom:8px}
.step p{color:#aebbd2;font-size:.9rem}

.areas{background:var(--paper)}
.areas .wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.area-tags{display:flex;flex-wrap:wrap;gap:11px;margin-top:8px}
.area-tags a,.area-tags span{background:var(--cream);border:1px solid var(--line);border-radius:50px;padding:9px 17px;font-weight:700;font-size:.86rem;color:var(--navy);transition:.2s}
.area-tags a:hover,.area-tags span:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.map-card{background:var(--cream);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow-sm)}
.map-card .mapviz{aspect-ratio:4/3;background:radial-gradient(60% 60% at 50% 45%, rgba(201,138,75,.22), transparent 70%),linear-gradient(160deg,#e7ecf5,#d6dded);position:relative;display:grid;place-items:center}
.map-card .pin{width:30px;height:30px;background:var(--copper);border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:var(--shadow-sm);position:relative}
.map-card .pin::after{content:"";position:absolute;width:12px;height:12px;background:#fff;border-radius:50%;top:9px;left:9px}
.map-card .mc-foot{padding:18px 22px;font-size:.88rem;color:var(--ink-soft);font-weight:600;display:flex;align-items:center;gap:9px}
.map-card .mc-foot svg{width:17px;height:17px;stroke:var(--copper)}

.reviews{background:var(--cream)}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.rev{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:28px;box-shadow:var(--shadow-sm)}
.rev .stars{font-size:1.05rem;margin-bottom:13px;display:block}
.rev p{font-size:.98rem;color:var(--ink);font-style:italic;margin-bottom:18px}
.rev .who{display:flex;align-items:center;gap:12px}
.rev .av{width:42px;height:42px;border-radius:50%;background:var(--navy);color:var(--copper-bright);display:grid;place-items:center;font-family:'Fraunces',serif;font-weight:700}
.rev .who b{display:block;color:var(--navy);font-size:.95rem}
.rev .who small{color:var(--ink-soft);font-size:.8rem}

.faq{background:var(--paper)}
.faq-wrap{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:24px 0;display:flex;justify-content:space-between;align-items:center;gap:20px;font-family:'Fraunces',serif;font-size:1.18rem;font-weight:600;color:var(--navy)}
.faq-q .pm{flex:none;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--copper);display:grid;place-items:center;transition:.25s;position:relative}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--copper);transition:.25s}
.faq-q .pm::before{width:13px;height:2px}
.faq-q .pm::after{width:2px;height:13px}
.faq-item.open .pm{background:var(--copper)}
.faq-item.open .pm::before,.faq-item.open .pm::after{background:#fff}
.faq-item.open .pm::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-a p{padding:0 0 24px;color:var(--ink-soft);font-size:1rem;max-width:680px}

.cta-band{background:linear-gradient(155deg,var(--copper),#b6743a);color:#fff;text-align:center}
.cta-band h2{font-size:clamp(2rem,4vw,3rem);color:#fff;margin-bottom:14px}
.cta-band p{font-size:1.15rem;color:#fff6ec;max-width:560px;margin:0 auto 28px}
.cta-band .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-info .ci-item{display:flex;gap:16px;align-items:flex-start;margin-bottom:26px}
.contact-info .ci-ic{flex:none;width:48px;height:48px;border-radius:11px;background:var(--navy);display:grid;place-items:center}
.contact-info .ci-ic svg{width:24px;height:24px;stroke:var(--copper-bright)}
.contact-info h3{font-size:1.1rem;color:var(--navy);margin-bottom:4px;font-family:'Mulish';font-weight:800}
.contact-info p,.contact-info a{color:var(--ink-soft);font-size:1rem}
.contact-info a{font-weight:700;color:var(--navy)}.contact-info a:hover{color:var(--copper)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-note{padding:14px 16px;border-radius:9px;font-size:.9rem;font-weight:600;margin-top:14px;display:none}
.form-note.ok{display:block;background:#e7f3ec;color:#256b43;border:1px solid #b7dcc4}
.form-note.err{display:block;background:#fdeceb;color:#a3352e;border:1px solid #f3c5c1}

footer.site{background:var(--navy-deep);color:#aebbd2;padding:64px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px;margin-bottom:46px}
footer.site h4{color:#fff;font-family:'Mulish';font-weight:800;font-size:.95rem;letter-spacing:.04em;margin-bottom:18px;text-transform:uppercase}
footer.site .brand .bt{color:#fff}
footer.site p{font-size:.92rem;margin-bottom:14px;line-height:1.7}
footer.site ul{list-style:none}
footer.site ul li{margin-bottom:11px}
footer.site ul a{font-size:.92rem;transition:color .2s}
footer.site ul a:hover{color:var(--copper-bright)}
.nap{font-size:.92rem;line-height:1.9}
.nap a{color:#e7ecf5;font-weight:700}.nap a:hover{color:var(--copper-bright)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.82rem}
.socials{display:flex;gap:14px}
.socials a{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.07);display:grid;place-items:center;transition:.2s}
.socials a:hover{background:var(--copper)}
.socials svg{width:17px;height:17px;fill:#cdd6e6}.socials a:hover svg{fill:#fff}

.callbar{display:none}

@media(max-width:960px){
  .hero .wrap{grid-template-columns:1fr;gap:40px;padding:54px 24px 64px}
  .why .wrap,.areas .wrap,.contact-grid,.content-grid{grid-template-columns:1fr;gap:40px}
  .sidebar-card{position:static}
  .svc-grid,.rev-grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .navlinks{display:none}
  .nav-cta .btn-ghost{display:none}
  .menu-btn{display:block}
  .navlinks.show{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;background:var(--paper);padding:20px 24px;gap:16px;box-shadow:var(--shadow);border-bottom:1px solid var(--line)}
  .trust-strip .wrap{grid-template-columns:1fr 1fr;gap:26px}
  .tstat:nth-child(2){border:none}
  .svc-grid,.rev-grid,.steps,.form-row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
  section{padding:60px 0}
  .topbar .tb-left span:last-child{display:none}
  .callbar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:200;gap:0}
  .callbar a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:15px;font-weight:800;font-size:.95rem}
  .callbar .c-call{background:var(--copper);color:#fff}
  .callbar .c-quote{background:var(--navy);color:#fff}
  .callbar svg{width:18px;height:18px}
  body{padding-bottom:54px}
}

/* Logo image inside brand mark */
.brand .mark img{width:100%;height:100%;object-fit:contain}
.brand .mark{overflow:hidden}

/* ---- Photo heroes ---- */
.page-hero.photo,.hero.photo{background-size:cover;background-position:center;background-repeat:no-repeat}
.page-hero.photo::before,.hero.photo::before{display:none}
.page-hero.photo::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,rgba(15,26,48,.93),rgba(15,26,48,.55));z-index:1}
.hero.photo::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,rgba(15,26,48,.95),rgba(15,26,48,.68));z-index:0}
.page-hero .wrap,.hero .wrap{z-index:2}
/* ---- Recent work gallery ---- */
.work{background:var(--cream)}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery figure{margin:0;position:relative;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm);aspect-ratio:3/2;background:var(--cream-deep)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gallery figure:hover img{transform:scale(1.06)}
.gallery figcaption{position:absolute;left:0;right:0;bottom:0;padding:24px 14px 11px;font-size:.78rem;font-weight:700;color:#fff;background:linear-gradient(transparent,rgba(15,26,48,.82));opacity:0;transition:opacity .3s}
.gallery figure:hover figcaption{opacity:1}
@media(max-width:680px){.gallery{grid-template-columns:1fr 1fr}}
/* ---- Before / during / after ---- */
.ba{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:14px 0 10px}
.ba figure{margin:0;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.ba img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.ba figcaption{background:var(--navy);color:#fff;font-weight:800;font-size:.8rem;text-align:center;padding:9px;letter-spacing:.03em}
@media(max-width:680px){.ba{grid-template-columns:1fr}}
.content-img{border-radius:14px;box-shadow:var(--shadow-sm);width:100%;max-width:520px;margin:10px auto 22px;display:block;aspect-ratio:4/3;object-fit:cover}

/* ---- Happy customers ---- */
.customers{background:var(--paper)}
.cust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cust{margin:0;position:relative;border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm);aspect-ratio:4/5;background:var(--cream-deep)}
.cust img{width:100%;height:100%;object-fit:cover}
.cust figcaption{position:absolute;left:0;right:0;bottom:0;padding:34px 16px 14px;color:#fff;font-weight:700;font-size:.9rem;line-height:1.4;background:linear-gradient(transparent,rgba(15,26,48,.9))}
.cust-note{text-align:center;margin-top:26px;font-size:1rem;color:var(--ink-soft)}
.cust-note strong{color:var(--navy)}
@media(max-width:680px){.cust-grid{grid-template-columns:1fr}.cust{aspect-ratio:4/3}}
/* ---- Infographic (natural aspect, not cropped) ---- */
.infographic{display:block;max-width:430px;width:100%;height:auto;margin:18px auto 24px;border-radius:12px;box-shadow:var(--shadow-sm)}

/* ---- Live Google rating badge (filled by /api/reviews) ---- */
.grev{display:inline-flex;align-items:center;gap:10px;margin:-8px auto 30px;padding:11px 20px;background:#fff;border:1px solid var(--line);border-radius:999px;box-shadow:var(--shadow-sm);text-decoration:none;font-weight:700;color:var(--navy);transition:transform .2s,box-shadow .2s}
.grev:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.grev-label{font-size:.9rem;color:var(--ink-soft);font-weight:700}
.grev-stars{position:relative;display:inline-block;font-size:1.15rem;line-height:1;color:#dfd3bb;letter-spacing:1px}
.grev-stars::before{content:"\2605\2605\2605\2605\2605"}
.grev-fill{position:absolute;top:0;left:0;width:0;overflow:hidden;white-space:nowrap;color:#e8a13a}
.grev-fill::before{content:"\2605\2605\2605\2605\2605"}
.grev-num{font-size:1.05rem;font-weight:800}
.grev-count{font-size:.88rem;color:var(--ink-soft);font-weight:700}

/* ---- Live rating bar (site-wide, flashes in at the very top) ---- */
.ratingbar{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin:0;
  padding:7px 16px;border:0;border-radius:0;box-shadow:none;
  background:linear-gradient(90deg,var(--copper),var(--copper-bright));
  color:var(--navy-deep);font-family:'Mulish',sans-serif;font-weight:800;font-size:.9rem;
  letter-spacing:.2px;text-decoration:none;position:relative;overflow:hidden;
  transform:translateY(-100%);opacity:0;transition:filter .2s}
.ratingbar:hover{transform:none;filter:brightness(1.05)}
.ratingbar.show{animation:rbIn .55s cubic-bezier(.2,.8,.25,1) forwards}
@keyframes rbIn{to{transform:translateY(0);opacity:1}}
.ratingbar .rb-stars{color:#5c3a14;letter-spacing:1px;font-size:1rem}
.ratingbar .grev-num{color:var(--navy-deep);font-size:1rem;font-weight:900}
.ratingbar .rb-mid{font-weight:700}
.ratingbar .grev-count{color:var(--navy-deep);font-weight:700;font-size:.86rem}
.ratingbar .rb-cta{font-weight:800;text-decoration:underline;text-underline-offset:2px}
.ratingbar.show::after{content:"";position:absolute;top:0;left:-60%;width:45%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);
  transform:skewX(-20deg);animation:rbShine 2.6s ease 1s 1}
@keyframes rbShine{to{left:130%}}
@media(max-width:680px){.ratingbar{font-size:.82rem;gap:6px}.ratingbar .rb-mid{display:none}}

/* read-all link under reviews + graceful fallback card */
.rev-readall{text-align:center;margin-top:26px}
.rev-readall a{color:var(--copper);font-weight:800;text-decoration:none;border-bottom:2px solid transparent;transition:border-color .2s}
.rev-readall a:hover{border-color:var(--copper)}
.rev-cta{grid-column:1/-1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.rev-cta p{font-style:normal}

/* ---- About page pull-quote ---- */
.pullquote{margin:28px 0;padding:22px 26px;border-left:4px solid var(--copper);
  background:var(--cream);border-radius:0 12px 12px 0;
  font-family:'Fraunces',serif;font-size:1.25rem;line-height:1.5;color:var(--navy);font-style:italic}
.pullquote cite{display:block;margin-top:12px;font-family:'Mulish',sans-serif;font-size:.9rem;
  font-style:normal;font-weight:700;color:var(--copper)}

/* ---- Roof cost calculator ---- */
.calc{display:grid;grid-template-columns:1fr 1fr;gap:28px;max-width:900px;margin:0 auto;
  background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:30px;box-shadow:var(--shadow-sm)}
.calc-form{display:flex;flex-direction:column;gap:16px}
.calc-form .field label small{color:var(--ink-soft);font-weight:600}
.calc-result{background:var(--navy);border-radius:14px;padding:26px;color:#fff;display:flex;flex-direction:column;gap:10px;text-align:center;justify-content:center}
.calc-result .calc-label{font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;color:var(--copper-bright);font-weight:800}
.calc-range{font-family:'Fraunces',serif;font-size:2.3rem;font-weight:700;color:#fff;line-height:1.1}
.calc-note{font-size:.85rem;color:#cdd6e6;margin:2px 0 8px}
.calc-result .btn{width:100%}
@media(max-width:680px){.calc{grid-template-columns:1fr;padding:20px}.calc-range{font-size:2rem}}

/* ---- Guides hub + Skool callout ---- */
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1000px;margin:0 auto}
.guide-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:26px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}
.guide-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.guide-card h3{font-family:'Fraunces',serif;font-size:1.2rem;line-height:1.25;margin-bottom:10px}
.guide-card h3 a{color:var(--navy);text-decoration:none}
.guide-card h3 a:hover{color:var(--copper)}
.guide-card p{color:var(--ink-soft);font-size:.95rem;margin-bottom:14px}
.guide-card .more{color:var(--copper);font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:6px;font-size:.9rem}
.guide-card .more svg{width:16px;height:16px;stroke:var(--copper)}
.skool-cta{margin:34px 0 0;padding:26px 28px;background:var(--navy);border-radius:16px;color:#fff}
.skool-cta.wide{max-width:1000px;margin:40px auto 0;text-align:center}
.skool-cta h3{font-family:'Fraunces',serif;color:#fff;font-size:1.4rem;margin-bottom:8px}
.skool-cta p{color:#cdd6e6;margin-bottom:16px}
.skool-cta .btn{display:inline-block}
@media(max-width:880px){.guide-grid{grid-template-columns:1fr}}

/* ---- Drone inspection band (homepage) ---- */
.drone{background:var(--cream)}
.drone-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center}
.drone-points{list-style:none;margin:0 0 24px;padding:0;display:flex;flex-direction:column;gap:12px}
.drone-points li{display:flex;align-items:flex-start;gap:10px;color:var(--ink);font-weight:600;font-size:1rem}
.drone-points svg{flex:0 0 auto;width:22px;height:22px;stroke:var(--copper);background:rgba(201,138,75,.12);border-radius:50%;padding:3px;margin-top:1px}
.drone-photo{margin:0;border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.drone-photo img{display:block;width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
@media(max-width:880px){.drone-grid{grid-template-columns:1fr;gap:26px}.drone-photo{order:-1}}
