/* ============================================================
   RuniverseHub UI-SYSTEM-1.3 · Navegación unificada
   Referencia visual: Athlete sidebar + hamburger.

   Alcance:
   - Normaliza estilo de Admin, Organizer, Athlete y Team.
   - Mantiene acentos sutiles por rol.
   - No cambia rutas, permisos ni lógica funcional.
   ============================================================ */

:root {
  --rui-nav-font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --rui-nav-display: "Space Grotesk", Inter, ui-sans-serif, system-ui, sans-serif;
  --rui-nav-sidebar-width: 252px;
  --rui-nav-admin-width: 300px;
  --rui-nav-card-radius: 26px;
  --rui-nav-card-radius-mobile: 22px;
  --rui-nav-link-radius: 16px;
  --rui-nav-icon-box: 32px;
  --rui-nav-icon-svg: 17px;
  --rui-nav-link-min-h: 42px;
  --rui-nav-link-pad-y: 7px;
  --rui-nav-link-pad-x: 10px;
  --rui-nav-gap: 14px;
  --rui-nav-link-gap: 10px;
  --rui-nav-kicker-size: 10px;
  --rui-nav-label-size: 13px;
  --rui-nav-desc-size: 11px;
  --rui-nav-muted: #94a3b8;
  --rui-nav-text: #dce7f6;
  --rui-nav-text-strong: #ffffff;
  --rui-nav-bg-a: rgba(9, 18, 32, .88);
  --rui-nav-bg-b: rgba(6, 12, 24, .76);
  --rui-nav-border: rgba(255, 255, 255, .08);
  --rui-nav-shadow: 0 24px 70px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.05);
  --rui-nav-mobile-w: min(360px, 88vw);
  --rui-nav-mobile-z-toggle: 80;
  --rui-nav-mobile-z-backdrop: 88;
  --rui-nav-mobile-z-drawer: 89;

  --rui-nav-admin-a: #60a5fa;
  --rui-nav-admin-b: #a78bfa;
  --rui-nav-organizer-a: #39f6c6;
  --rui-nav-organizer-b: #56bfff;
  --rui-nav-athlete-a: #7dffd7;
  --rui-nav-athlete-b: #72c7ff;
  --rui-nav-team-a: #3b82f6;
  --rui-nav-team-b: #38bdf8;
}

.rh-ath-sidebar,
.rh-team-sidebar,
.rh-ec-organizer-sidebar,
.rh-admin-sidebar-v2,
.rh-ath-mobile-drawer,
.rh-team-mobile-drawer,
.rh-topbar-mobile-panel,
.rh-admin-mobile-toggle {
  font-family: var(--rui-nav-font) !important;
}

.rh-ath-sidebar,
.rh-ath-mobile-drawer,
.rh-ath-mobile-toggle {
  --rui-nav-accent: var(--rui-nav-athlete-a);
  --rui-nav-accent-2: var(--rui-nav-athlete-b);
  --rui-nav-fg: #06131d;
}

.rh-team-sidebar,
.rh-team-mobile-drawer,
.rh-team-mobile-toggle {
  --rui-nav-accent: var(--rui-nav-team-a);
  --rui-nav-accent-2: var(--rui-nav-team-b);
  --rui-nav-fg: #041018;
}

.rh-ec-organizer-sidebar,
.rh-topbar-mobile-panel,
.rh-topbar-menu-btn {
  --rui-nav-accent: var(--rui-nav-organizer-a);
  --rui-nav-accent-2: var(--rui-nav-organizer-b);
  --rui-nav-fg: #05131d;
}

.rh-admin-sidebar-v2,
.rh-admin-mobile-toggle {
  --rui-nav-accent: var(--rui-nav-admin-a);
  --rui-nav-accent-2: var(--rui-nav-admin-b);
  --rui-nav-fg: #07111f;
}

/* ──────────────────────────────────────────────────────────
   Base común para desktop sidebars
   ────────────────────────────────────────────────────────── */
@media (min-width: 1180px) {
  .rh-ath-sidebar,
  .rh-team-sidebar {
    width: var(--rui-nav-sidebar-width) !important;
    gap: var(--rui-nav-gap) !important;
  }
}

