/* ====== Общие переменные и базовые цвета ====== */
:root{
  --cat-bg:#0b0f1a;
  --cat-bg-2:#121827;
  --cat-glass:rgba(255,255,255,.08);
  --cat-border:rgba(255,255,255,.12);
  --cat-text:#eaf0ff;
  --cat-muted:#9aa3b2;
  --cat-accent:#e52037;
  --cat-accent-2:#ff6b6b;
  --cat-shadow:0 18px 50px rgba(3,10,23,.25);
}

/* ====== Мобильный топ-бар (кнопка открытия меню) ====== */
.category-topbar{
  position: sticky; top: 0; z-index: 1040;
  background: linear-gradient(90deg,#0e1424 0%, #121a2e 100%);
  border-bottom: 1px solid rgba(255,255,255,.08);
  padding: 8px 12px;
}
.cat-topbar-btn{
  width: 100%;
  display: flex; align-items: center; justify-content: center;
  gap: 10px;
  background: #fe8621;
  color:#fff; border:none; border-radius:5px; padding:12px 14px;
  font-weight:700; letter-spacing:.2px;
  box-shadow: 0 12px 28px rgba(229,32,55,.32);
}
.cat-topbar-btn i{font-size:18px}

/* ====== Универсальный aside ====== */
.category-sidebar{
  color: var(--cat-text);
  background: linear-gradient(180deg, rgba(14,20,36,.85) 0%, rgba(18,26,46,.85) 100%);
  backdrop-filter: blur(8px);
  border:1px solid var(--cat-border);
  /* border-radius: 16px; */
  box-shadow: var(--cat-shadow);
  overflow: hidden;
}

/* Шапка панели */
.cat-panel-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 14px;
  background: linear-gradient(90deg, rgba(229,32,55,.15), rgba(255,107,107,.07));
  border-bottom:1px solid var(--cat-border);
}
.menu-section-title{
  color:#fff; font-weight:800; font-size:18px;
}
.cat-close{
  background:transparent; border:none; color:#fff; font-size:22px; line-height:1;
}

/* Блок меню */
.menu-block{padding:10px 10px 14px;}
.menu-group{
  border:1px solid var(--cat-border);
  background: var(--cat-glass);
  border-radius:14px; overflow: hidden;
  margin-bottom:10px;
}
.menu-title{
  display:flex; align-items:center; gap:10px;
  font-weight:700; padding:12px 14px; cursor:pointer;
  color:#fff; user-select:none;
}
.menu-title i{color:#fe8621;}

.submenu{
  list-style:none; margin:0; padding: 0 10px 10px;
  overflow: hidden;
}
.submenu li{margin: 6px 0;}
.submenu a,
.submenu .nolink{
  display:inline-block;
  background: rgba(255,255,255,.06);
  border:1px solid var(--cat-border);
  color:#fff; text-decoration:none;
  padding:8px 12px; border-radius:10px;
  transition: transform .25s ease, background .25s ease, border-color .25s ease;
}
.submenu a:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.22);
}
.submenu .nolink{color: var(--cat-muted);}

/* ====== Десктопный вид (АДАПТАЦИЯ) ====== */
@media (min-width: 992px){
  /* Переводим блок в полноширинную “полку” с плитками */
  .category-sidebar{
    position: relative;  /* убираем sticky, чтобы занять всю ширину секции */
    top: auto;
    max-height: none;
    overflow: visible;
    width: 100%;
    /* border-radius: 16px; */
    margin-bottom: 18px;
  }

  /* Шапка компактнее, без разделительной линии снизу */
  .cat-panel-head{
    padding: 12px 16px;
    border-bottom: none;
  }

  /* Основная раскладка: плитки в линию с переносом */
  .category-sidebar .menu-block{
    display: flex;
    flex-wrap: wrap;        /* перенос при нехватке ширины */
    gap: 14px;
    padding: 14px 16px 18px;
  }

  /* Плитка группы: одинаковая высота, приятный hover */
  .category-sidebar .menu-group{
    margin: 0;
    flex: 1 1 calc(16.66% - 14px); /* пытаться уместить до 6 плиток в ряд */
    min-width: 220px;              /* не сжимать слишком сильно */
    display: flex;
    flex-direction: column;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  }
  .category-sidebar .menu-group:hover{
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(0,0,0,.14);
    border-color: rgba(255,255,255,.2);
  }

  /* Заголовок на десктопе не аккордеон */
  .category-sidebar .menu-title{
    cursor: default;
    padding: 14px 16px;
  }

  /* Подменю всегда раскрыто на десктопе */
  .category-sidebar .submenu{
    max-height: none !important;
    padding: 10px 12px 14px !important;
    overflow: visible;
  }
}

