
:root{
  --bg:#ffffff;
  --ink:#2b2b2b;
  --sage:#79857f;
  --sage-dark:#5f736b;
  --menu:#7b867d;
  --menu-active:#2d2d2d;
  --green:#1f473d;
  --light:#f8f8f4;
  --line:#d7d7d2;
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:Arial,Helvetica,sans-serif;
  background:#ffffff;
  color:#1f332d;
  line-height:1.55;
}
a{color:inherit}

.site-header{
  max-width:1320px;
  margin:0 auto;
  padding:12px 26px 0;
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
  gap:34px;
}
.brand{
  display:block;
  width:470px;
  flex:0 0 470px;
  margin:0;
}
.brand img{width:100%;display:block}

nav{
  display:grid;
  grid-template-columns:163px 163px 258px 180px;
  width:764px;
  margin:14px 0 0 0;
  border:1px solid #ecece8;
  background:#ecece8;
  flex:0 0 764px;
}
nav a{
  background:var(--menu);
  color:#fff;
  text-decoration:none;
  text-align:center;
  font-size:18px;
  font-weight:600;
  padding:16px 10px;
  border-right:1px solid #d8ddd6;
}
nav a:last-child{border-right:none}
nav a.active{background:var(--menu-active)}

main{overflow:hidden}

.hero{
  max-width:1320px;
  margin:10px auto 64px;
  display:grid;
  grid-template-columns:360px minmax(0, 1fr);
  gap:46px;
  align-items:start;
  padding:0 26px;
}
.hero-copy{
  order:1;
  padding:14px 0 0 10px;
}
.hero-copy h1,
.hero-title-final{
  color:var(--sage) !important;
  -webkit-text-fill-color:var(--sage) !important;
  font-size:45px !important;
  line-height:1.35 !important;
  font-weight:700 !important;
  letter-spacing:.02em !important;
  text-shadow:none !important;
  background:none !important;
  filter:none !important;
  margin:0 0 16px !important;
}
.hero-copy h1 span,
.hero-title-final span{
  color:var(--sage) !important;
  -webkit-text-fill-color:var(--sage) !important;
}
.tagline{
  font-size:26px;
  line-height:1.30;
  color:#20352f;
  margin:0;
}
.hero-copy h2{
  font-size:26px;
  line-height:1.18;
  margin:28px 0 12px;
  color:var(--ink);
  letter-spacing:.16em;
}
.hero-copy p:last-child{
  font-size:16px;
  line-height:1.45;
  max-width:330px;
  color:#2e2e2e;
}
.hero-image{
  order:2;
  height:auto;
  overflow:visible;
}
.hero-image img{
  width:100%;
  height:auto;
  display:block;
  object-fit:contain;
  object-position:center top;
}

