/* ============================================================
   menu_megamenu.css — Estilos del megamenú frontend
   RapiWeb by Niarux — Sesión 27
   Cargado en index.php y paginas/pagina.php
   ============================================================ */

/* ── Wrapper del ítem padre ─────────────────────────────── */
.rw-nav-has-sub {
  position: relative;
}

/* ── Puente invisible: cubre el gap entre link y panel ──── */
.rw-nav-has-sub::after {
  content: '';
  position: absolute;
  top: 100%;
  left: -20px;
  right: -20px;
  height: 18px;
  background: transparent;
  z-index: 199;
}

/* ── Chevron indicador ──────────────────────────────────── */
.rw-nav-has-sub > .rw-nav-link .rw-nav-chevron {
  display: inline-block;
  margin-left: 5px;
  font-size: 0.6rem;
  opacity: 0.55;
  transition: transform 0.22s ease, opacity 0.22s;
  vertical-align: middle;
}
.rw-nav-has-sub:hover > .rw-nav-link .rw-nav-chevron,
.rw-nav-has-sub:focus-within > .rw-nav-link .rw-nav-chevron {
  transform: rotate(180deg);
  opacity: 1;
  color: var(--rw-primario);
}

/* ── Dropdown panel ─────────────────────────────────────── */
.rw-nav-sub {
  position: absolute;
  top: calc(100% + 4px);
  left: 50%;
  transform: translateX(-50%) translateY(-4px);
  min-width: 220px;
  background: rgba(var(--rw-fondo-rgb, 11,13,20), 0.98);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  padding: 8px;
  box-shadow:
    0 20px 60px rgba(0,0,0,0.5),
    0 4px 16px rgba(0,0,0,0.25),
    inset 0 1px 0 rgba(255,255,255,0.06);
  z-index: 200;
  list-style: none;
  margin: 0;
  /* Oculto por defecto */
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
  /* Evitar overflow del viewport */
  max-width: min(580px, calc(100vw - 24px));
}

/* Mostrar al hover / focus / clase .open */
.rw-nav-has-sub:hover > .rw-nav-sub,
.rw-nav-has-sub:focus-within > .rw-nav-sub,
.rw-nav-has-sub > .rw-nav-sub.open {
  opacity: 1;
  pointer-events: all;
  transform: translateX(-50%) translateY(0);
}

/* ── Punta decorativa ───────────────────────────────────── */
.rw-nav-sub::before {
  content: '';
  position: absolute;
  top: -7px;
  left: 50%;
  transform: translateX(-50%);
  width: 14px;
  height: 14px;
  background: rgba(var(--rw-fondo-rgb, 11,13,20), 0.98);
  border-top: 1px solid rgba(255,255,255,0.08);
  border-left: 1px solid rgba(255,255,255,0.08);
  clip-path: polygon(0 100%, 50% 0, 100% 100%);
}

/* ── Item del submenú ───────────────────────────────────── */
.rw-nav-sublink {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 10px 14px;
  border-radius: 10px;
  font-size: 0.87rem;
  font-weight: 500;
  color: rgba(255,255,255,0.65);
  text-decoration: none;
  white-space: nowrap;
  transition: background 0.15s ease, color 0.15s ease, padding-left 0.15s ease;
  position: relative;
}
.rw-nav-sublink::before {
  content: '';
  position: absolute;
  left: 8px;
  width: 3px;
  height: 0;
  background: var(--rw-primario);
  border-radius: 2px;
  transition: height 0.15s ease;
}
.rw-nav-sublink i {
  width: 18px;
  height: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.82rem;
  opacity: 0.55;
  flex-shrink: 0;
  transition: opacity 0.15s, color 0.15s, transform 0.15s;
}
.rw-nav-sublink:hover {
  background: rgba(255,255,255,0.07);
  color: #fff;
  padding-left: 18px;
}
.rw-nav-sublink:hover::before {
  height: 18px;
}
.rw-nav-sublink:hover i {
  opacity: 1;
  color: var(--rw-primario);
  transform: scale(1.1);
}

/* ── Separador opcional ─────────────────────────────────── */
.rw-nav-sub-sep {
  height: 1px;
  background: rgba(255,255,255,0.07);
  margin: 5px 10px;
  border: none;
  list-style: none;
}

