.city-page {
  background: #001827;
  color: white;
  overflow-x: hidden;
}

.city-hero,
.city-trust,
.city-services,
.city-projects-section {
  /* max-width: 1300px; */
  margin: 0 auto;
  padding: 24px 20px;
  padding-left:5%;
  padding-right:5%;
}

.city-hero {
  min-height: 430px;
  display: flex;
  align-items: center;
}

.city-hero-content {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 28px;
  align-items: center;
}

.city-eyebrow {
  color: #20c7ff;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 1px;
}

.city-hero h1 {
  font-size: clamp(36px, 5vw, 62px);
  line-height: 1.02;
  margin: 10px 0 18px;
}

.city-hero p {
  max-width: 560px;
  font-size: 16px;
  line-height: 1.6;
  color: #d9ecf7;
}

.city-hero-buttons {
  display: flex;
  gap: 12px;
  margin-top: 24px;
}

.city-btn {
  padding: 14px 22px;
  border-radius: 10px;
  text-decoration: none;
  font-weight: 800;
  font-size: 14px;
  text-transform: uppercase;
}

.city-btn.primary {
  background: linear-gradient(135deg, #00aeff, #006dff);
  color: white;
}

.city-btn.outline {
  border: 1px solid rgba(255,255,255,.4);
  color: white;
}

section{
  padding-bottom:20px;
}

.city-hero-image img {
  width: 100%;
  max-height: 360px;
  object-fit: cover;
  border-radius: 18px;
}

.city-trust {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

.city-trust div {
  border: 1px solid rgba(36, 196, 255, .35);
  border-radius: 12px;
  padding: 18px;
  background: #041f36;
  justify-content: center;
}

.city-trust strong {
  font-size:18px;
  }

.city-trust span {
  display: block;
  color: #b7d6e9;
  font-size: 16px;
  margin-top: 4px;
}

.city-services h2,
.section-header h2 {
  text-align: center;
  font-size: 28px;
  margin: 0;
}

.service-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
  margin-top: 22px;
}

.service-grid article,
.client-card,
.ba-card,
.panel {
  padding:10px;
  background: linear-gradient(180deg, #06243b, #021526);
  border: 1px solid rgba(36, 196, 255, .28);
  border-radius: 12px;
}

.ba-h3{
  padding-top:20px;
  /* margin-top:50px; */
}

.service-grid article {
  padding: 18px 14px;
  text-align: center;
}

.service-grid h3 {
  font-size: 15px;
  line-height: 1.25;
}

.service-grid p {
  font-size: 13px;
  color: #c6dcec;
}

.service-grid a {
  color: #21c6ff;
  font-size: 13px;
  text-decoration: none;
}

.section-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 14px 0 18px;
}

.section-header span {
  height: 1px;
  background: #1089bd;
  flex: 1;
}

.section-header a {
  color: #20c7ff;
  font-size: 14px;
  text-decoration: none;
  white-space: nowrap;
}

.client-scroll,
.before-after-scroll {
  display: grid;
  grid-auto-flow: column;
  gap: 18px;
  overflow-x: auto;
  padding-bottom: 12px;
  scroll-snap-type: x mandatory;
}

.client-scroll {
  grid-auto-columns: 340px;
}

.before-after-scroll {
  grid-auto-columns: 360px;
}

.client-card,
.ba-card {
  overflow: hidden;
  color: white;
  text-decoration: none;
  scroll-snap-align: start;
}

.client-img {
  height: 150px;
  position: relative;
}

.client-img img,
.ba-images img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.client-img span,
.ba-images span {
  position: absolute;
  left: 10px;
  bottom: 10px;
  background: #078ed7;
  padding: 5px 8px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 700;
}

.client-body,
.ba-card h3,
.ba-card p {
  padding-left: 14px;
  padding-right: 14px;
}

.client-body {
  padding-top: 12px;
  padding-bottom: 14px;
}

.client-body h3,
.ba-card h3 {
  font-size: 16px;
  margin: 0 0 6px;
}

.client-body p,
.ba-card p {
  color: #b9d5e7;
  font-size: 13px;
  margin: 0 0 10px;
}

.client-body small {
  color: #20c7ff;
}

.ba-card {
  border: 1px solid rgba(36, 196, 255, .28);
  cursor: pointer;
  text-align: left;
  padding: 0 0 14px;
}

.ba-images {
  display: grid;
  grid-template-columns: 1fr 1fr;
  height: 135px;
}

.ba-images div {
  position: relative;
}

.bottom-grid {
  display: grid;
  grid-template-columns: 1.15fr 1.45fr .9fr;
  gap: 16px;
  margin-top: 22px;
  align-items: stretch;
}

.panel {
  padding: 16px;
  min-height: 250px;
}

.panel h2 {
  font-size: 18px;
  margin: 0 0 14px;
}

.faq-scroll {
  max-height: 220px;
  overflow-y: auto;
}

details {
  background: #031d32;
  border: 1px solid rgba(36, 196, 255, .25);
  border-radius: 8px;
  margin-bottom: 8px;
}

summary {
  padding: 10px;
  cursor: pointer;
  font-size: 13px;
}

details p {
  padding: 0 10px 10px;
  color: #bed7e8;
  font-size: 13px;
}

.map-layout {
  display: grid;
  grid-template-columns: 1.4fr .9fr;
  gap: 14px;
}

#serviceMap {
  min-height: 205px;
  border-radius: 10px;
  overflow: hidden;
  background: #102c40;
}

.area-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.area-list li {
  font-size: 13px;
  margin-bottom: 8px;
}

.area-list li::before {
  content: "✓";
  color: #20c7ff;
  margin-right: 8px;
}

.quote-panel {
  text-align: center;
}

.knight-icon {
  width: 80px;
  max-width: 100%;
  margin-bottom: 10px;
}

.quote-btn {
  display: inline-block;
  margin-top: 12px;
  background: linear-gradient(135deg, #00aeff, #006dff);
  color: white;
  padding: 13px 18px;
  border-radius: 10px;
  text-decoration: none;
  font-weight: 800;
  text-transform: uppercase;
  font-size: 13px;
}

@media (max-width: 1100px) {
  .service-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .bottom-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .city-hero-content {
    grid-template-columns: 1fr;
  }

  .city-trust {
    grid-template-columns: 1fr 1fr;
  }

  .service-grid {
    grid-template-columns: 1fr 1fr;
  }

  .client-scroll {
    grid-auto-columns: 82%;
  }

  .before-after-scroll {
    grid-auto-columns: 88%;
  }

  .map-layout {
    grid-template-columns: 1fr;
  }
}
