/**
    Applies all the outline properties useful to show a dashed-focus ring around a component.
    TODO: replace `$border-radius: 0.1rem` with semantic border-radius but keep in mind some components that must stay at 2px border-radius: checkbox, radio, links, ...
 */
/**
    Applies all the outline properties useful to show a dashed-focus ring around a component.
    TODO: replace `$border-radius: 0.1rem` with semantic border-radius but keep in mind some components that must stay at 2px border-radius: checkbox, radio, links, ...
 */
:host {
  --wcs-com-nav-menu-bar-height: calc(var(--wcs-semantic-size-base) * 8);
  --wcs-com-nav-border-color: var(--wcs-semantic-color-border-secondary);
  --wcs-com-nav-border-width: var(--wcs-semantic-border-width-default);
  --wcs-com-nav-background-color: var(--wcs-semantic-color-background-surface-primary);
  --wcs-com-nav-app-name-color: var(--wcs-semantic-color-text-primary);
  --wcs-com-nav-app-name-font-weight: var(--wcs-semantic-font-weight-heavy);
  --wcs-com-nav-app-name-font-size: var(--wcs-semantic-font-size-heading-5);
  --wcs-com-nav-app-name-line-height: var(--wcs-semantic-font-line-height-large);
  --wcs-com-nav-item-color: var(--wcs-semantic-color-foreground-action-neutral-default);
  --wcs-com-nav-item-font-weight: var(--wcs-semantic-font-weight-medium);
  --wcs-com-nav-focus-outline-color: var(--wcs-semantic-color-border-focus-base);
  --wcs-com-nav-vertical-padding: 0;
  --wcs-com-nav-horizontal-padding: var(--wcs-semantic-spacing-large);
  --wcs-com-nav-mobile-overlay-gap: var(--wcs-semantic-spacing-large);
  --wcs-com-nav-mobile-overlay-padding: var(--wcs-semantic-spacing-large);
  --wcs-com-nav-mobile-menu-icon-border-color: var(--wcs-semantic-color-border-secondary);
  --wcs-com-nav-mobile-menu-icon-gap: calc(var(--wcs-semantic-spacing-base) * 2);
  --wcs-com-nav-mobile-menu-icon-margin-left: var(--wcs-semantic-spacing-base);
  --wcs-com-nav-mobile-menu-icon-color: var(--wcs-semantic-color-foreground-action-secondary-default);
  --wcs-com-nav-menu-bar-gap: calc(var(--wcs-semantic-spacing-base) * 5);
  --wcs-com-nav-menu-bar-margin-left: calc(var(--wcs-semantic-spacing-base) * 6.25);
  display: block;
  position: relative;
  height: var(--wcs-com-nav-menu-bar-height);
  border-bottom: var(--wcs-com-nav-border-width) solid var(--wcs-com-nav-border-color);
}
:host .container {
  padding: var(--wcs-com-nav-vertical-padding) var(--wcs-com-nav-horizontal-padding);
  height: 100%;
  display: flex;
  align-items: center;
  flex-direction: row;
  justify-content: space-between;
}
:host .container nav {
  display: flex;
  align-items: center;
}
:host .container-left {
  display: flex;
  height: 100%;
  align-items: center;
  flex-direction: row;
}
:host .container-right {
  display: flex;
  align-items: center;
}
:host .app-name {
  font-weight: var(--wcs-com-nav-app-name-font-weight);
  font-size: var(--wcs-com-nav-app-name-font-size);
  line-height: var(--wcs-com-nav-app-name-line-height);
  color: var(--wcs-com-nav-app-name-color);
}
:host .app-name ::slotted(a) {
  user-select: none;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
  font-weight: inherit;
}
:host .app-name ::slotted(a:focus-visible) {
  outline: none;
}
:host .app-name:focus-within {
  outline: var(--wcs-semantic-border-width-large) dashed var(--wcs-com-nav-focus-outline-color);
  outline-offset: var(--wcs-semantic-spacing-small);
  border-radius: 0.1rem;
}
:host .menu-bar {
  display: none;
}
:host #mobile-menu-icon {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  color: var(--wcs-com-nav-mobile-menu-icon-color);
  padding-left: var(--wcs-com-nav-mobile-menu-icon-gap);
  margin-left: var(--wcs-com-nav-mobile-menu-icon-margin-left);
  border-left: solid 1px var(--wcs-com-nav-mobile-menu-icon-border-color);
}
:host #mobile-menu-icon:focus {
  outline: none;
}
:host #mobile-menu-icon:focus-visible::after {
  outline: var(--wcs-semantic-border-width-large) dashed var(--wcs-com-nav-focus-outline-color);
  outline-offset: var(--wcs-semantic-spacing-small);
  border-radius: 0.1rem;
}
@supports not selector(#mobile-menu-icon:focus-visible::after) {
  :host #mobile-menu-icon:focus::after {
    outline: var(--wcs-semantic-border-width-large) dashed var(--wcs-com-nav-focus-outline-color);
    outline-offset: var(--wcs-semantic-spacing-small);
    border-radius: 0.1rem;
  }
}
:host button {
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
}
:host #mobile-menu-icon:after {
  font-family: icons;
  font-size: 18px;
  cursor: pointer;
  content: "\f198";
  line-height: 1;
  box-sizing: border-box;
}
:host #mobile-menu-icon[aria-expanded=true]:after {
  content: "\f129";
}
:host .mobile-overlay {
  display: none;
}
:host .mobile-overlay[data-mobile-open] {
  padding: var(--wcs-com-nav-mobile-overlay-padding);
  position: absolute;
  top: var(--wcs-com-nav-menu-bar-height);
  left: 0;
  right: 0;
  display: flex;
  flex-direction: column;
  gap: var(--wcs-com-nav-mobile-overlay-gap);
  z-index: 9999;
  background-color: var(--wcs-com-nav-background-color);
}
:host .mobile-overlay[data-mobile-open] ::slotted(wcs-com-nav-item) {
  color: var(--wcs-com-nav-item-color);
  font-weight: var(--wcs-com-nav-item-font-weight);
}

@media (min-width: 576px) {
  :host .container {
    margin: 0 auto;
    max-width: var(--wcs-com-content-max-width);
  }
  :host nav {
    height: 100%;
  }
  :host .menu-bar {
    display: flex;
    align-items: center;
    height: 100%;
    margin-left: var(--wcs-com-nav-menu-bar-margin-left);
  }
  :host .menu-bar ::slotted(*:not(:first-child)) {
    margin-left: var(--wcs-com-nav-menu-bar-gap);
  }
  :host .menu-bar ::slotted(wcs-com-nav-item) {
    height: 100%;
    color: var(--wcs-com-nav-item-color);
    font-weight: var(--wcs-com-nav-item-font-weight);
  }
  :host .menu-bar ::slotted(wcs-com-nav-item:focus-within) {
    outline: var(--wcs-semantic-border-width-large) dashed var(--wcs-com-nav-focus-outline-color);
    outline-offset: 0.1rem;
    border-radius: 2px;
  }
  :host #mobile-menu-icon {
    display: none;
  }
  :host .mobile-overlay {
    display: none !important;
  }
}