.active-always{
    position:fixed;
    transform: translateY(0);
}
.room-availability-section{
    padding:50px 0;
    padding-top: 80px;
    background:#f8f7f4;
    color:#2E2A27;
}

.container{
    width:min(1400px,90%);
    margin:auto;
}

.section-title{
    font-size:48px;
    margin-bottom: 10px;
    font-family:"Cormorant Garamond", serif;
    color:#2E2A27;
}

.room-card{
    display:grid;
    grid-template-columns:400px 1fr;
    gap:40px;

    background:white;

    border-radius:24px;

    overflow:hidden;

    box-shadow:
        0 15px 40px rgba(0,0,0,.05);
    margin-bottom: 15px;
}

/* LEFT */

.room-info{
    padding:30px;
}

.room-name{
    font-size:34px;
    margin-bottom:25px;
}

.room-gallery{
    position: relative;
    border-radius:18px;
    overflow:hidden;
    margin-bottom:15px;
}

.room-gallery img{
    width:100%;
    height:280px;
    object-fit:cover;
}

.room-save-btn{
    position: absolute;
    top: 12px;
    right: 12px;
    width: 40px;
    height: 40px;
    border: none;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.9);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    z-index: 10;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    padding: 0;
}

.room-save-btn:hover{
    background: white;
    transform: scale(1.1);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
}

.save-icon{
    font-size: 20px;
    line-height: 1;
    color: #C4AB74;
}

.room-specs{
    display:block;
    gap:14px;

    color:#666;

    margin-bottom:10px;
    font-size: 15px;
}

.room-specs div{
    margin-bottom:5px;
}

.room-specs i.ph{
    font-size:20px;
}

.room-facilities{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:5px;
    color:#666;
    margin-bottom:25px;
    font-size:12px;
}

.room-detail-btn{
    display:inline-block;

    padding:12px 24px;

    background:#4B3A30;
    color:white;
    text-decoration:none;
    text-align:center;

    border-radius:10px;
}

/* RIGHT */

.room-options{
    padding: 96px 30px 30px 30px;
}

.room-option{
    background:#fff;
    border:1px solid #ece7df;
    border-radius:20px;

    margin-bottom:18px;

    overflow:hidden;

    transition:.3s ease;
}

.room-option:hover{
    box-shadow:
        0 15px 40px rgba(0,0,0,.06);

    transform:translateY(-2px);
}

.room-table{
    border:1px solid #eee;
    border-radius:18px;
    overflow:hidden;
}

.table-header{
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    background: #A66A4E;
    font-weight: 600;
    color: #fff;
    font-size: 12px;
}

.table-header div{
    padding:22px;
}

.table-row{
    display:grid;
    grid-template-columns:2fr 1fr 1fr 1fr;

    border-top:1px solid #eee;
}

.table-row > div{
    padding: 15px 24px 15px 24px;
}

.option-type{
    display:block;

    font-size:12px;

    color:#999;

    margin-bottom:3px;
}

.option-info h4{
    margin-bottom:3px;
}

.option-info p{
    color:#777;
}

.price{
    color:#d29f3f;

    font-size:15px;
    font-weight:700;
}

.booking-action{
    display:flex;
    flex-direction:column;
    gap:3px;
}

.availability{
    color:#d34f4f;
    font-size:12px;
}

.booking-action button{
        height: 35px;
    border: none;
    background: #4B3A30;
    color: white;
    border-radius: 3px;
    cursor: pointer;
    border-radius: 9px;
}

.booking-action button:hover{
    background:#c4a46a;
}

/* MOBILE */

@media(max-width:992px){

    .room-card{
        grid-template-columns:1fr;
    }

    .table-header{
        display:none;
    }

    .table-row{
        grid-template-columns:1fr;
    }

    .price{
        font-size:22px;
    }
}

/* ========================================= */
/* BOOKING BAR */
/* ========================================= */

.hotel-booking-bar{
    position:relative;

    background:white;

    box-shadow:
        0 5px 30px rgba(0,0,0,.05);

    z-index:50;
    margin-top:80px;
}

.booking-container{
    width:min(1400px,92%);
    margin:auto;
}

/* ========================================= */
/* SEARCH BAR */
/* ========================================= */

.booking-search{

    display:grid;

    grid-template-columns:
        1.2fr
        1fr
        1fr
        auto;

    gap:16px;

    padding:24px 0;
}

.booking-field{

    display:flex;
    align-items:center;

    gap:0px;

    height:64px;

    padding:0 20px;

    border:
        1px solid #e4e4e4;

    border-radius:14px;
}

.booking-field input{

    width:100%;

    border:none;

    outline:none;

    background:none;

    font-size:18px;

    color:#333;
}

.icon{
    font-size:22px;
}

.search-btn{

    min-width:180px;

    border:none;

    border-radius:14px;

    background:#4b3a30d1;

    color:white;

    font-size:16px;

    cursor:pointer;

    transition:.3s;
}

.search-btn:hover{
    background: #b79a5d;
    transform: translateY(-4px);
}

/* ========================================= */
/* NAVIGATION */
/* ========================================= */

.hotel-navigation{

    display:flex;

    justify-content:space-between;
    align-items:center;

    border-top:
        1px solid #efefef;
}

.hotel-tabs{

    display:flex;
    gap:10px;
}

