/* Pixel-matched Jenkins homepage based on the approved mockup. */
:root{
  --red:#e63946;
  --red-dark:#cf2c39;
  --black:#090a0c;
  --ink:#121418;
  --muted:#686d75;
  --line:#d8dce2;
  --soft:#f6f7f9;
  --white:#ffffff;
  --max:1024px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--ink);
  background:#fff;
  font-family:Montserrat, Arial, Helvetica, sans-serif;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}

/* Header */
.site-header{
  position:absolute;
  z-index:20;
  top:0;
  left:0;
  right:0;
  height:78px;
  display:flex;
  align-items:center;
  padding:0 30px;
  color:#fff;
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  flex:0 0 auto;
}
.brand-icon{
  width:46px;
  height:auto;
  display:block;
  flex:0 0 auto;
  object-fit:contain;
}
.footer-brand .brand-icon{width:54px}
.brand-name{
  color:#fff;
  font-family:Montserrat, Arial, sans-serif;
  font-size:31px;
  line-height:1;
  font-weight:900;
  letter-spacing:-1px;
}
.brand-since{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:34px;
  min-width:45px;
  padding:0 7px;
  background:var(--red);
  color:#fff;
  font-size:10px;
  line-height:1.05;
  font-weight:900;
  letter-spacing:1.5px;
}
.main-nav{
  margin-left:auto;
  display:flex;
  align-items:center;
  gap:28px;
  color:#fff;
  font-size:12px;
  line-height:1;
  text-transform:uppercase;
  font-weight:900;
  letter-spacing:.25px;
}
.main-nav span{font-size:12px}
.main-nav .nav-caret{width:9px;height:6px;display:inline-block;vertical-align:middle;margin-left:3px;color:#fff}
.quote-button{
  margin-left:28px;
  background:var(--red);
  padding:18px 24px;
  color:#fff;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  line-height:1;
}

/* Hero */
.hero{
  position:relative;
  height:470px;
  overflow:hidden;
  background:#091018;
  color:#fff;
}
.hero-photo{
  position:absolute;
  top:0;
  right:0;
  bottom:0;
  width:68%;
  background-image:url("assets/hero-digital-dozer.jpg");
  background-repeat:no-repeat;
  background-size:auto 100%;
  background-position:right center;
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(0,0,0,.96) 0%, rgba(0,0,0,.78) 30%, rgba(0,0,0,.30) 61%, rgba(0,0,0,.34) 100%),
    radial-gradient(circle at 76% 48%, rgba(0,0,0,0) 0%, rgba(0,0,0,.22) 55%, rgba(0,0,0,.55) 100%);
}
.hero-content{
  position:relative;
  z-index:3;
  height:100%;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  padding:92px 52px 39px;
}
.hero-copy{
  width:430px;
  align-self:center;
  transform:translateY(27px);
}
.hero-copy h1{
  margin:0;
  font-family:"Barlow Condensed", Impact, Arial Black, sans-serif;
  color:#fff;
  text-transform:uppercase;
  font-size:57px;
  line-height:.94;
  letter-spacing:.5px;
  font-weight:900;
}
.short-rule{
  display:block;
  width:54px;
  height:3px;
  margin:24px 0 18px;
  background:var(--red);
}
.hero-copy p{
  max-width:405px;
  margin:0 0 23px;
  color:#fff;
  font-size:17px;
  line-height:1.48;
  font-weight:600;
}
.hero-actions{
  display:flex;
  align-items:center;
  gap:26px;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:13px;
  min-height:42px;
  padding:0 21px;
  color:#fff;
  font-size:12px;
  line-height:1;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.25px;
}
.btn-red{background:var(--red)}
.btn-outline-light{
  min-width:148px;
  border:1px solid rgba(255,255,255,.75);
  background:rgba(0,0,0,.12);
}
.year-badge{
  width:230px;
  margin-bottom:8px;
  text-align:right;
  color:#fff;
  text-transform:uppercase;
}
.year-line{
  display:flex;
  align-items:flex-end;
  justify-content:flex-end;
  line-height:.8;
}
.year-number{
  font-family:Arial, Helvetica, sans-serif;
  font-size:86px;
  line-height:.78;
  font-weight:300;
  letter-spacing:-6px;
}
.year-slash{
  color:var(--red);
  font-size:58px;
  line-height:.58;
  font-weight:900;
  margin-left:-4px;
}
.year-yrs{
  display:inline-block;
  margin-left:-4px;
  margin-bottom:4px;
  padding:6px 8px 5px;
  background:var(--red);
  color:#fff;
  font-size:13px;
  line-height:1;
  font-weight:900;
  letter-spacing:3px;
}
.celebrate{
  display:inline-block;
  margin-top:8px;
  padding:7px 14px;
  background:var(--red);
  color:#fff;
  font-size:13px;
  line-height:1;
  font-weight:900;
  letter-spacing:5px;
}
.since-line{
  margin-top:10px;
  color:#fff;
  font-size:12px;
  line-height:1;
  font-weight:700;
  letter-spacing:4px;
}

