﻿/* ============================================
   THE VINTAGE GAZETTE - Responsive Styles
   ============================================ */

@media (max-width: 1024px) {
    :root { --gutter: 1rem; }
    
    .hero-section {
        padding-top: calc(20px + var(--spacing-md));
        padding-bottom: var(--spacing-xl);
    }
    
    .featured-section, .opinion-section {
        padding: var(--spacing-md) 0;
    }
    
    .newsletter-section { padding: var(--spacing-xl) 0; }
    
    .hero-split {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }
    
    .hero-main-card {
        min-height: 500px;
    }
    
    .hero-secondary-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-md);
    }
    
    /* Masonry - 3 columns */
    .news-masonry {
        column-count: 3;
        gap: var(--spacing-md);
    }
    
    .opinion-stack { 
        grid-template-columns: repeat(2, 1fr); 
        gap: var(--spacing-md);
    }
}

@media (max-width: 768px) {
    .main-navigation, .header-actions { display: none; }
    .mobile-menu-toggle { display: flex; }
    .logo-text { font-size: var(--text-xl); }
    
    .hero-section {
        padding-top: calc(10px + var(--spacing-sm));
        padding-bottom: var(--spacing-md);
    }
    
    .hero-split {
        gap: var(--spacing-md);
    }
    
    .hero-main-card {
        min-height: 400px;
    }
    
    .hero-main-card .hero-image-wrapper {
        height: 300px;
    }
    
    .hero-secondary-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-sm);
    }
    
    /* Masonry - 2 columns */
    .news-masonry {
        column-count: 2;
        gap: var(--spacing-sm);
    }
    
    .section-title { font-size: var(--text-2xl); margin-bottom: var(--spacing-sm); }
    .section-header { margin-bottom: var(--spacing-sm) !important; }
    
    .opinion-stack { 
        grid-template-columns: 1fr; 
        gap: var(--spacing-sm);
    }
    
    .opinion-card.featured { grid-column: span 1; }
    .opinion-title { font-size: var(--text-lg); }
    
    .newsletter-title { font-size: var(--text-3xl); margin-bottom: var(--spacing-sm); }
    .newsletter-subtitle { font-size: var(--text-base); margin-bottom: var(--spacing-md); }
    .newsletter-form .form-group { flex-direction: column; }
    .submit-btn { width: 100%; }
    
    .site-footer { padding: var(--spacing-xs) 0; }
    .footer-grid { grid-template-columns: 1fr; gap: var(--spacing-md); }
    .footer-bottom {
        flex-direction: column;
        gap: var(--spacing-sm);
        text-align: center;
    }
}