.tab{
    position: relative;
    height: 50px;
    padding: 0px 25px;
    border: none;
    background: none;
    font-size: 15px;
    font-weight: 600;
    color: #777;
    cursor: pointer;
}

.tab.active{
    color:#111;
}

.tab.active::after{

    content:'';

    position:absolute;

    left:0;
    right:0;
    bottom:0;

    height:3px;

    background:#4b3a30d1;
}

.hotel-actions{

    display:flex;
    gap:20px;
}

.action-btn{

    border:none;

    background:none;

    color:#4b3a30d1;

    font-size:12px;

    font-weight:600;

    cursor:pointer;
}

/* ========================================= */
/* MOBILE */
/* ========================================= */

@media(max-width:992px){

    .booking-search{

        grid-template-columns:1fr;
    }

    .search-btn{
        height:60px;
    }

    .hotel-navigation{

        flex-direction:column;

        align-items:flex-start;
    }

    .hotel-tabs{

        width:100%;

        overflow-x:auto;
    }

    .hotel-actions{

        padding:
            16px 0 24px;
    }

}

/* ========================================= */
/* ROOM FILTER SECTION */
/* ========================================= */

.room-filter-section{
    width:min(1400px,92%);
    margin:50px auto 40px;
}

/* ========================================= */
/* PROMO */
/* ========================================= */

.promo-banner{
    display:flex;
    align-items:center;
    gap:20px;

    padding:22px 30px;

    background:#ecefd2;

    border-radius:18px;

    margin-bottom:24px;
}

.promo-icon{
    font-size:32px;
}

.promo-text{
    font-size:18px;
    color:#222;
}

.promo-text a{
    color:#0066cc;
    text-decoration:none;
    font-weight:600;
}

/* ========================================= */
/* FILTER BOX */
/* ========================================= */

.room-filter-box{
    display:flex;
    justify-content:space-between;
    align-items:center;

    padding:40px;

    background:white;

    border:1px solid #ececec;

    border-radius:30px;

    box-shadow:
        0 10px 30px rgba(0,0,0,.03);
    margin-bottom:15px;
}

/* ========================================= */
/* LEFT */
/* ========================================= */

.filter-left h3{
    font-size:25px;
    margin-bottom:30px;

    color:#222;
}

.filter-tags{
    display:flex;
    flex-wrap:wrap;
    gap:14px;
}

.filter-tag {
    padding: 8px 15px;
    border: none;
    border-radius: 999px;
    background: #f2f6fa;
    color: #4b3a30d1;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: .3s;
}

.filter-tag:hover,
.filter-tag.active{
    background:#4b3a30d1;
    color:white;
}

/* ========================================= */
/* RIGHT */
/* ========================================= */

.filter-right{
    min-width:380px;

    padding-left:40px;

    border-left:
        1px solid #ececec;
}

.filter-right label{
    display:block;

    margin-bottom:14px;

    font-size:14px;
    font-weight:600;

    color:#666;
}

.price-dropdown{
    display:flex;
    justify-content:space-between;
    align-items:center;

    height:68px;

    padding:0 24px;

    border:
        1px solid #d8d8d8;

    border-radius:18px;

    cursor:pointer;
}

.dropdown-icon{
    width:40px;
    height:40px;

    display:flex;
    align-items:center;
    justify-content:center;

    border-radius:50%;

    background:#D8C7B5;

    color:#3f6d8f;
}

@media(max-width:992px){

    .room-filter-box{
        flex-direction:column;
        align-items:flex-start;
        gap:30px;
    }

    .filter-right{
        width:100%;
        min-width:unset;

        padding-left:0;

        border-left:none;
        border-top:1px solid #ececec;

        padding-top:30px;
    }

    .filter-left h3{
        font-size:28px;
    }

}

.booking-field .icon{
    color: #2E2A27;
}

.room-gallery{
    position:relative;
    overflow:hidden;
    border-radius:24px;
}

.gallery-nav{
    position:absolute;
    inset:0;

    display:flex;
    justify-content:space-between;
    align-items:center;

    padding:0 20px;

    pointer-events:none;
}

.gallery-nav button{
    pointer-events:auto;

    width:48px;
    height:48px;

    border:none;
    border-radius:50%;

    background:rgba(0,0,0,.4);

    backdrop-filter:blur(10px);

    color:white;

    cursor:pointer;
}

.old-price{
    display:block;

    color:#9b9b9b;

    text-decoration:line-through;

    font-size:10px;
}

.current-price{
    font-size:16px;
    font-weight:700;

    color:#4B3A30;

    line-height:1.1;
}

.tax-note{
    color:#777;
    font-size:10px;
}

.room-options .option-spec{
    font-size: 12px;
}

.room-options .option-spec div{
    display: block;
}

.room-options .option-spec i.ph{
    font-size: 15px;
}

.ml18{
    margin-left: 18px;
}

.show-more-options{
    display: block;
    text-align: center;
    margin-top: 15px;
    text-decoration: none;
    color: #2E2A27;
}

.room-modal{
    position:fixed;
    inset:0;

    display:flex;
    align-items:center;
    justify-content:center;

    background:rgba(0,0,0,.55);

    opacity:0;
    visibility:hidden;

    transition:
        opacity .35s ease,
        visibility .35s ease;

    z-index:9999;
}

