/* style_navbar.css | v2.0.0 | updated: 2026-01-14 20:23 */

:root {
  --nav-h: 72px;
  --nav-blur: 16px;

  --dark-bg: rgba(15, 23, 42, 0.92);
  --dark-border: rgba(255, 255, 255, 0.1);
  --dark-text: rgba(255, 255, 255, 0.92);
  --dark-muted: rgba(255, 255, 255, 0.7);
  --dark-hover: rgba(255, 255, 255, 0.6);

  --backdrop-bg: rgba(0, 0, 0, 0.55);
  --backdrop-blur: 10px;
}

.navbar-brand img {
  height: auto;
  max-height: 35px;
  width: auto;
  display: block;
  opacity: 0.98;
}
.offcanvas .offcanvas-header img {
  height: auto;
  max-height: 35px;
  width: auto;
  display: block;
  opacity: 0.98;
}

.nav-hero,
.nav-minimal {
  top: 0;
  z-index: 1035;
  background: transparent !important;
  border-bottom: 1px solid transparent;
  transition: background 0.22s ease, border-color 0.22s ease,
    box-shadow 0.22s ease;
}

.nav-hero.is-scrolled,
.nav-minimal.is-scrolled {
  background: rgba(0, 0, 0, 0.18) !important;
  backdrop-filter: blur(var(--nav-blur));
  -webkit-backdrop-filter: blur(var(--nav-blur));
  border-bottom-color: rgba(255, 255, 255, 0.1);
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.18);
}

.navbar {
  padding-left: 0 !important;
}

.nav-hero .navbar {
  min-height: var(--nav-h);
  padding: 10px 0;
}
.nav-minimal .navbar {
  min-height: 64px;
  padding: 8px 0;
}

.nav-hero .navbar-brand,
.nav-minimal .navbar-brand {
  /* padding-left: 6px; */
}

.nav-hero .navbar-brand img {
  height: auto;
  max-height: 35px;
  width: auto;
  display: block;
}
.nav-minimal .navbar-brand img {
  height: auto;
  max-height: 35px;
  width: auto;
  display: block;
}

@media (max-width: 992px) {
  .nav-hero .navbar {
    min-height: 64px;
    padding: 8px 0;
  }
  .nav-hero .navbar-brand {
    /* padding-left: 12px; */
  }
  .nav-hero .navbar-brand img {
    height: auto;
    max-height: 35px;
  }
  .nav-minimal .navbar-brand {
    /* padding-left: 12px; */
  }
  .nav-minimal .navbar-brand img {
    height: auto;
    max-height: 35px;
  }
}

body.academy-app .navbar-brand img,
body.academy-app .offcanvas .offcanvas-header img,
body.academy-app .nav-hero .navbar-brand img,
body.academy-app .nav-minimal .navbar-brand img {
  height: auto;
  max-height: 23px !important;
  width: auto;
}

.nav-hero .navbar-nav,
.nav-minimal .navbar-nav {
  gap: 6px;
}

.navbar a,
.navbar a:hover,
.navbar a:focus,
.navbar a:active {
  text-decoration: none !important;
}

.nav-hero .nav-link,
.nav-minimal .nav-link {
  font-weight: 700;
  letter-spacing: 0.2px;
  padding: 10px !important;
  border-radius: 10px;
  background: transparent !important;
  transition: background 0.16s ease, opacity 0.16s ease, transform 0.12s ease;
}
.nav-hero .nav-link:hover,
.nav-minimal .nav-link:hover {
  background: rgba(0, 0, 0, 0.04) !important;
}
.nav-hero .nav-link:active,
.nav-minimal .nav-link:active {
  background: rgba(255, 255, 255, 0.3) !important;
}
.nav-hero .nav-link:focus-visible,
.nav-minimal .nav-link:focus-visible {
  /* outline: 2px solid rgba(255, 255, 255, 0.28); */
  outline-offset: 2px;
  /* background: rgba(255, 255, 255, 0.1) !important; */
}

.navbar-toggler {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 10px !important;
  /* margin-right: 6px; */
  opacity: 0.8;
}
.navbar-toggler:focus,
.navbar-toggler:active,
.navbar-toggler:focus-visible {
  outline: none !important;
  box-shadow: none !important;
}
.navbar-toggler-icon {
  /* filter: invert(1) !important; */
  /* opacity: 1 !important; */
  width: 1.15em;
  height: 1.15em;
}

.nav-contrast-toggle {
  position: relative;
  color: #0f172a;
  isolation: isolate;
}

