.custom-container {
  margin: 0 auto;
}
.row {
  margin: 0;
}
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/* BANNER */
#banner {
  background-image: url(/assets/img/impact-hero-img.jpg);
}

/* COMMITMENT */
section#commitment {
  padding: 90px 64px;
}
#commitment .row {
  display: flex;
  gap: 60px;
  flex-wrap: nowrap;
}
#commitment .row .col-left {
  width: 25%;
}
#commitment .row .col-right {
  width: 70%;
}
#commitment .col-left .sub-heading p {
  font-size: 16px;
  font-weight: 700;
  line-height: 24px;
  margin: 0;
  padding: 0 0 16px;
}
#commitment .col-left .heading h2 {
  font-weight: 300;
  font-size: 48px;
  line-height: 57.6px;
  color: #595378;
  margin: 0;
}
#commitment .col-right .description p {
  font-weight: 400;
  font-size: 18px;
  line-height: 27px;
  color: var(--secondary-color);
}
#commitment .two-col {
  display: flex;
  align-items: center;
}
#commitment .two-col p {
  padding-left: 32px;

}
.sustainability-report {
  display: block;
  width: fit-content;
  color: #595378;
  font-size: 16px;
  line-height: 24px;
  font-weight: 700;
  font-family: 'Montserrat', sans-serif;
  padding: 12px 44px;
  border: 2px solid #595378;
  margin-left: auto;
  margin-top: 12px;

}
.sustainability-report:hover {
  background: #595378;
  color: #fff;
  text-decoration: none;
}
.author-box {
  display: flex;
  align-items: center;
  gap: 25px;
  margin-bottom: 25px;
  padding: 25px;
  background: var(--primary-color);
}
.author-box div:first-child {
  width: 45%;
}
.author-box .author {
  font-weight: 700;
  color: var(--white);
}
.author-box img {
  background: var(--grey);
  border-radius: var(--border-radius);
  max-width: 220px;
  height: 220px;
  object-fit: cover;
}
.author-box p {
  color: var(--white) !important;
}
/* OUR APPROACH */
section#approach {
  padding: 90px 64px;
  background: #FFFFFF;
}
#approach .row {
  display: flex;
  gap: 60px;
  flex-wrap: nowrap;
}
#approach .row .col-left {
  width: 25%;
}
#approach .row .col-right {
  width: 70%;
}
#approach .col-left .sub-heading p {
  font-size: 16px;
  font-weight: 700;
  line-height: 24px;
  margin: 0;
  padding: 0 0 16px;
  color: #000000;
}
#approach .col-left .heading h2 {
  font-weight: 300;
  font-size: 48px;
  line-height: 57.6px;
  color: #595378;
  margin: 0;
}
#approach .col-right .description p {
  font-weight: 400;
  font-size: 18px;
  line-height: 27px;
  color: #000000;
}
#approach .col-right .description ul {
  padding-left: 30px;
}
#approach .col-right .description ul li {
  font-weight: 400;
  font-size: 18px;
  line-height: 27px;
  color: #000000;
}

.slider .item .card-title {
  color: #595378;
  font-weight: 700;
  font-size: 20px;
  line-height: 30px;
}
.slider li p {
  padding-top: 10px;
}
.owl-item .item {
  padding: 25px !important;
  border: 3px solid #696386;
  border-radius: var(--border-radius);
}

