/* ===================================================
   RESPONSIVE STYLES
   Breakpoints:
   - 768px  — tablet
   - 480px  — phone
   - 375px  — iPhone mini
   Десктоп стилі залишено без змін у основному CSS.
   =================================================== */

/* ─────────────────────────────────────────────────────
   TABLET — 768px
───────────────────────────────────────────────────── */


/* ─────────────────────────────────────────────────────
   PHONE — 480px
───────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .site-footer {
        height: 100vh;
        min-height: 100vh;
        max-height: 100vh;
        padding-bottom: 10px;
    }
    .coop-rule__text {
        padding: 0 30px;
    }
    .fullscreen-menu__container {
        width: min(100% - 48px, var(--container)) !important;
    }
    .product-swiper__slide {
        height: 60vw!important;
    }
    .site-footer__container {
        padding: 0 5px 15px;
    }
    .fullscreen-menu__body {
        gap: 0;
    }
    .fullscreen-menu__container {
        padding-top: 0;
    }
    .fullscreen-menu__logo img {
        width: 64px;
    }
    .traceability-block__header {
        padding: 55px 0 50px;
    }
    .logistics-block {
        padding: 85px 0 50px;
    }
    .logistics-block__grid {
        gap: 50px!important;
    }
    .partners-block {
        padding: 40px 0 80px;
    }
    .licenses-block__title {
        margin: 0 0 15px;
    }
    .catalog-page__title, .catalog-home__title, .traceability-block__title, .logistics-block__title, .how-block__title, .partners-block__title {
        margin: 0;
    }
    .catalog-page__hero {
        min-height: 25vh;
    }
    .catalog-page__hero-content {
        padding: 0;
    }
    .catalog-page__grid-section {
        margin-top: 0;
    }
    .site-footer__logo {
        display: none;
    }
    .title {
        font-size: 2.85rem;
    }
    .subtitle {
        font-size: 1rem;
    }
    .catalog-page__subtitle {
        padding: 0 16px;
    }

    .catalog-page__title,
    .catalog-home__title,
    .traceability-block__title,
    .logistics-block__title,
    .how-block__title,
    .partners-block__title,
    .licenses-block__title,
    .about-block__title,
    .contacts-block__title,
    .prod-hero__title,
    .prod-trace__title,
    .prod-slider-title,
    .coop-hero__title
    {
        font-size: 2.5rem;
    }
    .contacts-block__title {
        margin-bottom: 20px;
    }
    .contacts-block__layout {
        gap: 25px;
    }
    .prod-slider-track {
        padding-left: 10px;
    }
    .contacts-item {
        padding: 10px 0;
    }
    /* ── Loader ── */
    .site-loader__logo img {
        width: 140px;
    }

    .site-loader__percent {
        font-size: 15px;
    }

    /* ── Hero title ── */
    .hero-title {
        font-size: clamp(36px, 11vw, 60px);
        line-height: 1.2;
    }

    /* ── Header ── */
    .site-header__inner {
        gap: 8px;
    }

    /* ── Catalog home ── */
    .catalog-home {
        padding: 56px 0 150px;
    }

    .catalog-home__header {
        margin-bottom: 28px;
    }

    .catalog-home__grid {
        grid-template-columns: 1fr;
        margin-bottom: 36px;
    }
    .site-header__logo img {
        width: 64px;
    }
    .btn--catalog-goto {
        height: 46px;
        padding: 0 28px;
        font-size: 14px;
    }

    /* ── Partners block ── */
    .partners-grid--3,
    .partners-grid--4 {
        grid-template-columns: 1fr 1fr;
        gap: 8px;
    }

    .partners-tile {
        min-height: 72px;
        padding: 14px 10px;
    }

    .partners-tile__title {
        font-size: 12px;
        line-height: 1.35;
    }

    .partners-block__section-label {
        font-size: 13px;
    }

    /* ── Licenses ── */
    .licenses-item {
        width: 180px;
        flex: 0 0 180px;
    }

    .licenses-item__name {
        font-size: 12px;
    }

    /* ── Product single ── */
    .product-single {
        padding-top: 80px;
        padding-bottom: 48px;
    }

    .product-single__title {
        font-size: clamp(26px, 8vw, 40px);
    }

    .product-single__specs {
        flex-direction: column;
        gap: 12px;
        padding: 16px;
    }

    .product-single__actions {
        flex-direction: column;
    }

    .btn--primary {
        width: 100%;
        justify-content: center;
    }

    .product-single__thumbs {
        gap: 6px;
    }

    .product-single__thumb {
        width: 58px;
        height: 58px;
    }
    .catalog-filters {
        flex-wrap: nowrap;
        gap: 6px;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        /* щоб крайні таги не прилипали до країв екрану */
        padding: 4px 16px;
        margin: 0 -16px;
        scroll-padding-inline: 16px;
    }

    .catalog-filters::-webkit-scrollbar {
        display: none;
    }

    .catalog-filter-tag {
        flex: 0 0 auto;
        font-size: 13px;
        padding: 8px 16px;
        white-space: nowrap;
    }

    .catalog-grid-4 {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    /* ── Catalog item ── */
    .catalog-item__body {
        padding: 14px 16px 10px;
    }

    .catalog-item__footer {
        padding: 10px 16px 14px;
    }

    .catalog-item__title {
        font-size: 16px;
    }

    /* ── Product related ── */
    .product-related__grid {
        grid-template-columns: 1fr;
    }

    /* ── Product tabs ── */
    .product-tabs__nav {
        flex-direction: column;
        align-items: stretch;
    }

    .product-tabs__btn {
        text-align: center;
        padding: 14px 16px;
    }

    /* ── Product intro ── */
    .product-intro__title {
        font-size: 25px;
        margin: 0 0 10px;
    }

    /* ── Catalog archive ── */
    .catalog-archive__title {
        font-size: clamp(36px, 10vw, 60px);
    }

    /* ── Catalog archive filters ── */
    .catalog-archive__filters {
        gap: 6px;
    }

    .catalog-filter-btn {
        font-size: 12px;
        padding: 7px 14px;
    }

    .product-tabs {
        max-width: 600px;
        margin: 0 auto;
    }

    .product-tabs__nav {
        display: flex;
        justify-content: flex-start; /* Выровнять по левому краю */
        gap: 12px;
        margin-bottom: 48px;
        flex-wrap: nowrap; /* Не переносим элементы на новый ряд */
        overflow-x: auto; /* Включаем горизонтальную прокрутку */
        -webkit-overflow-scrolling: touch; /* Плавная прокрутка на мобильных */
    }

    .product-tabs__btn {
        font-family: "Gilroy", sans-serif;
        font-weight: 500;
        font-size: 14px;
        letter-spacing: 0.04em;
        padding: 14px 32px;
        border-radius: 999px;
        border: 1px solid var(--p-border);
        background: transparent;
        color: var(--p-cream);
        cursor: pointer;
        transition: background var(--p-transition), border-color var(--p-transition);
        flex: 0 0 auto; /* Устанавливаем фиксированную ширину для кнопок */
        min-width: 150px; /* Задаем одинаковую минимальную ширину для каждого таба */
        white-space: nowrap; /* Запрещаем перенос текста внутри кнопок */
    }

    .product-tabs__nav::-webkit-scrollbar {
        display: none; /* Скрываем скроллбар */
    }

    .product-tabs__nav {
        flex-direction: row; /* Делаем табы в один ряд */
        align-items: center; /* Выровняем элементы по центру */
    }
    /* ── Btn load more ── */
    .btn--load-more {
        width: 100%;
        height: 48px;
        font-size: 14px;
    }

    /* ── Product breadcrumbs ── */
    .product-single__breadcrumbs {
        font-size: 12px;
        gap: 6px;
        margin-bottom: 28px;
    }
}


