@media (max-width: 1024px) {
  footer {
    text-align: center;
  }
}
footer .copyright {
  background: #fafafa;
  padding: 15px 0;
  text-align: center;
}
footer .copyright span {
  font-family: "Poppins";
  color: #202020;
  font-size: 14px;
  font-weight: 300;
}
footer .copyright a {
  font-family: "Poppins";
  font-weight: 500;
  color: #202020;
  font-size: clamp(11px, calc(11px + (13 - 11) * ((100vw - 576px) / (1440 - 576))), 13px);
  vertical-align: baseline !important;
}
footer .copyright a:hover {
  color: #8c8c8c;
}
footer > .row1375 {
  width: 1920px;
  max-width: 100%;
  padding: 30px 0;
}
@media (max-width: 767px) {
  footer > .row1375 {
    padding: 0 0 30px;
  }
}
footer > .row1375 > .flex {
  flex-basis: 25%;
  position: relative;
  padding: 20px;
}
@media (max-width: 1024px) {
  footer > .row1375 > .flex {
    flex-basis: 100%;
    padding: 0 20px 0;
  }
}
footer > .row1375 > .flex:before {
  content: "";
  width: 1px;
  height: 100%;
  background: #4a4a4a;
  position: absolute;
  top: 0;
  right: 0;
}
@media (max-width: 1024px) {
  footer > .row1375 > .flex:before {
    display: none;
  }
}
footer > .row1375 > .flex:last-child::before {
  display: none;
}
@media (max-width: 1024px) {
  footer > .row1375 .brochure {
    padding: 0 65px 30px;
  }
}
@media (max-width: 1024px) {
  footer .main_nav_wrap {
    margin: 10px 0 20px;
  }
}
footer .main_nav_wrap .main_nav {
  margin: 0;
  padding: 0 0 0 40px;
}
@media (max-width: 1024px) {
  footer .main_nav_wrap .main_nav {
    padding: 0 0 0 0;
  }
}
footer .main_nav_wrap .main_nav ul li {
  display: block;
  text-align: left;
  margin: 0;
}
footer .main_nav_wrap .main_nav ul li a {
  padding: 5px 0;
}
@media (max-width: 1024px) {
  footer .main_nav_wrap .main_nav ul li a {
    text-align: center;
    display: block;
    font-size: 14px;
  }
}
footer .address-footer {
  align-items: flex-start;
}
footer .address-footer > div {
  margin-bottom: 10px;
  width: 100%;
}
@media (max-width: 1024px) {
  footer .address-footer > div {
    margin-bottom: 20px;
  }
}
footer .address-footer > div p {
  font-family: "Poppins";
  font-weight: 400;
  font-size: 10px;
  line-height: 1.3;
  padding-bottom: 0;
  color: #102342;
}
@media (max-width: 1024px) {
  footer .address-footer > div p {
    font-size: 12px;
  }
}
footer .address-footer > div p a {
  font-family: "Poppins";
  font-weight: 400;
  font-size: 12px;
  line-height: 1.5;
  padding-bottom: 0;
  color: #102342;
}
footer .brochure img {
  padding: 0 20px;
}
@media (max-width: 1024px) {
  footer .brochure img {
    padding: 0 0;
  }
}
footer .footer-title {
  font-family: "Poppins";
  font-weight: 500;
  font-size: 15px;
  color: #4a4a4a;
  display: block;
  margin-bottom: 10px;
}
.social-icons {
  cursor: pointer;
  display: inline-block;
  font-size: 0;
  text-align: center;
}
@media (max-width: 1024px) {
  .social-icons {
    width: 100%;
  }
}
.social-icons a {
  display: inline-block;
  position: relative;
  -webkit-transition: all 0.3s ease;
  -khtml-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
  font-size: 20px;
  margin: 0 10px;
  width: 20px;
  height: 20px;
  background: transparent;
  border-radius: 5px;
  color: #102342;
}
.social-icons a:first-child {
  margin-left: 0;
}
.social-icons a:last-child {
  margin-right: 0;
}
.social-icons a i {
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  color: #fff;
  -webkit-transition: all 0.3s ease;
  -khtml-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.social-icons a:hover {
  color: #4a4a4a;
}
.social-icons a:hover i {
  color: #4a4a4a;
}

/* === Footer layout overrides (from style.css) === */
/* ================================
   Footer — 4-Column Layout
   ================================ */

/* Desktop: 4-column horizontal layout */
footer > .row1375.flex {
  flex-wrap: nowrap;
  align-items: stretch;
}

/* All footer columns — equal padding, relative for dividers */
footer > .row1375.flex > div {
  flex: 1 1 25%;
  padding: 20px 30px;
  min-width: 0;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* Divider lines — stretch between columns */
footer > .row1375.flex > div:not(:last-child):after {
  content: "";
  width: 1px;
  background: #4a4a4a;
  position: absolute;
  top: 15px;
  bottom: 15px;
  right: 0;
}

/* Kill all theme :before dividers (m.css) */
footer .logo-footer-wrap:before,
footer .main_nav_wrap:before,
footer .address-footer:before,
footer > .row1375.flex > div:before,
footer > .row1375 > .flex:before {
  display: none !important;
}

/* Column 1: Logo */
footer .logo-footer-wrap {
  align-items: flex-start;
}
footer .logo-footer {
  display: inline-block;
}
footer .logo-footer img {
  max-width: 180px;
  width: 100%;
  height: auto;
}

/* Column 2: Navigation */
footer .main_nav_wrap {
  align-items: flex-start;
  margin: 0 !important;
}
footer .main_nav_wrap .main_nav {
  padding-left: 0 !important;
  margin-left: 0 !important;
  width: 100%;
}

/* Desktop nav alignment */
@media (min-width: 1001px) {
  footer .main_nav_wrap .main_nav,
  footer .main_nav_wrap .main_nav ul,
  footer .main_nav_wrap .main_nav li,
  footer .main_nav_wrap .main_nav a {
    padding-left: 0 !important;
    margin-left: 0 !important;
    text-align: left !important;
    text-indent: 0 !important;
  }
}

/* Column 3: Address / Contact */
footer .address-footer {
  align-items: flex-start;
}

/* Column 4: Social Icons */
footer > .row1375.flex > div:last-child {
  align-items: flex-start;
  justify-content: center;
}
footer > .row1375.flex > div:last-child:before {
  display: none !important;
}
footer .social-icons {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  gap: 15px;
}
footer .social-icons:before,
footer .social-icons:after {
  display: none !important;
}
footer .social-icons a {
  display: inline-block !important;
  margin: 0 !important;
}

/* Footer: Tablet — stack at 1000px */
@media (max-width: 1000px) {
  footer > .row1375.flex {
    flex-wrap: wrap !important;
    align-items: center;
  }
  footer > .row1375.flex > div {
    flex: 1 1 100% !important;
    width: 100% !important;
    padding: 20px 30px !important;
    text-align: center;
    align-items: center !important;
  }
  /* Hide all dividers */
  footer > .row1375.flex > div:not(:last-child):after,
  footer > .row1375.flex > div:before,
  footer > .row1375.flex > div:after,
  footer > .row1375 > .flex:before {
    display: none !important;
  }
  footer .logo-footer-wrap {
    justify-content: center;
    align-items: center !important;
  }
  footer .logo-footer img {
    max-width: 200px;
  }
  footer .main_nav_wrap {
    margin: 0 !important;
    align-items: center !important;
  }
  footer .main_nav_wrap .main_nav,
  footer .main_nav_wrap .main_nav ul,
  footer .main_nav_wrap .main_nav li,
  footer .main_nav_wrap .main_nav a {
    text-align: center !important;
    padding-left: 0 !important;
    margin-left: 0 !important;
  }
  footer .main_nav_wrap .main_nav ul li a {
    display: block;
    font-size: 14px;
  }
  footer .address-footer {
    text-align: center;
    align-items: center !important;
  }
  footer .social-icons {
    justify-content: center;
    width: 100%;
    padding: 0;
    margin: 0;
  }
  footer .social-icons a {
    margin: 0 !important;
  }
}

/* Footer: Mobile */
@media (max-width: 767px) {
  footer > .row1375.flex {
    align-items: stretch;
  }
  footer > .row1375.flex > div {
    flex: 1 1 100% !important;
    width: 100% !important;
    padding: 20px !important;
    text-align: center;
    align-items: center !important;
  }
  footer > .row1375.flex > div:not(:last-child):after {
    display: none !important;
  }
  footer > .row1375.flex > div:before,
  footer > .row1375.flex > div:after,
  footer .logo-footer-wrap:before,
  footer .logo-footer-wrap:after,
  footer .main_nav_wrap:before,
  footer .main_nav_wrap:after,
  footer .address-footer:before,
  footer .address-footer:after,
  footer > .row1375.flex > div:last-child:before,
  footer > .row1375.flex > div:last-child:after {
    display: none !important;
  }
  footer .logo-footer-wrap {
    justify-content: center;
  }
  footer .logo-footer img {
    max-width: 200px;
  }
  footer .main_nav_wrap,
  footer .address-footer {
    text-align: center;
  }
  footer .social-icons {
    justify-content: center;
    width: 100%;
    padding: 0;
    margin: 0;
  }
  footer .social-icons a {
    margin: 0 !important;
  }
}
