/* =========================================================
   J Stokes Builders — site stylesheet
   Industrial-craft / editorial design system
   ========================================================= */

:root{
  --ink:#14181b;
  --ink-2:#20262b;
  --slate:#1d3a4d;          /* blueprint blue (secondary dark) */
  --slate-2:#16303f;
  --concrete:#f5f2ea;       /* warm paper background */
  --concrete-2:#ece6da;
  --line:#ddd5c6;           /* warm hairline */
  --muted:#5d6164;
  --muted-light:#9aa0a3;
  --amber:#e3a02e;          /* construction amber accent */
  --amber-strong:#cf8916;
  --white:#ffffff;
  --shadow:0 18px 40px -22px rgba(20,24,27,.45);
  --shadow-sm:0 8px 22px -16px rgba(20,24,27,.5);
  --maxw:1200px;
  --r:4px;
  --ease:cubic-bezier(.4,.01,.2,1);
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:"Barlow",-apple-system,Segoe UI,sans-serif;
  font-size:17px;
  line-height:1.7;
  color:var(--ink-2);
  background:var(--concrete);
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

h1,h2,h3,h4{
  font-family:"Barlow Condensed",sans-serif;
  font-weight:700;
  line-height:.98;
  letter-spacing:.005em;
  color:var(--ink);
  margin:0 0 .4em;
  text-transform:uppercase;
}
h1{font-size:clamp(2.7rem,6.2vw,5rem);}
h2{font-size:clamp(2rem,4.4vw,3.25rem);}
h3{font-size:1.5rem;letter-spacing:.01em;}
p{margin:0 0 1.1em;}
.lead{font-size:1.18rem;color:var(--muted);}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.section{padding:clamp(64px,9vw,120px) 0;}
.section--tight{padding:clamp(48px,6vw,84px) 0;}
.center{text-align:center;}

/* Eyebrow label */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:"Barlow Condensed",sans-serif;
  text-transform:uppercase;letter-spacing:.28em;font-weight:600;
  font-size:.86rem;color:var(--amber-strong);margin-bottom:14px;
}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--amber);}
.center .eyebrow::before{display:none;}
.dark .eyebrow{color:var(--amber);}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:"Barlow Condensed",sans-serif;font-weight:600;
  text-transform:uppercase;letter-spacing:.12em;font-size:1.05rem;
  padding:15px 30px;border:2px solid var(--amber);background:var(--amber);
  color:var(--ink);border-radius:var(--r);cursor:pointer;
  transition:transform .25s var(--ease),background .25s,box-shadow .25s;
}
.btn:hover{background:var(--amber-strong);border-color:var(--amber-strong);transform:translateY(-2px);box-shadow:var(--shadow-sm);}
.btn--ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,.55);}
.btn--ghost:hover{background:var(--white);color:var(--ink);border-color:var(--white);}
.btn--dark{background:var(--ink);border-color:var(--ink);color:var(--white);}
.btn--dark:hover{background:var(--slate);border-color:var(--slate);}

/* ---------- Top bar ---------- */
.topbar{background:var(--ink);color:#cfd3d4;font-size:.92rem;}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;
  gap:18px;padding-top:9px;padding-bottom:9px;flex-wrap:wrap;}
.topbar a{color:#cfd3d4;}
.topbar .ti{display:inline-flex;align-items:center;gap:8px;}
.topbar .ti+.ti{margin-left:22px;}
.topbar strong{color:#fff;font-weight:600;}
.topbar .tb-social a{margin-left:14px;opacity:.8;transition:opacity .2s,color .2s;}
.topbar .tb-social a:hover{opacity:1;color:var(--amber);}
.topbar svg{width:15px;height:15px;stroke:var(--amber);}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(245,242,234,.92);
  backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line);
  transition:box-shadow .3s,background .3s;}
.site-header.scrolled{box-shadow:var(--shadow-sm);background:rgba(245,242,234,.98);}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding-top:14px;padding-bottom:14px;}
.brand img{height:54px;width:auto;}
.nav-links{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0;}
.nav-links a{
  font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;
  font-weight:600;letter-spacing:.1em;font-size:1.08rem;color:var(--ink);
  padding:10px 14px;position:relative;
}
.nav-links a::after{content:"";position:absolute;left:14px;right:14px;bottom:4px;
  height:2px;background:var(--amber);transform:scaleX(0);transform-origin:left;
  transition:transform .28s var(--ease);}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);}
