/* ============================================
   Bhavana Decors - Responsive Styles
   Mobile-First Approach
   ============================================ */

/* Prevent Horizontal Scrolling */
html {
    overflow-x: hidden;
    max-width: 100%;
}

body {
    overflow-x: hidden;
    max-width: 100%;
    position: relative;
}

.container,
.container-fluid {
    max-width: 100%;
    
}

/* Ensure containers don't cause overflow */
.container {
    width: 100%;
    max-width: 100%;
    padding-left: 15px;
    padding-right: 15px;
    box-sizing: border-box;
}

@media (max-width: 768px) {
    .container {
        padding-left: 15px;
        padding-right: 15px;
    }
}

/* Mobile Devices (up to 768px) */
@media (max-width: 768px) {
    h1 {
        font-size: 2.5rem;
    }
    
    h2 {
        font-size: 2rem;
    }
    
    h3 {
        font-size: 1.5rem;
    }
    
    body {
        padding-top: 70px;
    }
    
    .hero-banner {
        min-height: 70vh;
        padding: 1rem;
    }
    
    .hero-banner h1 {
        font-size: 2.5rem;
    }
    
    .hero-banner p {
        font-size: 1rem;
    }
    
    .section {
        padding: 3rem 0;
        overflow: visible;
        width: 100%;
        max-width: 100%;
    }
    
    .section-title {
        margin-bottom: 2rem;
    }
    
    .about-preview-content {
        flex-direction: column;
        gap: 2rem;
    }
    
    .about-preview-image {
        height: 300px;
    }
    
    .page-banner {
        min-height: 250px;
    }
    
    .page-banner h1 {
        font-size: 2rem;
    }
    
    .contact-form {
        padding: 2rem 1.5rem;
    }
    
    .contact-item {
        padding: 1.5rem 1rem;
    }
    
    .contact-icon {
        font-size: 2rem;
    }
    
    .gallery-grid {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
    
    .gallery-item {
        aspect-ratio: 1;
    }
    
    /* Product Cards Mobile */
    .product-card {
        margin-bottom: 1.5rem;
    }
    
   
    
    .product-body {
        padding: 1rem;
    }
    
    .product-name {
        font-size: 1.1rem;
    }
    
    .product-price {
        font-size: 1.25rem;
    }
    
    .book-now-btn {
        font-size: 0.9rem;
        padding: 0.5rem 1rem;
    }
    
    /* Gallery Modal Mobile */
    #galleryModal .modal-dialog {
        margin: 0.5rem;
        max-width: calc(100% - 1rem);
    }
    
    #galleryModal .modal-content {
        border-radius: 0.5rem;
    }
    
    #galleryModal .modal-body {
        padding: 1rem 0.5rem;
    }
    
    #galleryModal .modal-body img {
        max-height: 70vh;
        width: auto;
        margin: 0 auto;
    }
    
    .modal-navigation {
        display: flex;
        flex-direction: column;
        gap: 0.5rem;
        padding: 0 1rem;
    }
    
    .modal-navigation .btn {
        width: 100%;
        margin: 0 !important;
    }
    
    /* Buttons Mobile */
    .btn-primary-custom,
    .btn-outline-custom {
        padding: 0.75rem 1.5rem;
        font-size: 0.9rem;
        width: 100%;
        margin-bottom: 0.5rem;
    }
    
    .btn-sm {
        padding: 0.5rem 1rem;
        font-size: 0.85rem;
    }
    
    /* Footer Mobile */
    .footer {
        text-align: center;
        padding: 2rem 0;
    }
    
    .footer .row > div {
        margin-bottom: 2rem;
    }
    
    .footer h5 {
        font-size: 1.25rem;
        margin-bottom: 1rem;
    }
    
    .footer p {
        font-size: 0.9rem;
        line-height: 1.6;
    }
    
    .footer-links {
        list-style: none;
        padding: 0;
    }
    
    .footer-links li {
        margin-bottom: 0.5rem;
    }
    
    .social-icons {
        justify-content: center;
        margin-top: 1rem;
    }
    
    /* Navigation Mobile */
    .navbar {
        padding: 0.5rem 0;
    }
    
    .navbar.scrolled {
        padding: 0.4rem 0;
    }
    
    .navbar.scrolled .navbar-brand img {
        height: 45px;
    }
    
    .navbar-brand {
        font-size: 1.25rem;
        padding: 0.25rem 0;
    }
    
    .navbar-brand img {
        height: 50px;
        /* max-width: 100%; */
        object-fit: contain;
    }
    
    .navbar-nav .nav-link {
        padding: 0.75rem 1rem !important;
        margin: 0;
        text-align: center;
    }
    
    /* Map Container Mobile */
    .map-container {
        padding-bottom: 75% !important;
        margin: 0;
        width: 100%;
        max-width: 100%;
    }
    
    /* Fix container padding on mobile */
    .container {
        padding-left: 15px;
        padding-right: 15px;
    }
    
    /* Ensure no element exceeds viewport */
 /*    * {
        max-width: 100%;
    } */
    
    /* Fix gallery grid for mobile */
    .gallery-grid {
        grid-template-columns: 1fr !important;
        gap: 1rem !important;
        margin-left: 0;
        margin-right: 0;
        padding-left: 0;
        padding-right: 0;
    }
    
    .gallery-grid .gallery-item {
        width: 100%;
        max-width: 100%;
        margin: 0;
    }
    
    /* Fix navbar container */
    .navbar .container {
        padding-left: 15px;
        padding-right: 15px;
    }
    
    /* Fix hero images overflow */
    .hero-images,
    .hero-image-container {
        max-width: 100%;
        overflow: hidden;
    }
    
    /* Fix product card overflow */
    .product-card {
        max-width: 100%;
        overflow: hidden;
    }
    
    /* Fix modal overflow */
    .modal-dialog {
        margin-left: 10px;
        margin-right: 10px;
        max-width: calc(100% - 20px);
    }
    

    /* Fix iframe overflow */
    iframe {
        max-width: 100% !important;
    }
    
    /* Fix table overflow */
    table {
        max-width: 100%;
        overflow-x: auto;
        display: block;
    }
    
    /* Fix pre and code overflow */
    pre,
    code {
        max-width: 100%;
        overflow-x: auto;
        word-wrap: break-word;
    }
    
    /* Fix long text overflow */
    p, h1, h2, h3, h4, h5, h6, span, div {
        word-wrap: break-word;
        overflow-wrap: break-word;
    }
    
    /* Fix absolute positioned elements */
    [class*="position-absolute"],
    [class*="position-fixed"] {
        max-width: 100vw;
    }
    
    /* Category Cards Mobile */
    .category-card {
        margin-bottom: 1.5rem;
    }
    
    .category-card-image {
        height: 200px;
    }
    
    .category-card-body {
        padding: 1rem;
    }
    
    /* Feature Box Mobile */
    .feature-box {
        padding: 1.5rem 1rem;
        margin-bottom: 1.5rem;
    }
    
    .feature-icon {
        font-size: 2.5rem;
    }
    
    /* CTA Section Mobile */
    .cta-section {
        padding: 3rem 1rem;
        text-align: center;
    }
    
    .cta-section h2 {
        font-size: 1.75rem;
        margin-bottom: 1rem;
    }
    
    .cta-section p {
        font-size: 1rem;
        margin-bottom: 1.5rem;
    }
    
    /* SEO Locations Mobile */
    .seo-locations {
        padding: 15px 0;
        font-size: 12px;
        line-height: 1.3;
    }
    
    .seo-locations strong {
        font-size: 13px;
    }
    
    .seo-locations p {
        padding: 0 10px;
    }
}

