/* Tablet — 2 columns */
@media (max-width: 900px) {
    .grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .header {
        padding: 3rem 1rem 2rem;
    }

    .header h1 {
        font-size: 1.8rem;
    }

    .grid {
        grid-template-columns: 1fr;
    }

    .timeline-date {
        min-width: 60px;
        font-size: 0.75rem;
    }

    .rec-grid {
        grid-template-columns: 1fr;
    }

    .petal {
        display: none;
    }

    .page-header h1 {
        font-size: 1.6rem;
    }

    /* About page */
    .about-hero h1 {
        font-size: 1.7rem;
    }

    .about-avatars {
        gap: 0.5rem;
    }

    .about-avatar {
        width: 80px;
        height: 80px;
        font-size: 1.3rem;
    }

    .fun-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Weather card mobile */
@media (max-width: 480px) {
    .weather-dual {
        flex-direction: column;
        gap: 0.5rem;
    }

    .weather-divider-v {
        width: 60%;
        height: 1px;
        margin: 0.3rem auto;
        background: linear-gradient(to right, transparent, #eee, transparent);
    }

    .mini-weather-card {
        max-width: 300px;
    }
}

/* Disable card hover lift on touch devices — prevents sticky hover state */
@media (max-width: 768px) {
    .card:hover {
        transform: none;
        box-shadow: var(--shadow-soft);
    }
    .month-tab:hover,
    .filter-btn:hover {
        transform: none;
    }
}

/* Gallery masonry — column count handled by JS applyMasonry() */
