/* Glass dropdown redesign for services menu
   Overrides aggressive white dropdown styles from bundled main.css */

.page__header {
  position: relative;
  z-index: 120;
}

.header-nav .nav-item.has-submenu {
  position: relative;
}

.header-nav .submenu {
  margin-top: 12px !important;
  padding: 14px !important;
  border-radius: 16px !important;
  border: 1px solid rgba(220, 238, 255, 0.30) !important;
  background: linear-gradient(160deg, rgba(18, 31, 46, 0.62), rgba(24, 41, 61, 0.58)) !important;
  box-shadow: 0 24px 42px rgba(8, 18, 30, 0.40) !important;
  backdrop-filter: blur(22px) saturate(145%);
  -webkit-backdrop-filter: blur(22px) saturate(145%);
  min-width: 430px !important;
  max-width: 600px !important;
  max-height: min(72vh, 560px) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  scrollbar-width: thin;
  scrollbar-color: rgba(177, 208, 236, 0.45) rgba(255, 255, 255, 0.08);
}

.header-nav .submenu::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 16px;
  background: radial-gradient(120% 140% at 0% 0%, rgba(255,255,255,0.16), transparent 55%);
  pointer-events: none;
}

.header-nav .submenu li,
.header-nav .submenu .submenu-section,
.header-nav .submenu .submenu-sub li {
  list-style: none;
}

.header-nav .submenu .submenu-section {
  position: relative;
  z-index: 1;
  margin-bottom: 10px;
  padding: 8px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.045) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.header-nav .submenu .submenu-section:last-child {
  margin-bottom: 0;
}

.header-nav .submenu .submenu-section-title {
  display: block;
  margin: 0 0 6px;
  padding: 8px 10px !important;
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.04) !important;
  color: rgba(237, 247, 255, 0.96) !important;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.header-nav .submenu .submenu-sub {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 4px;
}

.header-nav .submenu-sub li a,
.header-nav .submenu > li > a,
.header-nav .submenu a {
  position: relative;
  display: block;
  padding: 8px 10px !important;
  border-radius: 9px;
  background: transparent !important;
  color: rgba(227, 242, 255, 0.94) !important;
  text-decoration: none;
  font-size: 14px !important;
  font-weight: 500;
  line-height: 1.3;
  border-left: none !important;
  transition: background-color 0.22s ease, color 0.22s ease, transform 0.22s ease;
}

.header-nav .submenu-sub li a:hover,
.header-nav .submenu > li > a:hover,
.header-nav .submenu a:hover {
  background: rgba(180, 215, 245, 0.18) !important;
  color: #ffffff !important;
  transform: translateX(2px);
  padding-left: 10px !important;
}

.header-nav .submenu a.active,
.header-nav .submenu a.current,
.header-nav .submenu-sub a.active,
.header-nav .submenu-sub a.current {
  background: rgba(89, 146, 193, 0.34) !important;
  color: #ffffff !important;
  border-left: none !important;
  font-weight: 600;
}

.header-nav .submenu a:active {
  transform: translateX(0) scale(0.995);
}

.header-nav .submenu::-webkit-scrollbar {
  width: 8px;
}

.header-nav .submenu::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.08);
  border-radius: 99px;
}

.header-nav .submenu::-webkit-scrollbar-thumb {
  background: rgba(177, 208, 236, 0.45);
  border-radius: 99px;
}

.header-nav .submenu::-webkit-scrollbar-thumb:hover {
  background: rgba(177, 208, 236, 0.62);
}

/* Header menu fit fix (desktop/tablet): prevent wrapping at ~1080 widths */
@media (min-width: 769px) {
  .page__header {
    gap: clamp(10px, 1.2vw, 26px);
  }

  .header-nav {
    flex: 1 1 auto;
    min-width: 0;
    justify-content: center;
    flex-wrap: nowrap;
    gap: clamp(8px, 0.9vw, 20px);
  }

  .header-nav a,
  .header-nav .nav-link {
    white-space: nowrap;
    font-size: clamp(12px, calc(0.45vw + 9px), 18px) !important;
    line-height: 1.15;
  }

  .header-nav .nav-item-wrapper {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    white-space: nowrap;
  }

  .header-contacts {
    flex: 0 0 auto;
    gap: clamp(8px, 0.8vw, 18px);
  }

  .header-contacts a,
  .header__mail,
  .header__phone {
    white-space: nowrap;
    font-size: clamp(13px, calc(0.4vw + 9px), 18px) !important;
    line-height: 1.15;
  }
}

