/* ==========================================
   Sticky Navbar (Premium)
   - offset below headerx via CSS vars
   ========================================== */

.portal-navbar-wrap{
  position: sticky;
  top: var(--headerx-h);
  z-index: 1030;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  /* Important so dropdowns can overflow */
  overflow: visible !important;
}

body.headerx-compact .portal-navbar-wrap{
  top: var(--headerx-h-compact);
}

/* Ensure dropdown is not clipped by inner wrappers */
.portal-navbar,
.portal-navbar .container-fluid,
.portal-navbar .navbar-collapse{
  overflow: visible !important;
}

.portal-navbar{
  padding: .55rem 0;
}

/* Mobile brand */
.portal-navbar__mobileBrand{
  color: var(--primary) !important;
  letter-spacing: .2px;
}

/* Toggler */
.portal-navbar__togglerIcon{
  display:flex;
  align-items:center;
  justify-content:center;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: #fff;
}

.navbar-toggler{
  border: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
}

/* Links */
.portal-navbar__links{
  gap: .15rem;
}

/* Nav links */
.portal-navbar .nav-link{
  color:#121416 !important;
  font-size:.98rem;
  font-weight:800;
  padding: .55rem .75rem !important;
  border-radius: 999px;
  line-height:1.1;
  transition: background .15s ease, color .15s ease, transform .15s ease;
}

.portal-navbar .nav-link:hover{
  background: #f3f4f7;
  color: var(--primary) !important;
  transform: translateY(-1px);
}

.portal-navbar .nav-link.active{
  background: rgba(211,47,47,.10);
  color: var(--primary) !important;
}

.portal-navbar__more{
  font-weight: 900;
}

/* ==========================================
   Mega Menu (ULTRA Premium)
   - no icons required
   - hover intent friendly
   ========================================== */

.portal-mega{
  position: static; /* allows wide menu alignment */
}

.portal-mega .dropdown-toggle::after{
  margin-left: .5rem;
}

/* Ensure mega is above sticky layers */
.portal-mega__menu{
  z-index: 2000 !important;
}

/* Mega dropdown container */
.portal-mega__menu--ultra{
  width: min(1120px, calc(100vw - 2rem));
  padding: 0;
  border: 0;
  margin-top: 14px;
  border-radius: 18px;
  overflow: visible;
  background: transparent;
}

/* Inner "glass" frame */
.portal-mega__inner--ultra{
  background:
    radial-gradient(1200px 140px at 40% 0%, rgba(211,47,47,.10), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(255,255,255,.96) 100%);
  border: 1px solid rgba(0,0,0,.07);
  border-radius: 18px;
  box-shadow: var(--shadow);
  overflow: hidden;
}

/* Header */
.portal-mega__head--ultra{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(0,0,0,.06);
}

.portal-mega__title{
  font-weight: 950;
  letter-spacing: .2px;
  color: #101214;
}

.portal-mega__all{
  text-decoration:none;
  font-weight: 900;
  font-size: .9rem;
  color: var(--primary);
  background: rgba(211,47,47,.08);
  border: 1px solid rgba(211,47,47,.18);
  padding: .45rem .75rem;
  border-radius: 999px;
  transition: background .15s ease, transform .15s ease, color .15s ease;
}
.portal-mega__all:hover{
  background: rgba(211,47,47,.12);
  transform: translateY(-1px);
  color: var(--primary-dark);
}

/* Body split */
.portal-mega__body{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 0;
}

.portal-mega__left{
  padding: 14px 14px 10px;
  border-right: 1px solid rgba(0,0,0,.06);
}

.portal-mega__right{
  padding: 14px;
  background: linear-gradient(180deg, rgba(246,247,251,.65), rgba(255,255,255,.0));
}

/* Category grid */
.portal-mega__grid--ultra{
  --mega-cols: 3;
  display:grid;
  grid-template-columns: repeat(var(--mega-cols), minmax(0, 1fr));
  gap: 10px;
}

/* Category item */
.portal-mega__item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;

  text-decoration:none;
  color:#15171a;

  padding: .7rem .75rem;
  border-radius: 14px;

  background: rgba(0,0,0,.02);
  border: 1px solid rgba(0,0,0,.06);

  transition: background .15s ease, transform .15s ease, border-color .15s ease, box-shadow .15s ease;
}