.room-modal.active{
  transform:
    translateY(0)
    scale(1);

  opacity:1;
  visibility:visible;
}

.room-modal.active .room-modal-box{
  transform:
    translateY(0)
    scale(1);

  opacity:1;
}

.room-modal-box{
  width:min(1500px,75%);
  height:92vh;

  background:white;

  border-radius:10px;

  overflow:hidden;

  transform:
    translateY(40px)
    scale(.96);

  opacity:0;

  transition:
    transform .45s cubic-bezier(.22,1,.36,1),
    opacity .35s ease;

  will-change:
    transform,
    opacity;
}

.room-modal-close{
  position:absolute;
  top:15px;
  right:22px;
  z-index:5;
  border:none;
  background:none;
  font-size:20px;
  color:#687078;
  cursor:pointer;
}

.room-modal-close i.ph{
    font-size:20px;
}

.room-modal-header{
  height:50px;
  display:flex;
  align-items:center;
  padding:0 24px;
  border-bottom:1px solid #eee;
}

.room-modal-header h2{
  font-size:20px;
}

.room-modal-content{
  height:calc(100% - 80px);
  display:grid;
  grid-template-columns:2fr 1fr;
}

.modal-gallery{
  background:#242c33;
  position:relative;
  display:flex;
  flex-direction:column;
}

.modal-gallery > img{
    width: 100%;
    height: calc(100% - 250px);
    object-fit: cover;
}

.modal-arrow{
  position:absolute;
  top:42%;
  transform:translateY(-50%);
  width:46px;
  height:46px;
  border-radius:50%;
  border:none;
  background:white;
  color:#1599f2;
  font-size:26px;
  cursor:pointer;
  z-index:3;
}

.modal-prev{
  left:28px;
}

.modal-next{
  right:28px;
}

.modal-thumbnails{
    height: 170px;
    padding: 10px;
    background: #29323a;
    color: white;
}

.thumb-title{
    display: flex;
    justify-content: space-between;
    font-size: 15px;
    font-weight: 600;
    margin-bottom: 10px;
}

.thumb-list{
  display:flex;
  gap:16px;
  overflow-x:auto;
}

.thumb-list img{
  width:210px;
  height:88px;
  object-fit:cover;
  border-radius:8px;
  opacity:.6;
  cursor:pointer;
  border:2px solid transparent;
}

.thumb-list img.active{
  opacity:1;
  border-color:#1599f2;
}

.modal-room-info{
  padding:28px 28px 0;
  overflow-y:auto;
  position:relative;
}

.modal-room-info h3{
  font-size:15px;
  margin-bottom:10px;
}

.modal-info-item{
  display:flex;
  align-items:center;
  gap:5px;
  font-size:20px;
  margin-bottom:5px;
}

.modal-info-item i{
  font-size:15px;
  color:#777;
}

.modal-room-info hr{
  border:none;
  border-top:1px solid #ddd;
  margin:15px 0;
}

.modal-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px 30px;
  padding-left:20px;
  font-size:18px;
}

.modal-list li{
    font-size: 12px;
}

.modal-price-box{
  position:sticky;
  bottom:0;
  background:white;
  box-shadow:0 -8px 20px rgba(0,0,0,.08);
  margin:30px -28px 0;
  padding:28px;
}

.modal-price-box p{
  margin:0 0 6px;
  font-size:12px;
}

.modal-info-item span{
    font-size:12px;
}

.modal-price-box strong{
  color:#ff5722;
  font-size:20px;
}

.modal-price-box span{
  font-size:10px;
}

.modal-price-box button{
    width: 100%;
    height: 32px;
    margin-top: 8px;
    margin-bottom: 8px;
    border: none;
    border-radius: 8px;
    background: #4B3A30;
    color: white;
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
}

@media(max-width:992px){
  .room-modal-box{
    height:95vh;
  }

  .room-modal-content{
    grid-template-columns:1fr;
    overflow-y:auto;
  }

  .modal-gallery > img{
    height:420px;
    padding:0 20px;
  }

  .modal-room-info{
    overflow:visible;
  }

  .modal-list{
    grid-template-columns:1fr;
  }
}

.room-modal{
    color: #2E2A27;
}

.footer-logo{
    width: 150px;
}

.nearby-section{
  padding:0px;
  background:#f8f7f4;
}

.nearby-container{
  width:min(1400px,92%);
  margin:auto;
  background:white;
  padding:28px;
  box-shadow:0 8px 30px rgba(0,0,0,.05);
  border-radius:20px;
}

.nearby-container h2{
  font-size:24px;
  margin-bottom:18px;
  color:#222;
}

.nearby-address{
  display:flex;
  align-items:center;
  gap:10px;
  color:#333;
  margin-bottom:24px;
  font-size:16px;
}

.nearby-map{
  position:relative;
  height:220px;
  overflow:hidden;
  margin-bottom:18px;
  background:#eee;
}

.nearby-map img{
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.75;
}

.discover-map-btn{
  position:absolute;
  right:28px;
  bottom:24px;
  border:none;
  border-radius:999px;
  padding:16px 24px;
  background:#d9f1ff;
  color:#005aa8;
  font-size:16px;
  font-weight:700;
  cursor:pointer;
  box-shadow:0 8px 25px rgba(0,0,0,.08);
}