.services{
  background:var(--light);
  text-align:center;
  padding:70px 26px;
}
.eyebrow{letter-spacing:.18em;color:var(--green);font-size:13px}
.services h2{font-size:25px;letter-spacing:.05em;margin:0 0 42px;color:var(--green)}
.service-grid{max-width:1020px;margin:auto;display:grid;grid-template-columns:repeat(3,1fr);gap:42px 38px}
.service-card{background:white;padding:0 0 20px;min-height:275px}
.service-card img{width:100%;height:132px;object-fit:cover}
.service-card h3{font-size:16px;color:var(--green);letter-spacing:.05em;margin:18px 18px 8px}
.service-card p{font-size:14px;color:#43524e;margin:0 20px}

.principal{max-width:1100px;margin:76px auto 46px;padding:0 26px;display:grid;grid-template-columns:430px 1fr;gap:58px;align-items:center}
.principal img{width:100%}
.principal h2{font-size:32px;line-height:1.18;color:var(--green);margin:0 0 20px}
.principal .large{font-size:23px;line-height:1.35;color:#1d312c}

.stats{
  background:#1e4b41;
  color:#fff;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  max-width:none;
  width:100%;
  margin:0;
  padding:8px 280px 24px;
}
.stats div{
  text-align:center;
  padding:8px 16px 0;
  border-right:none;
}
.stats div:last-child{border-right:none}
.stats img{
  height:26px;
  width:auto;
  object-fit:contain;
  opacity:.55;
  margin-bottom:8px;
}
.stats p{
  margin:0;
  font-size:14px;
  line-height:1.35;
  letter-spacing:.03em;
  font-weight:700;
}

footer{
  background:#2f2e31;
  color:#f2f0eb;
  padding:42px 0 34px;
  border-top:0;
}
.footer-inner{
  max-width:1180px;
  margin:0 auto;
  padding:0 32px;
  display:grid;
  grid-template-columns:320px 1fr 80px;
  gap:60px;
  align-items:center;
}
.footer-title{
  font-family:Georgia, 'Times New Roman', serif;
  font-style:italic;
  font-size:58px;
  line-height:.95;
  font-weight:400;
  letter-spacing:.01em;
  color:#f4f0ea;
}
.footer-info{
  color:#ece7df;
}
.footer-info p{
  margin:0 0 10px;
  font-size:17px;
  line-height:1.45;
}
.footer-info p.small{
  font-size:14px;
  margin-top:4px;
  color:#ddd5ca;
}
footer a{color:#ece7df;text-decoration:none}
footer a:hover{text-decoration:underline}
.footer-social{
  display:flex;
  align-items:center;
  justify-content:center;
  color:#ffffff;
  font-size:28px;
  font-weight:700;
  text-decoration:none;
}
.copy{margin:0}

.page-title{max-width:1040px;margin:52px auto 18px;padding:0 26px;color:var(--green);font-size:42px;letter-spacing:.06em}
.content-section{max-width:1040px;margin:0 auto 70px;padding:0 26px}
.two-col{display:grid;grid-template-columns:420px 1fr;gap:52px;align-items:start}
.two-col img{width:100%}
.feature-grid,.category-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:44px}
.feature,.category{text-align:center;border:1px solid var(--line);padding:24px 20px;background:#fff}
.feature img{width:100%;height:170px;object-fit:cover}
.category img{width:70px}
.feature h3,.category h3{color:var(--green);letter-spacing:.06em}
.project-img{width:100%;margin:22px 0;box-shadow:0 10px 30px rgba(0,0,0,.12)}
.contact-form{max-width:520px;margin:10px auto 60px;display:grid;gap:14px}
.contact-form input,.contact-form textarea{border:1px solid #cfcfcf;padding:13px;font:inherit}
.contact-form button{background:var(--green);color:white;border:0;padding:14px;font-weight:bold;letter-spacing:.08em}

@media(max-width:1180px){
  .site-header{flex-direction:column;gap:16px;padding-top:14px}
  .brand{width:360px;flex:0 0 auto}
  nav{margin-top:0;flex:0 0 auto}
  .hero{grid-template-columns:1fr;gap:24px}
  .hero-copy{order:1;padding:0 0 0 18px}
  .hero-image{order:2;height:auto}
  .hero-image img{height:auto}
}
@media(max-width:900px){
  nav{grid-template-columns:repeat(2,minmax(140px,1fr));max-width:440px;width:100%;flex:0 0 auto}
  .service-grid,.feature-grid,.category-grid{grid-template-columns:1fr}
  .principal,.two-col{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .hero-copy h1,.hero-title-final{font-size:38px !important}
  .hero-copy h2{font-size:22px}
  .tagline{font-size:22px}
}
@media(max-width:560px){
  .site-header{padding:18px 12px 8px}
  .brand{width:300px}
  nav{grid-template-columns:1fr;max-width:320px}
  nav a{border-right:none;border-bottom:1px solid #d8ddd6}
  nav a:last-child{border-bottom:none}
  .hero{padding:0 16px;margin-top:18px;gap:22px}
  .hero-copy{padding:0}
  .hero-copy h1,.hero-title-final{font-size:32px !important}
  .tagline,.hero-copy p:last-child{font-size:18px}
  .page-title{font-size:34px}
}


/* V12: Projects gallery page alignment to match the Wix reference more closely */
.projects-page .site-header {
  max-width: 1085px;
  padding-left: 0;
  padding-right: 0;
  gap: 28px;
}

.projects-page .brand {
  width: 400px;
  flex-basis: 400px;
}

.projects-page nav {
  width: 645px;
  flex-basis: 645px;
  grid-template-columns: 137px 137px 216px 155px;
  margin-top: 32px;
}

.projects-page nav a {
  font-size: 16px;
  padding-top: 14px;
  padding-bottom: 14px;
}

.projects-page .content-section {
  max-width: 1085px;
  padding-left: 0;
  padding-right: 0;
  margin-top: 88px;
}

.projects-page .page-title {
  max-width: 1085px;
  padding-left: 0;
  padding-right: 0;
  margin-top: 0;
  margin-bottom: 18px;
  font-size: 58px;
  line-height: 1.05;
  color: #79857f;
  letter-spacing: 0.035em;
}

.projects-page .content-section > p {
  max-width: 1085px;
  font-size: 22px;
  line-height: 1.45;
  color: #1f1f1f;
  margin-bottom: 30px;
}

.projects-page .project-img {
  width: 1085px;
  max-width: 100%;
  margin-top: 24px;
  box-shadow: none;
}

@media(max-width:1180px){
  .projects-page .site-header {
    max-width: 100%;
    padding-left: 20px;
    padding-right: 20px;
  }
  .projects-page .brand {
    width: 360px;
    flex-basis: auto;
  }
  .projects-page nav {
    width: 100%;
    max-width: 645px;
    flex-basis: auto;
    margin-top: 0;
  }
  .projects-page .content-section,
  .projects-page .page-title {
    max-width: 100%;
    padding-left: 26px;
    padding-right: 26px;
  }
}

@media(max-width:900px){
  .projects-page .page-title {
    font-size: 42px;
  }
  .projects-page .content-section > p {
    font-size: 18px;
  }
}

@media(max-width:900px){
  .footer-inner{grid-template-columns:1fr;gap:24px;text-align:center}
  .footer-title{font-size:48px}
}

.projects-page footer{
  margin-top:12px;
}


/* V15: handwritten-style principal signature */
.signature {
  font-family: "Brush Script MT", "Segoe Script", "Lucida Handwriting", cursive;
  font-size: 31px;
  line-height: 1;
  color: #1c2930;
  letter-spacing: .02em;
  margin: 16px 0 12px !important;
  font-weight: 400 !important;
}

.principal-role {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: .04em;
  color: #101923;
  margin-top: 4px !important;
}

@media(max-width:1180px){
  .stats{padding-left:40px;padding-right:40px}
}
@media(max-width:700px){
  .stats{grid-template-columns:1fr 1fr;padding-left:20px;padding-right:20px}
}


/* V16: About page feature/cards + service icons closer to old Wix reference */
.about-page .feature-grid {
  max-width: 1235px;
  margin: 44px auto 56px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 38px;
}

.about-page .feature {
  border: 0 !important;
  padding: 0 26px 10px !important;
  background: transparent !important;
  text-align: center;
}

.about-page .feature img {
  width: 100%;
  height: 215px;
  object-fit: cover;
  margin-bottom: 28px;
}

.about-page .feature h3 {
  color: #123f37;
  font-size: 24px;
  letter-spacing: .12em;
  margin: 0 0 22px;
}

.about-page .feature p {
  font-size: 20px;
  line-height: 1.45;
  color: #082a2b;
  margin: 0 auto;
  max-width: 310px;
}

.about-page .content-section > h2 {
  max-width: 980px;
  margin: 36px auto 18px;
  text-align: center;
  font-size: 20px;
  line-height: 1;
  font-style: italic;
  font-weight: 800;
  color: #1e2930;
  letter-spacing: .03em;
  position: relative;
}

.about-page .content-section > h2::before,
.about-page .content-section > h2::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 19%;
  height: 1px;
  background: #1e2930;
}

.about-page .content-section > h2::before {
  right: calc(100% - 205px);
}

.about-page .content-section > h2::after {
  left: calc(100% - 205px);
}

.about-page .category-grid {
  max-width: 980px;
  margin: 18px auto 20px;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 24px;
  align-items: start;
}

.about-page .category {
  border: 0 !important;
  background: transparent !important;
  padding: 0 !important;
  text-align: center;
}

.about-page .category img {
  width: 58px;
  height: 58px;
  object-fit: contain;
  display: block;
  margin: 0 auto 12px;
  filter: grayscale(1) contrast(1.15);
}

.about-page .category h3 {
  color: #151515;
  font-size: 12px;
  line-height: 1.15;
  font-weight: 800;
  letter-spacing: 0;
  margin: 0;
}

@media(max-width:900px){
  .about-page .feature-grid {
    grid-template-columns: 1fr;
    max-width: 520px;
  }
  .about-page .category-grid {
    grid-template-columns: repeat(3, 1fr);
    max-width: 520px;
  }
  .about-page .content-section > h2::before,
  .about-page .content-section > h2::after {
    display: none;
  }
}

@media(max-width:560px){
  .about-page .category-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}


/* V17: Correct About page order and spacing */
.about-page .feature-grid {
  margin-top: 34px !important;
  margin-bottom: 72px !important;
}

.about-page .content-section > h2 {
  margin-top: 0 !important;
  margin-bottom: 28px !important;
  max-width: 1040px !important;
}

.about-page .content-section > h2::before,
.about-page .content-section > h2::after {
  width: 26% !important;
}

.about-page .content-section > h2::before {
  left: 0 !important;
  right: auto !important;
}

.about-page .content-section > h2::after {
  right: 0 !important;
  left: auto !important;
}

.about-page .category-grid {
  max-width: 1040px !important;
  margin-top: 0 !important;
  margin-bottom: 34px !important;
  gap: 30px !important;
}

.about-page .category img {
  width: 62px !important;
  height: 62px !important;
  margin-bottom: 14px !important;
}

.about-page .category h3 {
  font-size: 12px !important;
  font-weight: 800 !important;
}


/* V18: Fix About page heading line so it does not cross the words */
.about-page .content-section > h2 {
  display: grid !important;
  grid-template-columns: 1fr auto 1fr !important;
  align-items: center !important;
  gap: 12px !important;
  max-width: 1040px !important;
  margin: 0 auto 28px !important;
  text-align: center !important;
  white-space: nowrap !important;
  font-size: 20px !important;
  line-height: 1.2 !important;
}

.about-page .content-section > h2::before,
.about-page .content-section > h2::after {
  content: "" !important;
  position: static !important;
  display: block !important;
  width: auto !important;
  height: 1px !important;
  background: #1e2930 !important;
}

@media(max-width:700px){
  .about-page .content-section > h2 {
    display: block !important;
    white-space: normal !important;
  }

  .about-page .content-section > h2::before,
  .about-page .content-section > h2::after {
    display: none !important;
  }
}


/* V19: Homepage hero text made taller/closer to Wix reference */
.home-page .hero-copy h1,
.home-page .hero-title-final {
  font-size: 38px !important;
  line-height: 1.42 !important;
  margin-bottom: 16px !important;
}

.home-page .tagline {
  font-size: 22px !important;
  line-height: 1.32 !important;
  margin-bottom: 24px !important;
}

.home-page .hero-copy h2 {
  font-size: 24px !important;
  line-height: 1.12 !important;
  letter-spacing: .16em !important;
  margin-top: 0 !important;
  margin-bottom: 18px !important;
}

.home-page .hero-copy p:last-child {
  font-size: 16px !important;
  line-height: 1.55 !important;
  max-width: 340px !important;
}

.home-page .hero-copy {
  padding-top: 18px !important;
}

@media(max-width:900px){
  .home-page .hero-copy h1,
  .home-page .hero-title-final {
    font-size: 34px !important;
  }
}


/* V20: Swap homepage principal section - text left, image right */
.home-page .principal {
  grid-template-columns: 1fr 430px !important;
}

.home-page .principal img {
  order: 2 !important;
}

.home-page .principal > div {
  order: 1 !important;
}

@media(max-width:900px){
  .home-page .principal {
    grid-template-columns: 1fr !important;
  }

  .home-page .principal img {
    order: 1 !important;
  }

  .home-page .principal > div {
    order: 2 !important;
  }
}


/* V21: Move homepage hero text block down to align better with image bottom */
.home-page .hero-copy {
  padding-top: 44px !important;
}

@media(max-width:900px){
  .home-page .hero-copy {
    padding-top: 18px !important;
  }
}


/* V23: push homepage hero text block further down */
.home-page .hero-copy {
  padding-top: 92px !important;
}

@media(max-width:900px){
  .home-page .hero-copy {
    padding-top: 18px !important;
  }
}


/* V24: About page two-column section swapped - text left, image right */
.about-page .two-col {
  grid-template-columns: 1fr 420px !important;
  align-items: start !important;
}

.about-page .two-col img {
  order: 2 !important;
}

.about-page .two-col > div {
  order: 1 !important;
}

@media(max-width:900px){
  .about-page .two-col {
    grid-template-columns: 1fr !important;
  }

  .about-page .two-col img {
    order: 1 !important;
  }

  .about-page .two-col > div {
    order: 2 !important;
  }
}


/* V25: Wix-like mobile menu */
.mobile-menu-toggle,
.mobile-menu-button,
.mobile-menu-panel,
.mobile-menu-backdrop {
  display: none;
}

@media(max-width:700px){
  .site-header {
    position: relative;
    flex-direction: row !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 12px !important;
    padding: 12px 18px 0 !important;
  }

  .brand {
    width: 245px !important;
    flex: 0 0 245px !important;
  }

  .site-header > nav {
    display: none !important;
  }

  .mobile-menu-button {
    display: flex;
    width: 42px;
    height: 42px;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    margin-top: 10px;
    z-index: 60;
  }

  .mobile-menu-button span,
  .mobile-menu-button span::before,
  .mobile-menu-button span::after {
    content: "";
    display: block;
    width: 28px;
    height: 2px;
    background: #2d2d2d;
    position: relative;
  }

  .mobile-menu-button span::before {
    position: absolute;
    top: -8px;
  }

  .mobile-menu-button span::after {
    position: absolute;
    top: 8px;
  }

  .mobile-menu-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.48);
    z-index: 80;
  }

  .mobile-menu-panel {
    position: fixed;
    top: 0;
    right: 0;
    width: 82vw;
    max-width: 380px;
    height: 100vh;
    background: #fff;
    z-index: 90;
    padding: 90px 44px 40px;
    box-shadow: -2px 0 8px rgba(0,0,0,.15);
  }

  .mobile-menu-close {
    position: absolute;
    top: 46px;
    right: 48px;
    font-size: 54px;
    line-height: 1;
    font-family: Arial, Helvetica, sans-serif;
    font-weight: 300;
    color: #252525;
    cursor: pointer;
  }

  .mobile-menu-panel a {
    display: block;
    font-family: Georgia, "Times New Roman", serif;
    font-style: italic;
    font-size: 37px;
    line-height: 1.3;
    color: #333;
    text-decoration: none;
    margin: 0 0 45px;
  }

  .mobile-menu-panel a.active {
    color: #7e96a6;
  }

  .mobile-menu-toggle:checked ~ .mobile-menu-backdrop,
  .mobile-menu-toggle:checked ~ .mobile-menu-panel {
    display: block;
  }
}


/* V26: Use Projects page header as the global reusable header */
.site-header {
  max-width: 1085px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  gap: 28px !important;
}

.site-header .brand {
  width: 400px !important;
  flex-basis: 400px !important;
}

.site-header > nav {
  width: 645px !important;
  flex-basis: 645px !important;
  grid-template-columns: 137px 137px 216px 155px !important;
  margin-top: 32px !important;
}

.site-header > nav a {
  font-size: 16px !important;
  padding-top: 14px !important;
  padding-bottom: 14px !important;
}

@media(max-width:1180px){
  .site-header {
    max-width: 100% !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  .site-header .brand {
    width: 360px !important;
    flex-basis: auto !important;
  }

  .site-header > nav {
    width: 100% !important;
    max-width: 645px !important;
    flex-basis: auto !important;
    margin-top: 0 !important;
  }
}

@media(max-width:700px){
  .site-header {
    position: relative !important;
    flex-direction: row !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 12px !important;
    padding: 12px 18px 0 !important;
  }

  .site-header .brand {
    width: 245px !important;
    flex: 0 0 245px !important;
  }

  .site-header > nav {
    display: none !important;
  }
}


/* V27: Global page width alignment - match Projects page/header width */
:root {
  --page-width: 1085px;
}

/* Header already uses this width; reinforce it globally */
.site-header {
  max-width: var(--page-width) !important;
}

/* General content pages: About, Contact, Projects */
.content-section,
.page-title {
  max-width: var(--page-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Home page sections should also align to the same width */
.home-page .hero,
.home-page .principal,
.home-page .services .service-grid {
  max-width: var(--page-width) !important;
}

/* Keep the home hero inside the same header/body width */
.home-page .hero {
  grid-template-columns: 330px minmax(0, 1fr) !important;
  gap: 38px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Keep principal section aligned to same width */
.home-page .principal {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* About page sections use the same visual width */
.about-page .feature-grid,
.about-page .category-grid,
.about-page .content-section > h2 {
  max-width: var(--page-width) !important;
}

/* Projects page already close; make exact */
.projects-page .site-header,
.projects-page .content-section,
.projects-page .page-title,
.projects-page .project-img {
  max-width: var(--page-width) !important;
}

.projects-page .project-img {
  width: 100% !important;
}

/* Contact page width alignment */
.contact-form {
  max-width: 520px !important;
}

/* Responsive: keep safe padding on smaller screens */
@media(max-width:1180px){
  .site-header,
  .content-section,
  .page-title,
  .home-page .hero,
  .home-page .principal {
    max-width: 100% !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  .home-page .hero {
    grid-template-columns: 1fr !important;
  }

  .home-page .principal {
    grid-template-columns: 1fr !important;
  }
}

@media(max-width:700px){
  .site-header {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .content-section,
  .page-title,
  .home-page .hero,
  .home-page .principal {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }
}


/* V28: Reusable footer placeholder */
#site-footer {
  width: 100%;
}


/* V29: Footer includes the stats strip on every page */
#site-footer .stats {
  margin-top: 0 !important;
}

#site-footer footer {
  margin-top: 0 !important;
}


/* V30: stable reusable footer + green stats strip on all pages */
#site-footer {
  width: 100%;
  display: block;
  clear: both;
  margin: 0;
  padding: 0;
}

/* The green stats strip belongs to the footer and must be full width */
#site-footer .stats {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 14px 0 18px !important;
  background: #1e4b41 !important;
  color: #ffffff !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 0 !important;
  box-sizing: border-box !important;
}

/* Keep the four footer stats evenly spaced and stable */
#site-footer .stats div {
  text-align: center !important;
  padding: 0 12px !important;
  margin: 0 !important;
  border: 0 !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

/* Footer icon style */
#site-footer .stats img {
  display: block !important;
  height: 24px !important;
  width: auto !important;
  max-width: 56px !important;
  object-fit: contain !important;
  opacity: 0.55 !important;
  margin: 0 auto 8px !important;
}

/* Footer stat text style */
#site-footer .stats p {
  margin: 0 !important;
  padding: 0 !important;
  color: #ffffff !important;
  font-size: 13px !important;
  line-height: 1.25 !important;
  letter-spacing: 0.02em !important;
  font-weight: 700 !important;
}

/* The dark footer should attach directly under the green stats strip */
#site-footer footer {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  background: #2f2e31 !important;
  color: #f2f0eb !important;
  border-top: 0 !important;
  box-sizing: border-box !important;
}

/* Keep footer content centered without shrinking the green strip itself */
#site-footer .footer-inner {
  max-width: 1085px !important;
  margin: 0 auto !important;
  box-sizing: border-box !important;
}

/* Mobile footer behavior */
@media (max-width: 700px) {
  #site-footer .stats {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    row-gap: 18px !important;
    padding: 18px 10px 22px !important;
  }

  #site-footer .stats img {
    height: 22px !important;
    margin-bottom: 7px !important;
  }

  #site-footer .stats p {
    font-size: 12px !important;
    line-height: 1.25 !important;
  }

  #site-footer .footer-inner {
    padding-left: 22px !important;
    padding-right: 22px !important;
  }
}