/* Stats */
.stats{
  min-height:106px;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  padding:0 50px;
  background:#fff;
  box-shadow:0 10px 24px rgba(0,0,0,.07);
}
.stats article{
  position:relative;
  display:grid;
  grid-template-columns:56px auto 1fr;
  align-items:center;
  gap:10px;
  padding:22px 23px 20px;
}
.stats article:not(:last-child)::after{
  content:"";
  position:absolute;
  top:22px;
  right:0;
  width:1px;
  height:62px;
  background:var(--line);
}
.stat-icon{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  color:var(--red);
  flex:0 0 auto;
}
.stat-icon svg{width:32px;height:32px;display:block}
.stats strong{
  color:#111;
  font-size:35px;
  line-height:.9;
  font-weight:900;
  letter-spacing:-1px;
}
.stats p{
  margin:0;
  color:#111;
  font-size:11px;
  line-height:1.1;
  font-weight:900;
  text-transform:uppercase;
}
.stats small{
  display:block;
  margin-top:7px;
  color:#575b61;
  font-size:9px;
  line-height:1.25;
  font-weight:600;
  text-transform:none;
}

/* Sections */
.section{
  padding-left:51px;
  padding-right:51px;
}
.section-heading{
  text-align:center;
  padding:45px 0 27px;
}
.section-heading span{
  display:inline-block;
  width:28px;
  height:2px;
  margin-right:9px;
  vertical-align:middle;
  background:var(--red);
}
.section-heading p{
  display:inline-block;
  margin:0;
  color:#222;
  font-size:11px;
  line-height:1;
  font-weight:900;
  text-transform:uppercase;
}
h2{
  margin:9px 0 0;
  color:#111;
  font-family:"Barlow Condensed", Impact, Arial Black, sans-serif;
  font-size:35px;
  line-height:.95;
  font-weight:900;
  letter-spacing:.2px;
  text-transform:uppercase;
}

/* Services */
.service-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.service-card{
  position:relative;
  height:238px;
  overflow:hidden;
  background:#111;
}
.service-card img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.card-band{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  display:grid;
  grid-template-columns:57px 1fr 20px;
  align-items:center;
  gap:13px;
  min-height:78px;
  padding:14px 16px;
  color:#fff;
  background:linear-gradient(90deg, rgba(0,0,0,.88), rgba(0,0,0,.72));
}
.red-icon{
  width:52px;
  height:52px;
  display:grid;
  place-items:center;
  background:var(--red);
  color:#fff;
}
.red-icon svg{width:26px;height:26px;display:block}
.card-band h3{
  margin:0 0 5px;
  color:#fff;
  font-size:16px;
  line-height:1;
  font-weight:900;
  text-transform:uppercase;
}
.card-band p{
  margin:0;
  color:#fff;
  font-size:11px;
  line-height:1.35;
  font-weight:600;
}
.card-band a{
  color:var(--red);
  font-size:25px;
  line-height:1;
}