.nearby-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  border-radius:5px;
  background:#c9f79c;
  color:#176c22;
  font-weight:700;
  font-size:14px;
  margin-bottom:32px;
}

.nearby-content{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:70px;
  max-width:900px;
}

.nearby-list-box h3{
  display:flex;
  align-items:center;
  gap:12px;
  font-size:20px;
  margin-bottom:18px;
  color: #2E2A27;
}

.nearby-list{
  list-style:none;
  padding:0 0 0 32px;
  margin:0;
}

.nearby-list li{
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 30px;
    font-size: 12px;
    color: #333;
    margin-bottom: 5px;
}

.nearby-list li span:last-child{
  color:#7b8085;
}

.distance-note{
  display:flex;
  align-items:center;
  gap:10px;
  margin:26px 0 36px;
  color:#73777b;
  font-size:14px;
  font-weight:600;
}

.discover-gallery{
  display:grid;
  grid-template-columns:1.6fr 1fr;
  gap:14px;
}

.discover-card{
  position:relative;
  height:280px;
  overflow:hidden;
}

.discover-card img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.discover-overlay{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  padding:20px;
  background:linear-gradient(
    to top,
    rgba(0,0,0,.75),
    rgba(0,0,0,.15)
  );
  color:white;
  font-size:22px;
  font-weight:700;
}

@media(max-width:992px){
  .nearby-content{
    grid-template-columns:1fr;
    gap:35px;
  }

  .discover-gallery{
    grid-template-columns:1fr;
  }

  .discover-map-btn{
    right:16px;
    bottom:16px;
    font-size:14px;
  }
}

.hotel-about-section{
    margin-top:50px;
    margin-bottom:25px;
}

.hotel-about-section h2{
    font-size:25px;
    font-family:"Cormorant Garamond", serif;
    margin-bottom:24px;
}

.hotel-about-text{
    color: #555;
    line-height: 1.8;
    overflow: hidden;
    transition: .4s ease;
    font-size: 10px;
}

.hotel-about-text.collapsed{
    max-height:120px;
}

.hotel-about-text.expanded{
    max-height:1000px;
}

.read-more-btn{
    margin: auto;
    display: block;
    align-items: center;
    gap: 10px;
    padding: 12px 24px;
    border: 0px solid #9ec8f0;
    background: white;
    border-radius: 14px;
    color: #4B3A30;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
}

.hotel-facilities-section{
    margin-top:25px;
}

.hotel-facilities-section h2{
    font-size:25px;
    font-family:"Cormorant Garamond", serif;
    margin-bottom:30px;
}

.facility-grid{
    display:grid;
    grid-template-columns:repeat(5,1fr);
    gap:20px;
}

.facility-card{
    position:relative;
    overflow:hidden;
    border-radius:18px;
    height:240px;
    cursor:pointer;
}

.facility-card img{
    width:100%;
    height:100%;
    object-fit:cover;

    transition:.5s ease;
}

.facility-card:hover img{
    transform:scale(1.08);
}

.facility-overlay{
    position:absolute;
    left:0;
    right:0;
    bottom:0;

    padding:18px;

    background:
        linear-gradient(
            to top,
            rgba(0,0,0,.75),
            rgba(0,0,0,.1)
        );

    color:white;
    font-size:28px;
    font-family:"Cormorant Garamond", serif;
}

.hotel-about-text h3{
    margin-top:15px;
    font-size:13px;
}
.facility-details-section{
    padding: 25px;
}

.facility-detail-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:15px 70px;
}

.facility-group h3{
    display:flex;
    align-items:center;
    gap:12px;

    font-size:17px;
    font-weight:600;

    margin-bottom:10px;

    color:#2E2A27;
}

.facility-group h3 i{
    font-size:28px;
    color:#8A6A4A;
}

.facility-group ul{
    list-style:none;
    margin:0 0 0 10px;
    padding:0;
}

.facility-group li{
    position: relative;
    padding-left: 22px;
    margin-bottom: 10px;
    color: #555;
    font-size: 13px;
}

.facility-group li::before{
    content:'○';

    position:absolute;
    left:0;
    top:0;

    color:#777;
    font-size:14px;
}

@media(max-width:992px){

    .facility-detail-grid{
        grid-template-columns:1fr;
        gap:40px;
    }

}

.hotel-overview{
    padding: 50px 0 0 0;
    background: #f8f7f4;
    color: #2E2A27;
}

.hotel-gallery-grid{
    display:grid;
    grid-template-columns:2fr 1fr;
    gap:10px;
}

.gallery-main img{
    width:100%;
    height:330px;
    object-fit:cover;
    border-radius:20px;
}

.gallery-side{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
}

.gallery-side img{
    width:100%;
    height:160px;
    object-fit:cover;
    border-radius:14px;
}

.see-all-photo{
    position:relative;
}

.photo-overlay{
    position:absolute;
    inset:0;

    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;

    background:rgba(0,0,0,.45);

    color:white;
    font-weight:600;

    border-radius:14px;
}

.hotel-summary{
    margin-top:-20px;

    background:white;

    border-radius:24px;

    padding:30px;

    box-shadow:
    0 10px 40px rgba(0,0,0,.08);
}

.summary-header{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;

    margin-bottom:30px;
}

.summary-header h1{
    font-size:35px;
    margin-bottom:10px;
}

.hotel-meta{
    display:flex;
    gap:15px;
    align-items:center;
}