.nav-links a.active{color:var(--amber-strong);}
.nav-cta{display:inline-flex;align-items:center;gap:18px;}
.nav-phone{font-family:"Barlow Condensed",sans-serif;font-weight:700;
  font-size:1.25rem;color:var(--ink);letter-spacing:.02em;white-space:nowrap;}
.nav-phone span{display:block;font-size:.7rem;letter-spacing:.2em;color:var(--muted);
  text-transform:uppercase;font-weight:600;}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;
  cursor:pointer;padding:8px;}
.burger span{width:26px;height:2px;background:var(--ink);transition:.3s;}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.burger.open span:nth-child(2){opacity:0;}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:84vh;display:flex;align-items:center;
  color:#fff;overflow:hidden;}
.hero__bg{position:absolute;inset:0;}
.hero__bg img{width:100%;height:100%;object-fit:cover;}
.hero__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(20,24,27,.92) 0%,rgba(20,24,27,.7) 42%,rgba(29,58,77,.35) 100%);}
.hero .wrap{position:relative;z-index:2;padding-top:90px;padding-bottom:90px;}
.hero h1{color:#fff;max-width:14ch;}
.hero h1 em{color:var(--amber);font-style:normal;}
.hero p{max-width:48ch;font-size:1.22rem;color:#e7e3da;}
.hero .actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:14px;}
.hero .reveal-up{opacity:0;transform:translateY(26px);animation:rise .9s var(--ease) forwards;}
.hero .reveal-up:nth-child(1){animation-delay:.05s;}
.hero .reveal-up:nth-child(2){animation-delay:.18s;}
.hero .reveal-up:nth-child(3){animation-delay:.32s;}
.hero .reveal-up:nth-child(4){animation-delay:.46s;}
@keyframes rise{to{opacity:1;transform:none;}}

/* Trust strip */
.trust{background:var(--ink);color:#e7e3da;}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:rgba(255,255,255,.08);}
.trust .ts{background:var(--ink);padding:26px 22px;display:flex;align-items:center;gap:14px;}
.trust svg{width:30px;height:30px;stroke:var(--amber);flex:none;}
.trust b{display:block;font-family:"Barlow Condensed",sans-serif;font-size:1.35rem;
  text-transform:uppercase;color:#fff;line-height:1;letter-spacing:.02em;}
.trust small{color:var(--muted-light);font-size:.82rem;letter-spacing:.04em;}

/* Section heading block */
.shead{max-width:680px;margin-bottom:48px;}
.center.shead{margin-inline:auto;}

/* ---------- Services ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.svc{background:var(--white);border:1px solid var(--line);border-radius:var(--r);
  padding:34px 30px;position:relative;overflow:hidden;
  transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;}
.svc::before{content:attr(data-n);position:absolute;top:-8px;right:14px;
  font-family:"Barlow Condensed",sans-serif;font-weight:700;font-size:4.4rem;
  color:var(--concrete-2);z-index:0;}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--amber);}
.svc>*{position:relative;z-index:1;}
.svc .ico{width:46px;height:46px;stroke:var(--amber-strong);stroke-width:1.6;margin-bottom:18px;}
.svc h3{margin-bottom:10px;}
.svc p{color:var(--muted);font-size:.98rem;margin:0;}

/* ---------- About split ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;}
.split__media{position:relative;}
.split__media img{border-radius:var(--r);box-shadow:var(--shadow);aspect-ratio:4/3;object-fit:cover;width:100%;}
.split__media .badge{position:absolute;left:-18px;bottom:-18px;background:var(--amber);
  color:var(--ink);padding:18px 24px;border-radius:var(--r);box-shadow:var(--shadow-sm);}
.split__media .badge b{font-family:"Barlow Condensed",sans-serif;font-size:2.6rem;
  display:block;line-height:.9;text-transform:uppercase;}
.split__media .badge span{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;}
.tick{list-style:none;padding:0;margin:18px 0 26px;}
.tick li{display:flex;gap:12px;align-items:flex-start;margin-bottom:12px;color:var(--ink-2);}
.tick svg{width:22px;height:22px;stroke:var(--amber-strong);flex:none;margin-top:3px;}

/* ---------- Gallery ---------- */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.gal a{position:relative;display:block;border-radius:var(--r);overflow:hidden;
  background:var(--concrete-2);aspect-ratio:4/3;}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);}
.gal a:hover img{transform:scale(1.07);}
.gal a::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(20,24,27,.7),transparent 55%);
  opacity:0;transition:opacity .35s;}
