/*
  L21 header + mobile menu
  - Uses the exact class logic from the provided L21 HTML/PHP archive.
  - All colors are driven by CSS variables injected via the WP Customizer.
*/


@font-face{font-family:'Manrope';src:url('../../fonts/l21x/Manrope-Regular.woff2') format('woff2'),url('../../fonts/l21x/Manrope-Regular.woff') format('woff');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Manrope';src:url('../../fonts/l21x/Manrope-Medium.woff2') format('woff2'),url('../../fonts/l21x/Manrope-Medium.woff') format('woff');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Manrope';src:url('../../fonts/l21x/Manrope-SemiBold.woff2') format('woff2'),url('../../fonts/l21x/Manrope-SemiBold.woff') format('woff');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Manrope';src:url('../../fonts/l21x/Manrope-Bold.woff2') format('woff2'),url('../../fonts/l21x/Manrope-Bold.woff') format('woff');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Manrope';src:url('../../fonts/l21x/Manrope-ExtraBold.woff2') format('woff2'),url('../../fonts/l21x/Manrope-ExtraBold.woff') format('woff');font-weight:800;font-style:normal;font-display:swap}


:root{
  --l21x-adminbar: 0px;
  --l21x-header-height: 70px;

  /* Header */
  --l21x-header-bg: #ffffff;
  --header-shadow: 0 2px 16px rgba(20, 34, 180, 0.10);

  /* Navigation */
  --navigation-link: #000000;
  --navigation-link-hover: #000000;

  /* Burger */
  --burger-color: #000000;
  --l21x-burger-hover-color: var(--burger-color);

  /* Mobile menu */
  --l21x-mobile-menu-bg: #f6f7f8;
  --l21x-mobile-menu-list-bg: rgba(255,255,255,0.10);

  /* Buttons common */
  --l21x-btn-border-width: 0px;
  --l21x-btn-border-color: transparent;

  /* Button 1 */
  --l21x-btn1-bg: #ffffff;
  --l21x-btn1-bg-hover: #f2f2f2;
  --l21x-btn1-text: #000000;
  --l21x-btn1-text-hover: #000000;

  /* Button 2 */
  --l21x-btn2-bg: #1b9eff;
  --l21x-btn2-bg-hover: #47a8f7;
  --l21x-btn2-text: #ffffff;
  --l21x-btn2-text-hover: #ffffff;
}

/* Push site content below the fixed header */
.space-box{
  padding-top: var(--l21x-header-height);
}


header.header,header.header * ,dialog.mobile-menu,dialog.mobile-menu *{font-family:'Manrope',sans-serif}

/* ===================== Header ===================== */
header.header{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: var(--l21x-header-bg);
  box-shadow: var(--header-shadow);
  padding: 0.875rem 1rem;
}
@media (min-width: 992px){
  header.header{ padding: 1rem 1.5rem; }
}

header.header .header__container{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
}

/* Logo */
header.header .logo{
  display: block;
  position: relative;
  text-decoration: none;
}
header.header .logo__img{
  display: block;
  max-height: 3.125rem;
  width: auto;
}

/* Navigation */
header.header nav.navigation{ display: none; }
@media (min-width: 992px){
  header.header nav.navigation{ display: block; }
}
header.header .navigation__list{
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 1.25rem;
}
header.header .navigation__link{
  color: var(--navigation-link);
  text-decoration: none;
  font-weight: 700;
  font-size: 1rem;
  line-height: 1;
  white-space: nowrap;
}
header.header .navigation__link:hover,
header.header .navigation__link:focus{
  color: var(--navigation-link-hover);
}

