/* Responsive CSS for public website */

/* Mobile First Approach */
@media (max-width: 480px) {
    /* Ultra small mobile devices */
    .container {
        padding: 0.5rem;
    }
    
    .text-xs {
        font-size: 0.75rem;
    }
    
    .text-sm {
        font-size: 0.875rem;
    }
    
    .p-2 {
        padding: 0.5rem;
    }
    
    .p-4 {
        padding: 0.75rem;
    }
    
    .gap-2 {
        gap: 0.5rem;
    }
    
    .gap-4 {
        gap: 0.75rem;
    }
}

@media (min-width: 481px) and (max-width: 640px) {
    /* Small mobile devices */
    .container {
        padding: 0.75rem;
    }
    
    .text-sm {
        font-size: 0.875rem;
    }
    
    .text-base {
        font-size: 1rem;
    }
}

@media (min-width: 641px) and (max-width: 768px) {
    /* Medium mobile devices */
    .container {
        padding: 1rem;
    }
}

@media (min-width: 769px) and (max-width: 1024px) {
    /* Tablet devices */
    .container {
        padding: 1.5rem;
    }
    
    .grid-cols-2 {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .grid-cols-3 {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 1025px) {
    /* Desktop devices */
    .container {
        padding: 2rem;
        max-width: 1200px;
        margin: 0 auto;
    }
    
    .grid-cols-4 {
        grid-template-columns: repeat(4, 1fr);
    }
    
    .grid-cols-5 {
        grid-template-columns: repeat(5, 1fr);
    }
}

/* Responsive typography */
@media (max-width: 640px) {
    h1 {
        font-size: 1.5rem;
        line-height: 1.2;
    }
    
    h2 {
        font-size: 1.25rem;
        line-height: 1.3;
    }
    
    h3 {
        font-size: 1.125rem;
        line-height: 1.4;
    }
}

@media (min-width: 641px) {
    h1 {
        font-size: 2rem;
        line-height: 1.1;
    }
    
    h2 {
        font-size: 1.5rem;
        line-height: 1.2;
    }
    
    h3 {
        font-size: 1.25rem;
        line-height: 1.3;
    }
}

/* Responsive spacing */
@media (max-width: 640px) {
    .section-padding {
        padding: 1rem 0;
    }
    
    .card-padding {
        padding: 0.75rem;
    }
}

@media (min-width: 641px) {
    .section-padding {
        padding: 2rem 0;
    }
    
    .card-padding {
        padding: 1.5rem;
    }
}

/* Responsive grid */
.responsive-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr;
}

@media (min-width: 640px) {
    .responsive-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .responsive-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Responsive images */
.responsive-img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

@media (max-width: 640px) {
    .responsive-img {
        height: 200px;
    }
}

@media (min-width: 641px) {
    .responsive-img {
        height: 300px;
    }
}

/* Responsive navigation */
@media (max-width: 768px) {
    .nav-mobile {
        display: block;
    }
    
    .nav-desktop {
        display: none;
    }
}

@media (min-width: 769px) {
    .nav-mobile {
        display: none;
    }
    
    .nav-desktop {
        display: block;
    }
}

/* Responsive forms */
@media (max-width: 640px) {
    .form-mobile {
        display: block;
    }
    
    .form-desktop {
        display: none;
    }
    
    .form-grid {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 641px) {
    .form-mobile {
        display: none;
    }
    
    .form-desktop {
        display: block;
    }
    
    .form-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Print styles */
@media print {
    .no-print {
        display: none !important;
    }
    
    .print-only {
        display: block !important;
    }
    
    body {
        font-size: 12pt;
        line-height: 1.4;
    }
    
    h1, h2, h3 {
        page-break-after: avoid;
    }
}
