/* Responsive Design - Global Rules */

/* Base Responsive Utilities */
.container {
    width: 100%;
    max-width: var(--container-max-width);
    margin: 0 auto;
    padding: 0 20px;
}

/* Large Desktop */
@media (min-width: 1400px) {
    .container {
        max-width: 1320px;
    }
    
    .section-title {
        font-size: 42px;
    }
    
    .hero-title {
        font-size: 56px;
    }
}

/* Desktop */
@media (min-width: 992px) and (max-width: 1399px) {
    .container {
        max-width: 960px;
    }
    
    .services-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .testimonials-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Tablet */
@media (min-width: 768px) and (max-width: 991px) {
    .container {
        max-width: 720px;
        padding: 0 16px;
    }
    
    /* Reduce section padding */
    section {
        padding: 60px 0;
    }
    
    /* Adjust typography */
    .section-title {
        font-size: 32px;
        margin-bottom: 40px;
    }
    
    .hero-title {
        font-size: 40px;
    }
    
    .hero-subtitle {
        font-size: 18px;
    }
    
    /* Grid adjustments */
    .services-grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }
    
    .packages-table {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }
    
    .testimonials-grid {
        grid-template-columns: 1fr;
    }
    
    .faq-grid {
        grid-template-columns: 1fr;
    }
    
    .guarantee-grid {
        grid-template-columns: 1fr;
    }
}

/* Mobile Landscape */
@media (min-width: 576px) and (max-width: 767px) {
    .container {
        max-width: 540px;
        padding: 0 16px;
    }
    
    /* Further reduce section padding */
    section {
        padding: 50px 0;
    }
    
    /* Typography adjustments */
    .section-title {
        font-size: 28px;
        margin-bottom: 32px;
    }
    
    .hero-title {
        font-size: 32px;
    }
    
    .hero-subtitle {
        font-size: 16px;
        margin-bottom: 32px;
    }
    
    /* All grids single column on mobile */
    .services-grid,
    .packages-table,
    .testimonials-grid,
    .faq-grid,
    .guarantee-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    
    /* Adjust card padding */
    .service-item,
    .package-card,
    .testimonial-card,
    .faq-item,
    .guarantee-item {
        padding: 20px;
    }
    
    /* Button adjustments */
    .cta-button {
        padding: 14px 28px;
        font-size: 16px;
    }
}

/* Mobile Portrait */
@media (max-width: 575px) {
    .container {
        padding: 0 12px;
    }
    
    /* Minimal section padding */
    section {
        padding: 40px 0;
    }
    
    /* Compact typography */
    .section-title {
        font-size: 24px;
        margin-bottom: 24px;
    }
    
    .hero-title {
        font-size: 26px;
        line-height: 1.3;
    }
    
    .hero-subtitle {
        font-size: 15px;
        margin-bottom: 24px;
    }
    
    /* Minimal spacing */
    .services-grid,
    .packages-table,
    .testimonials-grid,
    .faq-grid,
    .guarantee-grid {
        gap: 16px;
        margin-top: 32px;
    }
    
    /* Compact cards */
    .service-item,
    .package-card,
    .testimonial-card,
    .faq-item,
    .guarantee-item {
        padding: 16px;
    }
    
    /* Small buttons */
    .cta-button {
        padding: 12px 24px;
        font-size: 14px;
    }
    
    .package-btn {
        padding: 10px 20px;
        font-size: 13px;
    }
    
    /* Compact story content */
    .story-content {
        font-size: 14px;
    }
    
    .key-formula {
        font-size: 15px;
        padding: 16px;
    }
    
    /* Adjust icons */
    .service-icon,
    .guarantee-icon {
        font-size: 32px;
        height: 48px;
    }
    
    /* Compact testimonials */
    .before, .after {
        font-size: 11px;
        padding: 4px 8px;
    }
    
    blockquote {
        font-size: 13px;
        padding-left: 16px;
    }
    
    blockquote::before {
        font-size: 28px;
    }
}

/* Extra Small Mobile */
@media (max-width: 375px) {
    .container {
        padding: 0 8px;
    }
    
    .section-title {
        font-size: 20px;
    }
    
    .hero-title {
        font-size: 22px;
    }
    
    .hero-subtitle {
        font-size: 14px;
    }
    
    .service-item,
    .package-card,
    .testimonial-card,
    .faq-item,
    .guarantee-item {
        padding: 12px;
    }
    
    .cta-button {
        padding: 10px 20px;
        font-size: 13px;
    }
}

/* Touch Device Optimizations */
@media (hover: none) and (pointer: coarse) {
    .service-item:hover,
    .package-card:hover,
    .testimonial-card:hover,
    .faq-item:hover,
    .guarantee-item:hover {
        transform: none;
    }
    
    .cta-button:hover,
    .package-btn:hover {
        transform: none;
        animation: none;
    }
    
    /* Increase touch targets */
    .cta-button,
    .package-btn {
        min-height: 44px;
        min-width: 44px;
    }
}

/* High DPI Display Optimizations */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    .service-icon,
    .guarantee-icon {
        image-rendering: -webkit-optimize-contrast;
        image-rendering: crisp-edges;
    }
}

/* Landscape Orientation */
@media (orientation: landscape) and (max-height: 600px) {
    .hero-section {
        min-height: 70vh;
    }
    
    section {
        padding: 30px 0;
    }
} 