/* Mobile Responsive Styles 
   This file contains all the CSS required to make the website look good on mobile devices.
*/

@media (max-width: 767px) {
  /* General Layout */
  body {
    overflow-x: hidden;
  }
  
  .container, .container-fluid {
    padding-left: 15px !important;
    padding-right: 15px !important;
  }

  /* Hero Section */
  .hero-section {
    height: 50vh !important;
  }
  .swiper-slide {
    height: 50vh !important;
  }
  .big-text {
    font-size: 36px !important;
    line-height: 46px !important;
    margin-bottom: 15px !important;
  }
  .fade-zoom {
    font-size: 24px !important;
  }

  /* Header & Navigation */
  .header-top-area {
    display: none !important;
  }
  .header-menu-area .logo {
    text-align: left;
  }
  .header-menu-area .logo img {
    max-width: 120px !important;
  }
  
  /* Section Titles */
  .section-title h1 {
    font-size: 28px !important;
    line-height: 38px !important;
  }
  .section-title p {
    font-size: 14px !important;
  }

  /* Image Galleries & Elements */
  .tile-gallery {
    margin-bottom: 30px !important;
  }
  .tile-gallery img {
    width: 100% !important;
    height: auto !important;
  }

  /* Counter Boxes */
  .counter .counter-box {
    margin-bottom: 20px;
  }
  .counter .counter-box img {
    max-width: 40px;
  }
  .counter .counter-number {
    font-size: 28px !important;
  }

  /* Rooms Grid */
  .single-room {
    margin-bottom: 30px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.1);
  }
  .single-room .room-thumb img {
    width: 100% !important;
    height: auto !important;
  }
  .single-room .room-desc {
    padding: 20px !important;
  }
  .single-room .room-desc h4 {
    font-size: 20px !important;
  }

  /* Services Box */
  .single-service-box {
    margin-bottom: 30px;
    padding: 30px 15px !important;
  }

  /* Call to Action */
  .cta-section {
    padding: 50px 0 !important;
  }
  .cta-section .cta-left-content h1 {
    font-size: 32px !important;
    line-height: 42px !important;
  }
  
  /* Footer */
  .footer-widget {
    margin-bottom: 40px;
  }
  .footer-bottom {
    text-align: center;
    padding: 20px 0 !important;
  }
  .footer-bottom .footer-nav {
    justify-content: center;
    margin-bottom: 15px;
    flex-wrap: wrap;
  }

  /* Room Details Page */
  .room-details-tab .main-slider .single-img img {
    width: 100% !important;
    height: auto !important;
  }
  .dots-slider .single-dots img {
    width: 100% !important;
    height: auto !important;
    margin-bottom: 10px;
  }
  .room-specification ul li {
    font-size: 14px;
    line-height: 24px;
  }
  .entry-title {
    font-size: 24px !important;
  }

  /* Hardcoded inline style overrides */
  .about-text-box[style] {
    width: 100% !important;
    max-width: 100% !important;
    padding: 20px !important;
  }
  .room-thumb img[style], img[style*="width:370px"] {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
  }
  .swiper-slide h2[style] {
    font-size: clamp(30px, 8vw, 66px) !important;
    line-height: 1.2 !important;
  }
}

/* Extra Small Devices - max-width: 480px */
@media (max-width: 480px) {
  .hero-section, .swiper-slide {
    height: 40vh !important;
  }
  .big-text {
    font-size: 28px !important;
    line-height: 38px !important;
  }
  .section-title h1 {
    font-size: 24px !important;
    line-height: 32px !important;
  }
  .single-room .room-desc h4 {
    font-size: 18px !important;
  }
  .cta-section .cta-left-content h1 {
    font-size: 26px !important;
    line-height: 36px !important;
  }
  .counter .counter-number {
    font-size: 24px !important;
  }
}