.gal a:hover::after{opacity:1;}
.gal .cap{position:absolute;left:0;right:0;bottom:0;padding:18px 20px;color:#fff;z-index:2;
  font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.04em;
  font-size:1.15rem;transform:translateY(8px);opacity:0;transition:.35s;}
.gal a:hover .cap{transform:none;opacity:1;}
.gal .plus{position:absolute;top:14px;right:14px;z-index:2;width:38px;height:38px;
  border:2px solid #fff;border-radius:50%;color:#fff;display:grid;place-items:center;
  opacity:0;transform:scale(.7);transition:.35s;font-size:1.4rem;line-height:1;}
.gal a:hover .plus{opacity:1;transform:none;}

/* Lightbox */
.lb{position:fixed;inset:0;z-index:200;background:rgba(16,18,20,.94);
  display:none;align-items:center;justify-content:center;padding:30px;}
.lb.open{display:flex;}
.lb img{max-width:92vw;max-height:86vh;border-radius:var(--r);box-shadow:0 30px 80px rgba(0,0,0,.6);}
.lb__btn{position:absolute;background:none;border:0;color:#fff;cursor:pointer;
  font-size:2.4rem;line-height:1;padding:14px;opacity:.8;transition:opacity .2s;}
.lb__btn:hover{opacity:1;}
.lb__close{top:10px;right:18px;}
.lb__prev{left:8px;top:50%;transform:translateY(-50%);}
.lb__next{right:8px;top:50%;transform:translateY(-50%);}

/* ---------- Testimonials ---------- */
.dark{background:var(--slate);color:#e7e3da;}
.dark h2,.dark h3{color:#fff;}
.tgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;}
.tcard{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r);padding:32px 30px;position:relative;}
.tcard .quote{font-size:4rem;font-family:"Barlow Condensed",sans-serif;color:var(--amber);
  line-height:.6;height:28px;}
.tcard p{color:#eee9df;font-size:1.06rem;}
.tcard .who{display:flex;align-items:center;gap:12px;margin-top:18px;}
.tcard .who b{font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;
  letter-spacing:.04em;font-size:1.15rem;color:#fff;}
.tcard .who span{color:var(--amber);font-size:.86rem;}
.stars{color:var(--amber);letter-spacing:2px;margin-bottom:14px;}

/* ---------- Areas ---------- */
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px;}
.chip{border:1px solid var(--line);background:var(--white);border-radius:40px;
  padding:9px 18px;font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;
  letter-spacing:.06em;font-size:1rem;color:var(--ink-2);}
.dark .chip{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.15);color:#eee;}

/* ---------- CTA band ---------- */
.cta{background:var(--amber);color:var(--ink);}
.cta .wrap{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;
  padding-top:54px;padding-bottom:54px;}
.cta h2{color:var(--ink);margin:0;}
.cta p{margin:6px 0 0;font-weight:600;}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:start;}
.field{margin-bottom:18px;}
.field label{display:block;font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;
  letter-spacing:.08em;font-weight:600;font-size:1rem;margin-bottom:7px;color:var(--ink);}
.field .req{color:var(--amber-strong);}
.field input,.field textarea{width:100%;font:inherit;font-size:1rem;padding:13px 15px;
  border:1.5px solid var(--line);border-radius:var(--r);background:var(--white);color:var(--ink);
  transition:border-color .2s,box-shadow .2s;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--amber);
  box-shadow:0 0 0 4px rgba(227,160,46,.15);}
