nav-primary-wide.css

Nav Primary (wide widths).

File

core/themes/olivero/css/components/navigation/nav-primary-wide.css

View source
  1. /*
  2. * DO NOT EDIT THIS FILE.
  3. * See the following change record for more information,
  4. * https://www.drupal.org/node/3084859
  5. * @preserve
  6. */
  7. /**
  8. * @file
  9. * Nav Primary (wide widths).
  10. */
  11. body:not(.is-always-mobile-nav) {
  12. @media (min-width: 75rem) {
  13. & .primary-nav__menu-item {
  14. flex-wrap: nowrap; /* Ensure that sub navigation toggle button doesn't wrap underneath link. */
  15. &.primary-nav__menu-item--has-children {
  16. & .primary-nav__menu-link--link,
  17. & .primary-nav__menu-link--nolink {
  18. flex-basis: auto;
  19. }
  20. /* Remove hover state if submenu exists. */
  21. & .primary-nav__menu-link--level-1 .primary-nav__menu-link-inner::after {
  22. content: none;
  23. }
  24. }
  25. }
  26. & .primary-nav__menu-link {
  27. letter-spacing: 0.02em;
  28. font-size: 1rem;
  29. line-height: var(--sp1-5);
  30. &:focus {
  31. position: relative;
  32. outline: 0;
  33. &::before {
  34. position: absolute;
  35. top: 50%;
  36. left: 50%;
  37. width: calc(100% + var(--sp));
  38. height: calc(100% - var(--sp3));
  39. content: "";
  40. transform: translate(-50%, -50%);
  41. border: solid 2px var(--color--primary-50);
  42. border-radius: 0.25rem;
  43. }
  44. }
  45. }
  46. & .primary-nav__menu-link--button {
  47. &.primary-nav__menu-link--has-children {
  48. padding-inline-end: 0.5625rem;
  49. &:focus::before {
  50. width: calc(100% + var(--sp1-5));
  51. content: "";
  52. }
  53. &::before {
  54. content: none;
  55. }
  56. /* Chevron icon for desktop navigation. */
  57. &::after {
  58. position: absolute;
  59. inset-block-start: 50%;
  60. inset-inline-start: calc(100% - 0.1875rem);
  61. width: 0.5rem;
  62. height: 0.5rem;
  63. margin-block-start: -2px;
  64. transform: translateY(-50%) rotate(45deg);
  65. /* Intentionally not using CSS logical properties. */
  66. border-top: 0;
  67. border-right: solid 2px currentColor;
  68. border-bottom: solid 2px currentColor;
  69. }
  70. &[aria-expanded="true"]::after {
  71. opacity: 1;
  72. }
  73. }
  74. }
  75. & .primary-nav__menu-link-inner {
  76. padding-block: var(--sp2);
  77. padding-inline-start: 0;
  78. padding-inline-end: 0;
  79. &::after {
  80. transform-origin: center;
  81. border-top-width: var(--sp0-5);
  82. }
  83. }
  84. & .primary-nav__menu--level-1 {
  85. display: flex;
  86. align-items: stretch;
  87. margin-inline-end: var(--sp);
  88. }
  89. & .primary-nav__menu-item--level-1 {
  90. position: relative; /* Anchor secondary menu */
  91. display: flex;
  92. align-items: center;
  93. width: max-content;
  94. max-width: 12.5rem;
  95. margin-block: 0;
  96. margin-inline-start: 0;
  97. margin-inline-end: 0;
  98. &:not(:last-child) {
  99. margin-inline-end: var(--sp2);
  100. }
  101. }
  102. & .primary-nav__menu--level-2 {
  103. position: absolute;
  104. z-index: 105; /* Appear above search container. */
  105. top: calc(100% - var(--sp0-5));
  106. left: 50%;
  107. visibility: hidden;
  108. overflow: auto;
  109. width: 15.625rem;
  110. /* Ensure that long level-2 menus will never overflow viewport (focused
  111. * elements should always be in viewport per accessibility guidelines). */
  112. max-height: calc(100vh - var(--site-header-height-wide) - var(--drupal-displace-offset-top, 0px) - var(--drupal-displace-offset-bottom, 0px) - var(--sp));
  113. margin-block-start: 0;
  114. margin-inline-start: 0;
  115. padding-block: var(--sp3);
  116. padding-inline-start: var(--sp2);
  117. padding-inline-end: var(--sp2);
  118. transition: none;
  119. transform: translate(-50%, -1.25rem);
  120. opacity: 0;
  121. /* Intentionally not using CSS logical properties. */
  122. border-top: solid var(--color--primary-50) var(--sp0-5);
  123. border-right: solid 1px transparent; /* Transparent borders useful for Windows High Contrast mode. */
  124. border-bottom: solid 1px transparent;
  125. border-left: solid 1px transparent;
  126. border-radius: 0 0 2px 2px;
  127. background: var(--color--white);
  128. box-shadow: 0 1px 36px rgb(0, 0, 0, 0.08);
  129. &.is-active-menu-parent {
  130. visibility: visible;
  131. margin-block-start: 0;
  132. transform: translate(-50%, 0);
  133. opacity: 1;
  134. }
  135. }
  136. & .primary-nav__menu-link--level-2 {
  137. display: block;
  138. &:focus::before {
  139. top: 0;
  140. left: calc(var(--sp0-5) * -1);
  141. height: 100%;
  142. transform: none;
  143. }
  144. & .primary-nav__menu-link-inner {
  145. padding-block: var(--sp0-5);
  146. padding-inline-start: 0;
  147. padding-inline-end: 0;
  148. &::after {
  149. transform-origin: left; /* LTR */
  150. border-top-width: 3px;
  151. &:dir(rtl) {
  152. transform-origin: right;
  153. }
  154. }
  155. }
  156. }
  157. /**
  158. * Arrow is placed outside of submenu because the submenu has the
  159. * `overflow: hidden` CSS rule applied.
  160. */
  161. & .primary-nav__menu-🥕 {
  162. position: absolute;
  163. z-index: 105; /* Match level 2 menus. */
  164. top: calc(100% - var(--sp));
  165. left: 50%;
  166. visibility: hidden;
  167. width: 0;
  168. height: 0;
  169. transform: translate(-50%, -1.25rem);
  170. opacity: 0;
  171. /* Intentionally not using CSS logical properties. */
  172. border-right: solid 10px transparent;
  173. border-bottom: solid 10px var(--color--primary-50);
  174. border-left: solid 10px transparent;
  175. &.is-active-menu-parent {
  176. visibility: visible;
  177. transform: translate(-50%, 0);
  178. opacity: 1;
  179. }
  180. }
  181. /**
  182. * When ensuring that long menus don't overflow viewport, we can give a
  183. * little extra room when the toolbar is fixed (and is shorter).
  184. */
  185. & .is-fixed .primary-nav__menu--level-2 {
  186. max-height: calc(100vh - var(--site-header-height-wide) - var(--drupal-displace-offset-top, 0px) - var(--drupal-displace-offset-bottom, 0px) - var(--sp) + var(--sp4));
  187. }
  188. }
  189. }
  190. /*
  191. * Only apply transition styles to menu when JS is loaded. This
  192. * works around https://bugs.chromium.org/p/chromium/issues/detail?id=332189
  193. */
  194. html.js body:not(.is-always-mobile-nav) {
  195. @media (min-width: 75rem) {
  196. & .primary-nav__menu--level-2,
  197. & .primary-nav__menu-🥕 {
  198. transition:
  199. visibility 0.2s,
  200. transform 0.2s,
  201. opacity 0.2s;
  202. }
  203. }
  204. }

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.