.custom-nav button i {
  color: var(--primary-color);
  padding: 5px 8px;
  border-radius: 100px;
  font-size: 20px;
}
button#customPrev, button#customNext {
  background: none;
}
.custom-nav {
  display: flex;
  gap: 25px;
  justify-content: center;
  padding-top: 15px;
}
.custom-pagination {
  display: flex;
  gap: 15px;
  align-items: center;
}
.custom-pagination .bullet {
  width: 10px;
  height: 10px;
  background: black;
  position: relative;
  border-radius: 100px;
}
.custom-pagination .bullet.active::before {
  opacity: 1;
}
.custom-pagination .bullet::before {
  content: '';
  width: 17px;
  height: 17px;
  border: 1px solid #0000005c;
  position: absolute;
  top: 50%;
  left: 50%;
  border-radius: 100px;
  transform: translate(-50%, -50%);
  transition: 0.3s;
  opacity: 0;
}
.approach-cards {
  cursor: pointer;
  gap: 16px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  overflow: hidden;

  @media (max-width: 1280px) {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  @media (max-width: 1024px) {
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 11px;
  }
}
#sub-heading {
  font-weight: 700;
  padding-bottom: 10px;
  font-size: 20px;
}
.approach-card {
  overflow: hidden;
  border-radius: var(--border-radius);
  padding: 66px 34px;
  aspect-ratio: 302/201;
  position: relative;
  border: 3px solid #696386;
  background: #FFF;
  display: flex;
  align-items: center;
  justify-content: center;

  @media (max-width: 1024px) {
    border: 3px solid transparent;
    aspect-ratio: 335/257;
  }
}
.approach-card .title {
  color: #595378;
  font-weight: 700;
  font-size: 28px;
  line-height: 33.6px;
  text-align: center;
  word-break: break-word;
  position: absolute;
}
.approach-card:hover .logo {
  opacity: 1;
}
.approach-card .logo {
  position: absolute;
  top: 0;
  left: 0;
  /* max-width: 302.33px;
    height: 201px; */
  transition: 0.3s;
  opacity: 0;
  width: 100%;
  height: 100%;
}
.approach-card .logo img {
  max-width: 250px;
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.approach-cards {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}
.approach-card {
  padding: 66px 34px;
  background: white;
  width: calc((100% / 3) - 16px);
  position: relative;
  border: 3px solid #696386;
}
.approach-card .title {
  color: #595378;
  font-weight: 700;
  font-size: 28px;
  line-height: 33.6px;
  text-align: center;
  font-family: 'Montserrat', sans-serif;
  word-break: break-word;
}
.approach-card:hover .logo {
  opacity: 1;
}
.approach-card .logo {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  background: #7a7593;
}


@media (max-width: 1024px) {
  #priorities .col-left .heading h2 {
      font-size: 36px;
      line-height: 42px;
  }
  #priorities .row {
      gap: 16px;
  }
  .approach-cards {
      margin-top: 25px;
  }
}
@media (max-width: 767px) {
  .approach-cards {
    justify-content: center;
  }
  .approach-card {
      max-width: 320px;
      width: 100% !important;
  }
  .approach-card .title {
      font-size: 20px;
  }
  .approach-card {
      min-height: 200px;
  }
}

.portfolio-modal .modal-dialog {
  max-width: 1150px;
  inset: 0;
  position: fixed;
  display: flex;
  align-items: center;
  padding: 0px;
}
@media (max-width: 1024px) {
  .portfolio-modal .modal-dialog {
      padding: 0px 10px;
  }
}

.portfolio-modal .modal-dialog:before {
  content: "";
  background: rgba(0, 0, 0, 0.5);
  position: fixed;
  inset: 0;
  z-index: 1;
}

.portfolio-modal .modal-content {
  z-index: 99;
}

.portfolio-modal .close-icon {
  display: flex;
  width: 24px;
  height: 24px;
  padding: 6px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  position: absolute;
  right: 10px;
  top: 9.5px;
  z-index: 99;
  cursor: pointer;
}

.portfolio-modal .close-icon svg {
  fill: #000;
}

.portfolio-modal .modal-body {
  display: flex;
  padding: 50px 50px 32px 50px;
  align-items: flex-start;
  gap: 40px;
  flex-shrink: 0;
  border: 3px solid #595378;
  background: #fff;
  width: 100%;
}

#modal-mobile-title {
  display: none;
}

@media (max-width: 1024px) {
  .portfolio-modal .modal-body {
      padding: 40px 20px 32px 20px;
      align-items: center;
      justify-content: center;
      flex-direction: column;
      gap: 4px;
      flex-shrink: 0;
      border: 3px solid #595378;
      background: #fff;
      width: 100%;
  }

  #modal-mobile-title {
      display: block;
  }
}

.portfolio-modal .modal-body .left {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-bottom: 32px;
  width: 40%;
}

@media (max-width: 1024px) {
  .portfolio-modal .modal-body .left {
      width: 100%;
      padding-bottom: 0px;
  }
}

.portfolio-modal .modal-body .left #modal-mobile-title {
  color: #595378;
  font-size: 36px;
  font-weight: 700;
  line-height: 120%;
  text-transform: uppercase;
}