/* ====== Мобильный off-canvas сверху ====== */
@media (max-width: 991.98px){
  .category-sidebar{
    position: fixed; left: 0; right: 0; top: 0;
    transform: translateY(-100%);
    transition: transform .4s cubic-bezier(.22,.61,.36,1);
    z-index: 1050;
    /* border-radius: 0 0 16px 16px; */
  }
  .category-sidebar.open{ transform: translateY(0); }

  /* Аккордеон на мобилке: высоту анимируем */
  .submenu{
    max-height: 0; padding: 0 10px; transition: max-height .35s ease, padding .35s ease;
  }
  .submenu.opened{
    max-height: 520px; /* при необходимости увеличь */
    padding: 0 10px 10px;
  }
}

/* ====== ОПЦИЯ: строго одна линия со скроллом по X на десктопе ====== */
/* Добавь класс .categories-one-line к <aside>, если хочешь без переноса */
@media (min-width: 992px){
  .category-sidebar.categories-one-line .menu-block{
    flex-wrap: nowrap;            /* без переноса */
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
  }
  .category-sidebar.categories-one-line .menu-group{
    flex: 0 0 320px;              /* фикс ширина плитки под скролл */
  }
}

/* =========================================================
   FIX: одинаковые плитки на десктопе без растяжения последней
   ========================================================= */

/* Базовая десктоп-сетка: 3 колонки начиная с 992px */
@media (min-width: 992px){
  .category-sidebar .menu-block{
    display: grid !important;
    grid-template-columns: repeat(3, minmax(220px, 1fr));
    gap: 14px;                       /* тот же шаг, что и был */
    padding: 14px 16px 18px;         /* сохраняем ваши отступы */
  }
  /* Сбрасываем flex-поведение плиток, запрещаем "рост" */
  .category-sidebar .menu-group{
    flex: initial !important;
    width: auto;
    min-width: 0;
    margin: 0;
  }
}

/* На широких экранах — 4 колонки */
@media (min-width: 1200px){
  .category-sidebar .menu-block{
    grid-template-columns: repeat(4, minmax(220px, 1fr));
  }
}

/* Очень широкие — 6 колонок (как вы и задумывали) */
@media (min-width: 1400px){
  .category-sidebar .menu-block{
    grid-template-columns: repeat(6, minmax(220px, 1fr));
  }
}










/* ====== Мелкие улучшения доступности/состояний ====== */
.menu-title:focus{ outline: 2px dashed rgba(255,255,255,.45); outline-offset: 2px; }
.submenu a:focus{ outline: 2px dashed rgba(255,255,255,.45); outline-offset: 2px; }

/* ==== MOBILE: внутренняя прокрутка в off-canvas панели ==== */
:root{
  --cat-head-h: 56px; /* высота шапки панели на мобилке */
}

