@media (max-width: 900px) {

    


    .hero {
        min-height: 100vh;
        min-height: 100dvh;
        height: auto;
    }

    .hero-wrapper {
        width: min(1200px, calc(100% - 32px));
        padding-top: 130px;
        padding-bottom: 60px;
    }

    .hero-content h1 {
        font-size: 34px;
        max-width: 100%;
    }

    .hero-content p {
        max-width: 100%;
        font-size: 16px;
    }

    .hero-btns {
        flex-direction: column;
        align-items: flex-start;
    }

    .btn-primary,
    .btn-secondary {
        width: min(200px, 100%);
        height: 54px;
        font-size: 18px;
    }

    .about,
    .services,
    .coffee-section,
    .contact-section {
        padding: 64px 0;
    }

    .about {
        margin-top: 0;
    }

    .grid-2,
    .contact-wrap {
        grid-template-columns: 1fr;
        gap: 28px;
    }

    h2,
    .coffee-intro h2,
    .contact-copy h2 {
        font-size: 34px;
        letter-spacing: 1px;
        line-height: 1.1;
    }

    .about p,
    .coffee-intro p,
    .contact-copy p {
        font-size: 16px;
        max-width: 100%;
    }

    .gallery-preview {
        height: auto;
        aspect-ratio: 4 / 3;
    }

    .thumb {
        height: 64px;
    }

    .stats {
        gap: 24px;
        margin-top: 24px;
    }

    .stat-item strong {
        font-size: 24px;
        letter-spacing: 0.03cm;
    }

    .service-grid {
        flex-direction: column;
        height: auto;
        gap: 14px;
    }

    .service-card,
    .service-card.active {
        flex: 1;
        min-height: 180px;
    }

    .service-card p {
        display: block;
    }

    .card-overlay {
        padding: 20px;
    }

    .coffee-grid {
        width: min(1200px, calc(100% - 32px));
        gap: 24px;
    }

    .coffee-cards {
        justify-content: flex-start;
        gap: 16px;
    }

    .coffee-card {
        width: min(280px, 100%);
    }

    .contact-wrap {
        width: min(1200px, calc(100% - 32px));
    }

    .contact-image {
        width: 100%;
        justify-self: stretch;
    }

    .contact-image img {
        height: auto;
        min-height: 240px;
    }
}

@media (max-width: 480px) {
    .hero-wrapper,
    .coffee-grid,
    .contact-wrap {
        width: min(1200px, calc(100% - 28px));
    }

    .hero-content h1,
    h2,
    .coffee-intro h2,
    .contact-copy h2 {
        font-size: 30px;
    }

    .btn-primary,
    .btn-secondary {
        height: 50px;
        font-size: 17px;
        padding: 0 4px 0 18px;
    }

    .arrow {
        width: 42px;
        height: 42px;
    }
}

@media (max-width: 360px) {
    .hero-wrapper,
    .coffee-grid,
    .contact-wrap {
        width: min(1200px, calc(100% - 24px));
    }
}