/* V31: footer green stats strip - full background, page-width inner content */
#site-footer .stats {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 14px 0 18px !important;
  background: #1e4b41 !important;
  color: #ffffff !important;
  display: block !important;
  box-sizing: border-box !important;
}

#site-footer .stats-inner {
  width: 100% !important;
  max-width: 1085px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 0 !important;
  box-sizing: border-box !important;
}

#site-footer .stats-inner > div {
  text-align: center !important;
  padding: 0 12px !important;
  margin: 0 !important;
  border: 0 !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

#site-footer .stats-inner img {
  display: block !important;
  height: 24px !important;
  width: auto !important;
  max-width: 56px !important;
  object-fit: contain !important;
  opacity: 0.55 !important;
  margin: 0 auto 8px !important;
}

#site-footer .stats-inner p {
  margin: 0 !important;
  padding: 0 !important;
  color: #ffffff !important;
  font-size: 13px !important;
  line-height: 1.25 !important;
  letter-spacing: 0.02em !important;
  font-weight: 700 !important;
}

/* dark footer: full width background, page-width content */
#site-footer footer {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  background: #2f2e31 !important;
  color: #f2f0eb !important;
  border-top: 0 !important;
  box-sizing: border-box !important;
}

#site-footer .footer-inner {
  max-width: 1085px !important;
  margin: 0 auto !important;
  box-sizing: border-box !important;
}

