@media (max-width: 1024px) {
    .dashboard-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .main-card {
        grid-column: span 2;
        grid-row: span 1;
        flex-direction: row;
        align-items: center;
        padding: var(--spacing-md) var(--spacing-lg);
    }
    
    .card-body {
        flex-direction: row;
        gap: var(--spacing-lg);
    }
    
    .highlights-grid {
        grid-column: span 2;
        grid-template-columns: repeat(2, 1fr);
    }
    
    .forecast-section, .daily-section, .charts-section {
        grid-column: span 2;
    }
}

@media (max-width: 768px) {
    .app-container {
        flex-direction: column;
    }
    
    .sidebar {
        width: 100%;
        height: auto;
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        padding: var(--spacing-sm) var(--spacing-md);
        border-right: none;
        border-bottom: 1px solid var(--glass-border);
    }
    
    .logo {
        margin-bottom: 0;
        font-size: 1rem;
    }
    
    .nav-items {
        flex-direction: row;
        gap: var(--spacing-xs);
    }

    .nav-btn span.text {
        display: none;
    }
    
    .nav-btn {
        padding: var(--spacing-sm);
        justify-content: center;
    }
    
    .main-content {
        padding: var(--spacing-md);
    }
    
    .main-card {
        flex-direction: column;
        text-align: center;
        padding: var(--spacing-lg);
    }
    
    .card-body {
        flex-direction: column;
        gap: var(--spacing-md);
    }

    .weather-icon-lg {
        margin: var(--spacing-sm) 0;
    }
    
    .highlights-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .top-bar {
        flex-direction: column;
        align-items: stretch;
        gap: var(--spacing-md);
    }
    
    .search-container {
        max-width: 100%;
    }
    
    .user-actions {
        justify-content: flex-end;
    }
    
    .hourly-item {
        min-width: 70px;
        padding: var(--spacing-sm);
    }
    
    .temp-container h1 {
        font-size: 3rem;
    }
}
