/* ==========================================
   Responsive Styles
   ========================================== */

/* 
  Breakpoints:
  - Small (sm): Up to 576px (Mobile phones)
  - Medium (md): 577px to 768px (Large phones, small tablets)
  - Large (lg): 769px to 992px (Tablets, small laptops)
  - Extra Large (xl): 993px to 1200px (Laptops, desktops)
  - Extra Extra Large (xxl): Above 1200px (Large desktops)
*/

/* Default styles are for mobile devices (up to 576px) */

/* Medium Devices (577px to 768px) */
@media (max-width: 768px) {
    /* Typography */
    h1 {
        font-size: 2.25rem;
    }
    
    h2 {
        font-size: 1.875rem;
    }
    
    h3 {
        font-size: 1.5rem;
    }
    
    /* Header & Navigation */
    .main-header .container {
        flex-wrap: wrap;
    }
    
    .mobile-menu-toggle {
        display: block;
        order: 2;
    }
    
    .main-nav {
        flex-basis: 100%;
        order: 3;
    }
    
    .nav-links {
        flex-direction: column;
        align-items: flex-start;
        max-height: 0;
        overflow: hidden;
        opacity: 0;
        transition: max-height var(--transition-medium), opacity var(--transition-medium);
    }
    
    .nav-links.active {
        max-height: 500px;
        opacity: 1;
    }
    
    .nav-links li {
        margin: 0;
        width: 100%;
        border-top: 1px solid rgba(0, 0, 0, 0.05);
    }
    
    .nav-links a {
        display: block;
        padding: var(--spacing-md) 0;
    }
    
    /* Hero Banner */
    .hero-banner {
        padding: var(--spacing-xl) 0;
    }
    
    .hero-content h1 {
        font-size: 2.25rem;
    }
    
    .hero-content p {
        font-size: 1.125rem;
    }
    
    .hero-buttons {
        flex-direction: column;
        gap: var(--spacing-sm);
    }
    
    .hero-buttons a {
        width: 100%;
        text-align: center;
    }
    
    /* Services Overview */
    .services-grid {
        grid-template-columns: 1fr;
    }
    
    /* About Section */
    .about-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }
    
    .about-image {
        order: -1;
    }
    
    .about-stats {
        justify-content: space-around;
    }
    
    /* Destinations */
    .destinations-grid {
        grid-template-columns: 1fr;
    }
    
    /* Newsletter */
    .form-group {
        flex-direction: column;
    }
    
    .form-group input[type="email"] {
        border-radius: var(--border-radius-md);
        margin-bottom: var(--spacing-sm);
    }
    
    .form-group .btn-primary {
        border-radius: var(--border-radius-md);
        width: 100%;
    }
    
    /* Footer */
    .footer-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }
    
    .footer-bottom {
        flex-direction: column;
        gap: var(--spacing-md);
        text-align: center;
    }
    
    .legal-links {
        justify-content: center;
    }
    
    /* Blog Preview */
    .blog-preview-grid {
        grid-template-columns: 1fr;
    }
    
    /* Blog Content */
    .blog-post {
        grid-template-columns: 1fr;
    }
    
    .blog-image {
        height: 200px;
    }
    
    .article-content .container {
        grid-template-columns: 1fr;
    }
    
    .article-sidebar {
        position: static;
        margin-top: var(--spacing-xl);
    }
    
    .articles-grid {
        grid-template-columns: 1fr;
    }
    
    /* Contact Page */
    .contact-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-xl);
    }
    
    .form-grid {
        grid-template-columns: 1fr;
    }
    
    /* Services Page */
    .service-grid,
    .service-grid.reverse {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
        direction: ltr;
    }
    
    .service-image {
        margin-top: var(--spacing-lg);
    }
    
    .packages-grid {
        grid-template-columns: 1fr;
    }
    
    .package-card.featured {
        transform: none;
        border: 2px solid var(--primary-color);
    }
    
    /* About Page */
    .story-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }
    
    .story-image {
        margin-bottom: var(--spacing-lg);
    }
    
    .mission-content {
        grid-template-columns: 1fr;
    }
    
    .team-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-xl);
    }
    
    .achievements-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }
    
    /* Cookie Banner */
    .cookie-buttons {
        flex-direction: column;
    }
    
    .cookie-buttons button {
        width: 100%;
    }
}

/* Large Devices (769px to 992px) */
@media (min-width: 769px) and (max-width: 992px) {
    /* Services Grid */
    .services-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    /* Blog Preview */
    .blog-preview-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    /* Footer */
    .footer-grid {
        grid-template-columns: 1fr 1fr;
        gap: var(--spacing-xl) var(--spacing-lg);
    }
    
    /* Article Content */
    .article-content .container {
        gap: var(--spacing-lg);
    }
    
    /* Team Grid */
    .team-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-xl);
    }
    
    /* Achievements Grid */
    .achievements-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    /* Packages Grid */
    .packages-grid {
        grid-template-columns: 1fr;
    }
    
    .package-card.featured {
        grid-row: 1;
        transform: none;
    }
    
    /* Articles Grid */
    .articles-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Extra Large Devices (993px to 1200px) */
@media (min-width: 993px) and (max-width: 1200px) {
    /* Minor adjustments for this range */
    .container {
        padding: 0 var(--spacing-lg);
    }
    
    /* Services Grid */
    .services-grid {
        gap: var(--spacing-md);
    }
    
    /* Blog Preview Grid */
    .blog-preview-grid {
        gap: var(--spacing-md);
    }
    
    /* Footer Grid */
    .footer-grid {
        gap: var(--spacing-lg);
    }
}

/* Extra Extra Large Devices (above 1200px) */
@media (min-width: 1201px) {
    /* Any specific adjustments for large screens */
    .container {
        padding: 0 var(--spacing-xl);
    }
}

/* Special breakpoint for tablets in portrait */
@media (min-width: 768px) and (max-width: 992px) and (orientation: portrait) {
    /* Adjustments specific to tablets in portrait orientation */
    .hero-content {
        max-width: 80%;
    }
    
    .service-grid,
    .service-grid.reverse {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
        direction: ltr;
    }
    
    .service-image {
        margin-top: var(--spacing-lg);
    }
}

/* Print styles */
@media print {
    .main-header,
    .main-footer,
    .newsletter-section,
    .cookie-banner,
    .more-articles,
    .article-engagement,
    .cta-section {
        display: none;
    }
    
    body {
        font-size: 12pt;
        line-height: 1.5;
        color: #000;
        background: #fff;
    }
    
    a {
        color: #000;
        text-decoration: underline;
    }
    
    .container {
        width: 100%;
        max-width: 100%;
        padding: 0;
        margin: 0;
    }
    
    .article-content .container {
        display: block;
    }
    
    .article-sidebar {
        display: none;
    }
    
    h1, h2, h3, h4, h5, h6 {
        page-break-after: avoid;
        page-break-inside: avoid;
    }
    
    img, svg {
        max-width: 500px !important;
        page-break-inside: avoid;
    }
    
    p, blockquote, ul, ol, dl, table {
        page-break-inside: avoid;
    }
    
    p, h2, h3 {
        orphans: 3;
        widows: 3;
    }
}