/* Tight width zone where wrapping was visible */
@media (min-width: 1024px) and (max-width: 1280px) {
  .page__header {
    padding-left: 16px;
    padding-right: 16px;
  }

  .header-nav {
    gap: 10px;
  }

  .header-nav a,
  .header-nav .nav-link {
    font-size: 13px !important;
  }
}

/* Services dropdown contrast + accordion redesign */
.header-nav .submenu {
  border: 1px solid rgba(209, 232, 255, 0.42) !important;
  background: linear-gradient(165deg, rgba(12, 25, 40, 0.88), rgba(20, 36, 54, 0.84)) !important;
  box-shadow: 0 24px 48px rgba(4, 12, 22, 0.58), inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
}

.header-nav .submenu::before {
  background: radial-gradient(120% 130% at 0% 0%, rgba(255, 255, 255, 0.20), transparent 56%);
}

.header-nav .submenu .submenu-section {
  margin-bottom: 8px;
  padding: 6px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
}

.header-nav .submenu .submenu-section-title.submenu-section-toggle {
  width: 100%;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .04em;
  color: rgba(245, 252, 255, 0.98) !important;
  border: 1px solid rgba(198, 226, 248, 0.22);
  background: linear-gradient(180deg, rgba(174, 209, 238, 0.16), rgba(174, 209, 238, 0.06)) !important;
}

.header-nav .submenu .submenu-section-title.submenu-section-toggle:hover {
  background: linear-gradient(180deg, rgba(192, 224, 250, 0.22), rgba(192, 224, 250, 0.10)) !important;
  color: #fff !important;
}

.header-nav .submenu .submenu-section-chevron {
  display: inline-flex;
  transition: transform .25s ease;
  opacity: .95;
}

.header-nav .submenu .submenu-sub {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  margin-top: 0;
  transition: max-height .28s ease, opacity .2s ease, margin-top .2s ease;
}

.header-nav .submenu .submenu-section.is-open .submenu-sub {
  max-height: 420px;
  opacity: 1;
  margin-top: 6px;
}

.header-nav .submenu .submenu-section.is-open .submenu-section-chevron {
  transform: rotate(180deg);
}

.header-nav .submenu-sub li a,
.header-nav .submenu > li > a,
.header-nav .submenu a {
  color: rgba(233, 245, 255, 0.97) !important;
}

.header-nav .submenu-sub li a:hover,
.header-nav .submenu > li > a:hover,
.header-nav .submenu a:hover {
  background: rgba(173, 211, 242, 0.26) !important;
}

/* Right aligned submenu section titles */
.header-nav .submenu .submenu-section-toggle {
  justify-content: flex-start;
}

.header-nav .submenu .submenu-section-label {
  margin-left: 0;
  margin-right: auto;
  text-align: left;
  display: block;
}

/* Long section title horizontal scroll */
.header-nav .submenu .submenu-section-toggle {
  overflow: hidden;
}

.header-nav .submenu .submenu-section-label {
  max-width: calc(100% - 24px);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.header-nav .submenu .submenu-section-toggle.has-overflow:hover .submenu-section-label {
  text-overflow: clip;
  animation: submenuLabelMarquee 4.8s ease-in-out infinite alternate;
}

@keyframes submenuLabelMarquee {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(calc(-1 * var(--label-scroll-distance, 0px)));
  }
}

/* Deeper level marquee: animate only service items, not section titles */
.header-nav .submenu .submenu-section-label {
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
}

.header-nav .submenu .submenu-sub li a {
  overflow: hidden;
  white-space: nowrap;
}

.header-nav .submenu .submenu-sub li a .submenu-link-label {
  display: inline-block;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: top;
}

.header-nav .submenu .submenu-sub li a.has-overflow-text:hover .submenu-link-label {
  text-overflow: clip;
  animation: submenuServiceMarquee 5.4s ease-in-out infinite alternate;
}

@keyframes submenuServiceMarquee {
  from { transform: translateX(0); }
  to { transform: translateX(calc(-1 * var(--link-scroll-distance, 0px))); }
}

