/* Bunyan Plastering Contractors — bespoke build (charcoal + petrol teal, Space Grotesk + Inter) */
:root{
  --ink:#23292b; --charcoal:#1c2426;
  --teal:#1f5b66; --teal-deep:#17454e; --teal-acc:#2f8c98; --teal-soft:#e2eef0;
  --plaster:#f2efe8; --stone:#e8e3d8;
  --muted:#5e6a6c; --line:#e2ddd0; --white:#fff;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',Arial,sans-serif;color:var(--ink);background:var(--white);
  font-size:16px;line-height:1.66;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Space Grotesk','Inter',sans-serif;font-weight:700;
  line-height:1.12;letter-spacing:-.5px}
.wrap{max-width:1180px;margin:0 auto;padding:0 26px}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.97rem;
  font-family:'Space Grotesk',sans-serif;padding:14px 28px;border-radius:2px;
  white-space:nowrap;transition:.2s;cursor:pointer;border:2px solid transparent}
.btn-primary{background:var(--teal-acc);color:#fff}
.btn-primary:hover{background:var(--teal)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost:hover{background:#fff;color:var(--teal-deep)}
.btn-dark{background:var(--teal-deep);color:#fff}
.btn-dark:hover{background:var(--charcoal)}
.ico{width:18px;height:18px;flex:none;stroke:currentColor;fill:none;stroke-width:1.8}

/* ---- header ---- */
.site-header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:300}
.site-header .wrap{display:flex;align-items:stretch;justify-content:space-between;
  min-height:86px;gap:20px}
.brand{display:flex;align-items:center;gap:13px}
.brand-mark{width:50px;height:50px;background:var(--teal);color:#fff;display:flex;
  align-items:center;justify-content:center;font-family:'Space Grotesk',sans-serif;
  font-weight:700;font-size:1.2rem;flex:none;transform:rotate(0)}
.brand-name{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.34rem;
  color:var(--charcoal);line-height:1.05;letter-spacing:-.5px}
.brand-name small{display:block;font-family:'Inter',sans-serif;font-size:.64rem;
  letter-spacing:2.6px;text-transform:uppercase;color:var(--teal-acc);font-weight:600;margin-top:4px}
.nav-wrap{display:flex;align-items:stretch}
.nav-main{display:flex;align-items:center;gap:2px}
.nav-links{display:flex;list-style:none;gap:2px}
.nav-links a{display:block;padding:10px 16px;font-family:'Space Grotesk',sans-serif;
  font-weight:600;font-size:.96rem;color:var(--ink);border-radius:2px;transition:.16s}
.nav-links a:hover,.nav-links a.active{background:var(--teal-soft);color:var(--teal-deep)}
.nav-phone{display:flex;align-items:center;gap:10px;align-self:stretch;padding:0 26px;
  margin-left:14px;background:var(--teal);color:#fff;font-family:'Space Grotesk',sans-serif;
  font-weight:700;font-size:1.1rem;white-space:nowrap}
.nav-phone:hover{background:var(--teal-deep)}
.nav-phone .ico{color:#fff}
.nav-phone span small{display:block;font-family:'Inter',sans-serif;font-size:.62rem;
  letter-spacing:1.6px;font-weight:600;color:#a9d2d6;text-transform:uppercase}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px;align-self:center}
.burger svg{width:30px;height:30px;stroke:var(--charcoal)}

/* ---- hero ---- */
.hero{position:relative;color:#fff}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero::after{content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(28,36,38,.72) 0%,rgba(28,36,38,.55) 45%,rgba(23,69,78,.82) 100%)}
.hero .wrap{position:relative;z-index:2;padding:104px 26px 140px;text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Space Grotesk',sans-serif;
  font-weight:600;letter-spacing:3px;text-transform:uppercase;font-size:.82rem;
  color:#8fd0d8;margin-bottom:20px}
.eyebrow::before,.eyebrow::after{content:'';width:26px;height:1.5px;background:var(--teal-acc)}
.hero h1{font-size:clamp(2.5rem,5.4vw,4rem);margin:0 auto 20px;max-width:880px}
.hero h1 em{font-style:normal;color:#8fd0d8}
.hero p.lead{font-size:1.14rem;color:#dde7e7;max-width:620px;margin:0 auto 30px;line-height:1.7}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
/* stat strip overlapping */
.statbar{position:relative;z-index:5;margin-top:-78px}
.statbar .wrap{display:grid;grid-template-columns:repeat(4,1fr);background:var(--charcoal);
  border-radius:3px;overflow:hidden;box-shadow:0 30px 60px -28px rgba(28,36,38,.6)}
.statbar .s{padding:30px 22px;text-align:center;border-right:1px solid rgba(255,255,255,.08)}
.statbar .s:last-child{border-right:0}
.statbar .s b{display:block;font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(2.1rem,4vw,2.9rem);color:#8fd0d8;line-height:1}
.statbar .s b.t{font-size:clamp(1.3rem,2.2vw,1.7rem);line-height:1.15}
.statbar .s span{display:block;margin-top:8px;font-size:.84rem;color:#aeb9ba;font-weight:500}

/* ---- trust strip ---- */
.trust{background:var(--plaster)}
.trust .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 38px;
  padding:22px 26px;font-size:.92rem;font-weight:600;color:var(--teal-deep)}
.trust span{display:flex;align-items:center;gap:9px}
.trust .ico{color:var(--teal-acc);width:18px;height:18px}

/* ---- sections ---- */
.section{padding:84px 0}
.section.plaster{background:var(--plaster)}
.section.teal{background:var(--teal-deep);color:#fff}
.sec-head{max-width:680px;margin-bottom:46px}
.sec-head.center{margin:0 auto 46px;text-align:center}
.sec-head .kick{font-family:'Space Grotesk',sans-serif;font-weight:600;letter-spacing:2.6px;
  text-transform:uppercase;color:var(--teal-acc);font-size:.82rem;display:block;margin-bottom:11px}
.sec-head h2{font-size:clamp(2rem,3.5vw,2.8rem);color:var(--charcoal)}
.section.teal .sec-head h2{color:#fff}
.sec-head p{margin-top:14px;color:var(--muted);font-size:1.04rem}
.section.teal .sec-head p{color:#bcd3d6}

/* ---- about split ---- */
.about{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.about .copy .kick{font-family:'Space Grotesk',sans-serif;font-weight:600;letter-spacing:2.6px;
  text-transform:uppercase;color:var(--teal-acc);font-size:.82rem;display:block;margin-bottom:11px}
.about .copy h2{font-size:clamp(2rem,3.3vw,2.6rem);color:var(--charcoal);margin-bottom:18px}
.about .copy p{margin-bottom:14px;color:#3d4647}
.about .media img{width:100%;border-radius:3px}
.about .media{position:relative}
.about .media .tag{position:absolute;right:-16px;bottom:-16px;background:var(--teal-acc);
  color:#fff;padding:18px 24px;border-radius:3px}
.about .media .tag b{font-family:'Space Grotesk',sans-serif;font-size:2rem;display:block;line-height:1}
.about .media .tag span{font-size:.8rem}

/* ---- service cards ---- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:#fff;border:1px solid var(--line);border-radius:3px;padding:32px 28px;
  transition:.2s}
.section.plaster .card{background:#fff}
.card:hover{transform:translateY(-5px);box-shadow:0 22px 40px -22px rgba(28,36,38,.4);
  border-color:var(--teal-soft)}
.card .ic{width:56px;height:56px;background:var(--teal-soft);display:flex;
  align-items:center;justify-content:center;margin-bottom:18px}
.card .ic .ico{width:27px;height:27px;color:var(--teal)}
.card h3{font-size:1.34rem;color:var(--charcoal);margin-bottom:8px}
.card p{font-size:.95rem;color:var(--muted)}

/* ---- feature row (image + service list) ---- */
.frow{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.frow .fimg img{width:100%;border-radius:3px}
.flist{list-style:none}
.flist li{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--line)}
.flist li:last-child{border-bottom:0}
.flist .n{width:32px;height:32px;background:var(--teal);color:#fff;flex:none;
  display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk',sans-serif;
  font-weight:700;font-size:.9rem}
.flist b{font-family:'Space Grotesk',sans-serif;font-size:1.06rem;color:var(--charcoal);display:block}
.flist span{font-size:.92rem;color:var(--muted)}

/* ---- gallery grid ---- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery .g{position:relative;overflow:hidden;border-radius:3px;cursor:pointer;
  aspect-ratio:4/3;background:var(--stone)}
.gallery .g img{width:100%;height:100%;object-fit:cover;transition:.5s}
.gallery .g:hover img{transform:scale(1.08)}
.gallery .g::after{content:'';position:absolute;inset:0;background:rgba(23,69,78,0);transition:.3s}
.gallery .g:hover::after{background:rgba(23,69,78,.22)}

/* ---- featured project ---- */
.feat{display:grid;grid-template-columns:1.1fr .9fr;gap:0;background:var(--charcoal);
  border-radius:3px;overflow:hidden;color:#fff}
.feat .fimg{min-height:340px;background-size:cover;background-position:center}
.feat .fbody{padding:48px 44px}
.feat .fbody .kick{font-family:'Space Grotesk',sans-serif;font-weight:600;letter-spacing:2.4px;
  text-transform:uppercase;color:#8fd0d8;font-size:.8rem;display:block;margin-bottom:12px}
.feat .fbody h3{font-size:1.85rem;margin-bottom:8px}
.feat .fbody .loc{color:#9fb0b1;font-size:.92rem;margin-bottom:16px}
.feat .fbody p{color:#cdd8d8;margin-bottom:18px}
.feat .tags{list-style:none;display:flex;flex-wrap:wrap;gap:8px}
.feat .tags li{background:rgba(255,255,255,.1);color:#dbe6e6;font-size:.82rem;
  padding:6px 12px;border-radius:2px}

/* ---- project name list ---- */
.pnames{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.pnames .pn{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);
  padding:16px 18px;border-radius:3px}
.section.plaster .pnames .pn{background:#fff}
.pnames .pn .ico{color:var(--teal-acc);width:18px;height:18px}
.pnames .pn span{font-weight:600;font-size:.95rem;color:var(--charcoal)}

/* ---- clients list ---- */
.clist{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.clist .ci{background:#fff;border:1px solid var(--line);border-left:3px solid var(--teal-acc);
  padding:22px 24px;border-radius:3px}
.clist .ci b{font-family:'Space Grotesk',sans-serif;font-size:1.12rem;color:var(--charcoal)}
.clist .ci span{display:block;font-size:.9rem;color:var(--muted);margin-top:3px}

/* ---- CTA band ---- */
.cta-band{background:var(--teal);color:#fff;text-align:center}
.cta-band .wrap{padding:64px 26px}
.cta-band h2{font-size:clamp(2rem,3.6vw,2.8rem);margin-bottom:12px}
.cta-band p{font-size:1.05rem;color:#cfe4e6;margin:0 auto 26px;max-width:560px}
.cta-band .hero-cta{justify-content:center}
.cta-band .btn-primary{background:#fff;color:var(--teal-deep)}
.cta-band .btn-primary:hover{background:var(--charcoal);color:#fff}

/* ---- page banner ---- */
.banner{background:var(--charcoal);color:#fff;position:relative;overflow:hidden}
.banner::after{content:'';position:absolute;right:-40px;bottom:-90px;width:280px;height:280px;
  background:var(--teal);opacity:.4;transform:rotate(45deg)}
.banner .wrap{position:relative;z-index:2;padding:62px 26px}
.banner .kick{font-family:'Space Grotesk',sans-serif;font-weight:600;letter-spacing:2.6px;
  text-transform:uppercase;color:#8fd0d8;font-size:.82rem;display:block;margin-bottom:10px}
.banner h1{font-size:clamp(2.3rem,4.4vw,3.3rem)}
.banner .crumb{font-size:.88rem;color:#9fb0b1;margin-top:10px}
.banner .crumb a:hover{color:#fff}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:48px}
.cinfo .cline{display:flex;gap:15px;padding:18px 0;border-bottom:1px solid var(--line)}
.cinfo .cline:last-child{border-bottom:0}
.cinfo .ic{width:46px;height:46px;background:var(--teal-soft);display:flex;
  align-items:center;justify-content:center;flex:none}
.cinfo .ic .ico{width:22px;height:22px;color:var(--teal)}
.cinfo b{font-family:'Space Grotesk',sans-serif;font-size:1.04rem;color:var(--charcoal)}
.cinfo a,.cinfo span{color:var(--muted);display:block}
.cinfo a:hover{color:var(--teal-acc)}
.regline{margin-top:20px;padding-top:18px;border-top:1px solid var(--line);
  font-size:.84rem;color:var(--muted)}
.form{background:#fff;border:1px solid var(--line);border-radius:3px;padding:34px;
  box-shadow:0 24px 50px -32px rgba(28,36,38,.4)}
.form h3{color:var(--charcoal);font-size:1.55rem;margin-bottom:6px}
.form .fsub{color:var(--muted);font-size:.93rem;margin-bottom:20px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.85rem;margin-bottom:6px;color:var(--charcoal)}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1px solid var(--line);
  border-radius:2px;font-family:inherit;font-size:.96rem;background:var(--plaster);color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal-acc);background:#fff}
.field textarea{resize:vertical;min-height:108px}
.form .btn{width:100%;justify-content:center}
.form .promise{margin-top:13px;font-size:.83rem;color:var(--muted);text-align:center}
.maprow{margin-top:50px}
.maprow iframe{width:100%;height:380px;border:0;border-radius:3px;filter:grayscale(.3)}

/* ---- footer ---- */
.site-footer{background:var(--charcoal);color:#a4b0b1;font-size:.93rem}
.site-footer .top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:38px;
  padding:60px 0 42px}
.site-footer h4{font-family:'Space Grotesk',sans-serif;color:#fff;font-size:1.1rem;margin-bottom:16px}
.site-footer .brand-name{color:#fff}
.site-footer p{margin:14px 0;color:#8c9a9b}
.site-footer ul{list-style:none}
.site-footer ul li{margin-bottom:9px}
.site-footer ul a:hover{color:#fff}
.site-footer .fcontact div{margin-bottom:10px}
.site-footer .fcontact a{color:#fff;font-weight:600}
.site-footer .bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.83rem;color:#768485}

/* ---- mobile call bar ---- */
.callbar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:400;background:var(--teal-acc);
  color:#fff;text-align:center;padding:13px;font-family:'Space Grotesk',sans-serif;
  font-weight:700;font-size:1.06rem;box-shadow:0 -6px 20px rgba(0,0,0,.2)}

/* ---- lightbox ---- */
.lb{display:none;position:fixed;inset:0;z-index:900;background:rgba(20,28,30,.95);
  align-items:center;justify-content:center}
.lb.open{display:flex}
.lb img{max-width:90vw;max-height:86vh;border-radius:3px}
.lb button{position:absolute;background:rgba(255,255,255,.13);color:#fff;border:0;
  cursor:pointer;width:50px;height:50px;border-radius:50%;font-size:1.4rem}
.lb .x{top:22px;right:22px}.lb .p{top:50%;left:20px;transform:translateY(-50%)}
.lb .n{top:50%;right:20px;transform:translateY(-50%)}
.lb button:hover{background:var(--teal-acc)}

/* ---- responsive ---- */
@media(max-width:980px){
  .about,.frow,.contact-grid,.feat{grid-template-columns:1fr;gap:34px}
  .feat .fimg{min-height:240px}
  .cards,.gallery,.pnames{grid-template-columns:repeat(2,1fr)}
  .statbar .wrap{grid-template-columns:repeat(2,1fr)}
  .statbar .s:nth-child(2){border-right:0}
  .clist{grid-template-columns:1fr}
  .site-footer .top{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  .burger{display:block}
  .nav-wrap{align-items:center}
  .nav-main{position:fixed;inset:0 0 0 auto;width:min(82vw,330px);background:#fff;
    flex-direction:column;align-items:stretch;padding:88px 22px 30px;gap:4px;
    transform:translateX(100%);transition:.28s;box-shadow:-12px 0 40px rgba(0,0,0,.22);overflow-y:auto}
  .nav-main.open{transform:translateX(0)}
  .nav-links{flex-direction:column}
  .nav-links a{padding:14px 10px;font-size:1.1rem;border-bottom:1px solid var(--line)}
  .nav-phone{margin:14px 0 0;padding:16px;justify-content:center}
  .callbar{display:block}
  body{padding-bottom:50px}
}
@media(max-width:560px){
  .cards,.gallery,.pnames,.statbar .wrap{grid-template-columns:1fr}
  .statbar .s{border-right:0}
  .site-footer .top{grid-template-columns:1fr}
  .hero .wrap{padding:80px 26px 130px}
}
