/* ===== SERVICE AREAS PAGE ===== */

.sa-hero{
  position:relative;overflow:hidden;
  border-bottom:1px solid var(--line);
  padding:64px 0 0;
  background:
    radial-gradient(ellipse 900px 500px at 80% 20%,rgba(47,125,255,.10),transparent 60%),
    var(--bg);
}
.sa-hero-grid{
  display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:end;
  padding-bottom:64px;
}
.sa-hero-copy .crumb{
  font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--mute-2);margin-bottom:22px;
}
.sa-hero-copy .crumb a:hover{color:var(--accent)}
.sa-hero-copy .crumb .sep{margin:0 8px}
.sa-hero-copy .crumb .here{color:var(--accent)}
.sa-hero-copy h1{
  margin:0 0 22px;font-size:clamp(2.4rem,4.4vw,3.6rem);
  font-weight:800;letter-spacing:-.025em;line-height:1.02;
}
.sa-hero-copy h1 .accent{color:var(--accent)}
.sa-hero-copy .lead{
  color:var(--mute);font-size:17px;line-height:1.7;
  margin:0 0 24px;max-width:560px;
}
.sa-radius-badge{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(47,125,255,.1);border:1px solid rgba(47,125,255,.3);
  color:var(--accent);padding:10px 18px;border-radius:6px;
  font-size:12px;font-weight:600;letter-spacing:.06em;margin-bottom:24px;
}
.sa-map-wrap{
  position:relative;aspect-ratio:1/1;
  border:1px solid var(--line);border-radius:14px;overflow:hidden;
  background:var(--bg-2);
}
.sa-map-wrap img.img-placeholder{width:100%;height:100%;display:block}
.sa-map-wrap .pin{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  display:flex;flex-direction:column;align-items:center;gap:6px;
  pointer-events:none;
}
.sa-map-wrap .dot{
  width:18px;height:18px;background:var(--accent);border-radius:50%;
  box-shadow:0 0 0 6px rgba(47,125,255,.2),0 0 0 14px rgba(47,125,255,.08);
  animation:pulse 2s infinite;
}
.sa-map-wrap .label{
  background:var(--bg);border:1px solid var(--line-2);padding:6px 12px;border-radius:6px;
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
}

/* metrics strip */
.sa-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--line);
}
.sa-stat{
  padding:30px 28px;border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:6px;
}
.sa-stat:last-child{border-right:0}
.sa-stat b{font-size:28px;font-weight:700;letter-spacing:-.02em;color:#fff;font-variant-numeric:tabular-nums;line-height:1}
.sa-stat b .ac{color:var(--accent)}
.sa-stat span{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute)}

