/* ================================================================
   CITY LANDING (Epoxy Medan / Jakarta) v1
   ================================================================ */

.city-intro {
  padding: var(--section-y) 0;
}
.city-intro__inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 var(--pad-x);
  display: grid;
  grid-template-columns: 1.4fr 0.9fr;
  gap: clamp(36px, 5vw, 70px);
  align-items: start;
}
.city-intro__title {
  font-family: var(--f-display);
  font-size: clamp(1.8rem, 3.2vw, 2.6rem);
  font-weight: 300;
  line-height: 1.1;
  margin: 14px 0 22px;
}
.city-intro__title em {
  font-style: italic;
  color: var(--gold-2);
}
.city-intro p {
  color: var(--text-2);
  font-size: 0.96rem;
  line-height: 1.85;
  font-weight: 300;
  margin-bottom: 16px;
}
.city-info {
  background: rgba(8,7,10,0.55);
  border: 1px solid var(--gold-line);
  border-radius: 14px;
  padding: 28px;
}
.city-info h3 {
  font-family: var(--f-display);
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  margin: 0 0 18px;
  color: var(--gold-2);
}
.city-info p {
  color: var(--text-2);
  font-size: 0.88rem;
  line-height: 1.7;
  font-weight: 300;
  margin: 0 0 14px;
}
.city-info p strong { color: var(--text); display: inline-block; min-width: 90px; }
.city-info .btn { margin-top: 8px; }

.city-services {
  padding: var(--section-y) 0;
}
.city-services__inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
.city-services__head {
  text-align: center;
  margin-bottom: 48px;
}
.city-services__head h2 {
  font-family: var(--f-display);
  font-size: clamp(1.8rem, 3.2vw, 2.4rem);
  font-weight: 300;
  line-height: 1.1;
  margin-top: 14px;
}
.city-services__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
.city-service {
  background: rgba(8,7,10,0.5);
  border: 1px solid var(--line-2);
  border-radius: 14px;
  padding: 28px;
  transition: border-color .35s, transform .35s;
}
.city-service:hover { border-color: var(--gold-line); transform: translateY(-2px); }
.city-service h3 {
  font-family: var(--f-display);
  font-size: 1.25rem;
  font-weight: 500;
  margin: 0 0 12px;
  color: var(--text);
}
.city-service p {
  color: var(--text-2);
  font-size: 0.88rem;
  line-height: 1.75;
  font-weight: 300;
  margin: 0 0 16px;
}
.city-service__link {
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-2);
  font-weight: 500;
  text-decoration: none;
}
.city-service__link:hover { color: var(--gold); }

.city-faq {
  padding: var(--section-y) 0;
}
.city-faq__inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
.city-faq__head { text-align: center; margin-bottom: 48px; }
.city-faq__head h2 {
  font-family: var(--f-display);
  font-size: clamp(1.8rem, 3.2vw, 2.4rem);
  font-weight: 300;
  margin-top: 14px;
}
.city-faq__list {
  display: flex; flex-direction: column; gap: 10px;
}
/* faq-item styles inherited from services.css if loaded; otherwise fallback */
.city-faq__list .faq-item {
  border: 1px solid var(--line-2);
  border-radius: 10px;
  background: rgba(8,7,10,0.45);
  overflow: hidden;
  transition: border-color .3s;
}
.city-faq__list .faq-item[open] { border-color: var(--gold-line); }
.city-faq__list .faq-item summary {
  padding: 18px 22px;
  font-family: var(--f-display);
  font-size: 1rem;
  font-weight: 400;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  list-style: none;
}
.city-faq__list .faq-item summary::-webkit-details-marker { display: none; }
.city-faq__list .faq-item summary::after {
  content: '+';
  font-size: 1.4rem;
  color: var(--gold-2);
  transition: transform .3s;
}
.city-faq__list .faq-item[open] summary::after { transform: rotate(45deg); }
.city-faq__list .faq-item__body {
  padding: 0 22px 18px;
  color: var(--text-2);
  font-size: 0.88rem;
  line-height: 1.75;
  font-weight: 300;
}

@media (max-width: 1024px) {
  .city-intro__inner { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .city-services__grid { grid-template-columns: 1fr; }
}
