/* Responsive Styles */

/* Hero Slider */
@media (max-width: 768px) {

    .swiper-button-prev,
    .swiper-button-next {
        width: 40px;
        height: 40px;
    }

    .swiper-button-prev {
        left: 15px;
    }

    .swiper-button-next {
        right: 15px;
    }

    .swiper-button-prev i,
    .swiper-button-next i {
        font-size: 18px;
    }
}

/* Content Grid Responsive */
@media (max-width: 1399px) {
    .content-grid .image-wrapper {
        width: 50%;
    }

    .content-grid .text-content {
        width: calc(50% - 50px);
    }
}

@media (max-width: 1199px) {
    .gallery-grid {
        grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
        gap: 20px;
    }
    .menu-open header.position-fixed nav.navbar {
        background-color: var(--color-primary);
    }

    nav.navbar .top-navbar .menu--bar .top--header ul.nav-links {
        padding-left: 30px;
    }

    nav.navbar .top-navbar .menu--bar .top--header ul.nav-links {
        gap: 20px;
    }

    nav.navbar .top-navbar .menu--bar .top--header .mobile-menu.open {
        padding-left: 20px;
    }

}

/* Consolidated Media Query for max-width: 991px */
@media (max-width: 991px) {

/* Footer Responsive */
    footer.footer {
        padding-top: 80px;
    }

    footer.footer .footer-brand-section {
        align-items: center;
        text-align: center;
        margin-bottom: 40px;
    }

    footer.footer .footer-logo {
        margin-bottom: 25px;
    }

    footer.footer .footer-logo img {
        max-height: 60px;
    }

    footer.footer .footer-title {
        font-size: 1em;
        margin-bottom: 20px;
    }

    footer.footer .footer-contact-info {
        gap: 18px;
    }

    footer.footer .contact-info-item {
        font-size: 0.9em;
        gap: 10px;
    }

    footer.footer .contact-info-item i {
        font-size: 1em;
    }

    footer.footer .footer-image {
        padding: 40px 0;
    }

    footer.footer .footer-image img {
        max-height: 80px;
    }

    footer.footer .footer-bottom-content {
        flex-direction: column;
        text-align: center;
        gap: 0px;
    }

    h1.heading-main {
        font-size: 2em;
        margin-bottom: 20px;
    }

    h2 {
        font-size: 1.5em;
    }

    h3 {
        font-size: 1.2em;
    }

    .breadcrumb-section {
        padding: 30px 0;
}

    /* Accommodation Detail Responsive */
    .room-hero-section {
        height: 60vh;
        min-height: 400px;
    }

    .room-hero-title {
        font-size: 2.5em;
    }

    .room-hero-subtitle {
        font-size: 1em;
    }

    .room-details-title {
        font-size: 2.5em;
    }

    .room-gallery-slider {
        height: 400px;
    }

    .facilities-features-grid {
        grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
        gap: 18px;
    }

    .facility-feature-card {
        padding: 18px 20px;
    }

    .facilities-inter-wrapper {
        padding: 80px 0;
    }

    .facilities-inter-wrapper .facilities-features-grid {
        grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
        gap: 10px;
    }

    /* Parallax Responsive */
    section.gallery-parallax-section .gallery-image-item {
        width: 100%;
        height: 50%;
    }

    /* Accommodation Grid Responsive */
    section.accommodation-wrapper .accommodation-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 20px;
    }

    section.accommodation-wrapper .accommodation-header .btn-view-more {
        align-self: flex-end;
    }

    .dining-wrapper .dining-slider .swiper-button-prev,
    .dining-wrapper .dining-slider .swiper-button-next {
        width: 50px;
        height: 50px;
    }

    .dining-wrapper .dining-slider .swiper-button-prev {
        left: 15px;
    }

    .dining-wrapper .dining-slider .swiper-button-next {
        right: 15px;
    }

    .dining-wrapper .dining-slider .swiper-button-prev i,
    .dining-wrapper .dining-slider .swiper-button-next i {
        font-size: 18px;
    }

    /* Content Grid Responsive */
    nav.navbar .top-navbar .menu--bar .top--header ul.nav-links {
        display: none;
    }

    nav.navbar .top-navbar .menu--bar .top--header .mobile-menu ul.nav-links {
        display: block;
    }

    .content-grid {
        flex-direction: column-reverse;
        gap: 100px;
    }

    .content-grid .text-content,
    .content-grid .image-wrapper {
        width: 100%;
    }

    .content-grid .image-wrapper .about--imgs img.image {
        width: 65%;
    }

    .content-grid .image-wrapper .about--imgs svg {
        top: -60px;
    }

    /* Accommodation Page Responsive */
    section.accommodation-wrapper.accomodationpage .accommodation-grid {
        flex-direction: column;
}

    section.accommodation-wrapper.accomodationpage .accommodation-grid .accommodation-card {
        width: 100%;
    }

    /* Room Details Responsive */
    section.room-details .swiper.image-slider .swiper-wrapper .swiper-slide {
        width: 33.33%;
    }

    /* Gallery Responsive */
    .gallery-section {
        padding: 80px 0;
    }

    .gallery-section-title {
        font-size: 2.5em;
    }

   

    /* Facilities Section Responsive */
    .facilities-section {
        padding: 80px 0;
    }

    .facilities-section-title {
        font-size: 2.5em;
    }

    .facilities-grid {
        grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
        gap: 18px;
    }

    .facility-item {
        padding: 18px 22px;
    }
}