/* ─────────────────────────────────────────────────────
   iPHONE MINI — 375px
───────────────────────────────────────────────────── */
@media (max-width: 375px) {

    /* ── Hero ── */
    .hero-title {
        font-size: 32px;
        line-height: 1.2;
    }

    /* ── Catalog home ── */
    .catalog-home {
        padding: 48px 0 56px;
    }

    .catalog-home__grid {
        gap: 6px;
    }

    /* ── Partners ── */
    .partners-tile {
        min-height: 64px;
        padding: 12px 8px;
    }

    .partners-tile__title {
        font-size: 11px;
    }

    /* ── Licenses ── */
    .licenses-item {
        width: 160px;
        flex: 0 0 160px;
    }

    .licenses-scroll-track {
        padding: 0 16px;
        gap: 12px;
    }

    /* ── Product single ── */
    .product-single__title {
        font-size: 26px;
    }

    .product-single__thumb {
        width: 52px;
        height: 52px;
    }

    /* ── Catalog page ── */
    .catalog-page__title {
        font-size: 32px;
        letter-spacing: 0.02em;
    }

    .catalog-page__hero-content {
        padding-top: 100px;
        padding-bottom: 40px;
    }

    /* ── Catalog grid ── */
    .catalog-grid-4 {
        grid-template-columns: 1fr 1fr;
        gap: 3px;
    }

    /* ── Catalog item ── */
    .catalog-item__title {
        font-size: 14px;
    }

    .catalog-item__body {
        padding: 12px 12px 8px;
    }

    /* ── Buttons ── */
    .btn--catalog-goto,
    .btn--load-more {
        height: 44px;
        padding: 0 20px;
        font-size: 13px;
    }

    .btn--primary {
        height: 46px;
        font-size: 13px;
    }

    /* ── Product tabs ── */
    .product-tabs__btn {
        font-size: 12px;
        padding: 12px 14px;
    }

    /* ── Product specs ── */
    .product-single__spec dt {
        font-size: 10px;
    }

    .product-single__spec dd {
        font-size: 14px;
    }

    /* ── Header btn ── */
    .header-contact-btn--menu {
        min-height: 44px;
        padding-inline: 18px;
        font-size: 13px;
    }

    /* ── Loader ── */
    .site-loader__logo img {
        width: 120px;
    }

    .site-loader__inner {
        gap: 24px;
    }
}