@media (max-width: 991.98px){
  /* Панель занимает всю высоту экрана, контент прокручивается внутри */
  .category-sidebar{
    display: flex;
    flex-direction: column;
    height: 100dvh;           /* корректная высота на моб. браузерах */
    max-height: 100dvh;
    overflow: hidden;         /* запрещаем внешний скролл контейнера */
    -webkit-overflow-scrolling: touch;
  }

  /* Шапка остаётся на месте */
  .cat-panel-head{
    flex: 0 0 var(--cat-head-h);
    position: sticky;
    top: 0;
    z-index: 1;
  }

  /* Прокручиваем ТОЛЬКО блок с пунктами меню */
  .category-sidebar .menu-block{
    flex: 1 1 auto;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    padding: 10px 10px calc(14px + env(safe-area-inset-bottom)); /* учёт нижней «чёлки» iOS */
    max-height: calc(100dvh - var(--cat-head-h));
  }

  /* Анимируем аккордеон как и раньше */
  .submenu{
    max-height: 0;
    padding: 0 10px;
    transition: max-height .35s ease, padding .35s ease;
  }
  .submenu.opened{
    max-height: 520px;
    padding: 0 10px 10px;
  }
}

/* ==== Мобильная панель контактов: фикс внизу (bottom:0) ==== */
@media (max-width: 991.98px){
  .contact-rail{
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;                               /* как просили */
    z-index: 1060;
    display: none;                           /* показываем через JS */
    padding: 10px calc(14px + env(safe-area-inset-right))
             calc(10px + env(safe-area-inset-bottom))
             calc(14px + env(safe-area-inset-left));
    background: rgba(14,20,36,.75);
    backdrop-filter: blur(8px);
    border-top: 1px solid rgba(255,255,255,.12);
    box-shadow: 0 -10px 30px rgba(0,0,0,.22);
    /* border-radius: 12px 12px 0 0;            скругление сверху */
    
    /* горизонтальное расположение кнопок */
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 14px;
  }
  .contact-rail-btn{
    width: 56px; height: 56px;               /* крупнее для тапа */
    border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    color: #fff; text-decoration: none;
    box-shadow: 0 10px 24px rgba(0,0,0,.22);
    transition: transform .2s ease, filter .2s ease;
  }
  .contact-rail-btn:hover{ transform: translateY(-1px); filter: saturate(1.05); }
  .contact-rail-btn i{ font-size: 22px; line-height: 1; }
}

/* на десктопе скрыто */
@media (min-width: 992px){
  .contact-rail{ display: none !important; }
}

/* брендовые фоны (оставляем как были) */
.contact-rail-btn.insta{
  background: radial-gradient(120% 120% at 30% 20%, #FFDC80 0%, #FCAF45 22%, #F77737 44%, #E1306C 66%, #C13584 78%, #833AB4 100%);
}
.contact-rail-btn.tg{
  background: linear-gradient(180deg, #2AABEE 0%, #229ED9 100%);
}
.contact-rail-btn.phone{
  background: linear-gradient(180deg, #34C759 0%, #28A745 100%);
}



/* Квадратна плитка-категорія 1:1 */
.category-sidebar .cat-thumb{
  position: relative;
  display: block;
  border-radius: 12px;
  overflow: hidden;
  /* box-shadow: 0 8px 20px rgba(0,0,0,.08); */
  transition: transform .12s ease, box-shadow .2s ease, filter .2s ease;
}

/* Тримаємо квадрат 1/1 незалежно від ширини сайдбара */
.category-sidebar .cat-thumb::before{
  content: "";
  display: block;
  aspect-ratio: 1 / 1;
}

.category-sidebar .cat-thumb img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  display: block;
  padding: 20px;
  border-radius: 30px;
  transform: scale(1.01); /* легка підстраховка від “смуг” */
}

.category-sidebar .cat-thumb:hover{
  transform: translateY(-2px);
  /* box-shadow: 0 12px 28px rgba(0,0,0,.12); */
  filter: saturate(1.05);
}

.category-sidebar .cat-thumb:focus-visible{
  outline: none;
  /* box-shadow: 0 0 0 .18rem rgba(201,162,39,.35); золота обводка у фокусі */
}
