/* SECTION */

.facilities-section{
padding:80px 20px;
background:#f7f7f7;
}

/* TITLE */

.facilities-title{
text-align:center;
font-size:32px;
margin-bottom:10px;
}

.facilities-intro{
text-align:center;
max-width:700px;
margin:0 auto 50px auto;
color:#555;
line-height:1.7;
}

.location-intro{
text-align:center;
max-width:900px;
margin:0 auto 20px auto;
color:#555;
line-height:1.7;
}

/* MAIN FACILITIES BOXES */

.main-facilities{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;
margin-bottom:60px;
}

.facility-box{
background:#fff;
padding:20px;
border-radius:10px;
box-shadow:0 8px 20px rgba(0,0,0,0.08);
text-align:center;
transition:0.3s;

display:flex;
flex-direction:column;
height:100%;
}

.facility-box:hover{
transform:translateY(-5px);
}

.facility-box img{
width:100%;
height:250px;
object-fit:cover;
border-radius:8px;
margin-bottom:15px;
}

.facility-box h3{
margin-bottom:10px;
position:relative;
padding-bottom:8px;
}

.facility-box h3::after{
content:"";
width:40px;
height:2px;
background:#ff7a00;
display:block;
margin:8px auto 0;
}

.facility-box p{
font-size:14px;
color:#555;
line-height:1.6;
margin-top:auto;
}

/* IMAGE CONTAINER */

.facility-image{
position:relative;
overflow:hidden;
border-radius:8px;
margin-bottom:15px;
}

/* IMAGE */

.facility-image img{
width:100%;
height:250px;
object-fit:cover;
display:block;
}

/* GRADIENT OVERLAY */

.facility-overlay{
position:absolute;
bottom:0;
left:0;
width:100%;
padding:20px;

background:linear-gradient(
to top,
rgba(0,0,0,0.65),
rgba(0,0,0,0.0)
);
}

/* TITLE */

.facility-overlay h3{
color:white;
font-size:20px;
margin:0;
}

.facility-image img{
transition:transform .4s ease;
}

.facility-box:hover img{
transform:scale(1.05);
}

/* GENERAL FACILITIES */

.general-title{
text-align:center;
margin-bottom:30px;
margin-top: 80px;
}

.general-facilities ul{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:12px 30px;
list-style:none;
padding:0;
max-width:800px;
margin:auto;
}

.general-facilities li{
display:flex;
align-items:center;
gap:10px;
font-size:15px;
color:#444;
}

.general-facilities i{
color:#ff7a00;
}

.facilities-cta{
  text-align:center;
  margin-top:30px;
}

.facilities-cta .btn-primary{
  display:inline-block;
}

.cta-trust{
  margin-top:8px;
  font-size:13px;
  color:#777;
  margin-bottom: 50px;
}

/* RESPONSIVE */

@media(max-width:900px){

.main-facilities{
grid-template-columns:1fr;
}

.general-facilities ul{
grid-template-columns:1fr 1fr;
}

}

@media(max-width:500px){

.general-facilities ul{
grid-template-columns:1fr;
}

}

.general-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:25px;
}

.general-item{
  display:flex;
  align-items:center;
  gap:10px;
  background:#fff;
  padding:12px 15px;
  border-radius:8px;
  box-shadow:0 4px 10px rgba(0,0,0,0.05);
  font-size:14px;
  color:#333;
}

.general-item svg{
  width:20px;
  height:20px;
  color:#8B5E3C;
}

.general-item:hover{
  transform:translateY(-3px);
  transition:0.3s;
}

/* TABLET */
@media(max-width:992px){
  .general-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

/* MOBILE */
@media(max-width:768px){
  .general-grid{
    grid-template-columns:1fr;
  }
}

.icon{
  width:20px;
  height:20px;
  stroke:currentColor;
  stroke-width:1.5;
  fill:none;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.icon-brown{
  color:#8B5E3C;
}

.general-item{
  display:flex;
  align-items:center;
  gap:10px;
  transition:0.3s;
}

.general-item:hover{
  transform:translateY(-3px);
}

.faq{
  padding:60px 0;
  background:#f9f7f4;
}

.faq-title{
  text-align:center;
  margin-bottom:30px;
}

.faq-item{
  background:#fff;
  border-radius:10px;
  margin-bottom:15px;
  box-shadow:0 4px 10px rgba(0,0,0,0.05);
  overflow:hidden;
}

.faq-question{
  width:100%;
  padding:18px;
  background:none;
  border:none;
  text-align:left;
  font-size:15px;
  font-weight:600;
  cursor:pointer;
  display:flex;
  justify-content:space-between;
  align-items:center;
}

.faq-question span{
  font-size:18px;
  color:#8B5E3C;
}

.faq-answer{
  max-height:0;
  overflow:hidden;
  transition:max-height 0.3s ease;
  padding:0 18px;
}

.faq-item.active .faq-answer{
  max-height:200px;
  padding:0 18px 15px;
}

.location-map-box{
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:25px;
  margin:40px 0;
  background:#fff;
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 8px 20px rgba(0,0,0,0.08);
}

.map-container iframe{
  width:100%;
  height:100%;
  min-height:350px;
  border:0;
}

.map-info{
  padding:25px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.map-info h3{
  margin-bottom:10px;
  color:#8B5E3C;
}

.map-info p{
  font-size:14px;
  color:#555;
  margin-bottom:10px;
}

.map-distance{
  font-weight:600;
}

.map-btn{
  display:inline-block;
  margin-top:10px;
  padding:10px 15px;
  background:#8B5E3C;
  color:#fff;
  text-decoration:none;
  border-radius:6px;
  font-size:14px;
}

.map-btn-book{
  display:inline-block;
  margin-top:10px;
  padding:10px 15px;
  background:#8B0000;
  color:#fff;
  text-decoration:none;
  border-radius:6px;
  font-size:14px;
}

/* MOBILE */
@media(max-width:768px){
  .location-map-box{
    grid-template-columns:1fr;
  }
}

.area-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
  margin-top:30px;
}

.area-item{
  display:flex;
  gap:12px;
  background:#fff;
  padding:18px;
  border-radius:10px;
  box-shadow:0 4px 10px rgba(0,0,0,0.05);
}

.area-item span{
  font-size:20px;
}

.area-item strong{
  display:block;
  margin-bottom:5px;
  color:#8B5E3C;
}

.area-item p{
  font-size:14px;
  color:#555;
}

/* MOBILE */
@media(max-width:768px){
  .area-grid{
    grid-template-columns:1fr;
  }
}

/* Nearby section (reuse area-grid) */

.area-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-top: 20px;
}

.area-item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  background: #f9f9f9;
  padding: 18px;
  border-radius: 10px;
}

.area-item span {
  font-size: 20px;
  line-height: 1;
}

.area-item strong {
  display: block;
  margin-bottom: 4px;
  font-size: 15px;
}

.area-item p {
  margin: 0;
  font-size: 14px;
  color: #555;
  line-height: 1.5;
}

/* Mobile */
@media (max-width: 768px) {
  .area-grid {
    grid-template-columns: 1fr;
  }

  .area-item {
    padding: 15px;
  }
}