/* Featured Projects */
.projects{padding-top:8px;padding-bottom:14px}
.project-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.project-card{
  position:relative;
  height:268px;
  overflow:hidden;
  background:#111;
}
.project-card img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.project-band{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  padding:14px 16px 16px;
  color:#fff;
  background:linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.55) 35%, rgba(0,0,0,.92) 100%);
}
.project-band .project-meta{
  margin:0 0 4px;
  color:var(--red);
  font-size:10px;
  line-height:1;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:1.2px;
}
.project-band h3{
  margin:0 0 6px;
  color:#fff;
  font-size:15px;
  line-height:1.2;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.2px;
}
.project-band .project-spec{
  margin:0;
  color:#dadde2;
  font-size:11px;
  line-height:1.45;
  font-weight:500;
}
.project-more summary{
  position:absolute;
  top:12px;
  right:12px;
  z-index:3;
  list-style:none;
  cursor:pointer;
  padding:5px 9px;
  background:var(--red);
  color:#fff;
  font-size:9px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:1px;
  border-radius:3px;
  box-shadow:0 1px 6px rgba(0,0,0,.35);
}
.project-more summary::-webkit-details-marker{display:none;}
.project-more summary::after{content:"Read more";}
.project-more[open] summary::after{content:"Close";}
.project-overview{
  position:absolute;
  inset:0;
  z-index:2;
  overflow-y:auto;
  padding:18px 18px 20px;
  background:rgba(10,12,16,.95);
  color:#e6e8ec;
}
.project-overview h3{
  margin:0 0 8px;
  color:#fff;
  font-size:14px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.2px;
  padding-right:60px;
}
.project-overview p{
  margin:0;
  font-size:11.5px;
  line-height:1.55;
  color:#cfd3da;
}
.projects-also{
  margin:18px 0 0;
  padding-top:14px;
  border-top:1px solid var(--line);
  color:#383d44;
  font-size:11px;
  line-height:1.55;
  font-weight:500;
}
.projects-also strong{color:#111;font-weight:900;text-transform:uppercase;letter-spacing:.5px;font-size:10px}

/* Work */
.work{
  padding-top:31px;
  padding-bottom:0;
}
.work-header{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  margin-bottom:12px;
}
.label{
  margin:0;
  color:#6d7179;
  font-size:12px;
  line-height:1;
  font-weight:800;
  text-transform:uppercase;
}
.label::before{
  content:"";
  display:inline-block;
  width:27px;
  height:2px;
  margin-right:9px;
  vertical-align:middle;
  background:var(--red);
}
.view-projects{
  display:inline-flex;
  align-items:center;
  gap:11px;
  height:39px;
  padding:0 19px;
  border:1px solid #111;
  color:#111;
  font-size:11px;
  line-height:1;
  font-weight:900;
  text-transform:uppercase;
}
.view-projects span{color:var(--red);font-size:18px}
.field-strip{
  display:grid;
  grid-template-columns:1.08fr 1.08fr 1fr 1fr 1fr 1fr;
  gap:7px;
}
.field-strip img{
  width:100%;
  height:132px;
  object-fit:cover;
}

/* About / Values */
.about-values{
  display:grid;
  grid-template-columns:40% 60%;
  margin-top:11px;
  background:var(--soft);
}
.about-panel{
  min-height:285px;
  padding:42px 52px 43px;
  color:#fff;
  background:linear-gradient(135deg,#111,#1e1f22);
}
.about-panel .label{color:#fff}
.about-panel h2{
  margin-top:15px;
  color:#fff;
  font-size:33px;
}
.about-panel p:not(.label){
  margin:17px 0 22px;
  max-width:335px;
  color:#fff;
  font-size:12px;
  line-height:1.55;
  font-weight:500;
}
.about-panel .btn{
  min-height:38px;
  padding:0 20px;
}
.values-panel{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  padding:42px 52px 38px;
}
.values-panel article{
  min-height:102px;
  display:grid;
  grid-template-columns:52px 1fr;
  column-gap:16px;
  align-items:start;
  padding:10px 21px 20px 0;
  border-bottom:1px solid var(--line);
}
.values-panel article:nth-child(odd){
  border-right:1px solid var(--line);
  margin-right:26px;
}
.values-panel article:nth-child(even){
  padding-left:6px;
}
.values-panel article:nth-last-child(-n+2){
  border-bottom:0;
  padding-top:24px;
}
.value-icon{
  width:46px;
  height:46px;
  display:grid;
  place-items:center;
  color:var(--red);
}
.value-icon svg{width:36px;height:36px;display:block}
.values-panel h3{
  margin:1px 0 7px;
  color:#111;
  font-size:14px;
  line-height:1;
  font-weight:900;
  text-transform:uppercase;
}
.values-panel p{
  margin:0;
  color:#383d44;
  font-size:10px;
  line-height:1.45;
  font-weight:500;
}

/* Legacy / Three Generations */
.legacy{
  display:grid;
  grid-template-columns:48% 52%;
  background:var(--soft);
}
.legacy-photo{
  position:relative;
  min-height:360px;
  background:#111;
}
.legacy-photo img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 30%;
  display:block;
}
.legacy-copy{
  align-self:center;
  padding:48px 52px;
}
.legacy-copy .label{color:var(--red)}
.legacy-copy h2{
  margin-top:14px;
  font-size:35px;
}
.legacy-copy p:not(.label){
  margin:18px 0 0;
  max-width:460px;
  color:#383d44;
  font-size:14px;
  line-height:1.6;
  font-weight:500;
}

/* Leadership */
.team{padding-top:14px;padding-bottom:30px;background:var(--soft)}
.team-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:24px;
  max-width:1000px;
  margin:0 auto;
}
.team-member{text-align:center}
.team-member img{
  width:120px;
  height:120px;
  margin:0 auto 12px;
  border-radius:50%;
  object-fit:cover;
  object-position:center 22%;
  background:#d8dce2;
  border:3px solid #fff;
  box-shadow:0 4px 12px rgba(0,0,0,.12);
}
.team-member h3{
  margin:0 0 3px;
  color:#111;
  font-size:13px;
  line-height:1.2;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.2px;
}
.team-member p{
  margin:0;
  color:var(--muted);
  font-size:10px;
  line-height:1.35;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.3px;
}

/* FAQ */
.faq{padding-top:18px;padding-bottom:46px;background:#fff}
.faq .section-heading{padding:32px 0 18px}
.faq-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px 44px;
  max-width:980px;
  margin:0 auto;
}
.faq-list article{
  border-top:2px solid var(--red);
  padding-top:13px;
}
.faq-list h3{
  margin:0 0 7px;
  color:#111;
  font-size:13px;
  line-height:1.3;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.2px;
}
.faq-list p{
  margin:0;
  color:#383d44;
  font-size:13px;
  line-height:1.6;
  font-weight:500;
}
.faq-list a{color:var(--red);text-decoration:underline}

/* CTA and Footer */
.cta-strip{
  min-height:86px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:25px;
  padding:20px 52px;
  background:#fff;
}
.cta-strip>div{min-width:0;flex:1 1 auto}
.cta-strip h2{
  margin:0;
  font-size:31px;
}
.cta-strip p{
  margin:4px 0 0;
  color:#555b63;
  font-size:14px;
  font-weight:700;
}

.site-footer{
  display:grid;
  grid-template-columns:1.3fr .65fr .92fr 1fr;
  gap:36px;
  padding:35px 52px 44px;
  color:#fff;
  background:linear-gradient(135deg,#08090c,#191b20);
}
.footer-brand .brand-name{font-size:35px}
.footer-brand-block p{
  width:240px;
  margin:14px 0 20px;
  color:#d8dadd;
  font-size:13px;
  line-height:1.55;
  font-weight:500;
}
.socials{
  display:flex;
  gap:11px;
}
.socials a{
  width:38px;
  height:38px;
  display:grid;
  place-items:center;
  border:2px solid rgba(255,255,255,.7);
  border-radius:50%;
  color:#fff;
  font-size:18px;
  font-weight:800;
}
.socials a svg{width:18px;height:18px;display:block}
.site-footer h3{
  margin:5px 0 15px;
  color:#fff;
  font-size:12px;
  line-height:1;
  font-weight:900;
  text-transform:uppercase;
}
.footer-links a{
  display:block;
  margin:0 0 8px;
  color:#fff;
  font-size:12px;
  font-weight:500;
}
.footer-contact p{
  margin:0 0 16px;
  color:#fff;
  font-size:13px;
  line-height:1.45;
}
.footer-years{
  align-self:center;
  justify-self:end;
  width:214px;
  color:#fff;
  text-align:right;
  text-transform:uppercase;
}
.footer-years .year-number{font-size:83px}
.footer-years .year-slash{font-size:53px}
.footer-years .year-yrs{font-size:11px}
.footer-years .celebrate{font-size:12px}
.footer-years .since-line{font-size:11px}

/* Responsive adjustments keep the mockup feel without breaking content. */
@media (min-width:1200px){
  .site-header{padding-left:52px;padding-right:52px}
  .hero{height:620px}
  .hero-content{padding:120px 76px 64px}
  .hero-copy{width:520px}
  .hero-copy h1{font-size:76px}
  .hero-copy p{font-size:22px;max-width:510px}
  .year-badge{transform:scale(1.18);transform-origin:right bottom;margin-bottom:30px}
  .stats{padding-left:76px;padding-right:76px}
  .section{padding-left:76px;padding-right:76px}
  .service-card{height:300px}
  .field-strip img{height:178px}
  .about-values{grid-template-columns:40% 60%}
  .about-panel{padding-left:76px}
  .values-panel{padding-right:76px}
  .cta-strip{padding-left:76px;padding-right:76px}
  .site-footer{padding-left:76px;padding-right:76px}
  .legacy-photo{min-height:440px}
  .legacy-copy{padding:64px 76px}
  .legacy-copy h2{font-size:42px}
  .legacy-copy p:not(.label){font-size:15px}
  .faq{padding-top:36px;padding-bottom:60px}
  .faq-list{max-width:1080px;gap:28px 60px}
  .faq-list h3{font-size:14px}
  .faq-list p{font-size:14px}
  .project-card{height:320px}
  .project-band h3{font-size:16px}
  .project-band .project-spec{font-size:12px}
  .projects-also{font-size:12px}
  .team-grid{max-width:1080px;gap:30px}
  .team-member img{width:140px;height:140px}
  .team-member h3{font-size:14px}
}
@media (min-width:1500px){
  .hero{height:660px}
  .hero-copy h1{font-size:82px}
  .hero-copy{width:570px}
  .site-header,.hero-content,.stats,.section,.cta-strip,.site-footer{padding-left:86px;padding-right:86px}
  .legacy-copy{padding:72px 86px}
  .year-badge{transform:scale(1.28);margin-bottom:44px}
}
/* Tablet: keep header desktop-style but tighter */
@media (min-width:881px) and (max-width:1199px){
  .site-header{padding:0 24px;height:74px}
  .main-nav{gap:18px;font-size:11px}
  .quote-button{margin-left:18px;padding:14px 16px;font-size:11px}
  .brand-name{font-size:26px}
  .brand-since{font-size:9px;min-width:38px;height:30px;padding:0 6px}
  .brand-icon{width:38px}

  /* Stats: 2x2 to prevent horizontal clip */
  .stats{
    grid-template-columns:repeat(2,1fr);
    padding:0 24px;
  }
  .stats article{padding:18px 16px}
  .stats article:nth-child(1)::after,
  .stats article:nth-child(3)::after{
    /* keep vertical divider only between columns within a row */
    display:block;
  }
  .stats article:nth-child(2)::after{display:none}
  .stats article:nth-child(-n+2){border-bottom:1px solid var(--line)}

  /* Section padding tighter */
  .section{padding-left:28px;padding-right:28px}

  /* Work header: prevent h2 clipping */
  .work-header{margin-bottom:18px;align-items:center}
  .work-header h2{white-space:nowrap;font-size:30px}
  .view-projects{flex:0 0 auto}

  /* About/Values: stack values 2-col with breathing room, tighten about column */
  .about-values{grid-template-columns:38% 62%}
  .about-panel{padding:34px 28px 36px}
  .about-panel h2{font-size:28px}
  .values-panel{padding:30px 28px 28px;column-gap:14px}
  .values-panel article{padding-right:10px;column-gap:12px}
  .values-panel article:nth-child(odd){margin-right:14px}
  .values-panel p{font-size:11px}

  /* CTA strip: give heading + sub vertical room */
  .cta-strip{padding:22px 28px;min-height:0;align-items:center}
  .cta-strip>div{flex:1 1 auto;min-width:0}
  .cta-strip h2{font-size:26px;white-space:normal}
  .cta-strip .btn{flex:0 0 auto}

  /* Footer: tighter */
  .site-footer{grid-template-columns:1.2fr .7fr .9fr 1fr;padding:32px 28px 38px;gap:24px}

  /* Legacy: tablet padding */
  .legacy-photo{min-height:340px}
  .legacy-copy{padding:36px 28px}
  .legacy-copy h2{font-size:30px}

  /* Leadership: 3-col on tablet */
  .team-grid{grid-template-columns:repeat(3,1fr);gap:24px 18px;max-width:560px}
}
@media (max-width:880px){
  .site-header{height:auto;padding:23px 24px}
  .main-nav,.quote-button{display:none}
  .brand-name{font-size:28px}
  .hero{height:auto;min-height:720px}
  .hero-photo{width:100%;opacity:.72;background-size:cover;background-position:center}
  .hero-content{display:block;padding:116px 24px 210px}
  .hero-copy{width:min(520px,100%);transform:none}
  .hero-copy h1{font-size:58px}
  .year-badge{position:absolute;left:24px;bottom:35px;text-align:left;transform:scale(.86);transform-origin:left bottom}
  .year-line,.year-badge .celebrate,.year-badge .since-line{justify-content:flex-start}
  .stats{grid-template-columns:1fr 1fr;padding:0 24px}
  .stats article{padding-left:0;padding-right:16px}
  .stats article:nth-child(2)::after{display:none}
  .stats article:nth-child(-n+2){border-bottom:1px solid var(--line)}
  .service-grid,.about-values,.legacy,.site-footer{grid-template-columns:1fr}
  .legacy-photo{min-height:280px}
  .legacy-copy{padding:32px 24px}
  .legacy-copy h2{font-size:30px}
  .faq-list{grid-template-columns:1fr;gap:20px}
  .project-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .project-card{height:240px}
  .team-grid{grid-template-columns:repeat(3,1fr);gap:22px 14px;max-width:420px}
  .team-member img{width:96px;height:96px}
  .field-strip{grid-template-columns:repeat(2,1fr)}
  .about-panel,.values-panel,.cta-strip,.site-footer,.section{padding-left:24px;padding-right:24px}
  .values-panel{grid-template-columns:1fr}
  .values-panel article,.values-panel article:nth-child(odd){border-right:0;margin-right:0}
  .footer-years{justify-self:start;text-align:left}
}
@media (max-width:560px){
  .hero-copy h1{font-size:48px}
  .hero-actions{display:block}
  .hero-actions .btn{margin:0 10px 12px 0}
  .stats{grid-template-columns:1fr}
  .stats article{border-bottom:1px solid var(--line)}
  .stats article::after{display:none}
  .stats article:last-child{border-bottom:0}
  .service-grid{grid-template-columns:1fr}
  .field-strip{grid-template-columns:1fr}
  .field-strip img{height:210px}
  .project-grid{grid-template-columns:1fr}
  .project-card{height:240px}
  .team-grid{grid-template-columns:repeat(2,1fr);gap:20px 12px}
  .work-header{display:block}
  .view-projects{margin-top:15px}
  .cta-strip{display:block}
  .cta-strip .btn{margin-top:18px}
}
