/* Mega Menu — Top level list */
.mega-menu {
  display: flex;
  align-items: center;
  gap: var(--spacing-50);
  list-style: none;
  margin: 0;
  padding: 0;
}

.mega-menu__item {
  position: static;
}

.mega-menu__link {
  color: var(--color-dark-blue);
  font-size: var(--p-size);
  font-weight: var(--font-weight-regular);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: var(--spacing-xs) 0;
  transition: color var(--transition-fast);
  text-decoration: none;
  display: block;
}

.mega-menu__icon {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  color: currentColor;
}

.mega-menu__icon svg {
  width: 20px;
  height: 20px;
  display: block;
}

.mega-menu__link:hover {
  color: var(--color-primary);
}

/* Dropdown panel */
.mega-menu__panel {
  display: none;
  position: absolute;
  left: auto;
  right: 0;
  top: 100%;
  background: var(--color-background);
  box-shadow: none;
  border-top: none;
  z-index: 999;
  min-width: 850px;
}

.mega-menu__panel--full {
  left: 50%;
  right: auto;
  transform: translateX(-50%);
  min-width: auto;
}

.mega-menu__panel.is-open {
  display: block;
}

.mega-menu__panel-inner {
  display: flex;
  gap: 0;
  padding: 0 0 12px;
  align-items: stretch;
  max-width: 1440px;
}

/* Orange sidebar */
.mega-menu__sidebar {
  flex: 0 0 300px;
  background-color: var(--color-primary);
  border-radius: 0;
  padding: var(--spacing-xl) var(--spacing-30);
  display: flex;
  flex-direction: column;
  gap: 0;
}

.mega-menu__sidebar-link {
  color: var(--color-white);
  font-size: 15px;
  padding: var(--spacing-xs);
  transition: background-color var(--transition-fast);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.mega-menu__sidebar-link strong {
  font-size: var(--p-size);
  line-height: var(--p-lh);
  font-weight: 700;
}

.mega-menu__sidebar-desc {
  font-size: var(--p-size);
  line-height: 18px;
  font-weight: var(--font-weight-regular);
}

.mega-menu__sidebar-link:hover {
  background-color: rgba(255, 255, 255, 0.15);
  color: var(--color-white);
}

/* Dark sidebar style */
.mega-menu__sidebar--dark {
  background-color: var(--color-footer-bg);
}

.mega-menu__sidebar-divider {
  border: none;
  border-top: 1px solid var(--color-white);
  margin: 32px 0;
}

/* Content area */
.mega-menu__content {
  flex: 1;
  padding: var(--spacing-xl) var(--spacing-30) var(--spacing-xl) var(--spacing-30);
}

@media (min-width: 1300px) {
  .mega-menu__content {
    padding-right: 0;
  }
}

/* =============================================
   Solutions — 3 columns with images & hierarchy
   ============================================= */
.mega-menu__solutions {
  display: flex;
  gap: var(--spacing-30);
  align-items: stretch;
}

.mega-menu__sol-column {
  flex: 0 0 320px;
  max-width: 345px;
  display: flex;
  flex-direction: column;
}

.mega-menu__sol-column:has(.mega-menu__sol-list) {
  flex-basis: 345px;
}

/* Column header image */
.mega-menu__sol-image {
  text-align: center;
  margin-bottom: var(--spacing-sm);
}

.mega-menu__sol-image img {
  width: 100%;
  height: 140px;
  object-fit: cover;
}

/* Column title — orange uppercase */
.mega-menu__sol-title {
  color: var(--color-primary);
  font-family: var(--font-family);
  font-size: var(--h4-size);
  line-height: var(--h4-lh);
  font-weight: 700;
  text-transform: uppercase;
  margin: 0 0 var(--spacing-md);
  padding: 0;
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.mega-menu__sol-title .mega-menu__icon svg {
  width: 24px;
  height: 24px;
}

/* Body — text area below image */
.mega-menu__sol-body {
  background: color-mix(in srgb, var(--color-background-alt) 50%, transparent);
  border: 1px solid var(--color-medium-gray);
  border-radius: var(--radius-card-lg);
  padding: var(--spacing-sm);
  flex: 1;
}

/* Subcategory group */
.mega-menu__sol-group {
  margin-bottom: 12px;
}

/* Group title (e.g. "Two-Way Radios & Accessories") */
.mega-menu__sol-group-title {
  font-family: var(--font-family);
  font-size: var(--h5-size);
  font-weight: 700;
  line-height: var(--h5-lh);
  letter-spacing: 0;
  color: var(--color-dark-blue);
  text-transform: uppercase;
  margin: 0 0 12px;
  padding: 0;
}

/* Subcategory heading within group (e.g. "Radios", "Accessories") */
.mega-menu__sol-subtitle {
  font-family: var(--font-family);
  font-size: var(--p-size);
  font-weight: var(--font-weight-regular);
  line-height: var(--p-lh);
  letter-spacing: 0;
  color: var(--color-dark-blue);
  text-transform: none;
  margin: 0;
  padding: 0 0 0 var(--spacing-xs);
}

.mega-menu__sol-list + .mega-menu__sol-subtitle {
  margin-top: 26px;
}

/* Bullet list under subcategory */
.mega-menu__sol-list {
  list-style: none;
  margin: 12px 0 0;
  padding: 0 0 0 var(--spacing-xs);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.mega-menu__sol-list li {
  font-family: var(--font-family);
  font-size: var(--p-size);
  font-weight: var(--font-weight-regular);
  line-height: var(--p-lh);
  color: var(--color-dark-blue);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.mega-menu__sol-list li::before {
  content: '';
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--color-error-orange) 60%, transparent);
  flex-shrink: 0;
}

.mega-menu__sol-list a {
  color: var(--color-dark-blue);
  transition: color var(--transition-fast);
}

.mega-menu__sol-list a:hover {
  color: var(--color-primary);
  text-decoration: underline;
  text-decoration-color: var(--color-primary);
}

/* Standalone bold link (Repeaters, BDA/DAS, etc.) */
.mega-menu__sol-link {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  font-family: var(--font-family);
  font-size: var(--h5-size);
  font-weight: 700;
  line-height: var(--h5-lh);
  letter-spacing: 0;
  color: var(--color-dark-blue);
  text-transform: uppercase;
  padding: 0;
  margin-bottom: var(--spacing-sm);
  transition: color var(--transition-fast);
}

.mega-menu__sol-link:last-child {
  margin-bottom: 0;
}

.mega-menu__sol-link:has(.mega-menu__icon) {
  padding: 6px 0;
}

.mega-menu__sol-list a {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.mega-menu__sol-link:hover {
  color: var(--color-primary);
  text-decoration: underline;
  text-decoration-color: var(--color-primary);
}

/* Industries — grid */
.mega-menu__grid--industries {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
}

.mega-menu__grid--industries .mega-menu__grid-item {
  flex: 0 0 calc(33.333% - var(--spacing-sm));
}

@media (max-width: 1100px) {
  .mega-menu__grid--industries .mega-menu__grid-item {
    flex: 0 0 calc(50% - var(--spacing-sm));
  }
}

.mega-menu__grid-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: 4px 0;
  color: var(--color-dark-blue);
  font-family: 'Roboto Condensed', var(--font-family);
  font-size: var(--h5-size);
  line-height: var(--h5-lh);
  font-weight: var(--font-weight-regular);
  text-transform: uppercase;
  letter-spacing: 0;
  transition: color var(--transition-fast);
}

.mega-menu__grid-item:hover {
  background-color: var(--color-background);
  color: var(--color-primary);
  text-decoration: underline;
  text-decoration-color: var(--color-primary);
}

/* Cards — Rentals (4) / Resources (3) */
.mega-menu__grid--cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-30);
  max-width: 1020px;
}

