/* frontend.css */
/* =========================================
   AWX Clone Translate – Language Switcher
   ========================================= */

/* -----------------------------------------
   Base: Menu Item (Desktop & Mobile)
   ----------------------------------------- */

.menu-item-awx-lang {
  display: flex;
  align-items: center;
  position: relative;
}

.menu-item-awx-lang .awx-plg-ct-switcher {
  display: inline-flex;
  align-items: center;
  position: relative;
  z-index: 10;
}

/* Unified button design (light pill-style) */
.menu-item-awx-lang .awx-plg-ct-btn,
#awx-plg-ct-switcher-root .awx-plg-ct-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  line-height: 1;
  cursor: pointer;

  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.96);
  color: inherit;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);

  font-size: 0.95rem;
  -webkit-tap-highlight-color: transparent;
}

/* Hover/Focus: slightly stronger shadow */
.menu-item-awx-lang .awx-plg-ct-btn:hover,
.menu-item-awx-lang .awx-plg-ct-btn:focus-visible,
#awx-plg-ct-switcher-root .awx-plg-ct-btn:hover,
#awx-plg-ct-switcher-root .awx-plg-ct-btn:focus-visible {
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.12);
}

/* Dropdown menu (light unified look) */
.menu-item-awx-lang .awx-plg-ct-menu,
#awx-plg-ct-switcher-root .awx-plg-ct-menu {
  position: absolute;
  top: calc(100% + 6px);
  min-width: 72px;
  list-style: none;
  margin: 0;
  padding: 8px;

  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 16px;
  background: #ffffff;
  color: inherit;
  display: none;
  z-index: 9999;
}

/* Show dropdown when parent has .open */
.menu-item-awx-lang .awx-plg-ct-switcher.open .awx-plg-ct-menu,
#awx-plg-ct-switcher-root .awx-plg-ct-switcher.open .awx-plg-ct-menu {
  display: block;
}

/* Alignment inside header menu: align right */
.menu-item-awx-lang .awx-plg-ct-menu {
  right: 0;
  left: auto;
}

/* Floating switcher default: align left */
#awx-plg-ct-switcher-root .awx-plg-ct-menu {
  left: 0;
  right: auto;
}

/* Floating switcher when aligned right */
#awx-plg-ct-switcher-root.awx-plg-ct-pos-right .awx-plg-ct-menu {
  left: auto;
  right: 0;
}

/* Dropdown menu items (shared) */
.menu-item-awx-lang .awx-plg-ct-item,
#awx-plg-ct-switcher-root .awx-plg-ct-item {
  display: block;
  padding: 6px 10px;
  text-decoration: none;
  color: inherit;
  border-radius: 8px;

  font-size: 0.95rem;
  font-weight: 400;
}

.menu-item-awx-lang .awx-plg-ct-item:hover,
.menu-item-awx-lang .awx-plg-ct-item:focus-visible,
#awx-plg-ct-switcher-root .awx-plg-ct-item:hover,
#awx-plg-ct-switcher-root .awx-plg-ct-item:focus-visible {
  background: rgba(0, 0, 0, 0.05);
  outline: none;
}

.menu-item-awx-lang .awx-plg-ct-item.is-active,
#awx-plg-ct-switcher-root .awx-plg-ct-item.is-active {
  font-weight: 600;
}

/* Caret arrow */
.awx-plg-ct-caret {
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 6px solid currentColor;
  transition: transform 0.2s ease;
  transform-origin: 50% 40%;
  opacity: 0.9;
}

.awx-plg-ct-switcher.open .awx-plg-ct-caret {
  transform: rotate(180deg);
}

/* Remove default browser focus outlines;
   accessibility relies on :focus-visible styling */
.awx-plg-ct-btn:focus,
.awx-plg-ct-btn:active {
  outline: none !important;
  box-shadow: none !important;
}

/* --- AWX Clone Translate – Label / Flag --- */
.awx-plg-ct-item {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  white-space: nowrap;
}

.awx-plg-ct-item.is-active {
  outline: none;
}

.awx-plg-ct-item:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}