.rh-ath-sidebar-card,
.rh-team-sidebar-card,
.rh-ec-sidebar-section,
.rh-admin-side-brand,
.rh-admin-side-current,
.rh-admin-side-session,
.rh-admin-menu-group {
  border-radius: var(--rui-nav-card-radius) !important;
  border-color: rgba(255,255,255,.085) !important;
  background: linear-gradient(145deg, var(--rui-nav-bg-a), var(--rui-nav-bg-b)) !important;
  box-shadow: var(--rui-nav-shadow) !important;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.rh-ath-sidebar-card,
.rh-team-sidebar-card,
.rh-ec-sidebar-section {
  padding: 16px !important;
}

.rh-ath-sidebar-card.is-soft,
.rh-team-sidebar-card.is-soft {
  background: linear-gradient(145deg, color-mix(in srgb, var(--rui-nav-accent) 10%, transparent), color-mix(in srgb, var(--rui-nav-accent-2) 7%, transparent)) !important;
}

.rh-ath-sidebar-kicker,
.rh-team-sidebar-kicker,
.rh-ec-sidebar-kicker,
.rh-admin-side-current span,
.rh-admin-side-session span {
  color: var(--rui-nav-accent) !important;
  font-size: var(--rui-nav-kicker-size) !important;
  font-weight: 950 !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
}

.rh-ath-sidebar-nav,
.rh-team-sidebar-nav,
.rh-ec-sidebar-nav,
.rh-admin-menu-items {
  display: grid !important;
  gap: 7px !important;
}

.rh-ath-sidebar-link,
.rh-team-sidebar-link,
.rh-ec-sidebar-link,
.rh-admin-menu-link {
  display: grid !important;
  grid-template-columns: var(--rui-nav-icon-box) minmax(0,1fr) auto !important;
  align-items: center !important;
  gap: var(--rui-nav-link-gap) !important;
  min-height: var(--rui-nav-link-min-h) !important;
  padding: var(--rui-nav-link-pad-y) var(--rui-nav-link-pad-x) !important;
  border-radius: var(--rui-nav-link-radius) !important;
  color: var(--rui-nav-text) !important;
  text-decoration: none !important;
  border: 1px solid transparent !important;
  background: transparent !important;
  font-size: var(--rui-nav-label-size) !important;
  font-weight: 850 !important;
  line-height: 1.18 !important;
  transform: none !important;
  transition: transform .18s ease, border-color .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease !important;
}

.rh-ath-sidebar-link:hover,
.rh-team-sidebar-link:hover,
.rh-ec-sidebar-link:hover,
.rh-admin-menu-link:hover {
  transform: translateX(3px) !important;
  background: rgba(255,255,255,.055) !important;
  border-color: color-mix(in srgb, var(--rui-nav-accent) 25%, transparent) !important;
  color: var(--rui-nav-text-strong) !important;
}

.rh-ath-sidebar-link.is-active,
.rh-team-sidebar-link.is-active,
.rh-ec-sidebar-link.is-active,
.rh-admin-menu-link.active {
  background: linear-gradient(135deg, color-mix(in srgb, var(--rui-nav-accent) 18%, transparent), color-mix(in srgb, var(--rui-nav-accent-2) 13%, transparent)) !important;
  border-color: color-mix(in srgb, var(--rui-nav-accent) 36%, transparent) !important;
  box-shadow: 0 12px 34px color-mix(in srgb, var(--rui-nav-accent) 12%, transparent) !important;
  color: #fff !important;
}

.rh-ath-sidebar-icon,
.rh-team-sidebar-icon,
.rh-ec-sidebar-icon,
.rh-admin-menu-icon {
  width: var(--rui-nav-icon-box) !important;
  height: var(--rui-nav-icon-box) !important;
  border-radius: 12px !important;
  display: grid !important;
  place-items: center !important;
  background: rgba(255,255,255,.055) !important;
  border: 1px solid var(--rui-nav-border) !important;
  color: var(--rui-nav-accent) !important;
  flex: 0 0 var(--rui-nav-icon-box) !important;
}

.rh-ath-sidebar-icon svg,
.rh-team-sidebar-icon svg,
.rh-ec-sidebar-icon svg,
.rh-admin-menu-icon svg {
  width: var(--rui-nav-icon-svg) !important;
  height: var(--rui-nav-icon-svg) !important;
  min-width: var(--rui-nav-icon-svg) !important;
  min-height: var(--rui-nav-icon-svg) !important;
  max-width: var(--rui-nav-icon-svg) !important;
  max-height: var(--rui-nav-icon-svg) !important;
  fill: none !important;
  stroke: currentColor !important;
  stroke-width: 1.9 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

.rh-ath-sidebar-link em,
.rh-team-sidebar-link em,
.rh-ec-sidebar-link em {
  margin-left: auto !important;
  font-style: normal !important;
  font-size: 10px !important;
  color: var(--rui-nav-fg) !important;
  background: linear-gradient(135deg, var(--rui-nav-accent), var(--rui-nav-accent-2)) !important;
  border-radius: 999px !important;
  padding: 3px 7px !important;
  font-weight: 950 !important;
  text-transform: uppercase !important;
}

.rh-team-sidebar-identity {
  border-radius: 24px !important;
  border-color: color-mix(in srgb, var(--rui-nav-accent) 22%, transparent) !important;
  background: linear-gradient(145deg, color-mix(in srgb, var(--rui-nav-accent) 12%, transparent), color-mix(in srgb, var(--rui-nav-accent-2) 7%, transparent)) !important;
}

/* ──────────────────────────────────────────────────────────
   Organizer: acercar sidebar desktop al patrón Athlete
   ────────────────────────────────────────────────────────── */
.rh-ec-organizer-sidebar {
  width: 250px;
  gap: var(--rui-nav-gap) !important;
  padding: 0 0 28px !important;
  border-right: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.rh-ec-sidebar-section {
  margin: 0 !important;
}

.rh-ec-sidebar-kicker {
  margin: 0 0 10px !important;
}

.rh-ec-sidebar-link > span:not(.rh-ec-sidebar-icon) {
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

/* ──────────────────────────────────────────────────────────
   Admin: mantener estructura funcional, sumar iconografía y compactar
   ────────────────────────────────────────────────────────── */
.rh-admin-sidebar-v2 {
  --rh-side-green: var(--rui-nav-admin-a);
  --rh-side-teal: var(--rui-nav-admin-b);
}

.rh-admin-side-brand,
.rh-admin-side-current,
.rh-admin-side-session {
  border-radius: 24px !important;
}

.rh-admin-side-logo {
  background: linear-gradient(135deg, var(--rui-nav-accent), var(--rui-nav-accent-2)) !important;
  box-shadow: 0 0 0 1px rgba(255,255,255,.12) inset, 0 16px 34px color-mix(in srgb, var(--rui-nav-accent) 24%, transparent) !important;
}

.rh-admin-side-current {
  border-color: color-mix(in srgb, var(--rui-nav-accent) 24%, transparent) !important;
  background: linear-gradient(135deg, color-mix(in srgb, var(--rui-nav-accent) 13%, transparent), color-mix(in srgb, var(--rui-nav-accent-2) 7%, transparent)) !important;
}

.rh-admin-side-current strong {
  color: #eff6ff !important;
}

.rh-admin-menu-group {
  overflow: hidden !important;
}

.rh-admin-menu-group.active {
  border-color: color-mix(in srgb, var(--rui-nav-accent) 34%, transparent) !important;
  background: linear-gradient(180deg, color-mix(in srgb, var(--rui-nav-accent) 10%, transparent), rgba(255,255,255,.025)) !important;
}

.rh-admin-menu-summary {
  padding: 12px 13px !important;
}

.rh-admin-menu-summary strong {
  font-size: 13px !important;
  font-weight: 900 !important;
}

.rh-admin-menu-summary small,
.rh-admin-menu-link small {
  color: var(--rui-nav-muted) !important;
  font-size: var(--rui-nav-desc-size) !important;
  line-height: 1.35 !important;
}

.rh-admin-menu-link {
  grid-template-columns: var(--rui-nav-icon-box) minmax(0,1fr) !important;
}

.rh-admin-menu-copy {
  min-width: 0 !important;
  display: grid !important;
  gap: 2px !important;
}

.rh-admin-menu-copy > span,
.rh-admin-menu-link > span:not(.rh-admin-menu-icon):not(.rh-admin-menu-copy) {
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.rh-admin-side-session a {
  border-color: color-mix(in srgb, var(--rui-nav-accent) 28%, transparent) !important;
  background: color-mix(in srgb, var(--rui-nav-accent) 11%, transparent) !important;
  color: #eff6ff !important;
}

.rh-admin-mobile-toggle,
.rh-admin-mobile-backdrop {
  display: none;
}

/* ──────────────────────────────────────────────────────────
   Mobile: botones/drawers con patrón Athlete
   ────────────────────────────────────────────────────────── */
.rh-ath-mobile-toggle,
.rh-team-mobile-toggle,
.rh-admin-mobile-toggle,
.rh-topbar-menu-btn {
  min-height: 42px !important;
  border-radius: 999px !important;
  border: 1px solid color-mix(in srgb, var(--rui-nav-accent) 32%, transparent) !important;
  background: linear-gradient(135deg, rgba(9,18,32,.90), rgba(12,33,48,.78)) !important;
  box-shadow: 0 16px 44px rgba(0,0,0,.38), 0 0 0 1px rgba(255,255,255,.04) inset !important;
  color: #ecf8ff !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  letter-spacing: .02em !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
}

.rh-ath-mobile-toggle i,
.rh-team-mobile-toggle i,
.rh-admin-mobile-toggle i {
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: var(--rui-nav-accent) !important;
  box-shadow: 0 0 18px color-mix(in srgb, var(--rui-nav-accent) 70%, transparent) !important;
}

.rh-ath-mobile-mark,
.rh-team-mobile-mark,
.rh-admin-mobile-mark,
.rh-topbar-brand-mark {
  background: linear-gradient(135deg, var(--rui-nav-accent), var(--rui-nav-accent-2)) !important;
  color: var(--rui-nav-fg) !important;
  box-shadow: 0 0 28px color-mix(in srgb, var(--rui-nav-accent) 35%, transparent) !important;
}

@media (max-width: 1199px) {
  .rh-topbar-menu-btn {
    display: inline-flex !important;
    width: auto !important;
    min-width: 42px !important;
    padding: 9px 12px !important;
    gap: 8px !important;
  }

  .rh-topbar-mobile-panel {
    display: flex !important;
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: auto !important;
    width: var(--rui-nav-mobile-w) !important;
    max-width: 88vw !important;
    max-height: none !important;
    z-index: 1200 !important;
    flex-direction: column !important;
    padding: 0 !important;
    overflow-y: auto !important;
    background: linear-gradient(165deg, rgba(6,13,27,.98), rgba(8,26,38,.96)) !important;
    border-left: 1px solid color-mix(in srgb, var(--rui-nav-accent) 24%, transparent) !important;
    box-shadow: -28px 0 90px rgba(0,0,0,.55) !important;
    transform: translateX(104%) !important;
    transition: transform .24s ease !important;
  }

  .rh-topbar-mobile-panel.is-open,
  .rh-topbar-mobile-panel[aria-hidden="false"] {
    transform: translateX(0) !important;
  }

  .rh-topbar-mobile-head {
    padding: 18px 16px 14px !important;
    margin: 0 !important;
    border-bottom: 1px solid rgba(255,255,255,.08) !important;
  }

  .rh-topbar-mobile-head .rh-topbar-brand {
    font-size: 16px !important;
  }

  .rh-topbar-mobile-head .rh-topbar-brand-mark {
    width: 34px !important;
    height: 34px !important;
    flex-basis: 34px !important;
    border-radius: 13px !important;
    font-size: 16px !important;
  }

  .rh-topbar-mobile-head .rh-topbar-menu-close {
    display: inline-flex !important;
    width: 36px !important;
    height: 36px !important;
    border-radius: 13px !important;
    background: rgba(255,255,255,.055) !important;
  }

  .rh-topbar-mobile-body {
    padding: 14px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
  }

  .rh-topbar-mobile-section {
    display: grid !important;
    gap: 8px !important;
    padding: 14px !important;
    border: 1px solid color-mix(in srgb, var(--rui-nav-accent) 17%, transparent) !important;
    border-radius: var(--rui-nav-card-radius-mobile) !important;
    background: linear-gradient(145deg, rgba(10,20,34,.92), rgba(6,14,26,.82)) !important;
    box-shadow: 0 18px 55px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.05) !important;
  }

  .rh-topbar-mobile-kicker {
    margin: 0 0 2px !important;
    color: var(--rui-nav-accent) !important;
    font-size: var(--rui-nav-kicker-size) !important;
  }

  .rh-topbar-mobile-link {
    display: grid !important;
    grid-template-columns: 36px minmax(0,1fr) !important;
    gap: 10px !important;
    min-height: 46px !important;
    padding: 8px 10px !important;
    border-radius: var(--rui-nav-link-radius) !important;
    border: 1px solid rgba(255,255,255,.06) !important;
    background: rgba(255,255,255,.025) !important;
    color: var(--rui-nav-text) !important;
    font-size: 13px !important;
    font-weight: 850 !important;
  }

  .rh-topbar-mobile-link:hover,
  .rh-topbar-mobile-link.is-active {
    background: linear-gradient(135deg, color-mix(in srgb, var(--rui-nav-accent) 18%, transparent), color-mix(in srgb, var(--rui-nav-accent-2) 13%, transparent)) !important;
    border-color: color-mix(in srgb, var(--rui-nav-accent) 34%, transparent) !important;
    color: #fff !important;
  }

  .rh-topbar-mobile-icon {
    width: 36px !important;
    height: 36px !important;
    border-radius: 13px !important;
    display: grid !important;
    place-items: center !important;
    background: rgba(255,255,255,.06) !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    color: var(--rui-nav-accent) !important;
  }

  .rh-topbar-mobile-icon svg {
    width: 18px !important;
    height: 18px !important;
  }
}

@media (max-width: 900px) {
  .rh-admin-mobile-toggle {
    display: inline-flex !important;
    position: fixed !important;
    right: 14px !important;
    top: 14px !important;
    z-index: var(--rui-nav-mobile-z-toggle) !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 9px 12px !important;
  }

  .rh-admin-mobile-toggle svg {
    width: 18px !important;
    height: 18px !important;
    fill: none !important;
    stroke: var(--rui-nav-accent) !important;
    stroke-width: 1.9 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
  }

  .rh-admin-mobile-backdrop {
    display: block;
    position: fixed;
    inset: 0;
    z-index: var(--rui-nav-mobile-z-backdrop);
    background: rgba(1,6,15,.62);
    backdrop-filter: blur(7px);
    -webkit-backdrop-filter: blur(7px);
    opacity: 0;
    pointer-events: none;
    transition: opacity .22s ease;
  }

  .rh-admin-sidebar-v2 {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: auto !important;
    z-index: var(--rui-nav-mobile-z-drawer) !important;
    width: var(--rui-nav-mobile-w) !important;
    max-width: 88vw !important;
    height: auto !important;
    max-height: none !important;
    overflow-y: auto !important;
    padding: 14px !important;
    border-right: 0 !important;
    border-left: 1px solid color-mix(in srgb, var(--rui-nav-accent) 24%, transparent) !important;
    border-bottom: 0 !important;
    background: linear-gradient(165deg, rgba(6,13,27,.98), rgba(8,26,38,.96)) !important;
    box-shadow: -28px 0 90px rgba(0,0,0,.55) !important;
    transform: translateX(104%) !important;
    transition: transform .24s ease !important;
  }

  body.rh-admin-mobile-open .rh-admin-mobile-backdrop {
    opacity: 1;
    pointer-events: auto;
  }

  body.rh-admin-mobile-open .rh-admin-sidebar-v2 {
    transform: translateX(0) !important;
  }

  body.rh-admin-mobile-open {
    overflow: hidden;
  }

  .rh-admin-menu-items {
    grid-template-columns: 1fr !important;
  }

  .rh-admin-side-brand {
    padding-right: 48px !important;
  }
}

@media (max-width: 520px) {
  .rh-admin-mobile-toggle,
  .rh-ath-mobile-toggle,
  .rh-team-mobile-toggle {
    right: 10px !important;
    top: 10px !important;
    min-height: 38px !important;
    padding: 8px 10px !important;
    font-size: 11px !important;
  }

  .rh-admin-mobile-toggle span,
  .rh-ath-mobile-toggle span,
  .rh-team-mobile-toggle span {
    display: none;
  }
}