/* sticky jump tabs */
.sa-tabs{
  border-bottom:1px solid var(--line);
  position:sticky;top:78px;z-index:40;
  background:rgba(5,5,7,.92);backdrop-filter:blur(12px);
}
.sa-tabs-inner{display:flex;gap:0;overflow-x:auto;scrollbar-width:none}
.sa-tabs-inner::-webkit-scrollbar{display:none}
.sa-tab{
  padding:18px 22px;border-right:1px solid var(--line);
  font-size:13px;font-weight:600;color:var(--mute);
  white-space:nowrap;flex-shrink:0;transition:color .15s,background .15s;
}
.sa-tab:first-child{border-left:1px solid var(--line)}
.sa-tab:hover{color:#fff;background:var(--bg-2)}
.sa-tab .ix{
  font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.18em;
  color:var(--accent);font-weight:500;margin-right:8px;
}

/* city block */
.city{
  padding-block:88px;border-bottom:1px solid var(--line);
  scroll-margin-top:160px;
}
.city:nth-child(even){background:var(--bg-2)}
.city-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.city-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:24px;margin-bottom:24px;
}
.city-ix{
  font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--mute-2);margin-bottom:8px;
}
.city-ix .ac{color:var(--accent)}
.city h2{
  margin:0;font-size:clamp(2.2rem,4vw,3.2rem);
  font-weight:800;letter-spacing:-.025em;line-height:1;
}
.city h2 .accent{color:var(--accent)}
.city-zip{
  font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.14em;
  color:var(--mute);text-align:right;
}
.city-zip b{color:#fff;font-weight:600;display:block;font-size:14px;letter-spacing:-.01em}
.city-pitch{
  color:var(--mute);font-size:16px;line-height:1.75;margin:0 0 24px;
}
.city-pitch b{color:#fff;font-weight:500}

.city-info{
  display:grid;grid-template-columns:repeat(2,1fr);gap:0;
  border:1px solid var(--line);border-radius:10px;overflow:hidden;margin-bottom:24px;
}
.city-info > div{padding:16px 18px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.city-info > div:nth-child(2n){border-right:0}
.city-info > div:nth-child(n+3){border-bottom:0}
.city-info .lbl{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute);font-weight:600;margin-bottom:5px}
.city-info .val{font-size:15px;font-weight:600;color:#fff;letter-spacing:-.005em}
.city-info .val .ac{color:var(--accent)}

.city-svcs{
  list-style:none;padding:0;margin:0 0 24px;
  display:grid;grid-template-columns:1fr 1fr;gap:8px 18px;
}
.city-svcs li{
  display:flex;gap:10px;font-size:14px;color:#dadcdf;line-height:1.5;
  padding:8px 0;border-bottom:1px solid var(--line);
}
.city-svcs li::before{
  content:"";flex-shrink:0;width:6px;height:6px;border-radius:50%;
  background:var(--accent);margin-top:8px;
}

.city-side{
  position:sticky;top:160px;
  display:flex;flex-direction:column;gap:18px;
}
.city-map{
  position:relative;aspect-ratio:5/4;
  background:var(--bg-3);border:1px solid var(--line);
  border-radius:12px;overflow:hidden;
}
.city-map img.img-placeholder{width:100%;height:100%;display:block}
.city-map .city-pin{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  display:flex;flex-direction:column;align-items:center;gap:6px;pointer-events:none;
}
.city-map .city-pin .dot{
  width:14px;height:14px;background:var(--accent);border-radius:50%;
  box-shadow:0 0 0 5px rgba(47,125,255,.2),0 0 0 11px rgba(47,125,255,.08);
  animation:pulse 2s infinite;
}
.city-map .city-pin .label{
  background:var(--bg);border:1px solid var(--line-2);padding:5px 10px;border-radius:5px;
  font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
}
.city-callout{
  background:var(--bg);border:1px solid var(--line);border-radius:10px;
  padding:20px 22px;
}
.city-callout .lbl{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:10px}
.city-callout .quote{font-size:14px;line-height:1.6;color:#dadcdf;margin:0 0 12px}
.city-callout .author{font-size:12px;color:var(--mute);font-weight:500}
.city-callout .stars{color:var(--accent);font-size:12px;letter-spacing:2px;margin-bottom:6px}

/* full city list (bottom) */
.all-cities{padding-block:88px;border-bottom:1px solid var(--line);background:#000}
.all-cities .lead{color:var(--mute);font-size:15px;line-height:1.7;margin:14px 0 0;max-width:600px}
.cities-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  margin-top:36px;
  border:1px solid var(--line);border-radius:12px;overflow:hidden;
}
.cities-grid li{
  list-style:none;font-size:13px;color:var(--mute);
  padding:14px 18px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:8px;
}
.cities-grid li:nth-child(4n){border-right:0}
.cities-grid li::before{content:"";width:4px;height:4px;background:var(--accent);border-radius:50%;flex-shrink:0}

.outside{
  margin-top:36px;
  background:var(--bg-2);border:1px solid var(--line);border-radius:12px;
  padding:32px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
}
.outside h3{margin:0 0 6px;font-size:18px;font-weight:600;letter-spacing:-.01em}
.outside p{margin:0;color:var(--mute);font-size:14px;line-height:1.6}

/* RESPONSIVE */
@media (max-width:1100px){
  .sa-hero-grid{grid-template-columns:1fr;gap:40px;padding-bottom:48px}
  .sa-stats{grid-template-columns:repeat(2,1fr)}
  .sa-stat:nth-child(2){border-right:0}
  .sa-stat:nth-child(1),.sa-stat:nth-child(2){border-bottom:1px solid var(--line)}
  .sa-tabs{top:67px}
  .city{padding-block:64px;scroll-margin-top:200px}
  .city-grid{grid-template-columns:1fr;gap:32px}
  .city-side{position:static}
  .cities-grid{grid-template-columns:repeat(2,1fr)}
  .cities-grid li:nth-child(4n){border-right:1px solid var(--line)}
  .cities-grid li:nth-child(2n){border-right:0}
}
@media (max-width:600px){
  .sa-stats{grid-template-columns:1fr}
  .sa-stat{border-right:0;border-bottom:1px solid var(--line)}
  .sa-stat:last-child{border-bottom:0}
  .city-head{flex-direction:column;align-items:flex-start}
  .city-zip{text-align:left}
  .city-svcs,.city-info{grid-template-columns:1fr}
  .city-info > div{border-right:0;border-bottom:1px solid var(--line)!important}
  .city-info > div:last-child{border-bottom:0!important}
  .cities-grid{grid-template-columns:1fr}
  .cities-grid li{border-right:0!important}
}