/* Dropdown submenu (desktop) */
@media (min-width: 992px){
  header.header .navigation__item{ position: relative; }
  header.header .navigation__sublist{
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    min-width: 220px;
    margin: 0;
    padding: 10px;
    list-style: none;
    background: var(--l21x-submenu-bg, rgba(255,255,255,0.95));
    border-radius: 16px;
    box-shadow: 0 14px 40px rgba(0,0,0,0.18);
    opacity: 0;
    visibility: hidden;
    transform: translateY(6px);
    transition: opacity .15s ease, transform .15s ease, visibility .15s ease;
    z-index: 2000;
  }
  header.header .navigation__item--has-children:hover > .navigation__sublist,
  header.header .navigation__item--has-children:focus-within > .navigation__sublist{
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }

  header.header .navigation__sublist .navigation__link{
    display: block;
    width: 100%;
    padding: 10px 12px;
    border-radius: 12px;
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--l21x-submenu-link, var(--navigation-link));
  }
  header.header .navigation__sublist .navigation__link:hover,
  header.header .navigation__sublist .navigation__link:focus{
    color: var(--l21x-submenu-link-hover, var(--navigation-link-hover));
}
}

/* Header actions (buttons) */
header.header ul.header__right{
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
header.header li.header__rightItem{ margin: 0; padding: 0; }

/* Button base (L21-like) */
header.header a.button,
header.header button.button{
  -webkit-appearance: none;
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 12px 16px;
  border-radius: 12px;
  font-weight: 800;
  text-decoration: none;
  line-height: 1;
  border: var(--l21x-btn-border-width) solid var(--l21x-btn-border-color);
  background: var(--l21x-btn-bg);
  color: var(--l21x-btn-text);
  box-shadow: 0 1px 0 rgba(0,0,0,0.05);
  box-sizing: border-box;
  white-space: nowrap;
}
header.header a.button:hover,
header.header a.button:focus,
header.header button.button:hover,
header.header button.button:focus{
  background: var(--l21x-btn-bg-hover, var(--l21x-btn-bg));
  color: var(--l21x-btn-text-hover, var(--l21x-btn-text));
}

/* Map per-button variables by position (exact L21 order: Registration then Login) */
header.header ul.header__right > li.header__rightItem:nth-child(1) > a.button{
  --l21x-btn-bg: var(--l21x-btn1-bg);
  --l21x-btn-bg-hover: var(--l21x-btn1-bg-hover);
  --l21x-btn-text: var(--l21x-btn1-text);
  --l21x-btn-text-hover: var(--l21x-btn1-text-hover);
}
header.header ul.header__right > li.header__rightItem:nth-child(2) > a.button{
  --l21x-btn-bg: var(--l21x-btn2-bg);
  --l21x-btn-bg-hover: var(--l21x-btn2-bg-hover);
  --l21x-btn-text: var(--l21x-btn2-text);
  --l21x-btn-text-hover: var(--l21x-btn2-text-hover);
}

/* ===================== Burger ===================== */
header.header button.burger{
  -webkit-appearance: none;
  appearance: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  padding: 0;
  margin-left: .5rem;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,0.18);
  background: rgba(255,255,255,0.20);
  box-shadow: 0 6px 18px rgba(0,0,0,0.14);
  transition: transform .12s ease-in-out, background-color .12s ease-in-out, border-color .12s ease-in-out;
}
header.header button.burger:active{ transform: scale(0.98); }
header.header button.burger:hover{
  border-color: rgba(0,0,0,0.28);
  background: rgba(255,255,255,0.28);
}
@media (min-width: 992px){
  header.header button.burger{ display: none; }
}

header.header .burger__line{ position: relative; display:block; width: 22px; height: 2px; background-color: var(--burger-color); border-radius: 999px; transition: transform .2s ease-in-out, background-color .2s ease-in-out; }
header.header .burger__line::before,
header.header .burger__line::after{
  content: "";
  position: absolute;
  left: 0;
  width: 22px;
  height: 2px;
  background-color: var(--burger-color);
  border-radius: 999px;
  transition: transform .2s ease-in-out, background-color .2s ease-in-out;
}
header.header .burger__line::before{ transform: translateY(-7px); }
header.header .burger__line::after{ transform: translateY(7px); }

header.header button.burger:hover .burger__line,
header.header button.burger:hover .burger__line::before,
header.header button.burger:hover .burger__line::after{
  background-color: var(--l21x-burger-hover-color);
}