.nav-contrast-toggle[data-contrast="light"] {
  color: #ffffff;
}

.nav-contrast-toggle[data-contrast="dark"] {
  color: #0f172a;
}

.nav-contrast-toggle[data-contrast="auto"] {
  color: #ffffff;
  mix-blend-mode: difference;
}

.nav-toggle-bars,
.nav-toggle-bars::before,
.nav-toggle-bars::after {
  display: block;
  width: 22px;
  height: 2.25px;
  border-radius: 999px;
  background: currentColor;
  transition: transform 0.18s ease, opacity 0.18s ease, background-color 0.18s ease;
}

.nav-toggle-bars {
  position: relative;
  margin: 0 auto;
}

.nav-toggle-bars::before,
.nav-toggle-bars::after {
  content: "";
  position: absolute;
  left: 0;
}

.nav-toggle-bars::before {
  top: -6px;
}

.nav-toggle-bars::after {
  top: 6px;
}
/* iconos dentro de links */
.nav-item i,
.nav-item-sm i,
.nav-item-lg i {
  float: none !important;
  display: inline-block;
  margin: 0 0.55rem 0 0 !important;
  padding: 0 !important;
  /* color: var(--dark-text) !important; */
}
.navbar-nav .nav-item a {
  font-weight: 700 !important;
  font-size: 14px !important;
}

.navbar-nav-lg .nav-item a {
  font-weight: 700 !important;
  font-size: 0.9rem !important;
}
.navbar .nav-link i.ms-1,
.offcanvas .nav-link i.ms-1 {
  margin-left: 0.4rem !important;
  margin-right: 0 !important;
}
.nav-link {
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", "Helvetica Neue", Helvetica, Arial, sans-serif !important;
}

/* dropdown (si usas dropdown en nav) */
.dropdown-menu {
  /* background: rgba(255, 255, 255, 0.92) !important; */
  color: var(--dark-text) !important;
  /* border: 1px solid rgba(255, 255, 255, 0.1); */
  /* backdrop-filter: blur(12px); */
  /* -webkit-backdrop-filter: blur(12px); */
  padding: 0.3rem 0 !important;
  min-width: 180px;
  border-radius: 14px;
}
.dropdown-menu li {
  margin: 0;
  padding: 0;
}
.dropdown-item {
  /* background: transparent !important; */
  /* color: var(--dark-text) !important; */
  text-decoration: none !important;
  display: flex;
  align-items: center;
  gap: 0.6rem;
  width: 100%;
  padding: 10px !important;
  line-height: 1.2;
  font-weight: 500;
  border-radius: 10px !important;
}
.dropdown-item i {
  width: 16px;
  min-width: 16px;
  text-align: center;
  margin-right: 0 !important;
}
.dropdown-item:hover {
  background: rgba(0, 0, 0, 0.04) !important;
  /* color: var(--dark-text) !important; */
}
.dropdown-item:active {
  background: rgba(255, 255, 255, 0.6) !important;
  /* color: var(--dark-text) !important; */
}

.nav-hero .nav-link.active,
.nav-minimal .nav-link.active,
.offcanvas .nav-link.active,
.nav-hero .show > .nav-link,
.nav-minimal .show > .nav-link {
  background: rgba(13, 110, 253, 0.08) !important;
  color: #fff !important;
  padding: 10px !important;
  border-radius: 10px !important;
}

.nav-hero .nav-link.active:hover,
.nav-minimal .nav-link.active:hover,
.offcanvas .nav-link.active:hover,
.nav-hero .show > .nav-link:hover,
.nav-minimal .show > .nav-link:hover {
  background: rgba(13, 110, 253, 0.14) !important;
  color: #fff !important;
  padding: 10px !important;
  border-radius: 10px !important;
}

.nav-hero .dropdown-item.active,
.nav-minimal .dropdown-item.active {
  background: rgba(13, 110, 253, 0.08) !important;
  color: #0b5ed7 !important;
  padding: 10px !important;
  border-radius: 10px !important;
}

.nav-hero .dropdown-item.active:hover,
.nav-minimal .dropdown-item.active:hover {
  background: rgba(13, 110, 253, 0.14) !important;
  color: #0b5ed7 !important;
  padding: 10px !important;
  border-radius: 10px !important;
}

body.academy-app .navbar .dropdown-menu {
  padding: 0.32rem 0 !important;
}
body.academy-app .navbar .dropdown-item {
  min-height: 42px;
  padding: 10px !important;
  font-size: 0.92rem;
}

/* =========================
   OFFCANVAS
   ========================= */