@media (max-width: 480px) {
    :root {
        --gutter: 0.5rem;
        --spacing-xs: 0.2rem;
        --spacing-sm: 0.4rem;
        --spacing-md: 0.6rem;
    }
    
    html, body { margin: 0; padding: 0; }
    body { overflow-x: hidden; }
    
    h1 { font-size: var(--text-4xl); }
    h2 { font-size: var(--text-3xl); }
    h3 { font-size: var(--text-2xl); }
    
    .header-container { padding: var(--spacing-sm) var(--gutter); }
    .site-header { top: 0; }
    .logo-tagline { display: none; }
    .logo-text { font-size: var(--text-xl); }
    .nav-menu { gap: var(--spacing-md); }
    .nav-menu a { font-size: 0.75rem; padding: var(--spacing-xs) 0; }
    .header-actions { gap: var(--spacing-xs); }
    
    .hero-section {
        padding-top: calc(10px + var(--spacing-xs));
        padding-bottom: var(--spacing-sm);
    }
    
    .hero-main-feature {
        min-height: 350px;
    }
    
    .hero-main-feature .hero-image-wrapper {
        height: 200px;
    }
    
    .hero-main-feature .hero-content {
        padding: var(--spacing-sm);
    }
    
    .hero-main-feature .hero-headline {
        font-size: var(--text-xl);
        margin-bottom: var(--spacing-sm);
    }
    
    .hero-main-feature .hero-excerpt {
        font-size: var(--text-sm);
        margin-bottom: var(--spacing-sm);
    }
    
    .hero-featured-list {
        max-height: 300px;
    }
    
    .hero-featured-item {
        padding: var(--spacing-xs);
    }
    
    .hero-featured-item .featured-img {
        width: 80px;
        height: 60px;
    }
    
    /* Masonry - 1 column */
    .news-masonry {
        column-count: 1;
        gap: var(--spacing-sm);
    }
    
    .news-card { margin-bottom: var(--spacing-sm); }
    .news-image-wrapper { aspect-ratio: 16/9; }
    .news-content { padding: var(--spacing-sm); }
    .news-title { font-size: var(--text-base); margin-bottom: var(--spacing-xs); }
    .news-category { margin-bottom: var(--spacing-xs); }
    .news-excerpt { display: none; }
    .news-meta { padding-top: var(--spacing-xs); }
    
    .opinion-section { padding: var(--spacing-lg) 0; }
    .opinion-columns { gap: var(--spacing-xs); grid-template-columns: 1fr; }
    .opinion-card { 
        padding: var(--spacing-sm); 
        min-height: auto;
    }
    .opinion-content {
        padding: var(--spacing-md);
    }
    .opinion-card-img {
        height: 160px;
    }
    .opinion-category { margin-bottom: var(--spacing-xs); }
    .opinion-title { font-size: var(--text-base); margin-bottom: var(--spacing-sm); }
    .opinion-excerpt { font-size: var(--text-sm); margin-bottom: var(--spacing-sm); }
    .section-title { font-size: var(--text-2xl); margin-bottom: var(--spacing-sm); }
    
    .newsletter-section { padding: var(--spacing-md) 0; }
    .newsletter-content { padding: 0 var(--spacing-xs); }
    .newsletter-title { font-size: var(--text-2xl); margin-bottom: var(--spacing-xs); }
    .newsletter-subtitle { font-size: var(--text-sm); margin-bottom: var(--spacing-sm); }
    .newsletter-form .form-group { gap: var(--spacing-xs); margin-bottom: var(--spacing-xs); }
    .email-input { padding: var(--spacing-sm); }
    .submit-btn { padding: var(--spacing-sm) var(--spacing-md); }
    .form-disclaimer { margin-top: var(--spacing-xs); }
    
    .site-footer { padding: var(--spacing-xs) 0; }
    .footer-grid { grid-template-columns: 1fr; gap: var(--spacing-md); margin-bottom: var(--spacing-xs); }
    .footer-logo { margin-bottom: var(--spacing-xs); }
    .footer-description { margin-bottom: var(--spacing-sm); }
    .social-links { justify-content: center; gap: var(--spacing-xs); }
    .social-links a { width: 32px; height: 32px; }
    .footer-links h4 { margin-bottom: var(--spacing-sm); }
    .footer-links ul { gap: var(--spacing-xs); }
    .footer-bottom { padding-top: var(--spacing-sm); flex-direction: column; gap: var(--spacing-xs); text-align: center; }
    
    .featured-section .section-header, .opinion-section .section-header {
        margin-bottom: var(--spacing-sm) !important;
    }
    
    h1, h2, h3 { margin-bottom: var(--spacing-sm) !important; }
    p { margin-bottom: 0; }
    
    body { margin: 0; padding: 0; }
    main, section { margin: 0; padding-top: var(--spacing-xs); padding-bottom: var(--spacing-xs); }
}

@media (min-width: 1440px) {
    :root { --container-max: 1600px; }
    .hero-grid { gap: var(--spacing-3xl); }
    .news-grid { gap: var(--spacing-2xl); }
    .opinion-grid { gap: var(--spacing-2xl); }
}

@media print {
    .site-header, .mobile-nav-overlay, .newsletter-section, .site-footer { display: none; }
    body { background-color: white; color: black; }
    .hero-section, .featured-section, .opinion-section { padding: 0; }
    a[href]::after { content: " (" attr(href) ")"; }
}