.portfolio-modal .modal-body .left .logo {
  padding: 24px 32px;
  max-width: 350px;
  height: 100%;
  overflow: hidden;

}
.portfolio-modal .modal-body .left .logo img {
  width: 100%;
}
@media (max-width: 1024px) {
  .portfolio-modal .modal-body .left .logo {
      aspect-ratio: 298 / 169;
      padding: 10px 0px;
      max-height: 169px;
  }
}

.portfolio-modal .modal-body .left .logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.portfolio-modal .modal-body .left .details .item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  width: 100%;
  margin-top: 20px;
}

@media (max-width: 1024px) {
  .portfolio-modal .modal-body .left .details .item {
      flex-direction: column;
      width: fit-content;
      text-align: start;
      align-items: start;
      gap: 10px;
      margin: 0 0 10px 0;
  }
  .portfolio-modal .modal-body .right,
  .portfolio-modal .modal-body .left {
      width: 100% !important;
  }
  .modal-body {
    max-height: 617px;
    overflow: scroll;
  }
}

.portfolio-modal .modal-body .left .details .item .key {
  color: #595378;
  font-size: 16px;
  font-weight: 700;
  line-height: 130%;
  min-width: 124px;
}

.portfolio-modal .modal-body .left .details .item .value {
  color: #212529;
  font-size: 16px;
  font-weight: 400;
  line-height: 130%;
  text-align: left;
  width: 100%;
}

.portfolio-modal .modal-body .right {
  display: block;
  width: 60%;
}

.portfolio-modal .modal-body .right .title {
  color: #595378;
  font-size: 48px;
  font-weight: 700;
  line-height: 120%;
  text-transform: uppercase;
  margin-bottom: 24px;
}

@media (max-width: 1024px) {
  .portfolio-modal .modal-body .right .title {
      display: none;
      margin-bottom: 16px;
  }
}

.portfolio-modal .modal-body .right .description {
  color: #212529;
  font-size: 16px;
  font-weight: 400;
  line-height: 150%;
  margin-bottom: 24px;
}

@media (max-width: 1024px) {
  .portfolio-modal .modal-body .right .description {
      margin-bottom: 16px;
  }
}

.portfolio-modal .modal-body .right .link {
  background: #595378;
  display: none;
  padding: 8px 20px;
  justify-content: center;
  align-items: center;
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  line-height: 150%;
  width: fit-content;
}

.portfolio-modal .modal-body .right .link.show {
  display: flex;
}

.portfolio-modal.show {
  display: block !important;
}

@media (max-width: 1024px) {
  .approach-card {

    .title {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      height: 56px;
      display: flex;
      align-items: center;
      justify-content: center;

      color: var(--Primary-Purple, #595378);
      text-align: center;
      font-size: 20px;
      font-weight: 700;
      line-height: 120%; /* 24px */
    }

    .logo {
      max-width: 100%;
      opacity: 100;

      img {
        height: calc(100% - 56px);
      }
    }
  }
}
section#priorities {
  padding: 0px 64px 90px;
}
#priorities .row {
  display: flex;
  gap: 60px;
  flex-wrap: nowrap;
}
#priorities .row .col-left {
  width: 25%;
}
#priorities .col-left .sub-heading p {
  font-size: 16px;
  font-weight: 700;
  line-height: 24px;
  margin: 0;
  padding: 0 0 16px;
  color: #000000;
}
#priorities .col-left .heading h2 {
  font-weight: 300;
  font-size: 48px;
  line-height: 57.6px;
  color: #595378;
  margin: 0;
}
#priorities ul {
  padding-left: 25px;
}
#priorities .col-right p {
  font-size: 18px;
}
@media (max-width: 1024px) {
  section#priorities {
      padding: 0 20px 70px;
  }
  #priorities .row {
      flex-direction: column;
  }
  #priorities .row .col-left {
      width: 100%;
  }
}
/* FOOTER */
footer {
  padding: 50px 64px 30px;
}
footer .row .col-left,
footer .row .col-right {
  width: 50%;
}
footer .row .col-left {
  display: flex;
  gap: 40px;
}
footer .row .col-left .footer-logo {
  max-width: 165.15px;
  height: 50px;
}
footer .row .col-left .footer-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
footer h5 {
  font-size: 16px;
  line-height: 24px;
  font-weight: 700;
  color: #595378;
}
footer ul li {
  list-style-type: none;
  padding: 8px 0;
}
footer ul li a {
  color: black;
  font-size: 14px;
  line-height: 21px;
  padding: 8px 0;
}
footer .form-group input[type="email"] {
  height: 48px;
  width: 373px;
  border: 1px solid black;
  padding: 12px;
}
footer .form-group button {
  height: 48px;
  width: 145px;
  background: #595378;
  color: white;
  font-size: 16px;
  font-weight: 700;
}