header.header button.burger[aria-expanded="true"] .burger__line{ background-color: transparent; }
header.header button.burger[aria-expanded="true"] .burger__line::before{ transform: rotate(45deg); }
header.header button.burger[aria-expanded="true"] .burger__line::after{ transform: rotate(-45deg); }

/* ===================== Mobile header layout (exact logic from L21) ===================== */
@media (max-width: 992px){
    header.header .header__container{
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 12px !important;
  }

  header.header .header__container > a.logo{
    order: 1 !important;
    flex: 0 0 auto !important;
  }

  header.header .header__container > button.burger{
    order: 2 !important;
    flex: 0 0 auto !important;
    margin-left: auto !important;
  }

  header.header .header__container > nav.navigation{
    display: none !important;
  }

  header.header .header__container > ul.header__right{
    order: 3 !important;
    width: 100% !important;
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    gap: 12px !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  header.header .header__container > ul.header__right > li.header__rightItem{
    flex: 1 1 0 !important;
    width: auto !important;
  }

  header.header .header__container > ul.header__right > li.header__rightItem > a.button{
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
  }

  header.header{ height: auto !important; overflow: visible !important; padding-bottom: 8px !important; }

  header.header .logo__img{
    max-height: 2.2rem !important;
    max-width: 10.5rem !important;
  }
}

@media (max-width: 360px){
  header.header .header__container > ul.header__right{ flex-direction: column !important; }
}

/* ===================== Mobile menu ===================== */
dialog.mobile-menu{
  position: fixed;
  top: var(--l21x-header-height);
  left: 0;
  right: 0;
  width: 100%;
  margin: 0;
  padding: 0;
  border: 0;
  background: var(--l21x-mobile-menu-bg);
  z-index: 999;
  display: none;
  height: calc(100vh - var(--l21x-header-height));
  overflow: hidden;
}
dialog.mobile-menu[open]{ display: flex; }

dialog.mobile-menu .mobile-menu__wrapper{
  width: 100%;
  height: 100%;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: transparent;
}

dialog.mobile-menu .mobile-menu__menuContainer{
  margin-top: 1.5rem;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

/* Mobile submenu */
dialog.mobile-menu .mobile-menu__menu{ align-items: stretch; }
dialog.mobile-menu .mobile-menu__item{ width: 100%; }
dialog.mobile-menu .mobile-menu__row{
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
}
dialog.mobile-menu .mobile-menu__row .mobile-menu__link{
  flex: 1 1 auto;
  justify-content: flex-start;
}
dialog.mobile-menu .mobile-menu__toggle{
  -webkit-appearance:none;
  appearance:none;
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,0.18);
  background: rgba(255,255,255,0.12);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex: 0 0 44px;
}
dialog.mobile-menu .mobile-menu__toggle::before{
  content:"";
  width: 10px;
  height: 10px;
  border-right: 2px solid var(--l21x-mobile-link, var(--navigation-link));
  border-bottom: 2px solid var(--l21x-mobile-link, var(--navigation-link));
  transform: rotate(45deg);
  transition: transform .15s ease, border-color .15s ease;
}
dialog.mobile-menu .mobile-menu__item.is-open > .mobile-menu__row .mobile-menu__toggle::before{
  transform: rotate(-135deg);
}
dialog.mobile-menu .mobile-menu__toggle:hover::before{
  border-color: var(--l21x-mobile-link-hover, var(--navigation-link-hover));
}

dialog.mobile-menu .mobile-menu__sublist{
  overflow: hidden;
  max-height: 0;
  transition: max-height .25s ease;
  width: 100%;
  margin: 8px 0 0;
  padding: 10px;
  list-style: none;
  background: var(--l21x-submenu-bg, rgba(255,255,255,0.18));
  border-radius: 16px;
}
dialog.mobile-menu .mobile-menu__item.is-open > .mobile-menu__sublist{
  /* max-height is set inline by JS to the scrollHeight */
}
dialog.mobile-menu .mobile-menu__sublist .mobile-menu__link{
  justify-content: center;
  color: var(--l21x-submenu-link, var(--navigation-link));
}
dialog.mobile-menu .mobile-menu__sublist .mobile-menu__link:hover,
dialog.mobile-menu .mobile-menu__sublist .mobile-menu__link:focus{
  color: var(--l21x-submenu-link-hover, var(--navigation-link-hover));
}
/* 2nd level dropdown (flyout to the right, like Mercury) */
header.header .navigation__sublist .navigation__item--has-children{ padding-right: 26px; }
header.header .navigation__sublist .navigation__sublist{
  top: 0;
  left: calc(100% + 12px);
}
header.header .navigation__sublist .navigation__item--has-children:hover > .navigation__sublist,
header.header .navigation__sublist .navigation__item--has-children:focus-within > .navigation__sublist{
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}


dialog.mobile-menu .mobile-menu__menu{
  margin: 0;
  padding: 1.5rem;
  list-style: none;
  background: var(--l21x-mobile-menu-list-bg);
  border-radius: 1.5rem;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  gap: 0.75rem;
}

dialog.mobile-menu .mobile-menu__link{
  display: flex;
  align-items: center;
  min-height: 44px;
  padding: 12px 14px;
  border-radius: 14px;
  font-weight: 700;
  text-decoration: none;
  text-transform: uppercase;
  color: var(--l21x-mobile-link, var(--navigation-link));
  outline: 0;
  white-space: nowrap;
  width: 100%;
  justify-content: flex-start;
}

dialog.mobile-menu .mobile-menu__link:hover,
dialog.mobile-menu .mobile-menu__link:focus{
  color: var(--l21x-mobile-link-hover, var(--navigation-link-hover));
  background: var(--l21x-mobile-item-hover-bg, transparent);
}

/* Hide mobile menu on desktop */
@media (min-width: 992px){
  dialog.mobile-menu{ display: none !important; }
}

/* =========================================================
   L21X - Mercury-like dropdown + mobile accordion submenus
   (namespaced to .header / .mobile-menu to avoid conflicts)
   ========================================================= */

/* Desktop caret */
header.header .navigation__item--has-children{
  padding-right: 26px; /* room for caret */
}
header.header .navigation__toggle{
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  color: var(--l21x-mobile-link, var(--navigation-link));
}
header.header .navigation__toggle::before{
  content: "";
  display: block;
  width: 7px;
  height: 7px;
  margin: 0 auto;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  opacity: 0.9;
  transition: transform .2s ease, opacity .2s ease;
}
header.header .navigation__item--has-children:hover > .navigation__toggle,
header.header .navigation__item--has-children:focus-within > .navigation__toggle{
  color: var(--l21x-mobile-link-hover, var(--navigation-link-hover));
}
header.header .navigation__item--has-children.is-open > .navigation__toggle{
  color: var(--l21x-mobile-link-hover, var(--navigation-link-hover));
}
header.header .navigation__item--has-children.is-open > .navigation__toggle::before{
  transform: rotate(-135deg);
}

/* Desktop dropdown like Mercury (fade + slide) */
header.header .navigation__sublist{
  position: absolute;
  left: 0;
  top: calc(100% + 16px);
  min-width: 240px;
  margin: 0;
  padding: 12px;
  list-style: none;
  background: var(--l21x-submenu-bg, #ffffff);
  border-radius: 16px;
  box-shadow: 0 14px 40px rgba(0,0,0,0.18);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: opacity .2s ease, transform .2s ease, visibility .2s ease;
  z-index: 9999;
}
header.header .navigation__item--has-children:hover > .navigation__sublist,
header.header .navigation__item--has-children:focus-within > .navigation__sublist,
header.header .navigation__item--has-children.is-open > .navigation__sublist{
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
header.header .navigation__sublist .navigation__item{
  position: relative;
  padding: 0;
  margin: 0;
}
header.header .navigation__sublist .navigation__link{
  display: block;
  width: 100%;
  padding: 10px 12px;
  border-radius: 12px;
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--l21x-submenu-link, var(--navigation-link));
  text-decoration: none;
  white-space: normal;
}
header.header .navigation__sublist .navigation__link:hover,
header.header .navigation__sublist .navigation__link:focus{
  color: var(--l21x-submenu-link-hover, var(--navigation-link-hover));
}

/* Mobile menu layout (Mercury-like, no centering) */
dialog.mobile-menu .mobile-menu__menu{
  align-items: stretch !important;
  justify-content: flex-start !important;
  gap: 0 !important;
  padding: 18px !important;
}
dialog.mobile-menu .mobile-menu__item{
  width: 100%;
}
dialog.mobile-menu .mobile-menu__row{
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
dialog.mobile-menu .mobile-menu__link{
  flex: 1 1 auto;
  justify-content: flex-start !important;
  text-align: left !important;
  padding: 12px 8px !important;
}

/* Mobile caret button (click on arrow only) */
dialog.mobile-menu .mobile-menu__toggle{
  width: 44px;
  height: 44px;
  border: 0;
  background: transparent;
  cursor: pointer;
  flex: 0 0 auto;
  color: var(--l21x-mobile-link, var(--navigation-link));
}
dialog.mobile-menu .mobile-menu__toggle::before{
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  margin: 0 auto;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  transition: transform .2s ease, opacity .2s ease;
  opacity: .9;
}
dialog.mobile-menu .mobile-menu__item.is-open > .mobile-menu__row .mobile-menu__toggle::before{
  transform: rotate(-135deg);
}

/* Mobile accordion submenu (pushes items down, no overlap) */
dialog.mobile-menu .mobile-menu__sublist{
  width: 100%;
  margin: 0;
  list-style: none;
  padding: 0 0 8px 16px;
  overflow: hidden;
  max-height: 0;
  transition: max-height .25s ease;
}
dialog.mobile-menu .mobile-menu__item.is-open > .mobile-menu__sublist{
  /* max-height is set inline via JS for smooth slide */
}
dialog.mobile-menu .mobile-menu__sublist .mobile-menu__link{
  padding: 10px 8px !important;
  border-radius: 12px;
  color: var(--l21x-submenu-link, var(--navigation-link));
}
dialog.mobile-menu .mobile-menu__sublist .mobile-menu__link:hover,
dialog.mobile-menu .mobile-menu__sublist .mobile-menu__link:focus{
  color: var(--l21x-submenu-link-hover, var(--navigation-link-hover));
}

header.header{ z-index: 9999 !important; }
dialog.mobile-menu{ z-index: 9998 !important; }



/* ===================== FINAL MOBILE LAYOUT FIX ===================== */
@media (max-width: 992px) {
  /* 1. Container: allow wrap so buttons can move to second row */
  header.header .header__container {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    padding: 5px 0 !important;
  }

  /* 2. Logo - left */
  header.header .header__container > a.logo {
    order: 1 !important;
    flex: 0 1 auto !important;
    margin-right: auto !important;
    max-width: calc(100% - 70px) !important;
  }

  /* 3. Burger - right */
  header.header .header__container > button.burger {
    order: 2 !important;
    flex: 0 0 auto !important;
    margin-left: 0 !important;
  }

  /* 4. Buttons row - full width on new line */
  header.header .header__container > ul.header__right {
    order: 3 !important;
    flex: 1 0 100% !important; /* force wrap */
    width: 100% !important;
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    gap: 12px !important;
    margin: 15px 0 5px 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  /* 5. Each button item shares space */
  header.header .header__container > ul.header__right > li.header__rightItem {
    flex: 1 1 0 !important;
    max-width: 180px !important;
  }

  header.header .header__container > ul.header__right > li.header__rightItem > a.button {
    width: 100% !important;
    min-height: 40px !important;
    padding: 8px 12px !important;
    font-size: 14px !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
  }

  /* 6. Header sticky */
  header.header {
    height: auto !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
  }

  /* Hide desktop nav on mobile */
  header.header .header__container > nav.navigation {
    display: none !important;
  }
}