/* mobile footer stats */
@media (max-width: 1180px) {
  #site-footer .stats-inner,
  #site-footer .footer-inner {
    max-width: 100% !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
}

@media (max-width: 700px) {
  #site-footer .stats-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    row-gap: 18px !important;
  }

  #site-footer .stats {
    padding: 18px 0 22px !important;
  }

  #site-footer .stats-inner img {
    height: 22px !important;
    margin-bottom: 7px !important;
  }

  #site-footer .stats-inner p {
    font-size: 12px !important;
    line-height: 1.25 !important;
  }
}


/* V32: Stable reusable footer. Unique classes avoid old .stats conflicts. */
#site-footer {
  width: 100%;
  display: block;
  clear: both;
  margin: 0;
  padding: 0;
}

/* Full-width green background */
.footer-stats-strip {
  width: 100% !important;
  background: #1e4b41 !important;
  margin: 0 !important;
  padding: 14px 0 18px !important;
  box-sizing: border-box !important;
}

/* Page-width content inside the green strip */
.footer-stats-inner {
  width: 100% !important;
  max-width: 1085px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  align-items: start !important;
  justify-items: center !important;
  column-gap: 0 !important;
  row-gap: 0 !important;
  box-sizing: border-box !important;
}

.footer-stat-item {
  width: 100% !important;
  text-align: center !important;
  padding: 0 12px !important;
  margin: 0 !important;
  box-sizing: border-box !important;
}

