.site-nav {
  position: relative;
  max-width: 100%;
  z-index: 1000;
}

.menu-toggle {
  display:none;
  width:44px;
  height:40px;
  border:1px solid rgba(255,255,255,.35);
  background:rgba(255,255,255,.08);
  border-radius:10px;
  padding:8px;
}
.menu-toggle span {
  display:block;
  height:2px;
  background:#fff;
  margin:5px 0;
  border-radius:2px;
}

.menu-panel {
  display:flex;
  align-items:center;
  max-width:100%;
}

.site-menu-list,
.site-submenu {
  list-style:none;
  padding:0;
  margin:0;
}

.site-menu-list {
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:4px;
  flex-wrap:wrap;
}

.site-menu-list > li { position:relative; }

.site-menu-list a {
  display:flex;
  align-items:center;
  gap:6px;
  color:#fff;
  text-decoration:none;
  padding:9px 10px;
  border-radius:10px;
  font-weight:600;
  font-size:16px;
  line-height:1.2;
  white-space:nowrap;
}
.site-menu-list a:hover { background:rgba(255,255,255,.14); }
.menu-caret { font-size:12px; opacity:.85; }

.site-submenu {
  position:absolute;
  top:100%;
  left:0;
  min-width:220px;
  background:#fff;
  border-radius:12px;
  padding:8px;
  box-shadow:0 16px 40px rgba(0,0,0,.18);
  display:none;
  z-index:1200;
}
.site-submenu li { position:relative; }
.site-submenu a {
  color:#1d2939;
  padding:10px 12px;
  border-radius:8px;
  justify-content:space-between;
}
.site-submenu a:hover { background:#f2f4f7; }
.site-menu-list li:hover > .site-submenu { display:block; }
.site-submenu .site-submenu {
  top:0;
  left:100%;
  margin-left:8px;
}

.client-logout-btn{
  font-weight:700;
  white-space:nowrap;
}

@media (max-width: 991px) {
  .site-nav {
    position: relative;
    z-index: 3000;
    margin-left:0 !important;
    flex:0 0 auto !important;
  }

  .menu-toggle {
    display:block !important;
    width:44px;
    height:44px;
    flex:0 0 44px !important;
  }

  .menu-panel {
    display:none;
    position:absolute;
    top:calc(100% + 12px);
    right:0 !important;
    left:auto !important;
    width:min(72vw, 280px);
    max-width:calc(100vw - 24px);
    background:#fff;
    border-radius:18px;
    padding:12px;
    box-shadow:0 18px 48px rgba(0,0,0,.24);
    z-index:3000;
    overflow:hidden;
  }

  .site-nav.is-open .menu-panel { display:block; }

  .site-menu-list {
    display:block;
    margin:0;
    padding:0;
  }

  .site-menu-list a {
    color:#1d2939;
    padding:12px 14px;
    justify-content:space-between;
    white-space:normal;
    font-size:16px;
  }

  .site-submenu {
    position:static;
    min-width:0;
    box-shadow:none;
    border-radius:10px;
    padding:4px 0 4px 14px;
    margin:0 0 4px 0;
    display:none;
    background:#f8fafc;
  }

  .site-menu-list li.open > .site-submenu { display:block; }
  .site-menu-list li:hover > .site-submenu { display:none; }
  .site-menu-list li.open:hover > .site-submenu { display:block; }

  /* Compatibilidad con otros headers del sitio */
  .site-header-row,
  .topbar .d-flex.justify-content-between { flex-wrap:nowrap !important; }

  .header-tools,
  .topbar .d-flex.align-items-center.gap-3.ms-auto {
    margin-left:auto !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-end !important;
    gap:8px !important;
    flex:0 0 auto !important;
  }

  .site-logo-link,
  .topbar a.text-decoration-none {
    flex:1 1 auto !important;
    min-width:0 !important;
  }

  .logo-img,
  .main-logo {
    max-width:clamp(165px, 52vw, 230px) !important;
    width:auto !important;
    height:auto !important;
  }

  .site-nav { order:3 !important; }
  .lang-dropdown,
  .dropdown:has(.lang-btn) { order:2 !important; }
}

@media (max-width:575px){
  .lang-dropdown .btn span:last-child,
  .lang-btn { font-size:0 !important; }

  .lang-dropdown .btn img,
  .lang-btn .flag-dot { font-size:initial !important; }
}
