/* Base */
.ulm {
  --c-text: #2e4a68;
  --c-active-bg: #6a7ba2;
  --c-hover-bg: #ef7f1b;
  --c-mobile-bg: #2e4a68;
  --c-sub-bg: #f7f7f9;

  font-family: "Inter", Sans-serif;
}

/* Toggle (hamburger) */
.ulm__toggle {
  display: none;
  align-items: center;
  gap: 10px;
  width: 100%;
  border: 0;
  padding: 12px 14px;
  background: var(--c-mobile-bg);
  color: #fff;
  cursor: pointer;
}

.ulm__togglelabel { font-size: 16px; font-weight: 500; }

.ulm__toggleicon {
  width: 22px;
  height: 16px;
  position: relative;
  display: inline-block;
}

.ulm__toggleicon::before,
.ulm__toggleicon::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 2px;
  background: #fff;
  border-radius: 2px;
}

.ulm__toggleicon::before { top: 0; }
.ulm__toggleicon::after  { bottom: 0; }

.ulm__toggleicon::before,
.ulm__toggleicon::after { transition: transform .2s ease, top .2s ease, bottom .2s ease; }

.ulm.is-open .ulm__toggleicon::before { transform: rotate(45deg); top: 7px; }
.ulm.is-open .ulm__toggleicon::after  { transform: rotate(-45deg); bottom: 7px; }

/* Panel */
.ulm__panel { width: 100%; }

/* Desktop menu layout */
.ulm__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 0;                 /* no gaps so submenu can touch cleanly */
  align-items: stretch;
}

.ulm__list > li { position: relative; }

/* Links */
.ulm__list a {
  display: flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  color: var(--c-text);
  font-size: 20px;
  font-weight: 400;
  padding: 12px 14px;
  border-radius: 0;        /* no rounding */
  line-height: 1.2;
}

/* Arrow (triangle) for items with submenu - desktop */
.ulm:not(.is-mobile) .menu-item-has-children > a::after {
  content: "";
  margin-left: 10px;
  width: 0;
  height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 7px solid currentColor; /* triangle down */
  opacity: .9;
}

/* Active item */
.ulm__list .current-menu-item > a,
.ulm__list .current_page_item > a,
.ulm__list .current-menu-ancestor > a {
  background: var(--c-active-bg);
  color: #fff;
}

/* Hover */
.ulm__list a:hover {
  background: var(--c-hover-bg);
  color: #fff;
}

/* Submenu (desktop: dropdown on hover/focus-within) */
.ulm__submenu {
  list-style: none;
  margin: 0;               /* remove gap between menu and submenu */
  padding: 8px 0;
  background: var(--c-sub-bg);
  border-radius: 0;        /* no rounding */
  min-width: 220px;
  position: absolute;
  left: 0;
  top: 100%;               /* flush to the bottom edge of parent */
  box-shadow: 0 10px 30px rgba(0,0,0,.10);
  opacity: 0;
  transform: translateY(0);  /* no "floating gap" animation */
  pointer-events: none;
  transition: opacity .18s ease;
  max-height: none !important; /* desktop doesn’t use max-height animation */
  z-index: 9999;
}

.ulm__submenu a {
  font-size: 18px;
  padding: 10px 14px;
  border-radius: 0;        /* no rounding */
  color: var(--c-text);
  background: transparent;
}

.ulm__submenu a:hover { color:#fff; }

.ulm__list > li:hover > .ulm__submenu,
.ulm__list > li:focus-within > .ulm__submenu {
  opacity: 1;
  pointer-events: auto;
}

/* Submenu toggle arrow button (mobile only) */
.ulm__subtoggle {
  display: none; /* desktop hidden */
  border: 0;
  background: transparent;
  cursor: pointer;
  padding: 0 10px 0 0;
  margin-left: -10px;
}

.ulm__chev {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  transition: transform .18s ease;
  color: inherit;
}

/* Mobile mode */
.ulm.is-mobile .ulm__toggle { display: flex; }
.ulm.is-mobile .ulm__list { 
  display: block;
  background: var(--c-mobile-bg);
  padding: 8px;
  border-radius: 0;
}
.ulm.is-mobile .ulm__panel {
  display: none;
}
.ulm.is-mobile.is-open .ulm__panel {
  display: block;
}

.ulm.is-mobile .ulm__list a {
  color: #fff;
  background: transparent;
  border-radius: 0;
}

.ulm.is-mobile .ulm__list a:hover {
  background: var(--c-hover-bg);
  color: #fff;
}

.ulm.is-mobile .ulm__list .current-menu-item > a,
.ulm.is-mobile .ulm__list .current_page_item > a,
.ulm.is-mobile .ulm__list .current-menu-ancestor > a {
  background: var(--c-active-bg);
  color: #fff;
}

/* Mobile submenu collapsible */
.ulm.is-mobile .menu-item-has-children {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
}

/* Arrow on the right for mobile link too (optional) */
.ulm.is-mobile .menu-item-has-children > a::after {
  content: "";
  margin-left: 10px;
  width: 0;
  height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 7px solid currentColor;
  opacity: .9;
}

.ulm.is-mobile .menu-item-has-children > a {
  grid-column: 1 / 2;
}

.ulm.is-mobile .ulm__subtoggle {
  display: inline-flex;
  grid-column: 2 / 3;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  color: #fff;
}

.ulm.is-mobile .menu-item-has-children.is-open > .ulm__subtoggle .ulm__chev {
  transform: rotate(225deg);
}

/* In mobile, submenu is not absolute; it slides open */
.ulm.is-mobile .ulm__submenu {
  position: static;
  grid-column: 1 / 3;
  margin: 0;
  background: rgba(255,255,255,.08);
  box-shadow: none;
  opacity: 1;
  transform: none;
  pointer-events: auto;
  overflow: hidden;
  transition: max-height .22s ease;
  max-height: 0px; /* animated by JS */
  padding: 0;
}

.ulm.is-mobile .ulm__submenu a {
  color: #fff;
  font-size: 18px;
  padding: 10px 12px;
}

.screen-reader-text {
  position:absolute !important;
  height:1px; width:1px;
  overflow:hidden;
  clip: rect(1px, 1px, 1px, 1px);
  white-space:nowrap;
}