/* Tablets (769px to 992px) */
@media (min-width: 769px) and (max-width: 992px) {
    .hero-banner h1 {
        font-size: 3rem;
    }
    
    .gallery-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .about-preview-content {
        gap: 2rem;
    }
    
 
    
    .product-body {
        padding: 1.25rem;
    }
    
    #galleryModal .modal-dialog {
        max-width: 90%;
    }
    
    .modal-navigation {
        flex-direction: row;
        justify-content: center;
    }
    
    .modal-navigation .btn {
        width: auto;
        min-width: 120px;
    }
    
    .btn-primary-custom,
    .btn-outline-custom {
        width: auto;
    }
    
    /* Logo Tablet */
    .navbar-brand img {
        height: 60px;
        /* max-width: 100%; */
        object-fit: contain;
    }
    
    .navbar {
        padding: 0.75rem 0;
    }
}

/* Large Tablets / Small Desktops (993px to 1200px) */
@media (min-width: 993px) and (max-width: 1200px) {
    .gallery-grid {
        grid-template-columns: repeat(3, 1fr);
    }
    
 
}

/* Extra Large Screens (1201px and above) */
@media (min-width: 1201px) {
    .container {
        max-width: 1200px;
    }
    
    .gallery-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Extra Small Devices (up to 576px) */
@media (max-width: 576px) {
    h1 {
        font-size: 2rem;
    }
    
    h2 {
        font-size: 1.75rem;
    }
    
    .hero-banner h1 {
        font-size: 2rem;
    }
    
    .page-banner h1 {
        font-size: 1.75rem;
    }
    
    .section {
        padding: 2rem 0;
        overflow: visible;
        width: 100%;
        max-width: 100%;
    }
    
 
    
    .product-body {
        padding: 0.75rem;
    }
    
    .product-name {
        font-size: 1rem;
    }
    
    .product-price {
        font-size: 1.1rem;
    }
    
    .book-now-btn {
        font-size: 0.85rem;
        padding: 0.4rem 0.8rem;
    }
    
    #galleryModal .modal-dialog {
        margin: 0.25rem;
        max-width: calc(100% - 0.5rem);
    }
    
    #galleryModal .modal-body img {
        max-height: 60vh;
    }
    
    .contact-form {
        padding: 1.5rem 1rem;
    }
    
    .contact-item {
        padding: 1rem 0.5rem;
    }
    
    .footer {
        padding: 1.5rem 0;
    }
    
    .footer p {
        font-size: 0.85rem;
    }
    
    .navbar {
        padding: 0.4rem 0;
    }
    
    .navbar.scrolled {
        padding: 0.3rem 0;
    }
    
    .navbar.scrolled .navbar-brand img {
        height: 45px;
    }
    
    .navbar-brand {
        font-size: 1.1rem;
        padding: 0.2rem 0;
    }
    
    .navbar-brand img {
        height: 50px;
        /* max-width: 100%; */
        object-fit: contain;
    }
    
    .map-container {
        padding-bottom: 100% !important;
        margin: 0;
        width: 100%;
    }
    
    .container {
        padding-left: 10px;
        padding-right: 10px;
    }
    
    .row {
        margin-left: -10px;
        margin-right: -10px;
    }
    
    .row > * {
        padding-left: 10px;
        padding-right: 10px;
    }
}

