﻿.page-top {
  display: flex;
  justify-content: space-between;
  background-color: var(--green);
  padding: var(--spacing-2) var(--spacing-4);

  a {
    color: var(--black);
    font: var(--nav-top);

    &:hover {
      color: var(--black-hover);
    }
  }

  .page-top-contact {
    display: flex;
    gap: var(--spacing-2);
  }
}

.header-wrapper {
  display: flex;
  background-color: var(--black);
  padding: var(--spacing-4);
  justify-content: space-between;
  gap: var(--spacing-2);
  align-items: center;
  width: 100%;
}

.header-btn {
  display: flex;
  align-items: center;

  .btn.main-btn {
    width: max-content;
  }
}

/* .header-wrapper nav.primary ul li a {
  color: var(--background) !important;
} */

.logo {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: max-content;

  img {
    display: inline-block;
    width: auto;
    height: clamp(2.75rem, 4vw, 3.5rem);
    max-width: 120px;
    object-fit: contain;
  }
}

.menu-social {
  padding: var(--spacing-2);
  display: none;
  flex-direction: row;
  gap: var(--spacing-1);

  a {
    display: flex;
    color: var(--black);
    background-color: var(--yellow);
    width: 2.5rem;
    height: 2.5rem;
    border-radius: var(--border-radius-xxs);
    align-items: center;
    justify-content: center;
    transition: var(--transition);

    &:hover {
      background-color: var(--light-yellow-1) !important;
    }
  }
}

/***** Start of primary nav ******/
#menu-bars {
  display: none;
}
nav.mobile {
  display: none;
}

nav.primary {
  display: flex;
  position: relative;
  padding: 0;
  margin: 0;
  width: auto;
  align-items: center;
  justify-content: center;

  ul {
    display: flex;
    margin: 0;
    padding: 0;
  }
}

/* Top level links */
nav.primary ul li {
  display: inline-block;
  display: flex;
  margin: 0;
  padding: 0 var(--spacing-2);
  list-style-type: none;
  width: auto;

  &:last-child {
    padding-right: 0;
  }

  a {
    color: var(--background);
    font: var(--nav-menu-lv1);
    text-decoration: none;
    display: block;
    margin: 0;
    text-align: center;
    -webkit-transition: 0.4s ease-in;
    -moz-transition: 0.2s ease-in;
    -o-transition: 0.2s ease-in;
    transition: 0.2s ease-in;

    &:hover {
      color: var(--yellow);
    }
  }
}

/*------------------- Appearance of the sub-level links ------------------- */

nav.primary .nav-second-level {
  display: none;
  position: absolute;
  top: 200%;
  background-color: var(--background);

  li {
    width: 270px;
    position: relative;
    margin: 0;
    display: block;
  }

  a {
    color: var(--black);
    text-align: left;
    border-right: none;
    border-left: none;
  }

  li:hover {
    background-color: var(--light-green-1);
  }
  a:hover {
    color: var(--black);
  }
}

nav.primary > ul > li:hover::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  height: 3rem;
}

nav.primary .nav-third-level {
  display: none;
  position: absolute;
  top: 0;
  left: 100%;
  background-color: var(--background);

  li:hover {
    background-color: var(--white-active);
  }

  a {
    color: var(--black);
  }
}

nav.primary .nav-second-level > li:hover > .nav-third-level,
nav.primary .nav-second-level > li:focus-within > .nav-third-level {
  display: block;
  z-index: 101;
}

nav.primary ul li:hover > .nav-second-level,
nav.primary ul li:focus-within > .nav-second-level {
  display: block;
  z-index: 100;
}

/******** End of primary Nav ***************/

