/* assets/css/components/nav.css
   Navigation component: main nav + megamenu + mobile menu behavior.
   Version: cleaned + light mobile sheet (white) + reliable submenu toggles.

   Notes:
   - Desktop: green bar + white megamenu.
   - Mobile: white sheet overlay for readability (forces white bg with !important to beat skin overrides).
*/

/* ===== Main navigation (desktop base) ===== */
.main-navigation{
  position: relative;
  z-index: 3000;
  background: linear-gradient(180deg, var(--green-700), var(--green-900));
  border-bottom: 1px solid rgba(0,0,0,.10);
}

.nav-list{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  list-style: none;
  margin: 0;
  padding: 10px 0;
}

.nav-list > li{ position: relative; }

/* IMPORTANT: full-width megamenu needs static li (desktop only) */
@media (min-width: 881px){
  .nav-list > li.has-megamenu{ position: static; }
}

.nav-list > li > a{
  color: rgba(255,255,255,.95);
  display: inline-flex;
  align-items: center;
  padding: 10px 14px;
  border-radius: 999px;
  position: relative;
  text-decoration: none;
  font-weight: 600;
  transition: background .14s ease, transform .14s ease, color .14s ease;
}

.nav-list > li > a:hover{
  background: transparent;
  color: #fff;
}

.nav-list > li.is-active > a{
  background: transparent;
  color: #fff;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 8px;
  text-decoration-color: rgba(255,255,255,.92);
}

.nav-list > li.is-active > a::after{
  content: none !important;
}


/* ===== Megamenu (desktop) ===== */
.megamenu{
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;          /* stretch to full width of nav */
  width: auto;
  z-index: 4000;

  background: #fff;
  border: 1px solid rgba(31,41,55,.12);
  box-shadow: 0 18px 56px rgba(17,24,39,.12);
  border-radius: 22px;

  padding: 18px;
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(180px, 240px);
  gap: 22px;
  justify-content: center;

  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: opacity .18s ease, transform .18s ease, visibility .18s ease;
}

/* show on hover (desktop) */
.has-megamenu:hover > .megamenu{
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.megamenu-column{ min-width: 180px; }

.megamenu-column h4{
  margin: 0 0 10px;
  font-size: 14px;
  font-weight: 900;
  color: rgba(215,161,0,.95);
  letter-spacing: .08em;
  text-transform: uppercase;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(31,41,55,.10);
}

.megamenu-column ul{ list-style:none; margin:0; padding:0; }
.megamenu-column li{ margin: 6px 0; }

.megamenu-column a{
  display:block;
  padding: 8px 10px;
  border-radius: 12px;
  color: var(--text);
  text-decoration: none;
}

.megamenu-column a:hover{
  background: rgba(148,179,82,.10);
  color: var(--green-800);
}

/* ===== Mobile menu (light sheet) ===== */
@media (max-width: 880px){

  /* menu hidden until burger toggles .active */
  .main-navigation{ display:none; }

  .main-navigation.active{
    display:block;
    max-height: 70vh;
    overflow: auto;

    /* FORCE white sheet even if skin sets green background */
    background: #fff !important;
    border-top: 1px solid rgba(31,41,55,.10);
    box-shadow: 0 18px 44px rgba(17,24,39,.14);
  }

  .nav-list{
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0;
    padding: 8px 0 10px;
  }

  .nav-list > li{
    position: relative;
    border-bottom: 1px solid rgba(31,41,55,.08);
  }

  .nav-list > li:last-child{ border-bottom: 0; }

  /* одинаковый right-padding у всех пунктов => стрелки не “ломают” сетку */
  .nav-list > li > a{
    display: block;
    width: 100%;
    text-align: left;

    padding: 14px 52px 14px 18px;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: .1px;

    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    color: var(--green-900);
  }

  .nav-list > li > a:hover{
    background: rgba(148,179,82,.10) !important;
  }

  .nav-list > li.is-active > a{
    background: rgba(148,179,82,.14) !important;
  }

  /* remove desktop underline in mobile */
  .nav-list > li.is-active > a::after{ content:none !important; }

  /* Submenu toggle button (minimal, readable on white) */
  .submenu-toggle{
    position:absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    width: 32px;
    height: 32px;
    border-radius: 10px;

    background: rgba(31,41,55,.04);
    border: 1px solid rgba(31,41,55,.14);
    color: rgba(31,41,55,.78);

    cursor: pointer;
    z-index: 5;
  }

  .submenu-toggle::before{
    content:"";
    display:inline-block;
    width: 8px;
    height: 8px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg);
    margin-top: 2px;
  }

  .has-megamenu.open > .submenu-toggle::before{
    transform: rotate(-135deg);
    margin-top: 0;
  }

  /* Megamenu becomes an inline light panel */
  .megamenu{
    position: static;
    left: auto;
    right: auto;
    width: auto;
    opacity: 1;
    visibility: visible;
    transform: none;
    transition: none;

    display: none;
    margin: 8px 14px 12px;
    padding: 8px 0;
    border-radius: 14px;

    background: rgba(148,179,82,.08);
    border: 1px solid rgba(31,41,55,.08);
    box-shadow: none;
  }

  .has-megamenu.open > .megamenu{ display:block; }

  .megamenu-column{ width: 100%; min-width: 0; }

  .megamenu-column h4{
    color: rgba(31,41,55,.55);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
    margin: 10px 14px 6px;
    padding: 0;
    border: 0;
  }

  .megamenu-column a{
    color: rgba(31,41,55,.92);
    padding: 10px 14px;
    border-radius: 12px;
    text-decoration: none;
  }

  .megamenu-column a:hover{
    background: rgba(255,255,255,.70);
    color: var(--green-900);
  }
}