.footer-stat-item img {
  display: block !important;
  height: 24px !important;
  width: auto !important;
  max-width: 56px !important;
  object-fit: contain !important;
  opacity: 0.55 !important;
  margin: 0 auto 8px !important;
}

.footer-stat-item p {
  margin: 0 !important;
  padding: 0 !important;
  color: #ffffff !important;
  font-size: 13px !important;
  line-height: 1.25 !important;
  letter-spacing: 0.02em !important;
  font-weight: 700 !important;
}

/* Dark footer */
.footer-main {
  width: 100% !important;
  background: #2f2e31 !important;
  color: #f2f0eb !important;
  margin: 0 !important;
  padding: 42px 0 34px !important;
  border: 0 !important;
  box-sizing: border-box !important;
}

.footer-main .footer-inner {
  max-width: 1085px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: 320px 1fr 80px !important;
  gap: 60px !important;
  align-items: center !important;
  box-sizing: border-box !important;
}

.footer-main .footer-title {
  font-family: Georgia, "Times New Roman", serif !important;
  font-style: italic !important;
  font-size: 58px !important;
  line-height: .95 !important;
  font-weight: 400 !important;
  color: #f4f0ea !important;
}

.footer-main .footer-info p {
  margin: 0 0 10px !important;
  font-size: 17px !important;
  line-height: 1.45 !important;
  color: #ece7df !important;
}