.offcanvas.nav-offcanvas {
  background: rgba(32, 32, 32, 0.6) !important;
  color: var(--dark-text) !important;
  border-left: 1px solid var(--dark-border);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
}

.offcanvas .offcanvas-header {
  border-bottom: 1px solid var(--dark-border);
}

/* X visible blanco */
.offcanvas .btn-close {
  opacity: 0.95 !important;
  margin-right: 12px !important;
  filter: invert(1) !important;
}
.offcanvas .btn-close:focus,
.offcanvas .btn-close:active {
  box-shadow: none !important;
  outline: none !important;
}

.offcanvas .navbar-nav {
  width: 100%;
  margin: 0 !important;
  padding: 0 !important;
}
.offcanvas .nav-item,
.offcanvas .nav-item-sm,
.offcanvas .nav-item-lg {
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
.offcanvas .nav-link {
  display: flex;
  align-items: center;
  font-weight: 800;
  width: 100%;
  padding: 12px 10px !important;
  border-radius: 12px;
  color: var(--dark-text) !important;
  text-decoration: none !important;
}
.offcanvas .nav-link,
.offcanvas .nav-link i,
.offcanvas .nav-link span,
.offcanvas .small,
.offcanvas .text-muted,
.offcanvas .text-tip,
.offcanvas .fw-semibold,
.offcanvas .fw-bold,
.offcanvas .fw-medium {
  color: var(--dark-text) !important;
}
.offcanvas .nav-link i {
  opacity: 0.96;
}
.offcanvas .nav-item > div,
.offcanvas .nav-item-sm > div,
.offcanvas .nav-item-lg > div {
  color: var(--dark-text) !important;
}
.logo-svg {
  height: 35px;
  max-height: 35px;
  width: auto;
  filter: brightness(10000%);
  fill: white;
  margin: 12px !important;
}

.offcanvas .nav-link:hover {
  color: #fff !important;
  border-radius: 12px !important;
}

/* backdrop con blur */
.offcanvas-backdrop.show {
  background: var(--backdrop-bg) !important;
  backdrop-filter: blur(var(--backdrop-blur));
  -webkit-backdrop-filter: blur(var(--backdrop-blur));
}

/* z-index correctos */
.modal {
  z-index: 1055;
}
.modal-backdrop {
  z-index: 1050;
}
.offcanvas {
  z-index: 1045;
}
.offcanvas-backdrop {
  z-index: 1040;
}

@media (max-width: 991.98px) {
  html,
  body {
    max-width: 100%;
    overflow-x: hidden !important;
  }

  body:not(.academy-app) {
    width: 100%;
    max-width: 100%;
    padding-right: 0 !important;
    overscroll-behavior-x: none;
  }

  body:not(.academy-app) > div,
  body:not(.academy-app) section,
  body:not(.academy-app) .section-bg-wrap,
  body:not(.academy-app) .section-bg-content,
  body:not(.academy-app) .section-container {
    max-width: 100%;
    overflow-x: hidden;
  }

  body:not(.academy-app) .navbar,
  body:not(.academy-app) .container,
  body:not(.academy-app) .container-fluid {
    max-width: 100%;
  }

  body:not(.academy-app) .navbar-toggler.nav-contrast-toggle {
    position: relative;
    z-index: 1047;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
  }

  body:not(.academy-app) .offcanvas.nav-offcanvas {
    position: fixed !important;
    inset: auto 12px auto 12px !important;
    top: calc(var(--nav-h) - 8px) !important;
    width: auto !important;
    max-width: none !important;
    height: auto !important;
    max-height: calc(100vh - var(--nav-h) - 20px) !important;
    margin: 0 !important;
    border: 1px solid rgba(255, 255, 255, 0.16) !important;
    border-radius: 18px !important;
    background: rgba(22, 22, 24, 0.60) !important;
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.28);
    transform: translate3d(0, -16px, 0) scale(0.985) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transition: transform 0.18s ease, opacity 0.18s ease, visibility 0.18s ease !important;
    will-change: transform, opacity;
  }

  body:not(.academy-app) .offcanvas.nav-offcanvas.show,
  body:not(.academy-app) .offcanvas.nav-offcanvas.nav-mobile-open,
  body:not(.academy-app) .offcanvas.nav-offcanvas.showing {
    transform: translate3d(0, 0, 0) scale(1) !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }

  body:not(.academy-app) .offcanvas.nav-offcanvas .offcanvas-header {
    padding: 0.95rem 1rem 0.55rem !important;
  }

  body:not(.academy-app) .offcanvas.nav-offcanvas .offcanvas-body {
    padding: 0.4rem 0.6rem 0.8rem !important;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
  }

  body:not(.academy-app) .offcanvas.nav-offcanvas .nav-link {
    min-height: 46px;
    padding: 12px 12px !important;
  }

  body:not(.academy-app) .offcanvas-backdrop.show {
    opacity: 0 !important;
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  body:not(.academy-app) .site-nav-offcanvas .btn-close {
    margin-right: 0 !important;
  }

  body:not(.academy-app).site-nav-open {
    overflow-x: hidden !important;
  }
}

@media (max-width: 576px) {
  body.academy-app .nav-hero .nav-link,
  body.academy-app .nav-minimal .nav-link,
  body.academy-app .navbar-nav .nav-item a {
    font-size: 1rem !important;
    line-height: 1.28 !important;
    padding: 11px 12px !important;
  }

  body.academy-app .navbar .dropdown-item,
  body.academy-app .dropdown-item {
    font-size: 0.98rem !important;
    line-height: 1.26 !important;
    padding: 11px 12px !important;
  }

  body.academy-app .offcanvas .nav-link {
    font-size: 1rem !important;
    line-height: 1.3 !important;
    padding: 13px 12px !important;
  }

  body.academy-app .offcanvas .text-tip,
  body.academy-app .offcanvas .small,
  body.academy-app .offcanvas .text-muted {
    font-size: 0.84rem !important;
    line-height: 1.35 !important;
  }
}

body.academy-app .nav-hero .nav-link,
body.academy-app .nav-minimal .nav-link,
body.academy-app .navbar-nav .nav-item a {
  font-size: 0.99rem !important;
}

body.academy-app .navbar .dropdown-item,
body.academy-app .dropdown-item {
  font-size: 0.97rem !important;
}

@media (max-width: 576px) {
  body.academy-app .nav-hero .nav-link,
  body.academy-app .nav-minimal .nav-link,
  body.academy-app .navbar-nav .nav-item a {
    font-size: 2.1rem !important;
    line-height: 1.3 !important;
    padding: 12px 13px !important;
  }

  body.academy-app .navbar .dropdown-item,
  body.academy-app .dropdown-item {
    font-size: 2.07rem !important;
    line-height: 1.3 !important;
    padding: 12px 13px !important;
  }

  body.academy-app .offcanvas .nav-link {
    font-size: 2.1rem !important;
    line-height: 1.34 !important;
    padding: 14px 13px !important;
  }

  body.academy-app .offcanvas .text-tip,
  body.academy-app .offcanvas .small,
  body.academy-app .offcanvas .text-muted {
    font-size: 1.77rem !important;
    line-height: 1.38 !important;
  }
}

/* =========================================================
   Menu Audit Normalize
   ========================================================= */

.nav-hero .navbar-nav,
.nav-minimal .navbar-nav {
  gap: 0.7rem;
}

.nav-hero .nav-link,
.nav-minimal .nav-link {
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1 !important;
  padding: 6px 9px !important;
  padding: 16px 8px !important;
  border-radius: 12px !important;
  position: relative;
  transition: padding 0.16s ease, background-color 0.16s ease, color 0.16s ease, transform 0.12s ease;
}

.nav-hero .nav-link:hover,
.nav-minimal .nav-link:hover,
.nav-hero .nav-link:focus-visible,
.nav-minimal .nav-link:focus-visible {
  padding: 16px 8px !important;
  background: rgba(255, 255, 255, 0.5) !important;
}

.nav-hero .dropdown-toggle,
.nav-minimal .dropdown-toggle,
.nav-account-toggle {
  gap: 0.32rem;
}

.nav-hero .dropdown-toggle::after,
.nav-minimal .dropdown-toggle::after,
.nav-account-toggle::after {
  margin: 0 0 0 0.14rem !important;
  vertical-align: middle !important;
  align-self: center;
}

.nav-hero .nav-link.nav-link-icon-only,
.nav-minimal .nav-link.nav-link-icon-only {
  min-width: 28px;
  justify-content: center;
  padding: 6px 7px !important;
}

.nav-hero .nav-link.active,
.nav-minimal .nav-link.active,
.offcanvas .nav-link.active,
.nav-hero .show > .nav-link,
.nav-minimal .show > .nav-link {
  background: rgba(242, 140, 40, 0.26) !important;
  color: #fff !important;
  padding: 8px 12px !important;
}

.nav-hero .nav-link.active:hover,
.nav-minimal .nav-link.active:hover,
.offcanvas .nav-link.active:hover,
.nav-hero .show > .nav-link:hover,
.nav-minimal .show > .nav-link:hover {
  background: rgba(242, 140, 40, 0.34) !important;
  color: #fff !important;
  padding: 8px 12px !important;
}

.dropdown-menu {
  min-width: 236px;
  padding: 0.18rem !important;
  border-radius: 16px;
}

.dropdown-item {
  min-height: 22px;
  padding: 6px 18px !important;
  line-height: 1.05 !important;
  border-radius: 12px !important;
}

.nav-account-toggle {
  padding: 10px 14px !important;
}

.nav-account-avatar {
  width: 32px;
  height: 32px;
  border-radius: 14px;
  object-fit: cover;
  display: block;
  background: #f8fafc;
  border: 1px solid rgba(15, 23, 42, 0.12);
  box-shadow: 0 4px 10px rgba(15, 23, 42, 0.08);
}

.nav-account-meta {
  min-width: 0;
}

.nav-account-name {
  line-height: 1.05;
}

.nav-account-role {
  font-size: 0.72rem !important;
  line-height: 1.1 !important;
  opacity: 0.78;
}

.nav-section-label {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.72rem !important;
  opacity: 0.72;
}

.offcanvas .nav-section-label {
  display: block;
  padding: 0.55rem 0.35rem 0.2rem !important;
  color: var(--dark-muted) !important;
}

.offcanvas .nav-link {
  min-height: 48px;
  gap: 0.75rem;
  padding: 12px 14px !important;
  border-radius: 12px !important;
}

body.academy-app .offcanvas.nav-offcanvas {
  width: min(90vw, 360px) !important;
}

body.academy-app .offcanvas.nav-offcanvas .offcanvas-header {
  padding: 1rem 1rem 0.55rem !important;
}

body.academy-app .offcanvas.nav-offcanvas .offcanvas-body {
  padding: 0.35rem 0.65rem 0.9rem !important;
}

body.academy-app .navbar .dropdown-item,
body.academy-app .dropdown-item {
  min-height: 22px;
  padding: 6px 18px !important;
  line-height: 1.05 !important;
  font-size: 0.92rem !important;
}

@media (max-width: 576px) {
  body.academy-app .nav-hero .nav-link,
  body.academy-app .nav-minimal .nav-link,
  body.academy-app .navbar-nav .nav-item a {
    font-size: 0.98rem !important;
    line-height: 1.26 !important;
    padding: 12px 14px !important;
  }

  body.academy-app .navbar .dropdown-item,
  body.academy-app .dropdown-item {
    font-size: 0.96rem !important;
    line-height: 1.08 !important;
    min-height: 22px !important;
    padding: 6px 18px !important;
  }

  body.academy-app .offcanvas .nav-link {
    font-size: 1rem !important;
    line-height: 1.28 !important;
    padding: 13px 14px !important;
  }

  body.academy-app .nav-account-toggle {
    padding: 10px 12px !important;
  }

  body.academy-app .nav-account-role {
    font-size: 0.74rem !important;
  }
}

/* =========================================================
   Shared Nav Font Reduce 10%
   ========================================================= */
.navbar-nav .nav-item a{
  font-size:12.6px !important;
}

.navbar-nav-lg .nav-item a{
  font-size:0.81rem !important;
}

.dropdown-item{
  font-size:0.81rem !important;
}

.nav-account-role,
.nav-section-label{
  font-size:0.65rem !important;
}

body.academy-app .nav-hero .nav-link,
body.academy-app .nav-minimal .nav-link,
body.academy-app .navbar-nav .nav-item a {
  font-size:0.89rem !important;
}

body.academy-app .navbar .dropdown-item,
body.academy-app .dropdown-item {
  font-size:0.87rem !important;
}

@media (max-width: 576px) {
  body.academy-app .nav-hero .nav-link,
  body.academy-app .nav-minimal .nav-link,
  body.academy-app .navbar-nav .nav-item a {
    font-size:0.88rem !important;
  }

  body.academy-app .navbar .dropdown-item,
  body.academy-app .dropdown-item {
    font-size:0.86rem !important;
  }

  body.academy-app .offcanvas .nav-link {
    font-size:0.9rem !important;
  }

  body.academy-app .offcanvas .text-tip,
  body.academy-app .offcanvas .small,
  body.academy-app .offcanvas .text-muted,
  body.academy-app .nav-account-role {
    font-size:0.67rem !important;
  }
}
