/* JMAC Bricklaying. Bold asymmetric overlay. Charcoal canvas, trade green. */
:root{
  --green:#6DB650; --green-d:#5aa043; --green-l:#8ed16a;
  --ink:#141414; --charcoal:#1d1d1d; --charcoal-2:#262626; --charcoal-3:#2f2f2f;
  --surface:#f5f5f3; --paper:#ffffff; --muted:#a9a9a9; --muted-2:#6c6c6c;
  --line:rgba(255,255,255,.10); --line-d:rgba(0,0,0,.10);
  --maxw:1200px;
  --ff-head:'Archivo',system-ui,sans-serif;
  --ff-body:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--ff-body);color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
h1,h2,h3,h4{font-family:var(--ff-head);font-weight:800;line-height:1.04;letter-spacing:-.02em}
h2{font-size:clamp(27px,4vw,42px)}
h3{font-size:21px;font-weight:700;letter-spacing:-.01em}
.eyebrow{font-family:var(--ff-head);font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:12.5px;color:var(--green)}
section{position:relative}

/* demo banner */
.demobar{background:var(--green);color:#10260a;font-size:13.5px;font-weight:600;text-align:center;padding:9px 16px;font-family:var(--ff-body)}
.demobar b{font-weight:800}

/* nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .3s,box-shadow .3s,padding .3s;padding:18px 0}
.nav.scrolled{background:rgba(20,20,20,.96);box-shadow:0 6px 24px rgba(0,0,0,.35);padding:11px 0;backdrop-filter:blur(6px)}
.nav.solid{background:var(--ink)}
.nav .row{display:flex;align-items:center;justify-content:space-between;gap:20px}
.nav .logo img{height:50px;width:auto;transition:height .3s}
.nav.scrolled .logo img{height:42px}
.nav .links{display:flex;align-items:center;gap:26px}
.nav .links a{color:#f1f1f1;font-size:14.5px;font-weight:600;letter-spacing:.01em;transition:color .15s}
.nav .links a:hover{color:var(--green-l)}
.nav .links a.active{color:var(--green)}
.nav .cta-phone{display:inline-flex;align-items:center;gap:8px;background:var(--green);color:#10260a;padding:10px 18px;border-radius:3px;font-weight:800;font-size:14.5px}
.nav .cta-phone:hover{background:var(--green-l);color:#10260a}
.nav .cta-phone svg{width:16px;height:16px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:26px;height:2.5px;background:#fff;border-radius:2px;transition:.25s}
.mobile-menu{display:none}

/* hero */
.hero{position:relative;min-height:90vh;display:flex;align-items:flex-end;background:var(--ink);overflow:hidden}
.hero .bg{position:absolute;inset:0;z-index:0}
.hero .bg img{width:100%;height:100%;object-fit:cover}
.hero .scrim{position:absolute;inset:0;z-index:1;background:
   linear-gradient(90deg,rgba(15,15,15,.92) 0%,rgba(15,15,15,.62) 42%,rgba(15,15,15,.18) 100%),
   linear-gradient(0deg,rgba(15,15,15,.95) 0%,rgba(15,15,15,.15) 45%,rgba(15,15,15,.35) 100%)}
.hero .inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px 64px}
.hero .accent{width:60px;height:5px;background:var(--green);margin-bottom:22px}
.hero h1{color:#fff;font-size:clamp(34px,6.4vw,58px);max-width:15ch;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.hero h1 em{font-style:normal;color:var(--green)}
.hero .sub{color:#dcdcdc;font-size:clamp(15px,2vw,18.5px);max-width:46ch;margin-top:20px}
.hero .actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--ff-body);font-weight:800;font-size:15px;padding:14px 24px;border-radius:3px;cursor:pointer;border:2px solid transparent;transition:.18s}
.btn svg{width:17px;height:17px}
.btn-green{background:var(--green);color:#10260a;border-color:var(--green)}
.btn-green:hover{background:var(--green-l);border-color:var(--green-l)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-dark{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-dark:hover{background:var(--charcoal-2)}

/* hero stat strip */
.herostats{background:var(--charcoal);border-top:3px solid var(--green)}
.herostats .grid{display:grid;grid-template-columns:repeat(3,1fr);max-width:var(--maxw);margin:0 auto}
.herostats .cell{padding:22px;border-right:1px solid var(--line);color:#fff}
.herostats .cell:last-child{border-right:0}
.herostats .k{font-family:var(--ff-head);font-weight:800;font-size:19px;color:var(--green-l);letter-spacing:-.01em}
.herostats .v{font-size:13.5px;color:var(--muted);margin-top:3px}

/* generic dark section */
.dark{background:var(--charcoal);color:#fff;padding:84px 0}
.dark h2{color:#fff}
.dark p{color:#cfcfcf}
.ink{background:var(--ink);color:#fff;padding:84px 0}
.light{background:var(--surface);color:var(--ink);padding:84px 0}
.lead{font-size:18px;max-width:60ch}

/* intro split */
.intro{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:center}
.intro .copy p{margin-top:16px}
.intro .points{list-style:none;margin-top:26px;display:grid;gap:14px}
.intro .points li{display:flex;gap:13px;align-items:flex-start;font-size:15.5px;color:#dcdcdc}
.intro .points svg{width:21px;height:21px;flex:0 0 21px;color:var(--green);margin-top:1px}
.intro .media{position:relative}
.intro .media img{border-radius:5px;width:100%;aspect-ratio:4/3;object-fit:cover}
.intro .media .tag{position:absolute;left:-14px;bottom:-14px;background:var(--green);color:#10260a;font-family:var(--ff-head);font-weight:800;font-size:14px;padding:14px 18px;border-radius:3px;max-width:60%;line-height:1.2}

/* section head */
.shead{margin-bottom:46px;max-width:60ch}
.shead .eyebrow{display:block;margin-bottom:14px}

/* services grid */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.svc-card{position:relative;border-radius:5px;overflow:hidden;min-height:330px;display:flex;align-items:flex-end;color:#fff;background:var(--ink)}
.svc-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform .5s}
.svc-card:hover img{transform:scale(1.05)}
.svc-card .ov{position:absolute;inset:0;z-index:1;background:linear-gradient(0deg,rgba(15,15,15,.92) 8%,rgba(15,15,15,.25) 70%,rgba(15,15,15,.45) 100%)}
.svc-card .c{position:relative;z-index:2;padding:26px}
.svc-card .ico{width:42px;height:42px;border:1.5px solid var(--green);border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--green);margin-bottom:16px}
.svc-card .ico svg{width:23px;height:23px}
.svc-card h3{font-size:22px;margin-bottom:8px}
.svc-card p{color:#cfcfcf;font-size:14.5px;margin-bottom:14px}
.svc-card .more{color:var(--green-l);font-weight:700;font-size:14px;display:inline-flex;align-items:center;gap:7px}
.svc-card .more svg{width:15px;height:15px}

/* feature band */
.feature{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:center}
.feature.rev{grid-template-columns:1.1fr .9fr}
.feature .media img{border-radius:5px;width:100%;aspect-ratio:5/4;object-fit:cover}
.feature .copy h2{margin-bottom:18px}

/* checklist */
.checks{list-style:none;display:grid;gap:13px;margin-top:8px}
.checks li{display:flex;gap:12px;align-items:flex-start;font-size:15.5px}
.checks svg{width:20px;height:20px;flex:0 0 20px;color:var(--green);margin-top:2px}
.dark .checks li,.ink .checks li{color:#dcdcdc}

/* gallery strip */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.gal a,.gal div{border-radius:4px;overflow:hidden;aspect-ratio:4/3}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gal a:hover img{transform:scale(1.06)}

/* stat row */
.statrow{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.statrow .s .k{font-family:var(--ff-head);font-weight:800;font-size:clamp(28px,4vw,40px);color:var(--green)}
.statrow .s .v{font-size:14px;color:var(--muted);margin-top:6px}
.light .statrow .s .v{color:var(--muted-2)}

/* cta band */
.ctaband{background:var(--green);color:#10260a;padding:60px 0}
.ctaband .row{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.ctaband h2{color:#10260a;max-width:18ch}
.ctaband .sub{color:#16380c;font-weight:600;margin-top:8px}
.ctaband .acts{display:flex;gap:14px;flex-wrap:wrap}

/* page header (sub pages) */
.phead{position:relative;min-height:52vh;display:flex;align-items:flex-end;background:var(--ink);overflow:hidden;margin-top:0}
.phead .bg{position:absolute;inset:0;z-index:0}
.phead .bg img{width:100%;height:100%;object-fit:cover}
.phead .scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(15,15,15,.9),rgba(15,15,15,.45) 60%,rgba(15,15,15,.2)),linear-gradient(0deg,rgba(15,15,15,.9),rgba(15,15,15,.1) 60%)}
.phead .inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;width:100%;padding:0 22px 50px}
.phead .accent{width:54px;height:5px;background:var(--green);margin-bottom:18px}
.phead h1{color:#fff;font-size:clamp(30px,5vw,50px);max-width:16ch}
.phead .crumb{color:var(--muted);font-size:13.5px;margin-bottom:16px}
.phead .crumb a:hover{color:var(--green-l)}

/* form */
.formwrap{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
.contact-form{background:var(--charcoal-2);padding:32px;border-radius:6px;border:1px solid var(--line)}
.ink .contact-form{background:var(--charcoal-2)}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:#cfcfcf;margin-bottom:6px;letter-spacing:.02em}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;background:var(--ink);border:1px solid var(--line);border-radius:4px;color:#fff;font-family:var(--ff-body);font-size:15px}
.field input:focus,.field select,.field textarea:focus{outline:2px solid var(--green);border-color:var(--green)}
.field textarea{min-height:120px;resize:vertical}
.form-note{font-size:12.5px;color:var(--muted);margin-top:6px}
.form-msg{display:none;margin-top:14px;padding:13px 16px;border-radius:4px;background:rgba(109,182,80,.16);border:1px solid var(--green);color:var(--green-l);font-size:14.5px}
.contact-cards{display:grid;gap:18px}
.cc{display:flex;gap:16px;align-items:flex-start;background:var(--charcoal-2);border:1px solid var(--line);border-radius:6px;padding:20px}
.cc .ico{width:44px;height:44px;flex:0 0 44px;border-radius:5px;background:rgba(109,182,80,.13);display:flex;align-items:center;justify-content:center;color:var(--green)}
.cc .ico svg{width:22px;height:22px}
.cc h4{font-family:var(--ff-head);font-size:15px;color:#fff;margin-bottom:3px}
.cc a,.cc p{color:#cfcfcf;font-size:15px}
.cc a:hover{color:var(--green-l)}

/* footer */
.foot{background:#0e0e0e;color:#bdbdbd;padding:64px 0 26px}
.foot .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px}
.foot .logo img{height:62px;margin-bottom:16px}
.foot p{font-size:14px;line-height:1.7}
.foot h4{font-family:var(--ff-head);color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px}
.foot ul{list-style:none;display:grid;gap:9px}
.foot a{font-size:14px}
.foot a:hover{color:var(--green-l)}
.foot .lic{font-size:13px;color:#8a8a8a;margin-top:4px}
.foot .bot{border-top:1px solid var(--line);margin-top:44px;padding-top:22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:12.5px;color:#7a7a7a}
.foot .bot a{color:var(--green)}
.fsoc{display:inline-flex;align-items:center;gap:8px;color:#cfcfcf;font-size:14px}
.fsoc svg{width:18px;height:18px}

@media(max-width:860px){
  .nav .links{display:none}
  .nav .cta-phone span{display:none}
  .burger{display:flex}
  .mobile-menu{display:block;position:fixed;inset:0 0 0 auto;width:78%;max-width:330px;background:var(--ink);z-index:80;transform:translateX(100%);transition:transform .3s;padding:90px 28px 28px;box-shadow:-20px 0 50px rgba(0,0,0,.5)}
  .mobile-menu.open{transform:translateX(0)}
  .mobile-menu a{display:block;color:#eee;font-family:var(--ff-head);font-weight:700;font-size:20px;padding:15px 0;border-bottom:1px solid var(--line)}
  .mobile-menu a:hover{color:var(--green)}
  .mobile-menu .mcall{margin-top:24px;background:var(--green);color:#10260a;text-align:center;border-radius:4px;border:0}
  .mclose{position:absolute;top:22px;right:22px;background:none;border:0;color:#fff;font-size:30px;cursor:pointer;line-height:1}
  .menu-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:70}
  .menu-backdrop.open{display:block}
  .intro,.feature,.feature.rev,.formwrap{grid-template-columns:1fr;gap:34px}
  .svc-grid{grid-template-columns:1fr}
  .herostats .grid{grid-template-columns:1fr;}
  .herostats .cell{border-right:0;border-bottom:1px solid var(--line)}
  .statrow{grid-template-columns:1fr 1fr;gap:30px 18px}
  .gal{grid-template-columns:1fr 1fr}
  .foot .top{grid-template-columns:1fr 1fr;gap:30px}
  .intro .media .tag{left:0;max-width:70%}
  .dark,.ink,.light{padding:62px 0}
  .ctaband .row{flex-direction:column;align-items:flex-start}
}
@media(max-width:480px){
  .foot .top{grid-template-columns:1fr}
  .statrow{grid-template-columns:1fr 1fr}
  .gal{grid-template-columns:1fr 1fr}
}
