/* =====================================================================
   redlawyers.ua — Адаптивне підменю (вкладені пункти)
   ===================================================================== */


/* Батьківський li відносно позиціонований — потрібно для абсолютного dropdown */
.menu-item-has-children {
  position: relative;
}

/* Загальні стилі для всіх рівнів sub-menu */
.menu-item-has-children > .sub-menu {
  display: block;
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 9999;
  min-width: 240px;
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.13);
  border: 1px solid rgba(0, 0, 0, 0.07);
  padding: 6px 0;
  margin: 0;
  list-style: none;
  /*transform: translateY(6px);*/
  transition: opacity 0.22s ease, visibility 0.22s;
}

/* Посилання всередині sub-menu */
.sub-menu li a {
  display: block;
  padding: 9px 18px;
  font-size: 14px;
  color: #1a1a1a;
  text-decoration: none;
  /*white-space: nowrap;*/
  transition: background 0.15s, color 0.15s;
}

.sub-menu li a:hover {
  background: #fff5f5;
  color: #c62828;
}

/* Активний/поточний пункт */
.sub-menu li.current-menu-item > a,
.sub-menu li.current-menu-ancestor > a {
  color: #c62828;
  font-weight: 600;
}

/* -------------------------------------------------------------------
   ВКЛАДЕНЕ підменю 2-го рівня (sub-menu всередині sub-menu)
   Відкривається вправо від батьківського li
   ------------------------------------------------------------------- */
@media screen and (min-width: 992px) {
  /* Показати підменю при hover або focus-within */
  .menu-item-has-children:hover > .sub-menu,
  .menu-item-has-children:focus-within > .sub-menu {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }

  .sub-menu .menu-item-has-children > .sub-menu {
    top: 0;
    left: 100%;
    margin-top: 0;
    /* Якщо немає місця справа — розкоментуйте рядок нижче */
    /* left: auto; right: 100%; */
    transform: translateX(6px);
    transition: opacity 0.22s ease, transform 0.22s ease, visibility 0.22s;
  }

  .sub-menu .menu-item-has-children:hover > .sub-menu,
  .sub-menu .menu-item-has-children:focus-within > .sub-menu {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
    transform: translateX(0);
  }
  .menu__list >  .menu-item-has-children > a::after {
    content: '';
    display: inline-block;
    width: 6px;
    height: 6px;
    border-right: 1.5px solid currentColor;
    border-top: 1.5px solid currentColor;
    transform: rotate(135deg);
    margin-left: 10px;
    margin-top: 8px;
    opacity: 0.6;
    float: right;
  }
}
/* Стрілка-індикатор для пунктів з підменю (десктоп) */
.sub-menu .menu-item-has-children > a::after {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-right: 1.5px solid currentColor;
  border-top: 1.5px solid currentColor;
  transform: rotate(45deg);
  margin-left: auto;
  float: right;
  margin-top: 5px;
  opacity: 0.6;
}

/* -------------------------------------------------------------------
   МОБІЛЬНИЙ: акордеон для sub-menu
   Breakpoint: <= 991px (адаптуйте під реальний breakpoint теми)
   ------------------------------------------------------------------- */

@media (max-width: 991px) {
  .menu__list > li._active .sub-menu {
    display: block;
    border-radius: 8px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.13);
  }
  .sub-menu .menu-item-has-children > .sub-menu {
    top: 100%;
  }
  .sub-menu .menu-item-has-children > a::after {
    display: none;
  }
  body._touch .menu-item-has-children {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .menu__arrow {
    display: flex;
    width: 16px;
    height: 16px;
    align-items: center;
    justify-content: center;
    margin-right: 10px;
  }
  .menu__list >  .menu-item-has-children > span {
    position: absolute;
    right: -35px;
  }
  /* Скидаємо десктопну поведінку */
  .menu-item-has-children > .sub-menu {
    /*position: static;*/
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
    box-shadow: none;
    border-radius: 0;
    border: none;
    padding: 0;
    /*transform: none;*/
    transition: none;

    /* Акордеон: приховуємо через max-height */
    display: block;
    max-height: 0;
    overflow: hidden;
    /*transition: max-height 0.3s ease;*/
    left: 50%;
    transform: translateX(-50%);
  }

  /* Відкритий акордеон — клас додається JS-скриптом */
  .menu-item-has-children._active > .sub-menu {
    max-height: 800px;
    overflow: inherit;
  }

  /* Скидаємо для вкладеного 2-го рівня */
  /*.sub-menu .menu-item-has-children > .sub-menu {
    left: auto;
    transform: none;
  }*/

  /* Відступ для вкладених пунктів (відчуття рівнів) */
  .sub-menu li a {
    padding-left: 24px;
  }

  .sub-menu .sub-menu li a {
    padding-left: 38px;
  }
  .sub-menu .sub-menu .sub-menu li a {
    padding-left: 52px;
  }

  /* Стрілка-індикатор (мобільний) — повертається при відкритті */
  /*.menu-item-has-children > a::after,*/
  .menu-item-has-children > span::after {
    content: '';
    display: inline-block;
    width: 7px;
    height: 7px;
    border-right: 1.5px solid currentColor;
    border-bottom: 1.5px solid currentColor;
    transform: rotate(45deg);
    /*float: right;
    margin-top: 4px;*/
    transition: transform 0.25s ease;
    opacity: 0.6;
  }

  /*.menu-item-has-children._active > a::after,*/
  .menu-item-has-children._active > span::after {
    transform: rotate(-135deg);
    margin-top: 8px;
  }

  /* Скидаємо стрілку 2-го рівня на мобільному */
  /*.sub-menu .menu-item-has-children > a::after {
    float: right;
    margin-top: 4px;
  }*/
}
