nav-primary-wide.css

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

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