/*==============================
	Mobile Nav Styles			
================================*/
@media screen and (max-width: 1000px) {
  nav.primary {
    display: none;
  }

  #menu-bars {
    /* width: 100%; */
    font: var(--body-l-bold);
    display: inline-block;
    position: relative;
    z-index: 400; /* needs to be lower than nav.mobile, adjust as needed */
    text-align: right;

    a {
      color: var(--background);
      text-decoration: none;
      padding: 0 0 0 var(--spacing-2);

      &:hover {
        color: var(--light-yellow-2);
        cursor: pointer;
      }
    }
  }

  .header-btn {
    justify-content: flex-end;
    width: 100%;
  }

  nav.mobile {
    display: block;
    position: fixed;
    top: 0;
    left: -250px;
    width: 250px;
    height: 100%;
    background: var(--black);
    z-index: 500; /* needs to be higher than #menu-button, adjust as needed */
    overflow: auto;

    .menu-header {
      display: flex;
      position: relative;
      align-items: center;
      font: var(--heading-h3);
      color: var(--background);
      padding: var(--spacing-2);
      height: 3rem;
    }

    a {
      color: var(--black);
    }

    /* MENU CLOSE 'X' BUTTON */
    .menu-toggle {
      position: absolute;
      font: var(--body-m-bold);
      color: var(--background);
      width: 30px;
      height: 30px;
      text-decoration: none;
      right: 5%;

      &:hover {
        /* Menu close button on hover */
        color: var(--light-yellow-2) !important;
        cursor: pointer;
      }
    }
  }

  /* MENU LIST STYLE */
  nav.mobile ul {
    list-style: none;
    margin: 0;
    padding: 0;

    li {
      font: var(--body-m-bold);
      position: relative;
    }
  }

  nav.mobile hr {
    border: none;
    border-top: 1px solid var(--black);
    margin: 0;
  }

  /*===================== FIRST LEVEL ===================== */
  nav.mobile ul li {
    a {
      position: relative;
      display: block;
      padding: var(--spacing-2);
      text-decoration: none;
      text-align: left;
      transition: var(--transition);
      color: var(--background);

      &:hover {
        background-color: var(--yellow);
        color: var(--black);
      }
    }

    .click {
      position: relative;
      display: block;
      width: 100%;
      padding: var(--spacing-2);
      text-decoration: none;
      text-align: left;
      transition: var(--transition);
      cursor: pointer;
    }
  }

  /* ===================== SECOND LEVEL ====================== */
  /* nav.mobile ul li li:last-child {
    border: none;
  } */

  nav.mobile .dropdown-list {
    display: none;
    margin: 0;
    padding: 0;
  }

  nav.mobile .dropdown-category {
    display: block;
    margin: 0;
    padding: 0;
    list-style: none;

    .category-toggle {
      display: block;
      font: var(--body-s-bold);
      padding: var(--spacing-1) 0 var(--spacing-1) var(--spacing-2);
      background-color: var(--background);
      cursor: pointer;
      text-decoration: none;
      color: var(--black);

      transition: var(--transition);

      &:hover {
        background-color: var(--light-green-1);
      }
    }

    /*===================== Third level dropdown categories ===================== */
    .category-items {
      display: none;
      margin: 0;
      padding: 0;
      list-style: none;

      a {
        display: block;
        position: relative;
        background: var(--background);
        color: var(--black);
        text-decoration: none;
        font: var(--body-s-reg);
        padding: var(--spacing-1) 0 var(--spacing-1) var(--spacing-5);

        &:hover {
          background-color: var(--white-active);
          color: var(--blue);
        }
      }
    }
  }
}

/* ============================================== */

@media screen and (max-width: 1020px) {
}

@media only screen and (max-width: 550px) {
  .page-top {
    --nav-top: var(--body-s-reg);
  }
}

@media only screen and (max-width: 480px) {
  .page-top {
    .page-top-contact {
      --nav-top: var(--body-xs-bold);
      width: 100%;
      align-items: center;
      justify-content: center;
    }

    .social {
      display: none;
    }
  }

  .menu-social {
    display: flex;
  }

  .header-wrapper {
    .header-btn {
      display: none;
    }

    .main-btn {
      padding: var(--spacing-1) var(--spacing-2);
      font: var(--body-s-bold) !important;
      gap: var(--spacing-1);
    }
  }
}

@media screen and (max-width: 450px) {
  .header-wrapper {
    padding: var(--spacing-4) var(--spacing-5);
  }
}