footer .col.subscribe span {
  font-size: 12px;
  line-height: 18px;
  color: black;
  font-weight: 400;
}
.row.top-part {
  padding-bottom: 100px;
}
.row.bottom-part {
  padding-top: 30px;
  border-top: 1px solid #595378;
}
.row.bottom-part p,
.row.bottom-part ul,
.row.bottom-part ul li,
.row.bottom-part ul li a {
  padding-bottom: 0;
  margin-bottom: 0;
  margin-top: 0;
  padding-top: 0;
}
.row.bottom-part .col-left {
  width: 60%;
}
.copyright {
  display: flex;
  align-items: center;
}
.copyright p {
  font-size: 14px;
  line-height: 21px;
}
.copyright ul {
  display: flex;
  gap: 24px;
  padding-left: 24px;
}
.copyright ul li a {
  text-decoration: underline;
  font-size: 14px;
  line-height: 21px;
}

section#approach {
  padding: 0px 64px 90px;
  @media (max-width: 1024px) {
    padding: 0px 20px 70px;
  }
}

@media (max-width: 1024px) {
  #commitment .col-left .heading h2 {
    font-size: 40px;
    line-height: 45px;
  }
  #approach .col-left .heading h2 {
    font-size: 40px;
    line-height: 45px;
  }
}
@media (max-width: 1024px) {
  section#commitment {
    padding: 70px 20px;
  }
  #commitment .row {
    flex-direction: column;
    gap: 20px;
  }
  #commitment .row .col-left,
  #commitment .row .col-right {
    width: 100%;
  }
  #commitment .col-left .heading h2 {
    font-size: 36px;
    line-height: 43.2px;
  }
  #commitment .col-right .description p {
    font-size: 16px;
    line-height: 24px;
  }
  #commitment .two-col {
    flex-direction: column;
    align-items: flex-start;
  }
  #commitment .two-col p {
    padding: 0;
  }
  #commitment a {
    width: 100%;
    text-align: center;
    margin-top: 32px;
  }
  #approach .row {
    flex-direction: column;
  }
  #approach .row .col-left,
  #approach .row .col-right {
    width: 100%;
  }
  #approach .col-left .heading h2 {
    font-size: 36px;
    line-height: 43.2px;
  }
  #approach .row {
    gap: 20px;
  }
  #approach .col-right .description ul li {
    font-size: 16px;
    line-height: 24px;
  }
  #approach .col-right .description p {
    font-size: 16px;
    line-height: 24px;
  }
  .approach-card {
    width: calc((100% / 3) - 16px);
    min-height: 257px;
  }
  .approach-card .logo img {
    width: 100%;
    object-fit: contain;
  }
  footer {
    padding: 47px 20px 30px;
  }
  footer .col {
    margin: 0;
    padding: 0;
  }
  .row.top-part {
    flex-direction: column;
  }
  .row.top-part .col-left,
  .row.top-part .col-right {
    width: 100%;
  }
  footer .row .col-left {
    flex-direction: column;
  }
  footer .form-group input[type="email"] {
    width: 100%;
  }
  footer .form-group button {
    width: 100%;
    padding: 0;
    margin-top: 16px;
  }
  .row.top-part {
    padding-bottom: 48px;
  }
  .copyright {
    flex-direction: column-reverse;
    align-items: flex-start;
  }
  .copyright ul {
    flex-direction: column;
    padding: 0;
    gap: 16px;
  }
  .row.bottom-part .col-left {
    width: 100%;
  }
  .copyright p {
    padding-top: 32px !important;
  }
}
@media (max-width: 1024px) {
  #commitment .two-col {
      flex-direction: column-reverse;
  }
  #banner .sub-heading p {
    width: 100% !important;
  }
  #priorities .col-left .heading h2 {
      font-size: 36px;
      line-height: 43.2px;
  }
  #priorities .row {
    gap: 20px;
  }
}
@media (max-width: 767px) {
  .author-box {
      flex-direction: column;
  }
  .author-box div:first-child {
      width: 100%;
  }
}