/* ── Modo claro ─────────────────────────────────────────── */
[data-tema="claro"] .rw-nav-sub {
  background: rgba(255,255,255,0.99);
  border-color: rgba(0,0,0,0.07);
  box-shadow:
    0 20px 60px rgba(0,0,0,0.12),
    0 4px 16px rgba(0,0,0,0.06),
    inset 0 1px 0 rgba(255,255,255,0.8);
}
[data-tema="claro"] .rw-nav-sub::before {
  background: rgba(255,255,255,0.99);
  border-color: rgba(0,0,0,0.07);
}
[data-tema="claro"] .rw-nav-sublink {
  color: #4b5563;
}
[data-tema="claro"] .rw-nav-sublink:hover {
  background: rgba(0,0,0,0.04);
  color: #111827;
}
[data-tema="claro"] .rw-nav-sub-sep {
  background: rgba(0,0,0,0.07);
}

/* ── Móvil: expandible inline ───────────────────────────── */
@media (max-width: 768px) {
  .rw-nav-sub {
    position: static;
    transform: none !important;
    left: auto;
    opacity: 1;
    pointer-events: all;
    box-shadow: none;
    background: rgba(255,255,255,0.04);
    border: none;
    border-left: 2px solid rgba(var(--rw-primario-rgb, 99,102,241), 0.35);
    border-radius: 0 8px 8px 0;
    padding: 4px 0 4px 8px;
    margin: 4px 0 6px 12px;
    /* Colapsado por defecto */
    display: none;
    backdrop-filter: none;
  }
  .rw-nav-sub.open {
    display: flex;
    flex-direction: column;
    gap: 1px;
    animation: mmgSlideDown 0.18s ease;
  }
  .rw-nav-sub::before { display: none; }
  .rw-nav-sublink {
    padding: 8px 12px;
    font-size: 0.86rem;
    border-radius: 7px;
    color: rgba(255,255,255,0.6);
  }
  .rw-nav-sublink:hover {
    padding-left: 14px;
    color: rgba(255,255,255,0.9);
    background: rgba(255,255,255,0.06);
  }
  .rw-nav-sublink::before { display: none; }
  [data-tema="claro"] .rw-nav-sub {
    background: rgba(0,0,0,0.03);
    border-left-color: rgba(99,102,241,0.25);
    box-shadow: none;
  }
  [data-tema="claro"] .rw-nav-sublink { color: #6b7280; }
  [data-tema="claro"] .rw-nav-sublink:hover { color: #111827; background: rgba(0,0,0,0.04); }
}

/* ── Drawer lateral / fullscreen: mismos estilos móvil ─── */
.rw-drawer .rw-nav-sub,
.rw-fullscreen .rw-nav-sub {
  position: static;
  transform: none !important;
  opacity: 1;
  pointer-events: all;
  box-shadow: none;
  background: rgba(255,255,255,0.04);
  border: none;
  border-left: 2px solid rgba(var(--rw-primario-rgb, 99,102,241), 0.35);
  border-radius: 0 8px 8px 0;
  padding: 4px 0 4px 8px;
  margin: 4px 0 6px 12px;
  display: none;
  backdrop-filter: none;
}
.rw-drawer .rw-nav-sub.open,
.rw-fullscreen .rw-nav-sub.open {
  display: flex;
  flex-direction: column;
  gap: 1px;
  animation: mmgSlideDown 0.18s ease;
}
.rw-drawer .rw-nav-sub::before,
.rw-fullscreen .rw-nav-sub::before { display: none; }

@keyframes mmgSlideDown {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
/* ============================================================
   MEGAMENÚ TIPOS — lista, tarjetas, destacado
   ============================================================ */

/* ── Anchos del panel ───────────────────────────────────── */
.rw-mega-normal  { min-width: 240px; max-width: 320px; }
.rw-mega-ancho   { min-width: 460px; max-width: 580px; }
.rw-mega-completo {
  position: fixed !important;
  left: 0 !important;
  right: 0 !important;
  transform: none !important;
  width: 100% !important;
  border-radius: 0 0 16px 16px !important;
  max-width: none !important;
}

/* ── MODO LISTA ─────────────────────────────────────────── */
.rw-mega-tipo-lista {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.rw-sublink-lista {
  display: flex !important;
  align-items: center;
  gap: 12px;
  padding: 10px 14px !important;
}
.rw-sublink-lista .rw-sublink-ico {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  background: color-mix(in srgb, var(--rw-primario) 12%, transparent);
  color: var(--rw-primario);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .88rem;
  flex-shrink: 0;
  transition: background .15s, transform .15s;
}
.rw-sublink-lista:hover .rw-sublink-ico {
  background: color-mix(in srgb, var(--rw-primario) 22%, transparent);
  transform: scale(1.1);
}
.rw-sublink-lista .rw-sublink-txt { flex: 1; min-width: 0; }
.rw-sublink-lista .rw-sublink-txt strong {
  display: block;
  font-size: .88rem;
  font-weight: 600;
  color: rgba(255,255,255,.85);
  white-space: nowrap;
}
.rw-sublink-lista .rw-sublink-txt small {
  display: block;
  font-size: .75rem;
  color: rgba(255,255,255,.45);
  margin-top: 1px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rw-sublink-lista:hover .rw-sublink-txt strong { color: #fff; }
.rw-sublink-lista:hover .rw-sublink-txt small  { color: rgba(255,255,255,.65); }

/* Modo lista ancho — 2 columnas */
.rw-mega-ancho.rw-mega-tipo-lista {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
}

/* ── MODO TARJETAS ──────────────────────────────────────── */
.rw-mega-tipo-tarjetas {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  padding: 10px !important;
}
.rw-mega-ancho.rw-mega-tipo-tarjetas  { grid-template-columns: repeat(3, 1fr); }
.rw-mega-completo.rw-mega-tipo-tarjetas { grid-template-columns: repeat(4, 1fr); }

.rw-mega-tarjeta-item { list-style: none; }
.rw-sublink-tarjeta {
  display: flex !important;
  flex-direction: column;
  padding: 0 !important;
  border-radius: 12px !important;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.07) !important;
  background: rgba(255,255,255,.03) !important;
  transition: border-color .2s, background .2s, transform .2s !important;
}
.rw-sublink-tarjeta:hover {
  border-color: color-mix(in srgb, var(--rw-primario) 50%, transparent) !important;
  background: color-mix(in srgb, var(--rw-primario) 6%, rgba(255,255,255,.03)) !important;
  transform: translateY(-2px) !important;
}
.rw-sublink-tarjeta:hover::before { display: none !important; }

.rw-sublink-tarjeta-img {
  position: relative;
  width: 100%;
  height: 90px;
  overflow: hidden;
  background: rgba(255,255,255,.04);
}
.rw-sublink-tarjeta-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .3s;
}
.rw-sublink-tarjeta:hover .rw-sublink-tarjeta-img img { transform: scale(1.05); }
.rw-sublink-tarjeta-img svg { width: 100%; height: 100%; }
.rw-sublink-tarjeta-ico {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  font-size: 1.3rem;
  color: var(--rw-primario);
  opacity: .7;
}
.rw-sublink-tarjeta strong {
  display: block;
  font-size: .83rem;
  font-weight: 700;
  color: rgba(255,255,255,.85);
  padding: .55rem .75rem .2rem;
}
.rw-sublink-tarjeta small {
  display: block;
  font-size: .72rem;
  color: rgba(255,255,255,.45);
  padding: 0 .75rem .6rem;
  line-height: 1.4;
}

/* ── MODO DESTACADO ─────────────────────────────────────── */
.rw-mega-tipo-destacado {
  display: grid !important;
  grid-template-columns: 1fr !important;
  padding: 0 !important;
}
.rw-mega-ancho.rw-mega-tipo-destacado,
.rw-mega-completo.rw-mega-tipo-destacado {
  grid-template-columns: 220px 1fr !important;
  /* el banner usa toda la primera columna */
}

.rw-mega-banner-wrap {
  display: contents; /* sus hijos participan en el grid del padre */
  list-style: none;
}

.rw-mega-banner {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  margin: 8px;
  background: color-mix(in srgb, var(--rw-primario) 15%, rgba(0,0,0,.4));
  min-height: 160px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.rw-mega-banner img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .7;
}
.rw-mega-banner-svg { width: 100%; height: 100%; position: absolute; inset: 0; }
.rw-mega-banner-info {
  position: relative;
  z-index: 2;
  padding: .75rem 1rem;
  background: linear-gradient(to top, rgba(0,0,0,.7), transparent);
}
.rw-mega-banner-info strong {
  display: block;
  color: #fff;
  font-size: .95rem;
  font-weight: 700;
}
.rw-mega-banner-info span {
  display: block;
  color: rgba(255,255,255,.7);
  font-size: .78rem;
  margin-top: 2px;
}

.rw-mega-lista-lateral {
  list-style: none;
  margin: 0;
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.rw-sublink-lateral {
  display: flex !important;
  align-items: center;
  gap: 10px;
  padding: 9px 12px !important;
}
.rw-sublink-lateral .rw-sublink-ico {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  background: color-mix(in srgb, var(--rw-primario) 12%, transparent);
  color: var(--rw-primario);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .82rem;
  flex-shrink: 0;
  transition: background .15s;
}
.rw-sublink-lateral:hover .rw-sublink-ico { background: color-mix(in srgb, var(--rw-primario) 22%, transparent); }
.rw-sublink-lateral .rw-sublink-txt { flex: 1; }
.rw-sublink-lateral .rw-sublink-txt strong {
  display: block;
  font-size: .85rem;
  font-weight: 600;
  color: rgba(255,255,255,.8);
}
.rw-sublink-lateral .rw-sublink-txt small {
  display: block;
  font-size: .73rem;
  color: rgba(255,255,255,.45);
  margin-top: 1px;
}
.rw-sublink-lateral:hover .rw-sublink-txt strong { color: #fff; }

/* ── Modo claro — todos los tipos ───────────────────────── */
[data-tema="claro"] .rw-sublink-lista .rw-sublink-txt strong,
[data-tema="claro"] .rw-sublink-lateral .rw-sublink-txt strong,
[data-tema="claro"] .rw-sublink-tarjeta strong { color: #1f2937; }

[data-tema="claro"] .rw-sublink-lista .rw-sublink-txt small,
[data-tema="claro"] .rw-sublink-lateral .rw-sublink-txt small,
[data-tema="claro"] .rw-sublink-tarjeta small { color: #6b7280; }

[data-tema="claro"] .rw-sublink-tarjeta {
  border-color: rgba(0,0,0,.08) !important;
  background: rgba(0,0,0,.02) !important;
}
[data-tema="claro"] .rw-sublink-tarjeta:hover {
  background: color-mix(in srgb, var(--rw-primario) 5%, #fff) !important;
}

/* ── Megamenú en móvil — override para todos los tipos ─── */
@media (max-width: 768px) {
  .rw-mega-normal,
  .rw-mega-ancho,
  .rw-mega-completo {
    min-width: 0 !important;
    max-width: none !important;
    width: auto !important;
    position: static !important;
    transform: none !important;
    border-radius: 0 8px 8px 0 !important;
  }
  .rw-mega-tipo-tarjetas {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 6px !important;
    padding: 6px !important;
  }
  .rw-sublink-tarjeta-img { height: 60px !important; }
  .rw-mega-tipo-destacado,
  .rw-mega-ancho.rw-mega-tipo-destacado,
  .rw-mega-completo.rw-mega-tipo-destacado {
    grid-template-columns: 1fr !important;
  }
  .rw-mega-banner { min-height: 100px !important; }
  .rw-mega-ancho.rw-mega-tipo-lista { grid-template-columns: 1fr !important; }
}
/* ══════════════════════════════════════════════════════════
   ESTILOS DEL SUBMENÚ CLÁSICO (nav normal, es_mega=0)
   Controlado por data-nav-sub-estilo en el <nav>
   Aplica solo cuando mega_activo=0
   ══════════════════════════════════════════════════════════ */

/* ── BASE — Panel flotante (default) ─────────────────────── */
[data-nav-sub="panel"] .rw-nav-sub,
.rw-nav-sub {
  background: rgba(var(--rw-fondo-rgb, 11,13,20), 0.98);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5), 0 4px 16px rgba(0,0,0,0.25);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}

/* ── Sólido — fondo color primario ───────────────────────── */
[data-nav-sub="solido"] .rw-nav-sub {
  background: var(--rw-primario) !important;
  border: none !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,255,255,0.1) !important;
  backdrop-filter: none !important;
}
[data-nav-sub="solido"] .rw-nav-sub::before {
  background: var(--rw-primario) !important;
  border-color: transparent !important;
}
[data-nav-sub="solido"] .rw-nav-sublink {
  color: rgba(255,255,255,0.88) !important;
}
[data-nav-sub="solido"] .rw-nav-sublink:hover {
  background: rgba(255,255,255,0.18) !important;
  color: #fff !important;
}
[data-nav-sub="solido"] .rw-nav-sublink::before {
  background: rgba(255,255,255,0.7) !important;
}
[data-nav-sub="solido"] .rw-nav-sub-sep {
  background: rgba(255,255,255,0.2) !important;
}

/* ── Glass — translúcido intenso ─────────────────────────── */
[data-nav-sub="glass"] .rw-nav-sub {
  background: rgba(255,255,255,0.08) !important;
  border: 1px solid rgba(255,255,255,0.2) !important;
  backdrop-filter: blur(32px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(32px) saturate(180%) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.15) !important;
}
[data-nav-sub="glass"] .rw-nav-sub::before {
  background: rgba(255,255,255,0.08) !important;
  border-color: rgba(255,255,255,0.2) !important;
}
[data-nav-sub="glass"] .rw-nav-sublink { color: rgba(255,255,255,0.8) !important; }
[data-nav-sub="glass"] .rw-nav-sublink:hover {
  background: rgba(255,255,255,0.12) !important;
  color: #fff !important;
}

/* ── Minimal — sin fondo, solo texto ─────────────────────── */
[data-nav-sub="minimal"] .rw-nav-sub {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  padding: 4px 0 !important;
  border-radius: 0 !important;
}
[data-nav-sub="minimal"] .rw-nav-sub::before { display: none !important; }
[data-nav-sub="minimal"] .rw-nav-sublink {
  color: rgba(255,255,255,0.7) !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 0 !important;
  padding: 10px 14px !important;
}
[data-nav-sub="minimal"] .rw-nav-sublink:hover {
  background: transparent !important;
  color: var(--rw-primario) !important;
  padding-left: 18px !important;
}

/* ── Borde — borde color primario llamativo ───────────────── */
[data-nav-sub="borde"] .rw-nav-sub {
  background: rgba(var(--rw-fondo-rgb, 11,13,20), 0.97) !important;
  border: 2px solid var(--rw-primario) !important;
  border-radius: 14px !important;
  box-shadow: 0 0 20px rgba(0,0,0,0.4), 0 0 0 4px color-mix(in srgb, var(--rw-primario) 15%, transparent) !important;
  backdrop-filter: blur(16px) !important;
}
[data-nav-sub="borde"] .rw-nav-sub::before {
  background: rgba(var(--rw-fondo-rgb, 11,13,20), 0.97) !important;
  border-top-color: var(--rw-primario) !important;
  border-left-color: var(--rw-primario) !important;
}
[data-nav-sub="borde"] .rw-nav-sublink:hover {
  background: color-mix(in srgb, var(--rw-primario) 12%, transparent) !important;
  color: var(--rw-primario) !important;
}

/* ── Compacto — items pequeños y juntos ───────────────────── */
[data-nav-sub="compacto"] .rw-nav-sub {
  background: rgba(var(--rw-fondo-rgb, 11,13,20), 0.98) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: 10px !important;
  padding: 4px !important;
  min-width: 180px !important;
}
[data-nav-sub="compacto"] .rw-nav-sublink {
  padding: 6px 10px !important;
  font-size: 0.8rem !important;
  border-radius: 6px !important;
}
[data-nav-sub="compacto"] .rw-nav-sublink:hover {
  padding-left: 13px !important;
}

/* ── Modo claro — overrides para todos los estilos ───────── */
[data-tema="claro"][data-nav-sub="solido"] .rw-nav-sublink { color: rgba(255,255,255,0.92) !important; }
[data-tema="claro"][data-nav-sub="glass"] .rw-nav-sub {
  background: rgba(255,255,255,0.7) !important;
  border-color: rgba(0,0,0,0.1) !important;
}
[data-tema="claro"][data-nav-sub="glass"] .rw-nav-sublink { color: #374151 !important; }
[data-tema="claro"][data-nav-sub="minimal"] .rw-nav-sublink { color: #4b5563 !important; }
[data-tema="claro"][data-nav-sub="minimal"] .rw-nav-sublink:hover { color: var(--rw-primario) !important; }
[data-tema="claro"][data-nav-sub="borde"] .rw-nav-sub { background: rgba(255,255,255,0.98) !important; }
[data-tema="claro"][data-nav-sub="borde"] .rw-nav-sublink { color: #374151 !important; }
[data-tema="claro"][data-nav-sub="compacto"] .rw-nav-sub { background: rgba(255,255,255,0.99) !important; }