.hp{position:absolute;left:-9999px;top:-9999px;}
#form-status{min-height:24px;font-weight:600;margin-top:6px;}
.info-card{background:var(--ink);color:#e7e3da;border-radius:var(--r);padding:34px 32px;}
.info-card h3{color:#fff;}
.info-row{display:flex;gap:14px;align-items:flex-start;padding:15px 0;border-top:1px solid rgba(255,255,255,.1);}
.info-row:first-of-type{border-top:0;}
.info-row svg{width:22px;height:22px;stroke:var(--amber);flex:none;margin-top:3px;}
.info-row b{display:block;color:#fff;font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.06em;}
.info-row a{color:#e7e3da;}.info-row a:hover{color:var(--amber);}
.map-embed{margin-top:26px;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);}
.map-embed iframe{display:block;width:100%;height:300px;border:0;filter:grayscale(.3) contrast(1.05);}

/* ---------- Page hero (inner pages) ---------- */
.phero{position:relative;color:#fff;padding:clamp(70px,11vw,140px) 0 clamp(50px,7vw,90px);}
.phero::before{content:"";position:absolute;inset:0;background:var(--ink);}
.phero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(29,58,77,.7),rgba(20,24,27,.4));}
.phero .wrap{position:relative;z-index:2;}
.phero h1{color:#fff;}
.phero .crumb{font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;
  letter-spacing:.14em;font-size:.92rem;color:#cdd2d4;}
.phero .crumb a:hover{color:var(--amber);}
.phero .crumb b{color:var(--amber);font-weight:600;}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#aeb3b6;padding-top:64px;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px;}
.site-footer img.flogo{height:56px;margin-bottom:18px;}
.site-footer h4{color:#fff;font-size:1.2rem;letter-spacing:.06em;margin-bottom:18px;}
.site-footer a{color:#aeb3b6;transition:color .2s;}
.site-footer a:hover{color:var(--amber);}
.fnav{list-style:none;padding:0;margin:0;}
.fnav li{margin-bottom:9px;}
.fcontact div{display:flex;gap:11px;margin-bottom:13px;}
.fcontact svg{width:18px;height:18px;stroke:var(--amber);flex:none;margin-top:4px;}
.fsocial{display:flex;gap:12px;margin-top:8px;}
.fsocial a{width:40px;height:40px;border:1px solid rgba(255,255,255,.18);border-radius:50%;
  display:grid;place-items:center;}
.fsocial a:hover{background:var(--amber);border-color:var(--amber);}
.fsocial svg{width:18px;height:18px;stroke:#fff;}
.fsocial a:hover svg{stroke:var(--ink);}
.copyright{border-top:1px solid rgba(255,255,255,.1);margin-top:54px;padding:22px 0;
  font-size:.88rem;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.in{opacity:1;transform:none;}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .split{grid-template-columns:1fr;gap:40px;}
  .split__media .badge{left:0;}
  .contact-grid{grid-template-columns:1fr;gap:34px;}
  .tgrid{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px;}
}
@media(max-width:820px){
  .svc-grid{grid-template-columns:1fr 1fr;}
  .trust .wrap{grid-template-columns:1fr 1fr;}
  .nav-cta .nav-phone{display:none;}
  .burger{display:flex;}
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(80vw,320px);background:var(--concrete);
    flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:0;
    padding:90px 26px;transform:translateX(100%);transition:transform .35s var(--ease);
    box-shadow:var(--shadow);z-index:55;}
  .nav-links.open{transform:none;}
  .nav-links a{width:100%;font-size:1.4rem;padding:14px 0;border-bottom:1px solid var(--line);}
  .nav-links a::after{display:none;}
  body.nav-open{overflow:hidden;}
  .nav-scrim{position:fixed;inset:0;background:rgba(16,18,20,.5);z-index:54;display:none;}
  .nav-scrim.open{display:block;}
}
@media(max-width:560px){
  .gal{grid-template-columns:1fr 1fr;gap:10px;}
  .svc-grid{grid-template-columns:1fr;}
  .trust .wrap{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr;}
  .topbar .ti:not(.ti--phone){display:none;}
  .cta .wrap{flex-direction:column;align-items:flex-start;}
}
