.promo-menu { padding-top: 1.5em; padding-bottom: 1.5em; position: relative; font-size: 14px; color: #fff; }

.promo-menu-button { width: 48px; height: 48px; margin: 0 auto; border-radius: 48px; position: relative; background-color: #fff; box-shadow: 0 1px 1px rgba(0, 0, 0, 0.25); }

.promo-menu-icon { width: 24px; height: 2px; margin-top: -1px; margin-left: -12px; position: absolute; z-index: 1; top: 50%; left: 50%; background-color: #002544; }
.promo-menu-icon:before, .promo-menu-icon:after { content: ''; height: 2px; position: absolute; top: -8px; left: 0; right: 0; background-color: #002544; }
.promo-menu-icon:after { top: 8px; }

.promo-menu-items { display: none; position: absolute; z-index: 50; top: 100%; left: 0; right: 0; font-size: 0; background: rgba(0, 0, 0, 0.5); }
.promo-menu-items.active { display: block; }

.promo-menu-item { font-size: 14px; }
.promo-menu-item.active .promo-menu-link .promo-menu-link-text:after { content: ''; display: block; width: 80%; height: 1px; margin: -1px auto 0; position: relative; top: 3px; background-color: #fff; }
.promo-menu-item.active .promo-menu-link:hover { color: #fff; }
.promo-menu-item.active .promo-menu-link:hover .promo-menu-link-text { text-decoration: none; }

.promo-menu-link { display: block; padding: 1em; color: #fff; text-decoration: none; }
.promo-menu-link:hover { color: #ddd; text-decoration: none; cursor: pointer; }
.promo-menu-link:hover .promo-menu-link-text { text-decoration: none; }

.promo-menu-link-text { display: inline-block; position: relative; padding: 0.15em 0.35em; }

.promo-menu-tag { display: table; margin-top: -0.25em; border-radius: 4px / 50%; background-color: #feb914; box-shadow: 0 1px 1px rgba(0, 0, 0, 0.25); text-shadow: 1px 1px rgba(0, 0, 0, 0.5); }

.promo-submenu { font-size: 12px; padding-left: 1em; }

.promo-submenu-item.active .promo-menu-link-text:after { content: ''; display: block; width: 80%; height: 1px; margin: -1px auto 0; position: relative; top: 3px; background-color: #fff; }

.promo-submenu-link { display: block; padding: 1em; color: #fff; text-decoration: none; }
.promo-submenu-link:hover { color: #ddd; text-decoration: underline; cursor: pointer; }

.promo-menu.sticky { position: relative !important; width: auto !important; }

@media screen and (min-width: 768px) { .promo-menu { height: 3.5em; padding: 0; position: static; }
  .promo-menu-button { display: none; }
  .promo-menu-items { display: block; position: absolute; z-index: 45; top: auto; left: 0; right: 0; }
  .promo-menu-items-wrapper { width: 960px; max-width: 100%; margin: 0 auto; }
  .promo-menu-item { display: inline-block; }
  .promo-submenu { display: none; font-size: 0; position: absolute; top: 100%; left: 0; right: 0; background: rgba(0, 0, 0, 0.6); }
  .promo-submenu-item { display: inline-block; font-size: 12px; }
  .promo-menu-dropdown:hover .promo-submenu { display: block; }
  .promo-menu-tag { display: block; margin-top: 0; }
  .promo-menu-parent .promo-menu-link .promo-menu-link-text:after { content: ''; display: block; width: 1px; height: 1px; margin: -4px auto 0; border-width: 3px 3px 0 3px; border-style: solid; border-color: #fff transparent transparent transparent; position: relative; top: 7px; }
  .sticky .promo-menu-items { position: fixed; z-index: 555; top: 0; } }
.promo-menu { height: 0 !important; }

@media screen and (min-width: 768px) { .promo-submenu { display: block; }
  .promo-menu-dropdown:hover { background: none; } }
