/* =========================================
   REGION HUB SYSTEM – SHARED LAYOUT
   Shared Region Portal Architecture
========================================= */


/* =========================================
   1. Base Page
========================================= */

.region-hub-page{
  width:100%;
}


/* =========================================
   2. Top Phone
========================================= */

.region-hub-page .region-phone{
  display:block;
  margin:8px 0;
  font-size:clamp(18px,3vw,24px);
  font-weight:700;
  color:#3b6ca9ed;
  text-align:center;
  text-decoration:none;
}


/* =========================================
   3. Main Section
========================================= */

.region-hub-page .region-hub-section{
  margin-top:clamp(20px,4vw,36px);
  padding:clamp(18px,4vw,32px);
}


/* =========================================
   4. Main Container
========================================= */

.region-hub-page .region-hub-container{
  max-width:1320px;
  margin:0 auto;
  background:#ffffff;
  border-radius:28px;
  padding:clamp(18px,4vw,32px);
  box-shadow:
    0 26px 70px rgba(15,23,42,.10),
    0 0 1px rgba(255,255,255,.7);
}


/* =========================================
   5. Header
========================================= */

.region-hub-page .region-hub-header{
  text-align:center;
  margin-bottom:clamp(20px,4vw,32px);
}

.region-hub-page .region-hub-title{
  margin:0 auto;
  font-size:clamp(28px,4vw,36px);
  font-weight:700;
  color:#222;
  text-align:center;
}

.region-hub-page .region-hub-intro{
  max-width:760px;
  margin:12px auto 0;
  font-size:clamp(15px,3.6vw,17px);
  line-height:1.5;
  color:#B90404;
  text-align:center;
  font-weight:600;
}


/* =========================================
   6. Grid Layout
========================================= */

.region-hub-page .region-hub-grid{
  display:grid;
  gap:clamp(24px,3.2vw,36px);
}


/* =========================================
   7. Region Card
========================================= */

.region-hub-page .region-card{
  background:#f3f4f6;
  border-radius:22px;
  padding:20px 20px 22px;
  border:1px solid rgba(148,163,184,.35);
  box-shadow:0 16px 34px rgba(15,23,42,.10);
  display:flex;
  flex-direction:column;
  align-items:center;
}


/* =========================================
   8. Card Media
========================================= */

.region-hub-page .region-card-media{
  position:relative;
  display:block;
  width:100%;
  aspect-ratio:3/2;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 14px 38px rgba(0,0,0,.28);
}

.region-hub-page .region-card-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.region-hub-page .region-card-media::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(
    to top,
    rgba(0,0,0,.38) 0%,
    rgba(0,0,0,.20) 45%,
    rgba(0,0,0,.06) 75%,
    rgba(0,0,0,0) 100%
  );
  z-index:1;
}


/* =========================================
   9. Card Title
========================================= */

.region-hub-page .region-card-title{
  position:absolute;
  inset:50% auto auto 50%;
  transform:translate(-50%,-50%);
  z-index:2;
  margin:0;
  color:#ffffff;
  font-size:clamp(18px,4.6vw,24px);
  white-space:nowrap;
  max-width:90%;
  line-height:1.15;
  font-weight:700;
  letter-spacing:.02em;
  text-align:center;
  text-shadow:
    0 2px 6px rgba(0,0,0,.45),
    0 1px 2px rgba(0,0,0,.35);
  pointer-events:none;
}

.region-hub-page .region-card-subtitle{
  position:absolute;
  bottom:80px;
  left:50%;
  transform:translateX(-50%);
  font-size:16px;
  font-weight:600;
  color:rgba(255,255,255,.85);
  z-index:3;
  text-shadow:
    0 1px 2px rgba(0,0,0,.55),
    0 2px 4px rgba(0,0,0,.35);
}


/* =========================================
   10. Card Meta
========================================= */

.region-hub-page .region-card-meta{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:2px;
  max-width:260px;
  margin:14px auto 0;
}


/* =========================================
   11. Menu / SEO / Contact
========================================= */

.region-hub-page .region-menu-logic,
.region-hub-page .region-seo-summary,
.region-hub-page .region-contact{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
}

.region-hub-page .region-menu-logic{
  margin-top:30px;
}

.region-hub-page .region-menu-title{
  font-size:clamp(22px,3vw,26px);
  font-weight:700;
  color:#111827;
  margin-bottom:20px;
}

.region-hub-page .region-menu-text{
  max-width:960px;
  margin:0 auto 16px;
  font-size:clamp(14px,2.4vw,15px);
  line-height:1.7;
  color:#4b5563;
}


/* =========================================
   12. SEO Summary
========================================= */

.region-hub-page .region-seo-summary{
  margin-top:26px;
  padding-top:18px;
  border-top:1px solid rgba(148,163,184,.25);
}

.region-hub-page .region-seo-summary p{
  max-width:1020px;
  margin:0 auto 12px;
  font-size:clamp(14px,1.05vw,15px);
  line-height:1.55;
  color:#767676;
}


/* =========================================
   13. Contact
========================================= */

.region-hub-page .region-contact{
  margin-top:18px;
}

.region-hub-page .region-contact-text{
  font-size:14px;
  color:var(--hw-orange-body);
  margin:0 auto;
}

.region-hub-page .region-contact-text a,
.region-hub-page .region-contact-link{
  font-weight:600;
  color:#2563eb;
  text-decoration:none;
}

.region-hub-page .region-contact-text a:hover,
.region-hub-page .region-contact-link:hover{
  text-decoration:underline;
}


/* =========================================
   14. Menu Links
========================================= */

.region-hub-page .region-menu-link{
  font-size:13px;
  line-height:1.6;
  padding:6px 4px;
  margin-top:2px;
  display:inline-block;
  color:#2563eb;
  text-decoration:none;
  border-radius:6px;
}

.region-hub-page .region-menu-link:hover{
  background:rgba(37,99,235,.08);
  text-decoration:underline;
}


/* =========================================
   15. Bottom More Links
========================================= */

.region-hub-page .locations-bottom__more{
  margin:28px auto 0;
  max-width:760px;
  text-align:center;
  font-size:14px;
  line-height:1.7;
  color:#64748b;
}

.region-hub-page .locations-bottom__more a{
  color:#2563eb;
  text-decoration:none;
  border-bottom:1px solid rgba(37,99,235,.3);
}

.region-hub-page .locations-bottom__more a:hover{
  border-bottom-color:#2563eb;
}


/* =========================================
   16. Responsive
========================================= */

@media (min-width:1024px){

  .region-hub-page .region-hub-grid{
    grid-template-columns:repeat(3,1fr);
  }

}

@media (min-width:768px) and (max-width:1023.98px){

  .region-hub-page .region-hub-grid{
    grid-template-columns:repeat(2,1fr);
  }

}

@media (max-width:767.98px){

  .region-hub-page .region-hub-grid{
    grid-template-columns:1fr;
    max-width:none;
    margin:0;
    gap:18px;
  }

  .region-hub-page .region-card{
    padding:16px 16px 48px;
    border-radius:20px;
  }

  .region-hub-page .region-card-media{
    aspect-ratio:4/3;
  }

  .region-hub-page .region-card-title{
    font-size:clamp(24px,7vw,30px);
  }

}

@media (max-width:768px){

  .region-hub-page .region-hub-container{
    max-width:none;
    width:100%;
    margin:0;
    border-radius:10px;
    padding:16px;
    box-shadow:none;
  }

  .region-hub-page .region-hub-grid{
    gap:18px;
  }

}