/* ============================================================
   G Mason Property Care — modern roofing lander design system
   Charcoal + lime brand. Built on the roofing CRO playbook:
   risk-reversal offer, real photos, proof beside the CTA,
   breadcrumb form, sticky mobile call bar.
   ============================================================ */
:root{
  --ink:#161a1d;         /* near-black charcoal */
  --ink-2:#232a2f;
  --slate:#3a454c;
  --grey:#5b666d;
  --grey-2:#8a949b;
  --line:#e6eaec;
  --paper:#f6f8f9;
  --white:#ffffff;
  --lime:#a3d221;        /* brand accent */
  --lime-d:#8bb814;      /* hover */
  --lime-ink:#1c2400;    /* text on lime */
  --gold:#f5a623;        /* review stars */
  --maxw:1200px;
  --side:24px;
  --r:14px;
  --shadow:0 18px 48px rgba(22,26,29,.14);
  --shadow-sm:0 6px 18px rgba(22,26,29,.10);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--white);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Archivo',sans-serif;line-height:1.06;letter-spacing:-.02em;font-weight:800}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--side)}
.lime{color:var(--lime)}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:'Archivo';font-weight:800;font-size:16px;border:0;border-radius:999px;padding:15px 26px;cursor:pointer;transition:transform .12s ease,background .15s ease}
.btn:hover{transform:translateY(-1px)}
.btn-lime{background:var(--lime);color:var(--lime-ink);box-shadow:0 8px 20px rgba(163,210,33,.34)}
.btn-lime:hover{background:var(--lime-d)}
.btn-ghost{background:transparent;color:var(--white);border:2px solid rgba(255,255,255,.5)}
.btn-dark{background:var(--ink);color:#fff}

/* top strip */
.topbar{background:var(--ink);color:#cfd6da;font-size:13.5px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;padding-top:9px;padding-bottom:9px;flex-wrap:wrap;gap:6px}
.topbar b{color:var(--lime)}
.topbar .t-r{display:flex;gap:20px;align-items:center}

/* header */
.header{position:sticky;top:0;z-index:80;background:var(--white);border-bottom:1px solid var(--line)}
.header .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:14px;padding-bottom:14px;gap:16px}
.header .logo img{height:42px;width:auto}
.header-right{display:flex;align-items:center;gap:14px}
.header .phone{display:flex;align-items:center;gap:9px;font-family:'Archivo';font-weight:800;font-size:19px;color:var(--ink)}
.header .phone svg{color:var(--lime-d)}
/* nav + services dropdown */
.nav{display:flex;align-items:center;gap:28px}
.nav>a,.nav .has-drop>a{font-weight:600;font-size:15.5px;color:var(--slate);display:inline-flex;align-items:center;gap:5px;padding:6px 0;transition:color .12s}
.nav>a:hover,.nav .has-drop>a:hover{color:var(--ink)}
.nav .has-drop{position:relative}
.nav .drop{position:absolute;top:100%;left:-14px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-sm);padding:8px;min-width:230px;opacity:0;visibility:hidden;transform:translateY(6px);transition:.15s;z-index:90}
.nav .has-drop:hover .drop{opacity:1;visibility:visible;transform:translateY(0)}
.nav .drop a{display:block;padding:10px 14px;border-radius:8px;font-weight:600;font-size:15px;color:var(--slate)}
.nav .drop a:hover{background:var(--paper);color:var(--lime-d)}