.portal-mega__item:hover{
  background: rgba(211,47,47,.06);
  border-color: rgba(211,47,47,.18);
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(16,18,20,.06);
  color: var(--primary);
}

.portal-mega__item.is-active{
  background: rgba(211,47,47,.10);
  border-color: rgba(211,47,47,.22);
  color: var(--primary);
}

.portal-mega__name{
  font-weight: 850;
  font-size: .95rem;
  line-height: 1.2;
  min-width: 0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.portal-mega__count{
  font-weight: 950;
  font-size: .8rem;
  color: rgba(0,0,0,.55);
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 999px;
  padding: .1rem .55rem;
  flex: 0 0 auto;
}

/* Footer hint */
.portal-mega__foot{
  padding: 10px 4px 4px;
  display:flex;
  justify-content:flex-end;
}

.portal-mega__hint{
  font-size: .85rem;
  color: rgba(0,0,0,.55);
}

/* Right preview panels */
.portal-mega__panel{
  background: rgba(255,255,255,.85);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 16px;
  box-shadow: 0 12px 24px rgba(16,18,20,.05);
  overflow:hidden;
}

.portal-mega__panel + .portal-mega__panel{
  margin-top: 12px;
}

.portal-mega__panelHead{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap: 10px;
  padding: 12px 12px 10px;
  border-bottom: 1px solid rgba(0,0,0,.06);
}

.portal-mega__panelTitle{
  font-weight: 950;
  letter-spacing: .2px;
  color: #101214;
}

.portal-mega__panelSub{
  font-size: .85rem;
  color: rgba(0,0,0,.55);
  font-weight: 700;
}

.portal-mega__panelBody{
  padding: 10px;
}

/* Preview row */
.portal-mega__newsRow{
  display:flex;
  gap: 10px;
  align-items:center;
  text-decoration:none;
  color: inherit;

  padding: .55rem .55rem;
  border-radius: 14px;
  transition: background .15s ease, transform .15s ease;
}

.portal-mega__newsRow:hover{
  background: rgba(0,0,0,.03);
  transform: translateY(-1px);
  color: var(--primary);
}

.portal-mega__thumb{
  width: 44px;
  height: 44px;
  border-radius: 12px;
  overflow:hidden;
  background: #eef1f4;
  border: 1px solid rgba(0,0,0,.06);
  flex: 0 0 auto;
}

.portal-mega__thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.portal-mega__newsMeta{
  display:flex;
  flex-direction:column;
  gap: 2px;
  min-width: 0;
}

.portal-mega__newsTitle{
  font-weight: 900;
  font-size: .92rem;
  line-height: 1.2;
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
  color: #101214;
}

.portal-mega__newsRow:hover .portal-mega__newsTitle{
  color: var(--primary);
}

.portal-mega__newsSub{
  font-size: .82rem;
  color: rgba(0,0,0,.55);
  font-weight: 700;
}

/* Empty state */
.portal-mega__empty{
  padding: 14px;
  border-radius: 16px;
  border: 1px dashed rgba(0,0,0,.12);
  background: rgba(255,255,255,.75);
  color: rgba(0,0,0,.6);
  font-weight: 700;
}

/* Keep mega aligned under trigger */
.portal-mega .dropdown-menu{
  left: 0;
  right: auto;
}

/* Better on smaller desktops */
@media (max-width: 1199.98px){
  .portal-mega__grid--ultra{ --mega-cols: 2; }
  .portal-mega__body{ grid-template-columns: 1fr; }
  .portal-mega__left{ border-right: 0; }
  .portal-mega__right{ display:none !important; }
}

/* Mobile collapse spacing */
@media (max-width: 991.98px){
  .portal-navbar .navbar-collapse{
    padding-top: .85rem;
    padding-bottom: .25rem;
  }
  .portal-navbar__links{
    gap: .35rem;
  }
  .portal-navbar .nav-link{
    padding: .65rem .9rem !important;
  }
  /* On mobile we use click, not mega dropdown hover */
  .portal-mega__menu--ultra{
    width: calc(100vw - 2rem);
    margin-top: 10px;
  }
}