.hotel-tag{
    padding: 6px 12px;
    border-radius: 999px;
    background: #D8C7B5;
    color: #4B3A30;
    font-size: 12px;
}

.partner-badge{
    color:#4B3A30;
    font-weight:600;
}

.summary-price{
    display:flex;
    align-items:center;
    gap:20px;
}

.summary-price strong{
    display:block;
    font-size:30px;
    color:#f26722;
    margin:5px 0;
}

.summary-price button{
    border:none;
    padding:14px 24px;
    border-radius:12px;
    background:#4b3a30d1;
    color:white;
    font-weight:600;
    cursor:pointer;
}

.summary-grid{
    display:grid;
    grid-template-columns:1fr 1fr 1fr;
    gap:20px;
}

.summary-card{
    border:1px solid #ececec;
    border-radius:18px;
    padding:24px;
}

.review-score{
    display:flex;
    gap:15px;
    margin-bottom:20px;
}

.review-score strong{
    font-size:42px;
    color:#0d84ff;
}

.review-tags{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
}

.review-tags span{
    padding:6px 12px;
    border-radius:999px;
    background:#eef6f0;
    font-size:12px;
}

.facility-mini{
    display:grid;
    gap:15px;
}

.facility-mini span{
    display:flex;
    gap:12px;
}

.area-list{
    list-style:none;
    padding:0;
    margin-top:15px;
}

.area-list li{
    display:flex;
    justify-content:space-between;
    margin-bottom:12px;
}

.hotel-description{
    margin-top:20px;

    padding:20px;

    border:1px solid #ececec;

    border-radius:16px;
}

.hotel-description a{
    display:inline-block;
    margin-top:15px;
    color:#0d84ff;
}

.hotel-summary{
    color: #2E2A27;
}

.price-info small{
    font-size:10px;
}

.hotel-stars{
    color:#f5a623;
    font-size:14px;
}

.review-card{
    position:relative;
    overflow:hidden;
    padding:24px;
}

.review-card::before{
    content:'';
    position:absolute;
    top:0;
    right:0;
    width:65%;
    height:70px;
    /* background: linear-gradient(160deg, #4b3a3052, rgba(255, 255, 255, .2)); */
    border-bottom-left-radius:80%;
    pointer-events:none;
}

.review-header{
    position:relative;
    z-index:1;

    display:flex;
    align-items:center;
    gap:22px;

    margin-bottom:24px;
}

.review-score-main{
    display:flex;
    align-items:flex-end;
    gap:3px;

    color:#007ce0;
}

.review-score-main strong{
    font-size:35px;
    line-height:1;
    font-weight:700;
}

.review-score-main span{
    font-size:18px;
    line-height:1.2;
}

.review-status h3{
    font-size:20px;
    line-height:1;
    margin-bottom:8px;
    color:#2b2b2b;
}

.review-count{
    display:flex;
    align-items:center;
    gap:6px;

    color:#007ce0;
    text-decoration:none;

    font-size:12px;
    font-weight:700;
}

.review-title{
    font-size:15px;
    line-height:1.3;
    margin-bottom:10px;
    color:#07131d;
}

.review-tags{
    display:flex;
    flex-wrap:wrap;
    gap:6px;
    margin-bottom:22px;
}

.review-tags span{
    padding: 4px 10px;
    border-radius: 999px;
    background:#defaea;
    color:#008653;
    font-size: 9px;
    font-weight:500;
}

.review-scroll{
    max-height:190px;
    overflow-y:auto;
    padding-right:8px;
}

.review-scroll::-webkit-scrollbar{
    width:6px;
}

.review-scroll::-webkit-scrollbar-track{
    background:transparent;
}

.review-scroll::-webkit-scrollbar-thumb{
    background:#c9c9c9;
    border-radius:999px;
}

.guest-review{
    padding: 10px 15px;
    border: 1px solid #e8e8e8;
    border-radius: 15px;
    margin-bottom: 7px;
    background: white;
}

.guest-review-top{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:16px;
    margin-bottom:5px;
}

.guest-review-top h5{
    font-size:15px;
    margin:0;
    color:#2a2a2a;
}

.mini-score{
    display:inline-flex;
    align-items:center;
    gap:5px;

    padding:4px 8px;
    border-radius:8px;

    background:#eef9ff;
    color:#008df0;

    font-size:12px;
    font-weight:700;
    white-space:nowrap;
}

.guest-review p{
    font-size:10px;
    line-height:1.7;
    color:#333;
    margin-bottom:14px;
}

.review-bottom{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:16px;
}

.review-bottom a{
    color:#007ce0;
    text-decoration:none;
    font-weight:700;
}

.review-bottom span{
    color:#aaa;
    font-size:9px;
    font-style:italic;
}

.review-bottom b{
    font-style:normal;
    color:#4285f4;
}

.review-bottom a{
    font-size:10px;
}

@media(max-width:768px){

    .review-header {
        align-items: flex-start;
        gap: 45px;
        padding-left: 10px;
    }

    .review-score-main strong{
        font-size:36px;
    }

    .review-status h3{
        font-size:22px;
    }

    .review-count{
        font-size:16px;
    }

    .review-title{
        font-size:20px;
    }

}

.area-card{
    position:relative;
    overflow:hidden;
    min-height:420px;
    padding:28px;
}