/* hero */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(18,22,25,.95) 0%,rgba(18,22,25,.82) 42%,rgba(18,22,25,.45) 100%),var(--hero-img,url('hero-roof.jpg')) center/cover no-repeat;z-index:0}
.hero .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1fr 448px;gap:46px;align-items:center;padding-top:64px;padding-bottom:64px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(163,210,33,.16);border:1px solid rgba(163,210,33,.4);color:var(--lime);font-weight:700;font-size:13.5px;padding:6px 14px;border-radius:999px;margin-bottom:20px}
.hero h1{font-size:52px;margin-bottom:18px}
.hero h1 .u{color:var(--lime)}
.hero-sub{font-size:18px;color:#d5dbdf;max-width:520px;margin-bottom:26px}
.hero-checks{display:flex;flex-direction:column;gap:12px;margin-bottom:30px}
.hero-checks .c{display:flex;align-items:center;gap:12px;font-weight:600;font-size:16.5px}
.hero-checks .ic{flex:0 0 24px;height:24px;border-radius:50%;background:var(--lime);color:var(--lime-ink);display:flex;align-items:center;justify-content:center}
.hero-cta{display:flex;gap:14px;align-items:center;flex-wrap:wrap}

/* rating pill */
.rating{display:inline-flex;align-items:center;gap:10px;font-size:14.5px;color:#e7ebee}
.rating .g{width:22px;height:22px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-family:'Archivo';font-weight:800;color:var(--ink);font-size:13px}
.rating .stars{color:var(--gold);letter-spacing:1px}

/* form card */
.form-card{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;color:var(--ink)}
.form-card .fc-head{background:var(--lime);color:var(--lime-ink);padding:18px 24px;text-align:center}
.form-card .fc-head h3{font-size:22px}
.form-card .fc-head p{font-size:13.5px;font-weight:600;opacity:.8;margin-top:2px}
.form-card form{padding:20px 22px 22px}
.form-proof{display:flex;align-items:center;gap:8px;justify-content:center;font-size:13px;color:var(--grey);margin-bottom:14px}
.form-proof .stars{color:var(--gold)}
.field{width:100%;background:var(--paper);border:1.5px solid var(--line);border-radius:10px;font:inherit;font-size:15px;padding:13px 15px;margin-bottom:11px;color:var(--ink)}
.field:focus{outline:none;border-color:var(--lime-d);background:#fff}
select.field{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9'%3E%3Cpath d='M1 1l6 6 6-6' fill='none' stroke='%23161a1d' stroke-width='2'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center;padding-right:40px;cursor:pointer}
select.field:invalid{color:var(--grey-2)}
textarea.field{resize:none;height:82px}
.form-card .btn-lime{width:100%}
.form-note{text-align:center;font-size:12.5px;color:var(--grey-2);margin-top:11px}

/* trust bar */
.trust{background:var(--paper);border-bottom:1px solid var(--line)}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding-top:26px;padding-bottom:26px}
.trust .t{display:flex;flex-direction:column;align-items:center;text-align:center;gap:4px}
.trust .t .n{font-family:'Archivo';font-weight:800;font-size:26px;color:var(--ink)}
.trust .t .l{font-size:13.5px;color:var(--grey);font-weight:600}

/* generic section */
.sec{padding:72px 0}
.sec.alt{background:var(--paper)}
.sec-head{text-align:center;max-width:680px;margin:0 auto 44px}
.sec-head .kick{color:var(--lime-d);font-weight:800;font-size:14px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px}
.sec-head h2{font-size:38px;margin-bottom:12px}
.sec-head p{color:var(--grey);font-size:17px}

/* services grid */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;transition:box-shadow .15s,transform .12s;display:flex;flex-direction:column}
.svc:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.svc .ic{width:48px;height:48px;border-radius:12px;background:rgba(163,210,33,.16);color:var(--lime-d);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.svc h3{font-size:20px;margin-bottom:8px}
.svc p{color:var(--grey);font-size:15px;margin-bottom:16px;flex:1}
.svc .more{color:var(--lime-d);font-weight:700;font-size:15px}

/* offer band */
.offer{background:var(--ink);color:#fff}
.offer .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;padding-top:60px;padding-bottom:60px}
.offer h2{font-size:34px;margin-bottom:14px}
.offer h2 .u{color:var(--lime)}
.offer ul{list-style:none;display:flex;flex-direction:column;gap:12px;margin-top:20px}
.offer li{display:flex;gap:12px;align-items:flex-start;font-size:16px;color:#dfe4e7}
.offer li .ic{flex:0 0 22px;height:22px;border-radius:50%;background:var(--lime);color:var(--lime-ink);display:flex;align-items:center;justify-content:center;margin-top:2px}
.offer-card{background:var(--ink-2);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);padding:30px;text-align:center}
.offer-card .big{font-family:'Archivo';font-weight:800;font-size:40px;color:var(--lime);line-height:1}
.offer-card .lbl{font-size:15px;color:#cfd6da;margin:8px 0 20px}

/* reviews */
.rev-top{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:34px}
.gbadge{display:inline-flex;align-items:center;gap:10px}
.gbadge .g{width:28px;height:28px;border-radius:50%;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:'Archivo';font-weight:800;color:var(--ink)}
.gbadge .stars{color:var(--gold);letter-spacing:2px;font-size:17px}
.gbadge b{font-family:'Archivo';font-size:16px}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px}
.rcard .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.rcard .stars{color:var(--gold);letter-spacing:1px}
.rcard .g{width:22px;height:22px;border-radius:50%;background:var(--paper);display:flex;align-items:center;justify-content:center;font-family:'Archivo';font-weight:800;font-size:12px}
.rcard p{font-size:14.5px;color:var(--slate);margin-bottom:14px}
.rcard .who{font-weight:700;font-size:14px}
.rcard .who span{display:block;color:var(--grey-2);font-weight:500;font-size:12.5px}

/* gallery */
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gal img{border-radius:12px;height:210px;width:100%;object-fit:cover}

/* how / steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:s}
.step{text-align:center}
.step .n{width:52px;height:52px;margin:0 auto 14px;border-radius:50%;background:var(--lime);color:var(--lime-ink);font-family:'Archivo';font-weight:800;font-size:22px;display:flex;align-items:center;justify-content:center}
.step h4{font-size:18px;margin-bottom:6px}
.step p{color:var(--grey);font-size:14.5px}

/* split CTA + form (service pages) */
.leadsplit .wrap{display:grid;grid-template-columns:1fr 430px;gap:44px;align-items:start}
.leadsplit .body h2{font-size:32px;margin-bottom:14px}
.leadsplit .body p{color:var(--grey);font-size:16px;margin-bottom:14px}
.leadsplit .body .pt{display:flex;gap:11px;align-items:flex-start;margin-bottom:11px;font-weight:600}
.leadsplit .body .pt .ic{flex:0 0 22px;height:22px;border-radius:50%;background:rgba(163,210,33,.18);color:var(--lime-d);display:flex;align-items:center;justify-content:center;margin-top:2px}

/* FAQ */
.faq{max-width:820px;margin:0 auto}
.faq details{border:1px solid var(--line);border-radius:12px;padding:2px 20px;margin-bottom:12px;background:#fff}
.faq summary{list-style:none;cursor:pointer;font-family:'Archivo';font-weight:700;font-size:17px;padding:18px 0;display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--lime-d);font-size:24px;font-weight:700}
.faq details[open] summary::after{content:"–"}
.faq details p{color:var(--grey);padding:0 0 18px;font-size:15px}

/* final CTA */
.finalcta{background:var(--lime);color:var(--lime-ink);text-align:center;padding:60px 0}
.finalcta h2{font-size:38px;margin-bottom:12px}
.finalcta p{font-size:18px;margin-bottom:24px;font-weight:500}

/* footer */
.footer{background:var(--ink);color:#aeb7bd;padding:52px 0 30px;font-size:14.5px}
.footer .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
.footer h4{color:#fff;font-size:16px;margin-bottom:14px}
.footer a{display:block;color:#aeb7bd;margin-bottom:8px}
.footer a:hover{color:var(--lime)}
.footer .logo img{height:40px;margin-bottom:16px;filter:brightness(0) invert(1)}
.footer .fbot{border-top:1px solid rgba(255,255,255,.1);margin-top:36px;padding-top:20px;text-align:center;color:#7b858b;font-size:13px}

/* sticky mobile call bar */
.sticky-cta{display:none}

/* responsive */
@media (max-width:960px){
  .nav{display:none}
  .hero .wrap{grid-template-columns:1fr;gap:30px;padding-top:44px;padding-bottom:44px}
  .hero h1{font-size:40px}
  .offer .wrap,.leadsplit .wrap{grid-template-columns:1fr;gap:28px}
  .trust .wrap{grid-template-columns:repeat(2,1fr);gap:22px}
  .svc-grid,.rev-grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .gal{grid-template-columns:1fr 1fr}
  .footer .wrap{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  :root{--side:18px}
  .topbar{display:none}
  .header .phone span{display:none}
  .hero h1{font-size:33px}
  .sec{padding:52px 0}
  .sec-head h2{font-size:30px}
  .svc-grid,.rev-grid,.steps,.gal{grid-template-columns:1fr}
  .finalcta h2{font-size:30px}
  .footer .wrap{grid-template-columns:1fr}
  body{padding-bottom:62px}
  .sticky-cta{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:200;box-shadow:0 -6px 18px rgba(22,26,29,.22)}
  .sticky-cta a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;font-family:'Archivo';font-weight:800;font-size:16px;padding:15px 8px calc(15px + env(safe-area-inset-bottom))}
  .sticky-cta .sc-call{background:var(--lime);color:var(--lime-ink);flex:1.3}
  .sticky-cta .sc-quote{background:var(--ink);color:#fff}
}

/* reCAPTCHA badge: lift above the mobile sticky bar */
@media (max-width:640px){ .grecaptcha-badge{ bottom:84px !important } }

/* reCAPTCHA checkbox inside the form card */
.rc-box{margin:4px 0 12px}
.rc-box>div{max-width:100%}
@media (max-width:360px){ .rc-box{transform:scale(.88);transform-origin:0 0} }
