/* =========================================================
   CITY PAGE (scoped) – NO toca State ni Business
   Aplica SOLO dentro de: .dirprog-city-page
   ========================================================= */

/* ------------------------------------------
   Sort pills (Default / Most Reviews / Top Rated)
------------------------------------------- */
.dirprog-city-page .dirprog-city-sort{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:10px 0 18px;
}

.dirprog-city-page .dirprog-city-sort__pill{
  display:inline-block;
  padding:10px 14px;
  border-radius:10px;
  border:1px solid rgba(0,0,0,.18);
  background:#fff;
  color:#111;
  text-decoration:none !important;
  font-weight:700;
  line-height:1;
}

.dirprog-city-page .dirprog-city-sort__pill:hover{ opacity:.92; }

.dirprog-city-page .dirprog-city-sort__pill.is-active{
  background:#111;
  color:#fff;
  border-color:#111;
}

/* ------------------------------------------
   Business list layout (cards)
------------------------------------------- */
.dirprog-city-page .dirprog-city-grid{
  display:flex;
  flex-direction:column;
  gap:18px;
  margin-top:18px;
}

.dirprog-city-page .dirprog-biz-card{
  display:flex;
  gap:18px;
  align-items:flex-start;
  border:1px solid rgba(0,0,0,.12);
  border-radius:4px; /* vos dijiste que te gusta 4px */
  padding:18px;
  background:#fff;
}

.dirprog-city-page .dirprog-biz-card__logo{
  width:110px;
  height:110px;
  flex:0 0 110px;
  border-radius:999px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.12);
  background:rgba(0,0,0,.04);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-top:6px;
}

.dirprog-city-page .dirprog-biz-card__logo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.dirprog-city-page .dirprog-biz-card__logo--ph{
  width:100%;
  height:100%;
}

.dirprog-city-page .dirprog-biz-card__body{
  flex:1 1 auto;
  min-width:0;
}

.dirprog-city-page .dirprog-biz-card__title{
  margin:0 0 10px;
  font-size:32px;
  line-height:1.1;
}

.dirprog-city-page .dirprog-biz-card__title a{
  text-decoration:none !important;
}

.dirprog-city-page .dirprog-biz-card__meta{
  margin:6px 0;
  font-size:14px;
  opacity:.9;
}

.dirprog-city-page .dirprog-biz-card__reviews{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

/* ------------------------------------------
   Buttons (Call Now / Business Info)
------------------------------------------- */
.dirprog-city-page .dirprog-biz-card__actions{
  display:flex;
  gap:10px;
  margin-top:12px;
  flex-wrap:wrap;
}

.dirprog-city-page .dirprog-btn{
  display:inline-block;
  padding:10px 14px;
  border-radius:4px;
  background:#111;
  color:#fff !important;
  text-decoration:none !important;
  font-weight:700;
  line-height:1;
}

.dirprog-city-page .dirprog-btn:hover{ opacity:.92; }

.dirprog-city-page .dirprog-btn--secondary{
  background:#111;
}

/* ------------------------------------------
   Divider under buttons
------------------------------------------- */
.dirprog-city-page .dirprog-card-divider{
  border:0;
  border-top:1px solid rgba(0,0,0,.12);
  margin:14px 0 12px;
}

/* ------------------------------------------
   Review block (más sutil: texto + estrellas más chicos)
------------------------------------------- */
.dirprog-city-page .dirprog-biz-card__review{
  margin-top:2px;
}

.dirprog-city-page .dirprog-biz-card__review > div:first-child{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  font-weight:800;
  font-size:14px;     /* más chico */
}

.dirprog-city-page .dirprog-biz-card__review > div:last-child{
  margin-top:6px;
  font-size:13px;     /* más chico */
  line-height:1.45;
  opacity:.9;
}

/* Estrellas un poco más chicas dentro de la review */
.dirprog-city-page .dirprog-biz-card__review .dirprog-stars-boxed{
  transform:scale(.9);
  transform-origin:left center;
}

/* ------------------------------------------
   Mobile tweaks
------------------------------------------- */
@media (max-width: 720px){
  .dirprog-city-page .dirprog-biz-card{
    gap:14px;
    padding:14px;
  }

  .dirprog-city-page .dirprog-biz-card__logo{
    width:86px;
    height:86px;
    flex:0 0 86px;
    margin-top:2px;
  }

  .dirprog-city-page .dirprog-biz-card__title{
    font-size:26px;
  }

  .dirprog-city-page .dirprog-btn{
    padding:10px 12px;
  }
}

/* =========================================================
   Other Areas in State – City Page only
   (tu sección “Other Areas in Manitoba”)
   ========================================================= */

.dirprog-city-page .dirprog-city-related-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
  margin:18px 0 28px;
}

@media (max-width: 1024px){
  .dirprog-city-page .dirprog-city-related-grid{ grid-template-columns:repeat(2, 1fr); }
}
@media (max-width: 640px){
  .dirprog-city-page .dirprog-city-related-grid{ grid-template-columns:1fr; }
}

.dirprog-city-page .dirprog-city-related-card{
  border:1px solid rgba(0,0,0,.12);
  border-radius:4px;
  padding:14px;
  background:#fff;
}

.dirprog-city-page .dirprog-city-related-title{
  margin:0 0 8px;
  font-size:15px;
  font-weight:700;
}

.dirprog-city-page .dirprog-city-related-meta{
  font-size:13px;
  opacity:.85;
  margin-bottom:10px;
}

.dirprog-city-page .dirprog-city-related-btn{
  display:inline-block;
  width:100%;
  text-align:center;
  padding:10px 12px;
  border-radius:4px;
  background:#111;
  color:#fff !important;
  text-decoration:none !important;
  font-weight:700;
}

.dirprog-city-page .dirprog-city-related-btn:hover{ opacity:.92; }


/* ----------------------------------------
   City page – Claim / Add Business Box
-----------------------------------------*/

.dirprog-city-claim{
  margin: 40px 0 20px;
}

.dirprog-city-claim__box{
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.12);
  background: #fff;
}

.dirprog-city-claim__top,
.dirprog-city-claim__bottom{
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 18px 20px;
}

.dirprog-city-claim__top{
  background: #fbf5d6;
  border-bottom: 1px solid rgba(0,0,0,.08);
}

.dirprog-city-claim__bottom{
  background: #fffbe6;
}

.dirprog-city-claim__icon{
  font-size: 28px;
  line-height: 1;
}

.dirprog-city-claim__text{
  flex: 1 1 auto;
  min-width: 0;
}

.dirprog-city-claim__text strong{
  display: block;
  font-size: 16px;
  margin-bottom: 2px;
}

.dirprog-city-claim__text p{
  margin: 0;
  font-size: 14px;
  opacity: .9;
}

.dirprog-city-claim__btn{
  background: #111;
  color: #fff;
  padding: 8px 14px;
  border-radius: 6px;
  text-decoration: none;
  font-weight: 700;
  white-space: nowrap;
}

.dirprog-city-claim__btn:hover{
  opacity: .9;
}

/* Mobile */
@media (max-width: 640px){
  .dirprog-city-claim__top,
  .dirprog-city-claim__bottom{
    flex-direction: column;
    align-items: flex-start;
  }

  .dirprog-city-claim__btn{
    margin-top: 6px;
  }
}