/* ITW Menu - Scoped styles */
.itw-menu-wrapper { position: relative; display: block; }
.itw-menu-wrapper .itw-toggle { display: none; background: transparent; border: 0; width: 2.5em; height: 2.5em; align-items: center; justify-content: center; gap: .35em; flex-direction: column; cursor: pointer; }
.itw-menu-wrapper .itw-toggle span { display: block; width: 1.4em; height: .16em; background: currentColor; transition: transform .25s ease, opacity .25s ease; will-change: transform, opacity; }
/* Explicit reset for closed state */
.itw-menu-wrapper .itw-toggle[aria-expanded="false"] span:nth-child(1),
.itw-menu-wrapper .itw-toggle[aria-expanded="false"] span:nth-child(3) { transform: none; }
.itw-menu-wrapper .itw-toggle[aria-expanded="false"] span:nth-child(2) { opacity: 1; }
/* Morph hamburger to X when open */
.itw-menu-wrapper .itw-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.itw-menu-wrapper .itw-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.itw-menu-wrapper .itw-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

/* Desktop menu */
.itw-menu { list-style: none; margin: 0; padding: 0; display: flex; align-items: center; gap: 28px; position: relative; }
.itw-menu > li { position: relative; }
.itw-menu > li > a { display: inline-flex; align-items: center; gap: .5rem; text-decoration: none; position: relative; line-height: 1; }
.itw-menu > li > a::after { display: none !important; content: none; }
/* Main items: background on hover/active */
.itw-menu > li > a { border-radius: 6px; padding: 10px 14px; }
.itw-menu > li:hover > a { background: rgba(242,106,33,.15); }

/* Submenu base - defaults resemble the provided design (overridable in widget) */
.itw-menu .itw-submenu { list-style: none; margin: 0; padding: 22px 28px; display: grid; gap: 12px 48px; position: absolute; top: 100%; left: 50%; width: min(1200px, calc(100vw - 24px)); background: #63676c; color: #fff; border-radius: 6px; box-shadow: 0 10px 30px rgba(0,0,0,.15); opacity: 0; visibility: hidden; transform: translate(calc(-50% + var(--itw-shift, 0px)), 10px); transition: opacity .2s ease, transform .2s ease, visibility .2s; z-index: 50; max-height: var(--itw-maxh, calc(100vh - 160px)); overflow: auto; }
.itw-menu .itw-submenu a { display: flex; align-items: center; gap: 10px; padding: 8px 6px; text-decoration: none; color: #fff; border-radius: 4px; text-transform: uppercase; letter-spacing: .06em; font-weight: 600; }
.itw-menu .itw-submenu li:hover > a { background: rgba(255,255,255,.06); }
/* Default submenu icon look (orange caret style) */
.itw-submenu-icon { display: inline-flex; align-items: center; justify-content: center; color: #f26a21; fill: currentColor; font-size: 10px; width: 10px; margin-inline-end: 10px; line-height: 1; flex: 0 0 auto; }
.itw-submenu-icon svg,
.itw-submenu-icon i { display: block; width: 1em; height: 1em; }

/* Open on hover (desktop) */
@media (hover:hover) and (pointer:fine) {
  .itw-menu > li:hover > .itw-submenu { opacity: 1; visibility: visible; transform: translate(calc(-50% + var(--itw-shift, 0px)), var(--itw-sub-open-y, 0)); }
}

/* Keyboard-open state */
.itw-menu li.itw-open > .itw-submenu { opacity: 1; visibility: visible; transform: translate(calc(-50% + var(--itw-shift, 0px)), var(--itw-sub-open-y, 0)); }

/* Nested submenus (right side) */
.itw-menu .itw-submenu .itw-submenu { top: 0; inset-inline-start: 100%; min-width: 260px; }

/* Mobile panel */
.itw-mobile-panel { position: fixed; inset: 0; background: rgba(0,0,0,.92); color: #fff; display: none; z-index: 9999; }
.itw-mobile-panel[hidden] { display: none !important; }
.itw-mobile-panel.open { display: block; }
.itw-mobile-panel .itw-mobile-inner { position: absolute; inset: 0; padding: 28px 22px; overflow: auto; }
/* Close button top-right */
.itw-mobile-panel .itw-close { position: absolute; top: 16px; right: 16px; background: transparent; border: 0; color: #fff; cursor: pointer; }
.itw-mobile-panel .itw-close svg { width: 1em !important; height: 1em !important; display: block; }

/* Slide variants */
.itw-mobile-panel[data-layout="left"].open .itw-mobile-inner { animation: itw-slide-left .28s ease forwards; }
.itw-mobile-panel[data-layout="right"].open .itw-mobile-inner { animation: itw-slide-right .28s ease forwards; }
.itw-mobile-panel[data-layout="overlay"].open .itw-mobile-inner { animation: itw-fade-in .2s ease forwards; }
@keyframes itw-slide-left { from { transform: translateX(-22%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes itw-slide-right { from { transform: translateX(22%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes itw-fade-in { from { opacity: 0; } to { opacity: 1; } }

/* Mobile menu list */
.itw-mobile-panel .itw-mobile-menu { list-style: none; margin: 60px 0 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.itw-mobile-panel .itw-mobile-menu > li > a { display: flex; align-items: center; justify-content: center; position: relative; padding: 14px 6px; text-decoration: none; color: #fff; font-weight: 600; letter-spacing: .08em; }
.itw-mobile-panel .itw-mobile-menu > li > a .itw-caret { position: absolute; right: 6px; }

/* Accordion */
.itw-mobile-panel .itw-mobile-menu .itw-submenu { position: static; display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 8px 16px; min-width: auto; background: transparent; box-shadow: none; padding: 8px 0 8px 8px; opacity: 1; visibility: visible; transform: none; }
.itw-accordion { overflow: hidden; transition: grid-template-rows .25s ease; }
/* Stronger rule so hidden state wins over grid display */
.itw-mobile-panel .itw-mobile-menu .itw-accordion[aria-hidden="true"],
.itw-mobile-panel .itw-mobile-menu .itw-submenu[aria-hidden="true"] { display: none !important; }

/* Responsive switch */
@media (max-width: 992px) {
  .itw-menu { display: none; }
  .itw-menu-wrapper .itw-toggle { display: inline-flex; }
}

/* RTL support */
:root[dir="rtl"] .itw-menu > li > a::after { transform-origin: right; }
:root[dir="rtl"] .itw-menu .itw-submenu { inset-inline-start: auto; inset-inline-end: 0; }
:root[dir="rtl"] .itw-menu .itw-submenu .itw-submenu { inset-inline-end: 100%; inset-inline-start: auto; }

html, body { overflow-x: hidden; }