/* ─────────────────────────────────────────────────────
   SITE FOOTER — адаптив
───────────────────────────────────────────────────── */
@media (max-width: 900px) {
    .site-footer__container {
        padding: 36px 24px;
    }

    .site-footer__top {
        margin-bottom: clamp(16px, 6vh, 48px);
    }

    .site-footer__body {
        grid-template-columns: 1fr;
        gap: clamp(16px, 4vh, 32px);
    }

    .site-footer__bottom {
        margin-top: clamp(16px, 6vh, 48px);
        padding-top: clamp(12px, 3vh, 24px);
    }

    .site-footer__contacts {
        gap: clamp(8px, 2.5vh, 24px);
    }

    .site-footer__list {
        gap: clamp(2px, 0.8vh, 8px);
        align-items: flex-end;
    }

    .site-footer__list a {
        line-height: clamp(1.4, 4vh, 2.2);
    }

    /* Меню зверху, по правому краю; контакти знизу, по лівому */
    .site-footer__right {
        order: -1;
        align-items: flex-end;
    }

    .site-footer__list a:hover {
        transform: translateX(-6px);
    }
}

@media (max-width: 600px) {
    .site-footer__bottom {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }

    .site-footer__cta {
        width: auto;
        align-self: flex-start;
    }
}

/* ─────────────────────────────────────────────────────
   GSAP — вимикаємо licenses horizontal scroll
   на планшеті і менше
───────────────────────────────────────────────────── */
/* (JS частина нижче — додай в main.js) */