.footer-main .footer-info p.small {
  font-size: 14px !important;
  color: #ddd5ca !important;
}

.footer-main a {
  color: #ece7df !important;
  text-decoration: none !important;
}

.footer-main a:hover {
  text-decoration: underline !important;
}

.footer-main .footer-social {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #ffffff !important;
  font-size: 28px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  border: 0 !important;
  width: auto !important;
  height: auto !important;
}

@media (max-width: 1180px) {
  .footer-stats-inner,
  .footer-main .footer-inner {
    max-width: 100% !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
}

@media (max-width: 700px) {
  .footer-stats-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    row-gap: 18px !important;
  }

  .footer-stats-strip {
    padding: 18px 0 22px !important;
  }

  .footer-stat-item img {
    height: 22px !important;
    margin-bottom: 7px !important;
  }

  .footer-stat-item p {
    font-size: 12px !important;
  }

  .footer-main .footer-inner {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    text-align: center !important;
  }

  .footer-main .footer-title {
    font-size: 48px !important;
  }
}


/* V33 FINAL FOOTER FIX
   Full-width background, but all footer content follows the same 1085px page width.
   Uses unique IDs/classes so no old .stats/footer CSS can disturb it.
*/
#site-footer {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  clear: both !important;
}

/* Green area background */
#footer-stats-strip {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 18px 0 20px !important;
  background: #1e4b41 !important;
  box-sizing: border-box !important;
}

