/* ═══════════════════════════════════════════════════════
   Puget Sound Moving — locations.css
═══════════════════════════════════════════════════════ */

/* ── Hero ────────────────────────────────────────────── */
.locations-hero { background:var(--navy); padding:88px 0 72px; text-align:center; position:relative; overflow:hidden; }
.locations-hero::after { content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(201,148,42,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(201,148,42,.04) 1px,transparent 1px); background-size:60px 60px; pointer-events:none; }
.locations-hero-inner { position:relative; z-index:2; }
.locations-hero-title  { font-family:'Bebas Neue',sans-serif; font-size:clamp(52px,7vw,96px); line-height:.92; color:var(--white); letter-spacing:2px; margin-bottom:16px; }
.locations-hero-desc   { font-size:18px; color:rgba(255,255,255,.5); max-width:560px; margin:0 auto; line-height:1.7; }

/* ── Office blocks ───────────────────────────────────── */
.loc-offices-list { display:flex; flex-direction:column; gap:0; }
.loc-office-block {
  display:grid; grid-template-columns:1fr 1fr;
  gap:0; align-items:stretch; min-height:420px;
}
/* Alternate: even offices flip map to right */
.loc-office-block .loc-office-map--right { order:2; }
.loc-office-block .loc-office-map--right + .loc-office-info { order:1; }

.loc-office-map { position:relative; background:var(--navy-mid); overflow:hidden; }
.loc-map-frame  { position:absolute; inset:0; }
.loc-map-frame iframe { width:100%; height:100%; border:0; display:block; }

.loc-office-info {
  padding:52px 48px; background:var(--white);
  display:flex; flex-direction:column; justify-content:center;
}
.loc-office-city {
  font-family:'Bebas Neue',sans-serif; font-size:clamp(32px,4vw,52px);
  letter-spacing:1px; color:var(--navy); line-height:1; margin-bottom:6px;
}
.loc-office-biz {
  font-size:12px; font-weight:700; letter-spacing:3px; text-transform:uppercase;
  color:var(--gold); margin-bottom:28px;
}
.loc-office-details { display:flex; flex-direction:column; gap:16px; margin-bottom:32px; }
.loc-detail-row {
  display:flex; align-items:flex-start; gap:14px;
}
.loc-detail-row .psm-icon { flex-shrink:0; margin-top:2px; }
.loc-detail-label { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--text-light); margin-bottom:3px; }
.loc-detail-value { font-size:15px; color:var(--text-dark); line-height:1.55; }
.loc-detail-value a { color:var(--navy); text-decoration:none; font-weight:600; }
.loc-detail-value a:hover { color:var(--gold); }

.loc-office-actions { display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.loc-maps-link {
  font-size:13px; font-weight:700; letter-spacing:.5px;
  color:var(--text-mid); text-decoration:none;
  display:inline-flex; align-items:center; gap:6px; transition:color .2s;
}
.loc-maps-link:hover { color:var(--gold); }

/* Alternate blocks — slightly tinted bg so they feel distinct */
.loc-office-block:nth-child(even) .loc-office-info { background:#FAFAF8; }

/* ── City cards grid ─────────────────────────────────── */
.loc-city-search-wrap {
  position:relative; max-width:480px; margin-bottom:36px;
}
.loc-city-search-wrap input {
  width:100%; padding:13px 48px 13px 18px;
  border:2px solid #E5E3DA; background:var(--white);
  font-size:15px; color:var(--text-dark); outline:none;
  transition:border-color .2s;
}
.loc-city-search-wrap input:focus { border-color:var(--navy); }
.loc-city-search-wrap .psm-icon {
  position:absolute; right:14px; top:50%; transform:translateY(-50%); pointer-events:none;
}

.loc-city-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:2px; background:#D8D5CC;
}
.loc-city-card {
  background:var(--white); text-decoration:none; display:flex;
  flex-direction:column; position:relative;
  transition:transform .3s cubic-bezier(.23,1,.32,1);
}
.loc-city-card:hover { transform:translateY(-5px); box-shadow:0 20px 48px rgba(13,31,74,.12); z-index:2; }

.loc-city-thumb { height:180px; background:var(--navy); overflow:hidden; position:relative; }
.loc-city-thumb img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s ease; }
.loc-city-card:hover .loc-city-thumb img { transform:scale(1.05); }
.loc-city-thumb-placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg,var(--navy),var(--navy-mid)); }
.loc-city-live-badge {
  position:absolute; bottom:10px; left:10px;
  background:rgba(13,31,74,.85); backdrop-filter:blur(4px);
  color:var(--gold-light); font-size:10px; font-weight:700;
  letter-spacing:1px; text-transform:uppercase;
  padding:4px 10px; display:inline-flex; align-items:center; gap:5px;
}

.loc-city-body { padding:20px 20px 24px; display:flex; flex-direction:column; flex:1; }
.loc-city-name { font-family:'Bebas Neue',sans-serif; font-size:22px; letter-spacing:1px; color:var(--navy); margin-bottom:8px; line-height:1; transition:color .2s; }
.loc-city-card:hover .loc-city-name { color:var(--navy-mid); }
.loc-city-address, .loc-city-phone {
  display:flex; align-items:center; gap:6px;
  font-size:12px; color:var(--text-light); margin-bottom:6px; line-height:1.4;
}
.loc-city-cta {
  font-size:12px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--gold); display:flex; align-items:center; gap:6px;
  margin-top:auto; padding-top:14px;
  transition:gap .2s;
}
.loc-city-card:hover .loc-city-cta { gap:10px; }

/* ── Responsive ──────────────────────────────────────── */
@media (max-width:1100px) {
  .loc-city-grid { grid-template-columns:repeat(3,1fr); }
}
@media (max-width:860px) {
  .loc-office-block { grid-template-columns:1fr; min-height:auto; }
  .loc-office-map   { height:300px; }
  .loc-office-map--right { order:0 !important; }
  .loc-office-map--right + .loc-office-info { order:0 !important; }
  .loc-office-info  { padding:36px 28px; }
  .loc-city-grid    { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:520px) {
  .loc-city-grid { grid-template-columns:1fr; }
}

/* ── City chips (service area section) ───────────────── */
.loc-chip {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 7px 14px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  font-size: 13px; font-weight: 500; color: rgba(255,255,255,.5);
  text-decoration: none;
  transition: none; /* plain chips don't animate */
}
/* Live chips — have a city page */
.loc-chip--live {
  background: rgba(201,148,42,.1);
  border-color: rgba(201,148,42,.35);
  color: var(--gold-light);
  font-weight: 600;
  transition: background .2s, border-color .2s, color .2s;
}
.loc-chip--live:hover {
  background: rgba(201,148,42,.2);
  border-color: var(--gold);
  color: var(--white);
}
