You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
226 lines
6.1 KiB
226 lines
6.1 KiB
10 months ago
|
/**
|
||
|
* @file
|
||
|
* Nav Primary (wide widths).
|
||
|
*/
|
||
|
|
||
|
@import "../../base/media-queries.pcss.css";
|
||
|
|
||
|
body:not(.is-always-mobile-nav) {
|
||
|
@media (--nav) {
|
||
|
& .primary-nav__menu-item {
|
||
|
flex-wrap: nowrap; /* Ensure that sub navigation toggle button doesn't wrap underneath link. */
|
||
|
|
||
|
&.primary-nav__menu-item--has-children {
|
||
|
& .primary-nav__menu-link--link,
|
||
|
& .primary-nav__menu-link--nolink {
|
||
|
flex-basis: auto;
|
||
|
}
|
||
|
|
||
|
/* Remove hover state if submenu exists. */
|
||
|
& .primary-nav__menu-link--level-1 .primary-nav__menu-link-inner::after {
|
||
|
content: none;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
& .primary-nav__menu-link {
|
||
|
letter-spacing: 0.02em;
|
||
|
font-size: 16px;
|
||
|
line-height: var(--sp1-5);
|
||
|
|
||
|
&:focus {
|
||
|
position: relative;
|
||
|
outline: 0;
|
||
|
|
||
|
&::before {
|
||
|
position: absolute;
|
||
|
top: 50%;
|
||
|
left: 50%;
|
||
|
width: calc(100% + var(--sp));
|
||
|
height: var(--sp3);
|
||
|
content: "";
|
||
|
transform: translate(-50%, -50%);
|
||
|
border: solid 2px var(--color--primary-50);
|
||
|
border-radius: 4px;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
& .primary-nav__menu-link--button {
|
||
|
&.primary-nav__menu-link--has-children {
|
||
|
overflow: visible; /* Necessary to view icon in IE11 */
|
||
|
padding-inline-end: 9px;
|
||
|
|
||
|
&:focus::before {
|
||
|
width: calc(100% + var(--sp1-5));
|
||
|
content: "";
|
||
|
}
|
||
|
|
||
|
&::before {
|
||
|
content: none;
|
||
|
}
|
||
|
|
||
|
/* Chevron icon for desktop navigation. */
|
||
|
&::after {
|
||
|
position: absolute;
|
||
|
inset-block-start: 50%;
|
||
|
inset-inline-start: calc(100% - 3px);
|
||
|
width: 8px;
|
||
|
height: 8px;
|
||
|
margin-block-start: -2px;
|
||
|
transform: translateY(-50%) rotate(45deg);
|
||
|
/* Intentionally not using CSS logical properties. */
|
||
|
border-top: 0;
|
||
|
border-right: solid 2px currentColor;
|
||
|
border-bottom: solid 2px currentColor;
|
||
|
}
|
||
|
|
||
|
&[aria-expanded="true"]::after {
|
||
|
opacity: 1;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
& .primary-nav__menu-link-inner {
|
||
|
padding-block: var(--sp2);
|
||
|
padding-inline-start: 0;
|
||
|
padding-inline-end: 0;
|
||
|
|
||
|
&::after {
|
||
|
transform-origin: center;
|
||
|
border-top-width: var(--sp0-5);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
& .primary-nav__menu--level-1 {
|
||
|
display: flex;
|
||
|
align-items: stretch;
|
||
|
margin-inline-end: var(--sp);
|
||
|
}
|
||
|
|
||
|
& .primary-nav__menu-item--level-1 {
|
||
|
position: relative; /* Anchor secondary menu */
|
||
|
display: flex;
|
||
|
align-items: center;
|
||
|
width: max-content;
|
||
|
max-width: 200px;
|
||
|
margin-block: 0;
|
||
|
margin-inline-start: 0;
|
||
|
margin-inline-end: 0;
|
||
|
|
||
|
&:not(:last-child) {
|
||
|
margin-inline-end: var(--sp2);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
& .primary-nav__menu--level-2 {
|
||
|
position: absolute;
|
||
|
z-index: 105; /* Appear above search container. */
|
||
|
top: calc(100% - (0.5 * var(--sp)));
|
||
|
left: 50%;
|
||
|
visibility: hidden;
|
||
|
overflow: auto;
|
||
|
width: 250px;
|
||
|
/* Ensure that long level-2 menus will never overflow viewport (focused
|
||
|
* elements should always be in viewport per accessibility guidelines). */
|
||
|
max-height: calc(100vh - var(--site-header-height-wide) - var(--drupal-displace-offset-top, 0px) - var(--drupal-displace-offset-bottom, 0px) - var(--sp));
|
||
|
margin-block-start: 0;
|
||
|
margin-inline-start: 0;
|
||
|
padding-block: calc(3 * var(--sp));
|
||
|
padding-inline-start: var(--sp2);
|
||
|
padding-inline-end: var(--sp2);
|
||
|
transition: none;
|
||
|
transform: translate(-50%, -20px);
|
||
|
opacity: 0;
|
||
|
/* Intentionally not using CSS logical properties. */
|
||
|
border-top: solid var(--color--primary-50) var(--sp0-5);
|
||
|
border-right: solid 1px transparent; /* Transparent borders useful for Windows High Contrast mode. */
|
||
|
border-bottom: solid 1px transparent;
|
||
|
border-left: solid 1px transparent;
|
||
|
border-radius: 0 0 2px 2px;
|
||
|
background: var(--color--white);
|
||
|
box-shadow: 0 1px 36px rgba(0, 0, 0, 0.08);
|
||
|
|
||
|
&.is-active-menu-parent {
|
||
|
visibility: visible;
|
||
|
margin-block-start: 0;
|
||
|
transform: translate(-50%, 0);
|
||
|
opacity: 1;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
& .primary-nav__menu-link--level-2 {
|
||
|
display: block;
|
||
|
|
||
|
&:focus::before {
|
||
|
top: 0;
|
||
|
left: calc(var(--sp0-5) * -1);
|
||
|
height: 100%;
|
||
|
transform: none;
|
||
|
}
|
||
|
|
||
|
& .primary-nav__menu-link-inner {
|
||
|
padding-block: var(--sp0-5);
|
||
|
padding-inline-start: 0;
|
||
|
padding-inline-end: 0;
|
||
|
|
||
|
&::after {
|
||
|
transform-origin: left; /* LTR */
|
||
|
border-top-width: 3px;
|
||
|
|
||
|
&:dir(rtl) {
|
||
|
transform-origin: right;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Arrow is placed outside of submenu because the submenu has the
|
||
|
* `overflow: hidden` CSS rule applied.
|
||
|
*/
|
||
|
& .primary-nav__menu-🥕 {
|
||
|
position: absolute;
|
||
|
z-index: 105; /* Match level 2 menus. */
|
||
|
top: calc(100% - var(--sp));
|
||
|
left: 50%;
|
||
|
visibility: hidden;
|
||
|
width: 0;
|
||
|
height: 0;
|
||
|
transform: translate(-50%, -20px);
|
||
|
opacity: 0;
|
||
|
/* Intentionally not using CSS logical properties. */
|
||
|
border-right: solid 10px transparent;
|
||
|
border-bottom: solid 10px var(--color--primary-50);
|
||
|
border-left: solid 10px transparent;
|
||
|
|
||
|
&.is-active-menu-parent {
|
||
|
visibility: visible;
|
||
|
transform: translate(-50%, 0);
|
||
|
opacity: 1;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* When ensuring that long menus don't overflow viewport, we can give a
|
||
|
* little extra room when the toolbar is fixed (and is shorter).
|
||
|
*/
|
||
|
& .is-fixed .primary-nav__menu--level-2 {
|
||
|
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));
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
* Only apply transition styles to menu when JS is loaded. This
|
||
|
* works around https://bugs.chromium.org/p/chromium/issues/detail?id=332189
|
||
|
*/
|
||
|
html.js body:not(.is-always-mobile-nav) {
|
||
|
@media (--nav) {
|
||
|
& .primary-nav__menu--level-2,
|
||
|
& .primary-nav__menu-🥕 {
|
||
|
transition: visibility 0.2s, transform 0.2s, opacity 0.2s;
|
||
|
}
|
||
|
}
|
||
|
}
|