.awx-plg-ct-flag {
  display: inline-block;
  border-radius: 2px;
  vertical-align: middle;
}

.awx-plg-ct-flag-emoji {
  font-size: 1.05em;
  line-height: 1;
}

.awx-plg-ct-label {
  line-height: 1;
}

.awx-plg-ct-select {
  min-width: 220px;
}

.awx-plg-ct-form {
  margin: 16px 0;
}

/* Flag icon tweaks (flag-icons or SVG flags) */
.awx-plg-ct-lang-switcher .awx-plg-ct-flag,
.awx-plg-ct-switcher .awx-plg-ct-flag {
  display: inline-block;
  vertical-align: middle;
  margin-right: 0.375rem;
}

.awx-plg-ct-lang-switcher .fi.awx-plg-ct-flag,
.awx-plg-ct-switcher .fi.awx-plg-ct-flag {
  width: 1.15em;
  height: 0.85em;
  border-radius: 2px;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.06) inset;
}

.awx-plg-ct-menu .fi.awx-plg-ct-flag {
  margin-right: 0.5rem;
}

.awx-plg-ct-btn .fi.awx-plg-ct-flag + .awx-plg-ct-caret {
  margin-left: 0.25rem;
}

/* -----------------------------------------
   Mobile Tweaks (≤ 992px)
   ----------------------------------------- */
@media (max-width: 992px) {
  :root {
    --awx-gap-right: 0px; /* Distance to hamburger column */
  }

  /* Shared container (hamburger + switcher) without gaps */
  .navbar-collapse.collapse.d-flex.flex-row-reverse {
    justify-content: flex-end !important;
    gap: 0 !important;
    padding: 0 !important;
  }

  /* Prevent .navbar-brand block from expanding */
  .navbar-collapse.collapse.d-flex.flex-row-reverse > .navbar-brand {
    flex: 0 0 auto !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
  }

  /* Shrinkable #menu-primary inside header */
  .navbar-collapse.collapse.d-flex.flex-row-reverse
    > .navbar-brand
    > #menu-primary {
    width: auto !important;
    flex: 0 0 auto !important;
    display: flex !important;
    align-items: center !important;
    margin: 0 !important;
    padding: 0 !important;
    gap: 0 !important;
  }

  #menu-primary.navbar-nav.nav-fill,
  #menu-primary.navbar-nav.nav-justified {
    flex: 0 0 auto !important;
  }

  /* Remove stretch on LI items */
  #menu-primary.navbar-nav > li {
    flex: 0 0 auto !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* Language switcher aligned to the right */
  #menu-primary.navbar-nav > li.menu-item-awx-lang {
    margin-left: auto !important;
    margin-right: var(--awx-gap-right) !important;
    padding-right: 0 !important;
  }

  /* Compact button */
  #menu-primary.navbar-nav > li.menu-item-awx-lang .awx-plg-ct-btn {
    height: 32px !important;
    padding: 0 12px !important;
    line-height: 1 !important;
    border-radius: 999px !important;
    margin-top: 0 !important;
  }

  /* Compact dropdown */
  #menu-primary .awx-plg-ct-menu {
    min-width: auto !important;
    width: auto !important;
    padding: 4px 8px !important;
  }

  #menu-primary .awx-plg-ct-item {
    font-size: inherit !important;
    font-weight: normal !important;
    padding: 6px 8px !important;
    line-height: 1.4 !important;
  }

  #menu-primary .awx-plg-ct-item.is-active {
    font-weight: 600 !important;
  }

  /* Hamburger safety: no left margin */
  .navbar-collapse.collapse.d-flex.flex-row-reverse
    > .navbar-icons
    .navbar-hamburger,
  .navbar-toggler {
    margin-left: 0 !important;
  }

  /* Ensure button border visibility on mobile */
  .menu-item-awx-lang .awx-plg-ct-btn {
    border-width: 1px !important;
  }
}

/* -----------------------------------------
   Remove fine lines / separators added by theme
   ----------------------------------------- */
