/**
 * Responsive Design
 * 
 * @package DataGeeksTheme2
 * @version 2.0
 */

/* Large screens */
@media (max-width: 1200px) {
    .content-area {
        grid-template-columns: 6% 84% 10%; /* Further reduced sidebar-left (6%), increased content-area (84%), sidebar-right (10%) */
        gap: var(--spacing-sm);
        margin-top: var(--spacing-xs);
    }
    
    .doc-sidebar,
    .sidebar-right {
        padding: var(--spacing-xs);
        min-height: 250px;
    }
    
    .main-content {
        padding: var(--spacing-sm);
        min-height: 350px;
    }
    
    .site-logo a {
        font-size: var(--font-size-lg);
    }
    
    .site-logo img {
        max-height: 45px;
    }
    
}

/* Medium screens */
@media (max-width: 1024px) {
    .content-area {
        grid-template-columns: 180px 1fr;
        gap: var(--spacing-sm);
        margin-top: var(--spacing-xs);
    }
    
    .sidebar-right {
        display: none;
    }
    
    .doc-sidebar {
        padding: var(--spacing-xs);
        min-height: 250px;
    }
    
    .main-content {
        padding: var(--spacing-sm);
        min-height: 350px;
    }
}

/* Small screens */
@media (max-width: 768px) {
    /* Prevent horizontal overflow on all elements */
    * {
        box-sizing: border-box;
    }
    
    body {
        overflow-x: hidden;
    }
    
    /* Mobile menu overlay backdrop */
    body.menu-open::before {
        content: '';
        position: fixed;
        top: 120px; /* Start below header on mobile */
        left: 0;
        right: 0;
        bottom: 0;
        background: rgba(0, 0, 0, 0.5);
        z-index: 9998 !important; /* Below mobile overlay but above navigation */
        opacity: 1;
        transition: opacity 0.3s ease;
    }
    .header-container {
        flex-direction: row;
        flex-wrap: wrap;
        gap: var(--spacing-sm);
        align-items: center;
    }
    
    .site-logo {
        order: 1;
        flex: 0 0 auto;
    }
    
    .header-search {
        order: 2;
        flex: 0 0 auto; /* Don't take up flex space on mobile */
        width: 0; /* Make container have no width visually */
        margin: 0;
        overflow: visible; /* Allow overlay to be positioned properly */
        /* Keep container in DOM for search overlay to work, but visually hidden */
    }
    
    /* Hide desktop search form visually */
    .header-search .desktop-search {
        display: none !important;
    }
    
    /* Keep search overlay accessible but hidden by default */
    .header-search .search-overlay {
        position: fixed;
        display: none;
    }
    
    .header-search .search-overlay.active {
        display: flex;
    }
    
    .header-actions {
        order: 3;
        flex: 0 0 auto;
    }
    
    .site-navigation {
        order: 4;
        width: 100%;
        margin-top: var(--spacing-sm);
    }
    
    .nav-container {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        padding: var(--spacing-xs) var(--spacing-sm);
        padding-left: 5rem !important; /* Space for fixed hamburger menu */
        min-height: 44px; /* Increased height on mobile for better touch targets */
        overflow: visible !important;
    }
    
    .mobile-menu-toggle {
        display: flex !important;
        order: -999 !important;
        flex: 0 0 auto !important;
        align-items: center !important;
        justify-content: center !important;
        position: fixed !important; /* Changed to fixed position */
        left: 1rem !important;
        right: auto !important;
        top: calc(120px + 18px) !important; /* Fixed position below header */
        transform: none !important;
        z-index: 10000 !important; /* Higher z-index */
        width: 36px !important;
        height: 36px !important;
        min-width: 36px !important;
        min-height: 36px !important;
        overflow: visible !important;
        margin-right: 0 !important; /* Remove right margin */
        padding-right: 0.75rem !important; /* Add right padding on mobile */
        background-color: rgba(44, 62, 80, 0.95) !important;
        border-radius: 4px !important;
        box-shadow: 0 2px 8px !important;
    }
    
    .nav-menu {
        display: flex !important; /* Show categories horizontally on mobile */
        flex-direction: row !important;
        position: relative !important;
        background-color: transparent !important;
        border: none !important;
        border-top: none !important;
        box-shadow: none !important;
        padding: 0 !important;
        padding-left: 6rem !important; /* Increased space for left-positioned hamburger menu */
        margin-left: 1rem !important; /* Increased margin for better spacing */
        z-index: auto !important;
        justify-content: flex-start !important;
        overflow-x: auto !important;
        padding-right: 1rem !important; /* Space from edge */
        -webkit-overflow-scrolling: touch !important;
    }

    .nav-menu li {
        flex-shrink: 0 !important;
        width: auto !important;
    }
    
    .nav-menu.active {
        display: flex;
    }
    
    .nav-menu li {
        width: 100%;
    }
    
    .nav-menu a {
        padding: var(--spacing-sm) var(--spacing-md) !important;
        border-radius: var(--border-radius) !important;
        text-align: left !important;
        margin: 0 var(--spacing-xs) !important;
        white-space: nowrap !important;
        display: block !important;
    }
    
    /* Left-align navigation - SAME for both states */
    .nav-container.has-hamburger .nav-menu,
    .nav-container.no-hamburger .nav-menu {
        margin: 0 !important;
        padding: 0 !important;
        justify-content: flex-start !important; /* Always left-aligned */
    }
    
    /* Hide desktop search completely on mobile */
    .desktop-search {
        display: none !important;
    }
    
    .mobile-search-icon {
        display: flex;
        width: 2rem;
        height: 2rem;
        font-size: var(--font-size-xs);
    }
    
    .search-overlay-content {
        width: 95%;
        padding: var(--spacing-md);
    }
    
    
    .content-area {
        grid-template-columns: 1fr;
        gap: var(--spacing-sm);
        margin-top: var(--spacing-xs);
        width: 100% !important; /* Full width container on mobile */
        max-width: 100% !important; /* Remove any max-width constraints */
        padding: 0 var(--spacing-sm) !important; /* Add horizontal padding to prevent content overflow */
        box-sizing: border-box; /* Include padding in width calculation */
    }
    
    .doc-sidebar {
        position: static;
        order: 2;
        padding: var(--spacing-xs);
        min-height: auto;
        margin-top: var(--spacing-sm);
    }
    
    .main-content {
        order: 1;
        padding: var(--spacing-sm);
        min-height: auto;
        width: 100% !important; /* Full width on mobile */
        max-width: 100% !important; /* Remove any max-width constraints */
        margin: 0 !important; /* Remove any margins */
        box-sizing: border-box; /* Include padding in width calculation */
        overflow-x: hidden; /* Prevent horizontal overflow */
        word-wrap: break-word; /* Allow long words to break */
        overflow-wrap: break-word; /* Modern word wrapping */
        hyphens: auto; /* Enable automatic hyphenation */
    }
    
    /* Ensure all text content wraps properly with responsive font sizes */
    .main-content p,
    .main-content li,
    .main-content div,
    .main-content span,
    .main-content a {
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        font-size: 1rem !important; /* Standard readable size for mobile */
        line-height: 1.6 !important; /* Comfortable line spacing */
    }
    
    /* Responsive heading sizes for mobile */
    .main-content h1 {
        font-size: 1.75rem !important; /* 28px */
        line-height: 1.3 !important;
        margin-bottom: 1rem !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .main-content h2 {
        font-size: 1.5rem !important; /* 24px */
        line-height: 1.3 !important;
        margin-bottom: 0.875rem !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .main-content h3 {
        font-size: 1.25rem !important; /* 20px */
        line-height: 1.4 !important;
        margin-bottom: 0.75rem !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .main-content h4 {
        font-size: 1.125rem !important; /* 18px */
        line-height: 1.4 !important;
        margin-bottom: 0.625rem !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .main-content h5 {
        font-size: 1rem !important; /* 16px */
        line-height: 1.5 !important;
        margin-bottom: 0.5rem !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .main-content h6 {
        font-size: 0.875rem !important; /* 14px */
        line-height: 1.5 !important;
        margin-bottom: 0.5rem !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    
    /* Specific handling for lists */
    .main-content ul,
    .main-content ol {
        padding-left: var(--spacing-md) !important;
        margin-left: 0 !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
    }
    
    .main-content li {
        margin-bottom: var(--spacing-xs) !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
    }
    
    /* Make tables, images, and other elements horizontally scrollable */
    .main-content table,
    .main-content .wp-block-table,
    .main-content img,
    .main-content figure,
    .main-content pre,
    .main-content code,
    .main-content .code-block,
    .main-content .highlight,
    .main-content .syntax-highlight,
    .main-content .gallery,
    .main-content .wp-block-gallery,
    .main-content .video-container,
    .main-content iframe,
    .main-content .embed-container {
        max-width: 100% !important;
        overflow-x: auto !important;
        display: block !important;
        white-space: nowrap;
    }
    
    /* Specific table styling for horizontal scroll */
    .main-content table {
        width: max-content !important;
        min-width: 100% !important;
        border-collapse: collapse;
    }
    
    /* Image responsiveness with horizontal scroll if needed */
    .main-content img {
        max-width: 100% !important;
        height: auto !important;
        display: block;
    }
    
    /* Code blocks horizontal scroll */
    .main-content pre,
    .main-content code {
        overflow-x: auto !important;
        white-space: pre !important;
        word-wrap: normal !important;
    }
    
    .pagination {
        flex-direction: column;
        gap: var(--spacing-md);
    }
    
    .pagination .nav-previous,
    .pagination .nav-next {
        max-width: 100%;
        text-align: center;
    }
}

/* Extra small screens */
@media (max-width: 480px) {
    .container {
        padding: 0 var(--spacing-sm);
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box;
        overflow-x: hidden;
    }
    
    .site-main {
        padding: 0 0 var(--spacing-lg) 0;
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box;
        overflow-x: hidden;
    }
    
    .main-content {
        padding: var(--spacing-sm);
        min-height: auto;
        width: 100% !important; /* Full width on extra small screens */
        max-width: 100% !important; /* Remove any max-width constraints */
        margin: 0 !important; /* Remove any margins */
        box-sizing: border-box; /* Include padding in width calculation */
        overflow-x: hidden; /* Prevent horizontal overflow */
        word-wrap: break-word; /* Allow long words to break */
        overflow-wrap: break-word; /* Modern word wrapping */
        hyphens: auto; /* Enable automatic hyphenation */
    }
    
    /* Ensure all text content wraps properly on extra small screens with responsive font sizes */
    .main-content p,
    .main-content li,
    .main-content div,
    .main-content span,
    .main-content a {
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        font-size: 0.9rem !important; /* Better readable size for very small screens */
        line-height: 1.6 !important; /* Comfortable line spacing */
    }
    
    /* Responsive heading sizes for extra small screens */
    .main-content h1 {
        font-size: 1.5rem !important; /* 24px */
        line-height: 1.3 !important;
        margin-bottom: 0.875rem !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .main-content h2 {
        font-size: 1.375rem !important; /* 22px */
        line-height: 1.3 !important;
        margin-bottom: 0.75rem !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .main-content h3 {
        font-size: 1.125rem !important; /* 18px */
        line-height: 1.4 !important;
        margin-bottom: 0.625rem !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .main-content h4 {
        font-size: 1rem !important; /* 16px */
        line-height: 1.4 !important;
        margin-bottom: 0.5rem !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .main-content h5 {
        font-size: 0.9rem !important; /* 14.4px */
        line-height: 1.5 !important;
        margin-bottom: 0.5rem !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .main-content h6 {
        font-size: 0.8rem !important; /* 12.8px */
        line-height: 1.5 !important;
        margin-bottom: 0.5rem !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    
    /* Specific handling for lists on extra small screens */
    .main-content ul,
    .main-content ol {
        padding-left: var(--spacing-sm) !important;
        margin-left: 0 !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
    }
    
    .main-content li {
        margin-bottom: var(--spacing-xs) !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
    }
    
    /* Make tables, images, and other elements horizontally scrollable on extra small screens */
    .main-content table,
    .main-content .wp-block-table,
    .main-content img,
    .main-content figure,
    .main-content pre,
    .main-content code,
    .main-content .code-block,
    .main-content .highlight,
    .main-content .syntax-highlight,
    .main-content .gallery,
    .main-content .wp-block-gallery,
    .main-content .video-container,
    .main-content iframe,
    .main-content .embed-container {
        max-width: 100% !important;
        overflow-x: auto !important;
        display: block !important;
        white-space: nowrap;
    }
    
    /* Specific table styling for horizontal scroll */
    .main-content table {
        width: max-content !important;
        min-width: 100% !important;
        border-collapse: collapse;
    }
    
    /* Image responsiveness with horizontal scroll if needed */
    .main-content img {
        max-width: 100% !important;
        height: auto !important;
        display: block;
    }
    
    /* Code blocks horizontal scroll */
    .main-content pre,
    .main-content code {
        overflow-x: auto !important;
        white-space: pre !important;
        word-wrap: normal !important;
    }
    
    .doc-sidebar {
        padding: var(--spacing-xs);
        min-height: auto;
    }
    
    .post-title {
        font-size: var(--font-size-xl);
    }
    
    .footer-container {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }
    
    .mobile-search-icon {
        width: 1.75rem;
        height: 1.75rem;
        font-size: var(--font-size-xs);
    }
    
    .search-overlay-content {
        width: 98%;
        padding: var(--spacing-sm);
    }
    
    .search-overlay .search-input {
        font-size: var(--font-size-base);
        padding: var(--spacing-sm) var(--spacing-md);
        padding-right: 3.5rem;
    }
    
}

/* Very small screens */
@media (max-width: 360px) {
    .site-logo a {
        font-size: var(--font-size-xs);
        gap: var(--spacing-xs);
    }
    
    .site-logo img {
        max-height: 25px;
    }
    
    .mobile-search-icon {
        width: 1.5rem;
        height: 1.5rem;
        font-size: var(--font-size-xs);
    }
    
}