/* 4+ cards — use 4 columns */
.mega-menu__grid--cards:has(.mega-menu__card:nth-child(4)) {
  grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 1200px) {
  .mega-menu__grid--cards:has(.mega-menu__card:nth-child(4)) {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 960px) {
  .mega-menu__grid--cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

.mega-menu__card {
  display: flex;
  flex-direction: column;
  border-radius: var(--radius-card);
  overflow: hidden;
  transition: box-shadow var(--transition-fast);
  color: var(--color-text-primary);
  gap: var(--spacing-sm);
  padding: var(--spacing-xs);
}

.mega-menu__card:hover {
  color: var(--color-primary);
  text-decoration: underline;
  text-decoration-color: var(--color-primary);
}

.mega-menu__card-image {
  width: 100%;
  width: 100%;
  height: 185px;
  background-color: var(--color-background);
  border-radius: var(--radius-card);
  object-fit: cover;
  display: block;
}

.mega-menu__card-title {
  padding: 0;
  font-family: 'Roboto Condensed', var(--font-family);
  font-size: var(--h5-size);
  line-height: var(--h5-lh);
  font-weight: var(--font-weight-regular);
  text-transform: uppercase;
  color: var(--color-dark-blue);
}

/* About — sidebar inside content, reset content padding */
.mega-menu__panel--about .mega-menu__content {
  padding: 0;
}

.mega-menu__about-layout {
  display: flex;
  gap: var(--spacing-lg);
  align-items: stretch;
}

.mega-menu__about-layout .mega-menu__about-list {
  padding-top: var(--spacing-xl);
}

.mega-menu__about-list {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--container-padding);
}

.mega-menu__about-link {
  color: var(--color-dark-blue);
  font-family: 'Roboto Condensed', var(--font-family);
  font-size: var(--h5-size);
  line-height: var(--h5-lh);
  font-weight: var(--font-weight-regular);
  text-transform: uppercase;
  letter-spacing: 0;
  padding: 4px 0;
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  transition: color var(--transition-fast);
}

.mega-menu__about-link:hover {
  color: var(--color-primary);
  text-decoration: underline;
  text-decoration-color: var(--color-primary);
}

/* === Solutions responsive === */

/* Step 1: Smaller cards, reduce padding */
@media (max-width: 1400px) {
  .mega-menu__sol-column {
    flex: 1 1 0;
    max-width: none;
  }

  .mega-menu__sol-column:has(.mega-menu__sol-list) {
    flex-basis: 0;
  }

  .mega-menu__content {
    padding: 40px 24px;
  }

  .mega-menu__sol-image img {
    height: 120px;
  }
}

/* Step 2: Smaller gap, hide images, reduce sidebar */
@media (max-width: 1200px) {
  .mega-menu__solutions {
    gap: var(--spacing-sm);
  }

  .mega-menu__sol-image {
    display: none;
  }

  .mega-menu__sol-body {
    padding: 12px;
  }

  .mega-menu__sidebar {
    flex: 0 0 240px;
    padding: 40px 20px;
  }

  .mega-menu__content {
    padding: 30px 20px;
  }

  .mega-menu__sol-title {
    font-size: 16px;
    margin-bottom: var(--spacing-sm);
  }

  .mega-menu__sol-group-title,
  .mega-menu__sol-subtitle {
    font-size: 14px;
  }

  .mega-menu__sol-list li,
  .mega-menu__sol-link {
    font-size: 14px;
  }
}


/* Hide mega-menu dropdowns on mobile (desktop only) */
@media (max-width: 960px) {
  .site-header__nav .mega-menu__panel,
  .site-header__nav .mega-menu__panel.is-open {
    display: none;
  }
}