#menu-primary .menu-item-awx-lang,
#menu-primary .menu-item-awx-lang > a,
#menu-primary .menu-item-awx-lang > .nav-link,
#menu-primary .menu-item-awx-lang > .awx-plg-ct-switcher,
#menu-primary .menu-item-awx-lang > .awx-plg-ct-switcher > .awx-plg-ct-btn {
  border: 0 !important;
  border-bottom: 0 !important;
  box-shadow: none !important;
  background-image: none !important;
}

/* Remove theme pseudo-separators */
#menu-primary .menu-item-awx-lang::before,
#menu-primary .menu-item-awx-lang::after,
#menu-primary .menu-item-awx-lang > a::before,
#menu-primary .menu-item-awx-lang > a::after,
#menu-primary .menu-item-awx-lang > .nav-link::before,
#menu-primary .menu-item-awx-lang > .nav-link::after,
#menu-primary .menu-item-awx-lang > .awx-plg-ct-switcher::before,
#menu-primary .menu-item-awx-lang > .awx-plg-ct-switcher::after,
#menu-primary
  .menu-item-awx-lang
  > .awx-plg-ct-switcher
  > .awx-plg-ct-btn::before,
#menu-primary
  .menu-item-awx-lang
  > .awx-plg-ct-switcher
  > .awx-plg-ct-btn::after {
  content: none !important;
  border: 0 !important;
  box-shadow: none !important;
  background: none !important;
}

/* Remove mobile separators if theme applies them globally */
.navbar-nav > li.menu-item-awx-lang,
.navbar-nav > li.menu-item-awx-lang > a {
  border-bottom: 0 !important;
}

/* Additional safety for the button itself */
.menu-item-awx-lang .awx-plg-ct-btn {
  outline: none !important;
  background-clip: padding-box;
}

/* =========================================
   Fallback: Stand-alone Switcher Root
   ========================================= */

#awx-plg-ct-switcher-root {
  position: fixed;
  top: 8px;
  left: 8px;
  z-index: 9999;
}

/* If WP admin bar is visible, move switcher down */
body.admin-bar #awx-plg-ct-switcher-root {
  top: 50px;
}

/* On smaller screens the admin bar is taller */
@media (max-width: 782px) {
  body.admin-bar #awx-plg-ct-switcher-root {
    top: 50px;
  }
}

/* Floating right instead of left */
#awx-plg-ct-switcher-root.awx-plg-ct-pos-right {
  right: 8px;
  left: auto;
}

/* Remove focus outlines on dropdown containers */
.menu-item-awx-lang .awx-plg-ct-menu:focus,
.menu-item-awx-lang .awx-plg-ct-menu:focus-visible,
#awx-plg-ct-switcher-root .awx-plg-ct-menu:focus,
#awx-plg-ct-switcher-root .awx-plg-ct-menu:focus-visible {
  outline: none !important;
}

/* -----------------------------------------
   UI tweaks (menu-end consistency)
   Added during 2.0.6 testing – keep minimal
   ----------------------------------------- */

/* Align flags in a single vertical column inside the dropdown */
.awx-plg-ct-menu .awx-plg-ct-flag {
  width: 20px;
  min-width: 20px;
  text-align: center;
}

/* Dropdown: slightly lower + a bit more spacing between items + tiny inner right shift */
.awx-plg-ct-menu {
  top: calc(100% + 10px);
  padding-left: calc(8px + 3px) !important;

  display: flex;
  flex-direction: column;
  gap: 2px;
}

/* Slightly taller click area per item (keeps hover look) */
.awx-plg-ct-menu .awx-plg-ct-item {
  padding: 4px 10px;
}

/* Menu-end: button should not look floating (dropdown keeps shadow) */
.menu-item-awx-lang .awx-plg-ct-btn {
  box-shadow: none !important;
}

/* Prevent theme menu link styles (e.g. underline) from affecting dropdown items */
.awx-plg-ct-menu .awx-plg-ct-item {
  text-decoration: none !important;
  color: inherit;
}

/* Make menu-end dropdown identical to floating (typography inherits from plugin) */
.menu-item-awx-lang .awx-plg-ct-menu {
  font-size: inherit;
  line-height: normal;
}

