/* =========================
   Cities (Archive + Single)
========================= */

/* Archive list */
.cities-grid {
  align-items: stretch;
}

.city-card {
  padding: 0;
  overflow: hidden;
}

.city-card-link {
  display: block;
  height: 100%;
  color: inherit;
}

.city-thumb {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 16px 16px 0 0;
}

.city-card-body {
  padding: 1.25rem;
}

.city-card h3 {
  margin-bottom: 0.35rem;
}

.city-card p {
  margin-top: 0.35rem;
}

/* Hover: match your site card vibe */
.city-card:hover {
  transform: translateY(-2px);
  transition: transform 0.12s ease;
}

.city-card:hover .btn {
  box-shadow: var(--shadow);
}

/* =========================
   Single City Page
========================= */

/* Reuse your single-post layout classes but make sure it behaves nicely */
.single-layout {
  align-items: start;
}

.single-article {
  overflow: hidden;
}

.single-thumb {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 14px;
  margin-bottom: 1rem;
}

/* City sidebar tweaks */
.mini-list {
  padding: 0;
  margin: 0.75rem 0 0;
  display: grid;
  gap: 0.5rem;
}

.mini-list li {
  padding-left: 1.1rem;
  position: relative;
  color: var(--muted);
  font-size: 0.95rem;
}

.mini-list li::before {
  content: "•";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--primary);
  font-weight: 700;
}

.hr {
  height: 1px;
  background: var(--border);
  margin: 1.25rem 0;
}

/* Mobile: ensure grid collapses cleanly */
@media (max-width: 900px) {
  .single-sidebar {
    position: static;
    top: auto;
  }
}

/* =========================
   ZIP Codes Archive
========================= */

.zip-search-row{
  display:flex;
  gap:0.75rem;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:1rem;
}

.zip-search-row input[type="search"]{
  width:min(520px, 100%);
  padding:0.95rem 1rem;
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--card);
  color:inherit;
}

.zip-grid{
  align-items:stretch;
}

.zip-card{
  padding:0;
  overflow:hidden;
}

.zip-card-link{
  display:block;
  height:100%;
  padding:1.25rem;
  color:inherit;
}

.zip-card-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:1rem;
}

.zip-number{
  font-size:1.15rem;
  font-weight:700;
  letter-spacing:0.2px;
}

.zip-badges{
  display:flex;
  gap:0.5rem;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.badge{
  display:inline-flex;
  align-items:center;
  padding:0.25rem 0.55rem;
  border-radius:999px;
  background:rgba(0,0,0,0.06);
  font-size:0.8rem;
  color:var(--muted);
}

.badge-outline{
  background:transparent;
  border:1px solid var(--border);
}

/* Pagination wrapper */
.pagination-wrap{
  margin-top:1.5rem;
}

.pagination-wrap ul{
  list-style:none;
  display:flex;
  gap:0.5rem;
  flex-wrap:wrap;
  justify-content:center;
  padding:0;
  margin:0;
}

.pagination-wrap a,
.pagination-wrap span{
  display:inline-flex;
  padding:0.5rem 0.75rem;
  border:1px solid var(--border);
  border-radius:12px;
  text-decoration:none;
  color:inherit;
}

.pagination-wrap .current{
  font-weight:700;
}

/* ZIP badges on single pages */
.page-hero .zip-badges { display:flex; gap:.5rem; flex-wrap:wrap; }

/* =========================
   Mini-list override (avoid double bullets inside .single-content)
========================= */

/* Kill the default UL bullets/padding that come from .single-content */
.single-content ul.mini-list,
.single-content ol.mini-list,
.single-sidebar ul.mini-list,
.single-sidebar ol.mini-list {
  list-style: none !important;
  padding-left: 0 !important;
  margin: 0.75rem 0 0 !important; /* keep your nice spacing */
}

/* Ensure no nested bullet styles sneak in */
.single-content ul.mini-list li,
.single-sidebar ul.mini-list li {
  margin: 0 !important;
}

/* =========================
   Mini-list as columns (useful for ZIP lists)
========================= */
.mini-list.mini-cols {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.5rem 1.25rem; /* row gap, column gap */
}

@media (max-width: 900px) {
  .mini-list.mini-cols {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 520px) {
  .mini-list.mini-cols {
    grid-template-columns: 1fr;
  }
}