@media (max-width: 767px) {
    .back-to-main-menu {
        top: 15px;
        left: auto;
        right: 15px;
    }

    .container {
        max-width: 100%;
    }

    /* Footer Responsive */
    footer.footer {
        padding-top: 60px;
    }

    footer.footer .footer-brand-section {
        margin-bottom: 35px;
    }

    footer.footer .footer-logo img {
        max-height: 50px;
    }

    footer.footer .footer-title {
        font-size: 0.95em;
        margin-bottom: 18px;
    }

    footer.footer .footer-social {
        gap: 10px;
    }

    footer.footer .footer-social .social-link i {
        font-size: 1em;
    }

    footer.footer .footer-contact-info {
        gap: 15px;
    }

    footer.footer .contact-info-item {
        font-size: 0.9em;
        gap: 10px;
    }

    footer.footer .contact-info-item i {
        font-size: 1em;
    }

    footer.footer .footer-image {
        padding: 30px 0;
    }

    footer.footer .footer-image img {
        max-height: 60px;
    }

    footer.footer .footer-bottom {
        padding: 25px 0;
        margin-top: 30px;
    }

    footer.footer .footer-photo {
        text-align: center;
        margin-bottom: 30px;
}

    /* Accommodation Detail Responsive */
    .room-hero-section {
        height: 50vh;
        min-height: 350px;
    }

    .room-hero-title {
        font-size: 2em;
    }

    .room-hero-subtitle {
        font-size: 0.9em;
    }

    .room-hero-overlay {
        padding: 40px 0 30px;
    }

    .room-details-title {
        font-size: 2em;
    }

    .booking-widget-title {
        font-size: 1.5em;
    }

    .room-gallery-slider {
        height: 300px;
    }

    .facilities-features-grid {
        grid-template-columns: 1fr;
        gap: 15px;
    }

    .facility-feature-card {
        padding: 16px 18px;
    }

    .facility-feature-title {
        font-size: 0.95em;
        padding-left: 10px;
    }

    .facilities-inter-wrapper {
        padding: 60px 0;
    }

    .facilities-inter-wrapper .facility-feature-card:hover {
        transform: translateX(3px);
    }

    .facilities-inter-wrapper .facility-feature-title {
        font-size: 1em;
    }

    .breadcrumb-accommodation {
        flex-wrap: wrap;
        font-size: 0.85em;
    }

    .description-content {
        font-size: 1em;
    }

    section.gallery-parallax-section .gallery-parallax-content {
        padding: 20px;
    }

    .gallery-parallax-copy {
        padding: 20px;
        max-width: 90%;
    }

/* Accommodation Grid Responsive */
    section.accommodation-wrapper .accommodation-section-title {
        font-size: 2em;
    }

    section.accommodation-wrapper .accommodation-header {
        margin-bottom: 30px;
        align-items: center;
        gap: 10px;
    }

    section.accommodation-wrapper .accommodation-header .btn-view-more {
        padding: 10px 25px;
        font-size: 0.9em;
        align-self: flex-start;
    }

    .dining-wrapper .accommodation-header {
        flex-direction: column;
        align-items: center;
        gap: 10px;
        margin-bottom: 30px;
    }

    .dining-wrapper .accommodation-section-title {
        font-size: 2em;
    }

    .dining-wrapper .dining-slider .swiper-button-prev,
    .dining-wrapper .dining-slider .swiper-button-next {
        width: 40px;
        height: 40px;
    }

    .dining-wrapper .dining-slider .swiper-button-prev {
        left: 15px;
    }

    .dining-wrapper .dining-slider .swiper-button-next {
        right: 15px;
    }

    .dining-wrapper .dining-slider .swiper-button-prev i,
    .dining-wrapper .dining-slider .swiper-button-next i {
        font-size: 18px;
    }

    /* Contact Section Responsive */
    .contact-section {
        padding: 60px 0;
    }

    .contact-header {
        margin-bottom: 50px;
    }

    .contact-section-title {
        font-size: 2em;
    }

    .contact-info-grid {
        grid-template-columns: 1fr;
        border-left: none;
    }

    .contact-info-item {
        padding: 35px 25px;
        border-left: 1px solid rgba(30, 29, 26, 0.1);
    }

    .contact-info-item:first-child {
        border-top: none;
    }

    .contact-info-label {
        font-size: 0.85em;
        margin-bottom: 15px;
    }

    .contact-info-value {
        font-size: 1em;
    }

    .map-section {
        padding: 0 0 60px;
    }

    .map-canvas {
        height: 350px;
    }

    /* Accessibility Responsive */
    .accessibility-panel {
        bottom: 15px;
        right: 15px;
        width: calc(100vw - 30px);
        max-width: 320px;
    }

    .accessibility-toggle-text {
        display: none;
    }

    .accessibility-options {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }

    .accessibility-option-btn {
        padding: 15px 10px;
    }

    .accessibility-icon {
        width: 35px;
        height: 35px;
    }

    .accessibility-icon i {
        font-size: 1.2em;
    }

    .accessibility-label {
        font-size: 0.8em;
    }

/* Content Grid Responsive */
    .content-grid .image-wrapper .about--imgs img.image {
        width: 85%;
    }

    .main-all-title .heading-main {
        font-size: 30px;
        line-height: 43px;
    }

    .main-all-title .about--section .sub-heading {
        font-size: 20px;
    }

    section,
    footer {
        padding-top: 50px;
        padding-bottom: 50px;
}

/* Room Details Responsive */
    section.room-details .swiper.image-slider .swiper-wrapper .swiper-slide {
        width: 100%;
    }

/* Gallery Responsive */
    .gallery-section {
        padding: 60px 0;
    }

    .gallery-section-title {
        font-size: 2em;
    }

    .gallery-filters {
        margin-bottom: 40px;
    }

    .gallery-filter-list {
        flex-wrap: wrap;
        gap: 10px;
    }

    .gallery-filter-btn {
        padding: 10px 25px;
        width: 100%;
        text-align: center;
    }

    .gallery-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 15px;
    }

    .gallery-overlay i {
        font-size: 2.5em;
    }

