/**
 * Responsive Styles for domain.com
 * Financial Audit Services Website
 */

/* Base Mobile First Approach */

/* Small devices (landscape phones, 576px and up) */
@media (min-width: 576px) {
    :root {
        --container-padding: 2rem;
    }
}

/* Medium devices (tablets, 768px and up) */
@media (min-width: 768px) {
    :root {
        --font-xxl: 4rem;
        --font-xl: 3rem;
        --font-lg: 2.25rem;
        --font-md: 1.75rem;
    }
    
    .statistics-grid {
        grid-template-columns: repeat(3, 1fr);
    }
    
    .testimonial-card {
        padding: var(--space-lg);
    }
}

/* Large devices (desktops, 992px and up) */
@media (min-width: 992px) {
    .about-content {
        flex-direction: row;
    }
    
    .services-grid,
    .audit-types-grid,
    .testimonials-grid {
        grid-template-columns: repeat(3, 1fr);
    }
    
    .articles-grid {
        grid-template-columns: repeat(3, 1fr);
    }
    
    .footer-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Extra large devices (large desktops, 1200px and up) */
@media (min-width: 1200px) {
    :root {
        --container-padding: 2rem;
    }
    
    .container {
        max-width: var(--container-max-width);
    }
}

/* Mobile & Tablet Styles (from largest to smallest for better CSS specificity) */

/* Medium devices and below (tablets and down) */
@media (max-width: 991px) {
    .about-content {
        flex-direction: column;
        gap: var(--space-md);
    }
    
    .about-image {
        order: -1;
    }
    
    .form-container {
        flex-direction: column;
    }
    
    .form-map {
        height: 300px;
        border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    }
    
    .form-content {
        padding: var(--space-md);
    }
    
    .footer-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-lg) var(--space-md);
    }
}

/* Small devices (landscape phones and down) */
@media (max-width: 767px) {
    :root {
        --font-xxl: 3rem;
        --font-xl: 2.5rem;
        --font-lg: 1.75rem;
        --font-md: 1.25rem;
    }
    
    .section {
        padding: var(--space-lg) 0;
    }
    
    .section-title {
        margin-bottom: var(--space-md);
    }
    
    .services-grid,
    .audit-types-grid,
    .testimonials-grid,
    .articles-grid {
        grid-template-columns: 1fr;
        gap: var(--space-sm);
    }
    
    .statistics-grid {
        grid-template-columns: 1fr;
        gap: var(--space-md);
    }
    
    .statistic-item {
        padding: var(--space-sm);
    }
    
    .cookie-content {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .cookie-content p {
        margin-bottom: var(--space-xs);
    }
}

/* Extra small devices (portrait phones and down) */
@media (max-width: 575px) {
    :root {
        --font-xxl: 2.5rem;
        --font-xl: 2rem;
        --font-lg: 1.5rem;
        --font-md: 1.2rem;
        --space-lg: 2rem;
        --space-xl: 3rem;
        --space-xxl: 4rem;
        --container-padding: 1rem;
    }
    
    .hero {
        padding: var(--space-xl) 0;
    }
    
    .hero p {
        font-size: var(--font-sm);
    }
    
    .policy-container {
        padding: var(--space-md);
    }
}

/* Mobile Menu Specific Styles */
@media (max-width: 991px) {
    .mobile-toggle {
        display: flex;
        z-index: 1100;
    }
    
    .main-nav {
        position: fixed;
        top: 0;
        right: -100%;
        width: 80%;
        height: 100vh;
        background-color: white;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        z-index: 1000;
        transition: right 0.3s ease;
        box-shadow: var(--shadow-lg);
    }
    
    body.menu-open {
        overflow: hidden;
    }
    
    .mobile-nav-open {
        right: 0;
    }
    
    .nav-list {
        flex-direction: column;
        align-items: center;
        width: 100%;
    }
    
    .nav-item {
        margin: var(--space-xs) 0;
        width: 100%;
        text-align: center;
    }
    
    .nav-item a {
        display: block;
        padding: var(--space-xs);
        font-size: var(--font-md);
    }
    
    .nav-cta {
        display: inline-block;
        margin-top: var(--space-xs);
    }
    
    .mobile-toggle.close .bar1 {
        transform: rotate(-45deg) translate(-5px, 6px);
    }
    
    .mobile-toggle.close .bar2 {
        opacity: 0;
    }
    
    .mobile-toggle.close .bar3 {
        transform: rotate(45deg) translate(-5px, -6px);
    }
}