/* Green area content follows page/header width */
#footer-stats-strip .footer-width {
  width: 1085px !important;
  max-width: 1085px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  align-items: start !important;
  justify-items: center !important;
  column-gap: 0 !important;
  box-sizing: border-box !important;
}

#footer-stats-strip .footer-stat {
  width: 100% !important;
  display: block !important;
  text-align: center !important;
  padding: 0 !important;
  margin: 0 !important;
  box-sizing: border-box !important;
}

#footer-stats-strip .footer-stat img {
  display: block !important;
  width: auto !important;
  height: 26px !important;
  max-width: 60px !important;
  margin: 0 auto 8px !important;
  object-fit: contain !important;
  opacity: 0.55 !important;
}

#footer-stats-strip .footer-stat p {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #ffffff !important;
  font-size: 14px !important;
  line-height: 1.28 !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
  text-align: center !important;
}

/* Dark footer background */
#footer-main-area {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 42px 0 34px !important;
  background: #2f2e31 !important;
  color: #f2f0eb !important;
  box-sizing: border-box !important;
  border: 0 !important;
}

/* Dark footer content follows page/header width */
#footer-main-area .footer-width {
  width: 1085px !important;
  max-width: 1085px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: 320px 1fr 80px !important;
  gap: 60px !important;
  align-items: center !important;
  box-sizing: border-box !important;
}

#footer-main-area .footer-title {
  font-family: Georgia, "Times New Roman", serif !important;
  font-style: italic !important;
  font-size: 58px !important;
  line-height: .95 !important;
  font-weight: 400 !important;
  color: #f4f0ea !important;
  margin: 0 !important;
  padding: 0 !important;
}

#footer-main-area .footer-info {
  margin: 0 !important;
  padding: 0 !important;
}

#footer-main-area .footer-info p {
  margin: 0 0 10px !important;
  padding: 0 !important;
  color: #ece7df !important;
  font-size: 17px !important;
  line-height: 1.45 !important;
}

#footer-main-area .footer-info p.small {
  font-size: 14px !important;
  color: #ddd5ca !important;
  margin-bottom: 0 !important;
}

#footer-main-area a {
  color: #ece7df !important;
  text-decoration: none !important;
}

#footer-main-area a:hover {
  text-decoration: underline !important;
}

#footer-main-area .footer-social {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
  height: auto !important;
  border: 0 !important;
  border-radius: 0 !important;
  color: #ffffff !important;
  font-size: 28px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Responsive footer */
@media (max-width: 1180px) {
  #footer-stats-strip .footer-width,
  #footer-main-area .footer-width {
    width: auto !important;
    max-width: none !important;
    margin-left: 20px !important;
    margin-right: 20px !important;
  }
}

@media (max-width: 700px) {
  #footer-stats-strip {
    padding: 18px 0 22px !important;
  }

  #footer-stats-strip .footer-width {
    grid-template-columns: repeat(2, 1fr) !important;
    row-gap: 18px !important;
  }

  #footer-stats-strip .footer-stat img {
    height: 22px !important;
  }

  #footer-stats-strip .footer-stat p {
    font-size: 12px !important;
  }

  #footer-main-area .footer-width {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    text-align: center !important;
  }

  #footer-main-area .footer-title {
    font-size: 48px !important;
  }
}


/* V34: final stable footer stats layout */
#shady-footer-stats {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 16px 0 18px !important;
  background: #1e4b41 !important;
  box-sizing: border-box !important;
  display: block !important;
}

#shady-footer-stats .shady-footer-stats-inner {
  width: 1085px !important;
  max-width: 1085px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  flex-wrap: nowrap !important;
}

#shady-footer-stats .shady-footer-stat {
  flex: 0 0 25% !important;
  width: 25% !important;
  max-width: 25% !important;
  min-width: 0 !important;
  display: block !important;
  text-align: center !important;
  padding: 0 10px !important;
  margin: 0 !important;
  box-sizing: border-box !important;
}

#shady-footer-stats .shady-footer-stat img {
  display: block !important;
  height: 24px !important;
  width: auto !important;
  max-width: 58px !important;
  object-fit: contain !important;
  opacity: 0.55 !important;
  margin: 0 auto 8px !important;
}

#shady-footer-stats .shady-footer-stat p {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #ffffff !important;
  font-size: 13px !important;
  line-height: 1.25 !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
  text-align: center !important;
}