.area-card-bg{
    position:absolute;
    inset:0;

    background:
        linear-gradient(
            to bottom,
            rgba(255,255,255,.65),
            rgba(255,255,255,.98) 58%
        ),
        url("../images/map-placeholder.jpg");

    background-size:cover;
    background-position:center top;

    opacity:.55;
    pointer-events:none;
}

.area-card-header,
.area-address,
.area-badge,
.area-place-list{
    position:relative;
    z-index:1;
}

.area-card-header{
    display:flex;
    align-items:center;
    justify-content:space-between;

    margin-bottom:22px;
}

.area-card-header h3{
    font-size:15px;
    margin:0;
    color:#07131d;
}

.area-card-header a{
    display:flex;
    align-items:center;
    gap:8px;

    color:#2E2A27;
    text-decoration:none;

    font-size:12px;
    font-weight:700;
}

.area-address{
    display:flex;
    align-items:flex-start;
    gap:14px;

    margin-bottom:16px;
}

.area-address i{
    margin-top:6px;
    color:#687078;
    font-size:22px;
}

.area-address p{
    margin:0;
    color:#07131d;

    font-size:10px;
    line-height:1.45;
    font-weight:500;
}

.area-badge{
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 16px;
    border-radius: 999px;
    background: #D8C7B5;
    color: #07131d;
    font-size: 10px;
    font-weight: 600;
    margin-bottom: 18px;
}

.area-badge i{
    color:#2E2A27;
}

.area-place-list{
    list-style:none;
    padding:0;
    margin:0;
}

.area-place-list li{
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    margin-bottom: 5px;
    font-size: 10px;
    color: #07131d;
}

.area-place-list li div{
    display:flex;
    align-items:center;
    gap:12px;
    min-width:0;
}

.area-place-list li div span{
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}

.area-place-list li i{
    color:#07131d;
    font-size:14px;
    flex-shrink:0;
}

.area-place-list li > span{
    color:#687078;
    font-size:10px;
    white-space:nowrap;
}

.main-facilities-card{
    min-height:420px;
    padding:28px;
}

.main-facilities-header{
    display:flex;
    align-items:center;
    justify-content:space-between;

    margin-bottom:34px;
}

.main-facilities-header h3{
    margin:0;

    font-size:15px;
    color:#07131d;
}

.main-facilities-header a{
    display: flex;
    align-items: center;
    gap: 8px;
    color: #2E2A27;
    text-decoration: none;
    font-size: 12px;
    font-weight: 700;
}

.main-facilities-list{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:15px 70px;
}

.main-facility-item{
    display: flex;
    align-items: center;
    gap: 16px;
    color: #07131d;
    font-size: 12px;
    font-weight: 500;
}

.main-facility-item i{
    width: 36px;
    color: #4b3a30d1;
    font-size: 22px;
    flex-shrink: 0;
}

.main-facility-item:nth-child(3),
.main-facility-item:nth-child(4),
.main-facility-item:nth-child(5){
    grid-column:1 / 2;
}

@media(max-width:768px){

    .main-facilities-card{
        min-height:auto;
    }

    .main-facilities-list{
        grid-template-columns:1fr;
        gap:22px;
    }

    .main-facility-item:nth-child(3),
    .main-facility-item:nth-child(4),
    .main-facility-item:nth-child(5){
        grid-column:auto;
    }

}

.hotel-description-card{
    margin-top:18px;

    padding:24px 28px;

    border:1px solid #e9e9e9;
    border-radius:14px;

    background:#fff;
}

.hotel-description-text{
    margin:0 0 5px;

    color:#111;
    font-size:12px;
    line-height:1.45;
    font-weight:400;
}

.hotel-description-link{
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #2E2A27;
    text-decoration: none;
    font-size: 12px;
    font-weight: 700;
}

.hotel-description-link i{
    font-size:18px;
}

.rating-detail-section{
    padding:60px 0;
    background:#f8f7f4;
    color:#07131d;
}

.rating-detail-container{
    width:min(1400px,92%);
    margin:auto;
    background:#fff;
    padding:18px;
    box-shadow:0 8px 30px rgba(0,0,0,.04);
    border-radius: 20px;
}

.rating-detail-container > h2{
    font-size:18px;
    margin-bottom:18px;
}

/* Tabs */

.rating-tabs{
    display:flex;
    border-bottom:1px solid #dcdcdc;
}

.rating-tab{
    min-width:240px;
    padding:18px 28px;
    border:none;
    background:none;
    color:#65717b;
    font-weight:700;
    cursor:pointer;
}

.rating-tab.active{
    background: #d8c7b57d;
    color: #4B3A30;
    border-bottom: 3px solid #4B3A30;
}

/* Rating Summary */

.rating-summary-box{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:80px;
    padding:42px 26px;
}

.rating-score-box{
    display:flex;
    align-items:center;
    gap:50px;
}

.big-rating{
    width:120px;
    height:120px;
    border:6px solid #dff5ff;
    border-radius:24px;

    display:flex;
    align-items:center;
    justify-content:center;

    color:#008cff;
    font-size:42px;
    font-weight:800;
}

.rating-label h3{
    margin:0 0 12px;
    color:#008cff;
    font-size:34px;
}

.rating-label strong{
    display:block;
    font-size: 15px;
    margin-bottom: 5px;
}

