.hero-about {
      position: relative;
      height: 260px;
      overflow: hidden;
    }

    .hero-about img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    .hero-about-title {
      position: absolute;
      left: 50%;
      bottom: 50%;
      transform: translateX(-50%);
      color: #ffffff;
      font-size: 54px;
      font-weight: 800;
      text-shadow: 0 2px 6px rgba(0, 0, 0, 0.4);
    }
header.hero-about {
    margin-top: 100px;
}
    .cta-banner {
      background: url("../../assets/img/generic/about-bottom-image.png") center/cover no-repeat;
      border-radius: 24px;
      padding: 46px 32px;
      color: #ffffff;
      position: relative;
      overflow: hidden; margin: 30px 0 0 0;
    }

    .cta-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(
        90deg,
        rgba(0, 0, 0, 0.6) 0%,
        rgba(0, 0, 0, 0.2) 55%,
        transparent 100%
      );
    }

    .cta-inner {
      position: relative;
      text-align:center;
    }

    .cta-btn {
      background-color: #ff6a18;
      border: none;
      border-radius: 999px;
      padding: 10px 26px;
      font-weight: 600;
      font-size: 0.96rem;
    }
	
	.cta-inner h3.mb-2 {
    font-size: 30px;
    color: #fff;
}

button.btn.btn-primary.cta-btn {
    background: #FF4E00;
    font-size: 16px;
    font-weight: bold;
    padding: 15px 30px;
    border: 0;
}

/* Toggle Switch */
.switch {
  position: relative;
  width: 46px;
  height: 24px;
}

.switch input {
  display: none;
}

.slider {
  position: absolute;
  background: #ff7a00;
  border-radius: 24px;
  inset: 0;
  cursor: pointer;
}

.slider::before {
  content: "";
  position: absolute;
  height: 18px;
  width: 18px;
  background: #fff;
  border-radius: 50%;
  top: 3px;
  left: 4px;
  transition: .3s;
}

input:checked + .slider::before {
  transform: translateX(22px);
}

.alphabet-filter span.active {
  background: #ffe6cc;
  color: #ff7a00;
}

.branch-title {
    color: #FF4E00;
    font-weight: bold;
    font-size: 16px;
}

.contact {
  margin-top: 12px;
  font-size: 14px;
}

/* Masonry Grid */
.masonry-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.branch-title.accent {
  color: #ff5a00;
}

/* Contact */
.contact {
  margin-top: 14px;
  font-size: 14px;
}

/* Index Number */
.card-index {
  position: absolute;
  bottom: 14px;
  right: 18px;
  font-size: 38px;
  font-weight: 700;
  color: #000;
  opacity: 0.05;
}

/* Responsive */
@media (max-width: 992px) {
  .masonry-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 576px) {
  .masonry-grid {
    grid-template-columns: 1fr;
  }
}



/* Toggle */
.switch {
  position: relative;
  width: 46px;
  height: 24px;
}
.switch input { display: none; }
.slider {
  background: #ff7a00;
  border-radius: 30px;
  position: absolute;
  inset: 0;
  cursor: pointer;
}
.slider::before {
  content: "";
  position: absolute;
  height: 18px;
  width: 18px;
  background: white;
  border-radius: 50%;
  top: 3px;
  left: 4px;
  transition: .3s;
}
input:checked + .slider::before {
  transform: translateX(22px);
}

/* Alphabet */
.alphabet-filter span {
    margin: 4px;
    padding: 6px 10px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 20px;
    color: #000;
    font-weight: 400;
}
.alphabet-filter span.active {
  background: #ffe5cc;
  color: #ff7a00;
}

/* Card */
.branch-card {
    background: #F8F8F8;
    border-radius: 18px;
    padding: 22px;
    margin-bottom: 10px;
    position: relative;
    transition: transform .25s ease, box-shadow .25s ease;
}

/* Hover Micro-interaction */
.branch-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 3px 5px rgba(0, 0, 0, .05);
}

.branch-title {
  color: #ff7a00;
  font-weight: 600;
}

.contact {
    font-size: 16px;
    margin-top: 12px;
    color: #000;
}

.index {
  position: absolute;
  bottom: 20px;
  right: 18px;
  font-size: 36px;
  font-weight: 700;
  opacity: .7;
}

.index {
    float: right;
    font-size: 50px;
    color: #D9D9D9;
    font-weight: bold;
}

.branch-card p {
    color: #000;
    font-size: 16px;
    line-height: normal;
}


.fw-semibold {
    font-weight: bold;
    color: #000;
    font-size: 30px;
}

.d-flex.justify-content-center.align-items-center.gap-3.mb-4 {
    padding: 0 0 40px 0;
}

#alphabetFilter {
    padding: 0 0 30px 0;
}