/* V34: dark footer uses the same width */
#shady-footer-main {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 42px 0 34px !important;
  background: #2f2e31 !important;
  color: #f2f0eb !important;
  box-sizing: border-box !important;
  display: block !important;
  border: 0 !important;
}

#shady-footer-main .shady-footer-main-inner {
  width: 1085px !important;
  max-width: 1085px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 60px !important;
  box-sizing: border-box !important;
}

#shady-footer-main .footer-title {
  flex: 0 0 320px !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-style: italic !important;
  font-size: 58px !important;
  line-height: .95 !important;
  font-weight: 400 !important;
  color: #f4f0ea !important;
  margin: 0 !important;
  padding: 0 !important;
}

#shady-footer-main .footer-info {
  flex: 1 1 auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

#shady-footer-main .footer-info p {
  margin: 0 0 10px !important;
  padding: 0 !important;
  color: #ece7df !important;
  font-size: 17px !important;
  line-height: 1.45 !important;
}

#shady-footer-main .footer-info p.small {
  font-size: 14px !important;
  color: #ddd5ca !important;
  margin-bottom: 0 !important;
}

#shady-footer-main .footer-social {
  flex: 0 0 80px !important;
  display: block !important;
  text-align: center !important;
  color: #ffffff !important;
  font-size: 28px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  border: 0 !important;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

#shady-footer-main a {
  color: #ece7df !important;
  text-decoration: none !important;
}

@media (max-width: 1180px) {
  #shady-footer-stats .shady-footer-stats-inner,
  #shady-footer-main .shady-footer-main-inner {
    width: auto !important;
    max-width: none !important;
    margin-left: 20px !important;
    margin-right: 20px !important;
  }
}

@media (max-width: 700px) {
  #shady-footer-stats .shady-footer-stats-inner {
    flex-wrap: wrap !important;
  }

  #shady-footer-stats .shady-footer-stat {
    flex: 0 0 50% !important;
    width: 50% !important;
    max-width: 50% !important;
    margin-bottom: 18px !important;
  }

  #shady-footer-main .shady-footer-main-inner {
    flex-direction: column !important;
    text-align: center !important;
    gap: 24px !important;
  }

  #shady-footer-main .footer-title,
  #shady-footer-main .footer-info,
  #shady-footer-main .footer-social {
    flex: 0 0 auto !important;
  }

  #shady-footer-main .footer-title {
    font-size: 48px !important;
  }
}


/* V35: green footer stats strip removed for now */
#shady-footer-stats,
#footer-stats-strip,
.footer-stats-strip,
.stats-inner,
.footer-stats-inner {
  display: none !important;
}


/* V36: thin green separator line above the dark footer */
#site-footer {
  border-top: 2mm solid #1e4b41 !important;
}

#site-footer #shady-footer-main,
#site-footer .footer-main,
#site-footer footer {
  margin-top: 0 !important;
}


/* V37: footer separator line included inside reusable footer.html */
.footer-green-separator {
  display: block !important;
  width: 100% !important;
  height: 2mm !important;
  background: #1e4b41 !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0 !important;
  font-size: 0 !important;
}

/* Prevent duplicate border effect from older v36 CSS */
#site-footer {
  border-top: 0 !important;
}


/* V38: Contact page title cleanup */
.contact-page .page-title {
  font-size: 34px !important;
  line-height: 1.1 !important;
  letter-spacing: .08em !important;
  margin-top: 48px !important;
  margin-bottom: 28px !important;
  color: #123f37 !important;
  white-space: nowrap !important;
}


/* V40: Footer BE IN TOUCH is now a link to Contact page */
.footer-title-link,
.footer-title-link:visited,
.footer-title-link:hover,
.footer-title-link:active {
  color: #f4f0ea !important;
  text-decoration: none !important;
  cursor: pointer !important;
}


/* V41: About page service/category icons link to Projects page */
.about-page .category-link,
.about-page .category-link:visited,
.about-page .category-link:hover,
.about-page .category-link:active {
  display: block !important;
  color: inherit !important;
  text-decoration: none !important;
  cursor: pointer !important;
}

.about-page .category-link:hover .category h3 {
  text-decoration: underline !important;
}


/* V42: Keep footer title as contact link */
.footer-title-link,
.footer-title-link:visited,
.footer-title-link:hover,
.footer-title-link:active {
  color: #f4f0ea !important;
  text-decoration: none !important;
  cursor: pointer !important;
}

/* V42: Keep About page service/category icons linked to Projects page */
.about-page .category-link,
.about-page .category-link:visited,
.about-page .category-link:hover,
.about-page .category-link:active {
  display: block !important;
  color: inherit !important;
  text-decoration: none !important;
  cursor: pointer !important;
}

.about-page .category-link:hover .category h3 {
  text-decoration: underline !important;
}


/* V45: use a more human handwritten signature image in the principal section */
.signature-image {
  display: block;
  width: 280px;
  max-width: 100%;
  height: auto;
  margin-top: 16px;
}

.signature,
.principal-role {
  display: none;
}