/* Final: fit menu width to text OR scroll long labels on hover (all submenu levels) */
@media (min-width: 1025px) {
  .header-nav .submenu {
    width: max-content !important;
    min-width: 340px !important;
    max-width: min(72vw, 980px) !important;
    padding: 10px !important;
  }

  .header-nav .submenu .submenu-section {
    max-width: 100%;
  }

  .header-nav .submenu .submenu-section-toggle {
    width: max-content !important;
    min-width: 100% !important;
    max-width: 100% !important;
    overflow: hidden;
  }

  .header-nav .submenu .submenu-section-label {
    display: inline-block;
    max-width: calc(100% - 24px) !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .header-nav .submenu .submenu-section-toggle.has-overflow-label:hover .submenu-section-label {
    text-overflow: clip;
    animation: submenuLabelMarquee 5.2s ease-in-out infinite alternate;
  }

  .header-nav .submenu .submenu-sub {
    width: max-content !important;
    min-width: 100% !important;
    max-width: min(76vw, 1100px) !important;
  }

  .header-nav .submenu .submenu-sub li a {
    width: max-content;
    min-width: 100%;
    max-width: 100%;
    overflow: hidden;
    white-space: nowrap !important;
  }

  .header-nav .submenu .submenu-sub li a .submenu-link-label {
    display: inline-block;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .header-nav .submenu .submenu-sub li a.has-overflow-text:hover .submenu-link-label {
    text-overflow: clip;
    animation: submenuServiceMarquee 5.6s ease-in-out infinite alternate;
  }
}

@media (max-width: 1024px) {
  .header-nav .submenu,
  .header-nav .submenu .submenu-sub {
    width: 100% !important;
    max-width: 100% !important;
  }

  .header-nav .submenu .submenu-sub li a,
  .header-nav .submenu .submenu-section-label {
    white-space: normal !important;
  }
}

/* FINAL overflow fix: no cut text in services submenu */
@media (min-width: 1025px) {
  .header-nav .submenu {
    width: clamp(420px, 42vw, 820px) !important;
    min-width: 420px !important;
    max-width: min(86vw, 980px) !important;
  }

  .header-nav .submenu .submenu-sub {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .header-nav .submenu .submenu-sub li a {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    box-sizing: border-box;
  }

  .header-nav .submenu .submenu-sub li a .submenu-link-label {
    display: inline-block;
    max-width: 100%;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
  }

  .header-nav .submenu .submenu-sub li a.has-overflow-text:hover .submenu-link-label {
    text-overflow: clip;
    animation: submenuServiceMarquee 6.2s linear infinite alternate;
  }
}

/* Real text marquee fix: move text content, not clipped box */
@media (min-width: 1025px) {
  .header-nav .submenu .submenu-sub li a {
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
  }

  .header-nav .submenu .submenu-sub li a .submenu-link-label {
    display: inline-block !important;
    width: max-content !important;
    min-width: 100% !important;
    max-width: none !important;
    white-space: nowrap !important;
    overflow: visible !important;
    text-overflow: clip !important;
    will-change: transform;
  }

  .header-nav .submenu .submenu-sub li a.has-overflow-text:hover {
    text-overflow: clip !important;
  }

  .header-nav .submenu .submenu-sub li a.has-overflow-text:hover .submenu-link-label {
    animation: submenuServiceMarquee 7s linear infinite alternate !important;
  }

  .header-nav .submenu .submenu-section-toggle .submenu-section-label {
    display: inline-block !important;
    width: max-content !important;
    min-width: 100% !important;
    max-width: none !important;
    overflow: visible !important;
    text-overflow: clip !important;
    white-space: nowrap !important;
  }

  .header-nav .submenu .submenu-section-toggle.has-overflow-label:hover .submenu-section-label {
    animation: submenuLabelMarquee 7s linear infinite alternate !important;
  }
}

/* Menu tune: less framing, slightly larger */
.header-nav .submenu {
  min-width: 470px !important;
  max-width: 680px !important;
  padding: 12px !important;
}

.header-nav .submenu .submenu-section {
  border: 0 !important;
  background: transparent !important;
  padding: 4px 0 !important;
}

.header-nav .submenu .submenu-section-title.submenu-section-toggle {
  border: 0 !important;
  background: rgba(255, 255, 255, 0.04) !important;
  font-size: 15px !important;
  padding: 10px 12px !important;
}

.header-nav .submenu-sub li a,
.header-nav .submenu > li > a,
.header-nav .submenu a {
  font-size: 15px !important;
  padding: 9px 12px !important;
  border: 0 !important;
  box-shadow: none !important;
}

.header-nav .submenu-sub li a:hover,
.header-nav .submenu > li > a:hover,
.header-nav .submenu a:hover {
  background: rgba(180, 215, 245, 0.16) !important;
}