/* FIX: skin-sever sets white links; mobile sheet is white -> force dark text */
@media (max-width: 880px){
  body.skin-sever .main-navigation.active .nav-list > li > a{
    color: var(--green-900) !important;
    opacity: 1 !important;
  }

  body.skin-sever .main-navigation.active .nav-list > li > a:hover{
    color: var(--green-900) !important;
  }
}


/* FIX: стрелка подменю не должна уезжать вниз при раскрытии */
@media (max-width: 880px){
  .main-navigation.active .has-megamenu{ position: relative; }

  .main-navigation.active .has-megamenu > .submenu-toggle{
    top: 22px !important;            /* центр первой строки пункта */
    transform: translateY(-50%) !important;
    z-index: 10;
  }

  /* на всякий случай, чтобы OPEN не переопределял позицию */
  .main-navigation.active .has-megamenu.open > .submenu-toggle{
    top: 22px !important;
  }
}

@media (max-width: 880px){
  .main-navigation.active .megamenu-column{
    position: relative;
    padding-left: 12px;
  }
  .main-navigation.active .megamenu-column:before{
    content:"";
    position:absolute;
    left: 4px;
    top: 10px;
    bottom: 10px;
    width: 3px;
    border-radius: 3px;
    background: rgba(0,0,0,.12);
  }
}

@media (max-width: 880px){
  /* мягкая подложка внутри раскрытого блока */
  .main-navigation.active .megamenu{
    background: rgba(0,0,0,.03);
    border: 1px solid rgba(0,0,0,.06);
    border-radius: 16px;
    padding: 10px;
  }

  /* === ПЛАШКА ЗАГОЛОВКА БЛОКА ===
     ВАЖНО: селекторы ниже на случай разных классов.
     Оставь тот, который реально есть у твоего "БЫТОВКИ" (через инспектор). */
  .main-navigation.active .megamenu .megamenu-title,
  .main-navigation.active .megamenu .megamenu-column-title,
  .main-navigation.active .megamenu .megamenu-heading{
    display: inline-block;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(0,0,0,.08);
    font-weight: 700;
    letter-spacing: .06em;
    margin: 6px 0 10px;
  }

  /* пункты меню — чуть “кнопочнее”, чтобы не было плоско */
  .main-navigation.active .megamenu-column a{
    border-radius: 12px;
    padding: 10px 12px;
    transition: background-color .15s ease;
  }
  .main-navigation.active .megamenu-column a:hover{
    background: rgba(0,0,0,.05);
  }
  .main-navigation.active .megamenu-column a:active{
    background: rgba(0,0,0,.08);
  }

  .main-navigation.active .megamenu-column li + li{
    margin-top: 4px;
  }
}