/* Facilities Section Responsive */
    .facilities-section {
        padding: 60px 0;
    }

    .facilities-section-title {
        font-size: 2em;
    }

    .facilities-section-subtitle {
        font-size: 1em;
        margin-top: 20px;
    }

    .facilities-grid {
        grid-template-columns: 1fr;
        gap: 15px;
    }

    .facility-item {
        padding: 18px 20px;
    }

    .facility-name {
        font-size: 1em;
    }

    .desktop-menu .nav-links li a,
    .desktop-menu .nav-links li button,
    .more-menu-list .dropdown-item {
        font-size: 1.2em;
    }

    .desktop-menu .nav-links,
    .more-menu-list,
    .desktop-menu-center {
        gap: 10px;
    }
}

@media (max-width: 575px) {
    main {
        padding-top: 60px;
    }
    .facilities-inter-wrapper .facilities-features-grid {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .language_dropdown {
        grid-auto-flow: row;
        min-width: auto;
    }

    section .fac-list ul {
        grid-template-columns: 1fr;
    }

    .lang-wrapper {
        margin-left: 10px;
        padding-left: 10px;
    }

    .hero-slider {
        height: 100%;
    }

    .hero-slider .swiper {
        height: 220px;
    }

    .widget-container {
        position: unset;
        margin: 20px 0;
    }

    .logo img {
        height: 35px;
    }

    section.gallery-parallax-section .gallery-parallax-content,
    .content-grid .text-content,
    .content-grid .image-wrapper {
        width: 90%;
    }

    .content-grid .image-wrapper .about--imgs svg {
        display: none;
    }

    .content-grid .image-wrapper .about--imgs img.image {
        border-radius: 0;
        height: 350px;
    }


    nav.navbar .top-navbar .menu--bar .top--header .logo img {
        max-height: 40px;
    }

    .about .about-media img {
        height: auto;
    }

    h1.heading-main,
    section.accommodation-wrapper .accommodation-section-title {
        font-size: 1.5em;
    }

    section.about:after {
        background-size: 100px;
        width: 100px;
        height: 100px;
    }

    body, p {
        font-size: 0.9em;
    }

    nav.navbar {
        padding: 10px;
    }

    header.position-fixed nav.navbar {
        padding: 10px;
    }

    nav.navbar .top-navbar .menu--bar .top--header .top--menu {
        width: auto;
    }

    nav.navbar .top-navbar .menu--bar .top--header .up-line {
        margin: 0 10px;
        margin-bottom: -25px;
    }
}

@media (orientation: landscape) and (max-height: 640px) {
    .desktop-menu-center,
    .dropdown-menu-wrapper {
        align-items: start;
}
}