.rating-label p{
    color:#6c757d;
    font-size:16px;
}

/* Bars */

.rating-bars{
    display:flex;
    flex-direction:column;
    gap:8px;
}

.rating-bar-item{
    display:grid;
    grid-template-columns:120px 1fr 40px;
    align-items:center;
    gap:16px;
}

.rating-bar-item span{
    font-size:12px;
}

.bar-track{
    height:12px;
    background:#f1f5f8;
    border-radius:999px;
    overflow:hidden;
}

.bar-fill{
    height:100%;
    background:#4B3A30;
    border-radius:999px;
}

.rating-bar-item strong{
    color:#4B3A30;
}

/* Filter Box */

.review-filter-box{
    border:1px solid #e8e8e8;
    border-radius:8px;
    padding:20px 14px 0;
    margin-bottom:32px;
}

.review-filter-box p{
    color:#65717b;
    font-size:16px;
    margin-bottom:16px;
}

.review-chip-list{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-bottom:22px;
}

.review-chip{
    display:inline-flex;
    align-items:center;
    gap:10px;

    padding:10px 14px;
    border:1px solid #d5dbe0;
    border-radius:12px;
    background:#fff;

    color:#07131d;
    font-size:15px;
    font-weight:600;

    cursor:pointer;
}

.review-chip i{
    color:#9ba6af;
}

.review-chip.active{
    background: #4B3A30;
    color: white;
    border-color: #4B3A30;
}

.review-chip.active i{
    color:white;
}

/* Filter Row */

.review-filter-row{
    display:grid;
    grid-template-columns:1fr 1fr 1fr;
    margin:0 -14px;
    border-top:1px solid #e6e6e6;
}

.review-filter-item{
    display:flex;
    align-items:center;
    gap:16px;

    padding:18px 24px;
    border-right:1px solid #e6e6e6;
}

.review-filter-item:last-child{
    border-right:none;
}

.review-filter-item > i:first-child{
    font-size:22px;
    color:#687078;
}

.review-filter-item div{
    flex:1;
}

.review-filter-item span{
    display:block;
    color:#65717b;
    font-size:13px;
}

.review-filter-item strong{
    display:block;
    color:#4B3A30;
    font-size:14px;
}

/* Header */

.customer-review-header{
    display:flex;
    justify-content:space-between;
    align-items:flex-end;
    margin-bottom:22px;
}

.customer-review-header p{
    color:#65717b;
    font-weight:700;
    margin-bottom:28px;
}

.customer-review-header h2{
    font-size:28px;
}

.review-pagination-control{
    display:flex;
    align-items:center;
    gap:12px;
}

.review-pagination-control button{
    min-width:42px;
    height:36px;
    border:none;
    border-radius:8px;
    background:#f3f6f8;
    color:#4B3A30;
    font-weight:700;
    cursor:pointer;
}

.review-pagination-control button.active{
    background:#4B3A30;
    color:white;
}

.review-pagination-control .circle{
    width:44px;
    height:44px;
    border-radius:50%;
    box-shadow:0 6px 16px rgba(0,0,0,.08);
}

.review-pagination-control .disabled{
    opacity:.35;
}

/* Customer Review */

.customer-review-card{
    display:grid;
    grid-template-columns:280px 1fr;
    gap:40px;

    border:1px solid #e8e8e8;
    border-radius:8px;
    padding:28px;
}

.review-user-column{
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:18px;
}

.review-avatar{
    width:68px;
    height:68px;
    border-radius:50%;
    background:#4B3A30;
    color:#9fd1ff;

    display:flex;
    align-items:center;
    justify-content:center;

    font-size:24px;
    font-weight:700;
}

.review-type{
    display:flex;
    align-items:center;
    gap:8px;
    color:#07131d;
}

.review-type i{
    color:#687078;
    font-size:20px;
}

.review-content-top{
    display:flex;
    align-items:center;
    gap:20px;
    margin-bottom:16px;
}

.customer-score{
    display:inline-flex;
    align-items:center;
    gap:6px;

    padding:6px 12px;
    border-radius:999px;

    background:#d8c7b57d;
    color:#4B3A30;

    font-weight:700;
}

.review-content-top strong{
    color:#65717b;
}

.review-content-column p{
    font-size:15px;
    line-height:1.6;
    margin-bottom:8px;
}

.review-read-more,
.translation-note a,
.helpful-link{
    color:#4B3A30;
    font-weight:700;
    text-decoration:none;
}

.translation-note{
    margin:26px 0;
    color:#999;
    font-size:13px;
    font-style:italic;
}

.translation-note b{
    color:#4B3A30;
    font-style:normal;
}

.helpful-link{
    display:inline-flex;
    align-items:center;
    gap:12px;
    margin-bottom:20px;
}

.helpful-link i{
    color:#07131d;
    font-size:24px;
}

.hotel-reply-box{
    background:#f6f8fa;
    border:1px solid #ececec;
    border-radius:8px;
    padding:18px;
}

.hotel-reply-box strong{
    display:block;
    color:#4B3A30;
    margin-bottom:8px;
}

.hotel-reply-box span{
    display:block;
    color:#65717b;
    font-weight:700;
    margin-bottom:14px;
}

.hotel-reply-box p{
    color:#65717b;
    margin:0;
}