/* Print Styles */
@media print {
    .navbar,
    .footer,
    .btn,
    .cta-section {
        display: none;
    }
}

/* ============================================
   Floating Action Buttons - Responsive
   ============================================ */
@media (max-width: 768px) {
    .floating-buttons {
        bottom: 15px;
        right: 15px;
        gap: 12px;
    }
    
    .floating-btn {
        width: 55px;
        height: 55px;
    }
    
    .floating-btn i {
        font-size: 22px;
    }
    
    .floating-btn-label {
        font-size: 13px;
        padding: 6px 10px;
        right: 65px;
    }
}

@media (max-width: 576px) {
    .floating-buttons {
        bottom: 10px;
        right: 10px;
        gap: 10px;
    }
    
    .floating-btn {
        width: 50px;
        height: 50px;
        min-width: 50px;
        min-height: 50px;
    }
    
    .floating-btn i {
        font-size: 20px;
    }
    
    .floating-btn-label {
        display: none;
    }
    
    /* Ensure buttons don't overlap with footer on mobile */
    .floating-buttons {
        margin-bottom: 10px;
    }
    
    .share-menu {
        min-width: 160px;
        padding: 6px;
    }
    
    .share-option {
        padding: 10px 12px;
        font-size: 13px;
        gap: 10px;
    }
    
    .share-option i {
        font-size: 16px;
        width: 18px;
    }
}