.booking-field{
    display:flex;
    flex-direction:column;
    justify-content:center;

    height:80px;

    padding:12px 20px;

    border:1px solid #e4e4e4;
    border-radius:14px;
}

.booking-field label{
    font-size:12px;
    color:#888;
    margin-bottom:6px;
}

.field-value{
    display:flex;
    align-items:center;
    gap:10px;
}

.field-value i{
    font-size:20px;
    color:#4B3A30;
}

.field-value input{
    border:none;
    outline:none;
    background:none;

    font-size:18px;
    font-weight:600;
    color:#2E2A27;

    width:100%;
}

.room-promo{
    display:inline-block;

    margin-bottom:15px;
    padding:6px 12px;

    background:#fff4e6;
    color:#d97706;

    border-radius:999px;

    font-size:12px;
    font-weight:700;
}

.offer-ribbon{
    width: min(1400px, 100%);
    margin: 10px 0px;

    display:flex;
    align-items:center;
    gap:20px;

    padding:18px 24px;

    background:
        linear-gradient(
            135deg,
            #F7F1E7,
            #EFE2CD
        );

    border:1px solid #E4D4BF;
    border-radius:18px;

    box-shadow:
        0 8px 25px rgba(0,0,0,.04);
}

.offer-ribbon-icon{
    width:56px;
    height:56px;

    display:flex;
    align-items:center;
    justify-content:center;

    border-radius:50%;

    background:white;

    color:#B78A4A;
    font-size:26px;
}

.offer-ribbon-content{
    flex:1;
}

.offer-ribbon-content strong{
    display:block;
    margin-bottom:4px;

    color:#4B3A30;
    font-size:18px;
}

.offer-ribbon-content span{
    color:#7A6A5F;
    font-size:14px;
}

.offer-ribbon a{
    text-decoration:none;

    padding:12px 18px;

    background:#4B3A30;
    color:white;

    border-radius:10px;

    font-weight:600;
}

.logo a{
    text-decoration:none;
}

@media(max-width:992px){

    .rating-summary-box{
        grid-template-columns:1fr;
        gap:40px;
    }

    .rating-score-box{
        gap:24px;
    }

    .review-filter-row{
        grid-template-columns:1fr;
    }

    .review-filter-item{
        border-right:none;
        border-bottom:1px solid #e6e6e6;
    }

    .customer-review-header{
        flex-direction:column;
        align-items:flex-start;
        gap:20px;
    }

    .customer-review-card{
        grid-template-columns:1fr;
    }

    .review-user-column{
        align-items:flex-start;
    }

    .summary-header {
        display: contents;
    }

    .summary-grid {
        display: contents;
    }

    .summary-price strong {
        font-size: 25px;
    }

    .area-card {
        min-height: 300px;
    }

    .room-options {
        padding: 0px 15px 30px 15px;
    }

    .room-card {
        gap: 0px;
    }

    .facility-grid {
        display: contents;
    }

    .room-modal-content {
        display: inline;
    }

    .room-modal-box {
        overflow: scroll;
    }

    .room-modal-box {
        width: min(1500px, 90%);
    }

    .hotel-summary {
        padding: 30px 20px 30px 20px;
    }

    .review-card {
        padding: 24px 15px;
    }

    .offer-ribbon {
        display: grid;
    }
}

@media(max-width:600px){

    .rating-detail-container{
        width:94%;
        padding:14px;
    }

    .rating-tabs{
        overflow-x:auto;
    }

    .rating-tab{
        min-width:190px;
    }

    .rating-score-box{
        flex-direction:column;
        align-items:flex-start;
    }

    .rating-bar-item{
        grid-template-columns:1fr;
        gap:8px;
    }

    .review-pagination-control{
        flex-wrap:wrap;
    }

    .summary-card{
        margin-top:10px;
    }

    .option-info h4 {
        font-size: 23px;
    }

    .current-price {
        font-size: 20px;
    }
    
}

.mobile-gallery-grid{
    display:none;
}

@media(max-width:768px){

    .hotel-gallery-grid{
        display:none;
    }

    .mobile-gallery-grid{
        display:grid;
        grid-template-columns:1.4fr .75fr;
        gap:14px;

        width:100%;
    }

    .mobile-gallery-main{
        grid-column:1 / 2;
    }

    .mobile-gallery-main img{
        width:100%;
        height:420px;
        object-fit:cover;
        border-radius:28px;
    }

    .mobile-gallery-top{
        display:grid;
        grid-template-columns:1fr;
        gap:14px;
    }

    .mobile-gallery-top img{
        width:100%;
        height:203px;
        object-fit:cover;
        border-radius:24px;
    }

    .mobile-gallery-bottom{
        grid-column:1 / 3;

        display:grid;
        grid-template-columns:1fr 1fr;
        gap:14px;
    }

    .mobile-gallery-bottom img{
        width:100%;
        height:180px;
        object-fit:cover;
        border-radius:24px;
    }

    .mobile-see-all{
        position:relative;
        overflow:hidden;
        border-radius:24px;
    }

    .mobile-see-all img{
        filter:brightness(.55);
    }

    .mobile-photo-overlay{
        position:absolute;
        inset:0;

        display:flex;
        align-items:center;
        justify-content:center;
        gap:8px;

        color:white;
        font-size:22px;
        font-weight:700;
        text-align:center;
    }

    
}