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.
202 lines
4.0 KiB
202 lines
4.0 KiB
10 months ago
|
/**
|
||
|
* @file
|
||
|
* Nav Primary.
|
||
|
*/
|
||
|
|
||
|
@import "../../base/media-queries.pcss.css";
|
||
|
|
||
|
.primary-nav__menu {
|
||
|
flex-wrap: wrap;
|
||
|
list-style: none;
|
||
|
}
|
||
|
|
||
|
.primary-nav__menu-item {
|
||
|
margin-block-end: var(--sp0-5);
|
||
|
|
||
|
&:last-child {
|
||
|
margin-block-end: 0;
|
||
|
}
|
||
|
|
||
|
&.primary-nav__menu-item--has-children {
|
||
|
display: flex;
|
||
|
flex-wrap: wrap;
|
||
|
justify-content: space-between;
|
||
|
|
||
|
& .primary-nav__menu-link--link,
|
||
|
& .primary-nav__menu-link--nolink {
|
||
|
/* Ensure that long text doesn't make the mobile expand button wrap. */
|
||
|
flex-basis: calc(100% - var(--sp3));
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.primary-nav__menu-link {
|
||
|
flex-grow: 1;
|
||
|
text-decoration: none;
|
||
|
color: var(--color-text-neutral-loud);
|
||
|
font-size: 28px;
|
||
|
font-weight: bold;
|
||
|
line-height: var(--sp2);
|
||
|
|
||
|
&:hover {
|
||
|
color: inherit;
|
||
|
}
|
||
|
|
||
|
&:focus {
|
||
|
outline: auto 2px var(--color--primary-50);
|
||
|
outline-offset: 2px;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.primary-nav__menu-link--nolink {
|
||
|
padding-block: var(--sp0-5);
|
||
|
padding-inline-start: 0;
|
||
|
padding-inline-end: 0;
|
||
|
color: var(--color-text-neutral-soft);
|
||
|
font-weight: normal;
|
||
|
}
|
||
|
|
||
|
.primary-nav__menu-link--button {
|
||
|
position: relative;
|
||
|
padding-block: 0;
|
||
|
padding-inline-start: 0;
|
||
|
padding-inline-end: 0;
|
||
|
cursor: pointer;
|
||
|
text-align: start;
|
||
|
border: 0;
|
||
|
background: transparent;
|
||
|
|
||
|
/* Plus icon for mobile navigation. */
|
||
|
&.primary-nav__menu-link--has-children {
|
||
|
padding-inline-end: var(--sp3); /* Ensure text does not overlap icon. */
|
||
|
|
||
|
&::before,
|
||
|
&::after {
|
||
|
position: absolute;
|
||
|
inset-inline-end: 9px;
|
||
|
inset-block-start: calc(var(--sp0-5) + 17px); /* Visually align button with menu link text. */
|
||
|
width: 18px;
|
||
|
height: 0;
|
||
|
content: "";
|
||
|
/* Intentionally not using CSS logical properties. */
|
||
|
border-top: solid 3px var(--color--primary-50);
|
||
|
}
|
||
|
|
||
|
&::after {
|
||
|
transition: opacity 0.2s;
|
||
|
transform: rotate(90deg);
|
||
|
}
|
||
|
|
||
|
&[aria-expanded="true"]::after {
|
||
|
opacity: 0;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.primary-nav__menu-link-inner {
|
||
|
position: relative;
|
||
|
display: inline-flex;
|
||
|
align-items: center;
|
||
|
padding-block: var(--sp0-5);
|
||
|
padding-inline-start: 0;
|
||
|
padding-inline-end: 0;
|
||
|
|
||
|
&::after {
|
||
|
position: absolute;
|
||
|
inset-block-end: 0;
|
||
|
inset-inline-start: 0;
|
||
|
width: 100%;
|
||
|
height: 0;
|
||
|
content: "";
|
||
|
transition: transform 0.2s;
|
||
|
transform: scaleX(0);
|
||
|
transform-origin: left;
|
||
|
/* Intentionally not using CSS logical properties. */
|
||
|
border-top: solid 5px var(--color--primary-50);
|
||
|
}
|
||
|
|
||
|
&::after {
|
||
|
@nest .primary-nav__menu-link:hover & {
|
||
|
transform: scaleX(1);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
Top level specific styles.
|
||
|
*/
|
||
|
.primary-nav__menu--level-1 {
|
||
|
margin-block: 0;
|
||
|
margin-inline-start: 0;
|
||
|
margin-inline-end: 0;
|
||
|
padding-block: 0;
|
||
|
padding-inline-start: 0;
|
||
|
padding-inline-end: 0;
|
||
|
}
|
||
|
|
||
|
.primary-nav__menu-link--level-1 {
|
||
|
position: relative;
|
||
|
display: flex;
|
||
|
letter-spacing: -1px;
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
Secondary menu specific styles.
|
||
|
*/
|
||
|
.primary-nav__menu--level-2 {
|
||
|
visibility: hidden;
|
||
|
overflow: hidden;
|
||
|
flex-basis: 100%;
|
||
|
max-height: 0;
|
||
|
margin-block: 0;
|
||
|
margin-inline-start: calc(-1 * var(--sp));
|
||
|
padding-inline-start: var(--sp2-5);
|
||
|
transition: opacity 0.2s, visibility 0.2s, max-height 0.2s;
|
||
|
opacity: 0;
|
||
|
border-inline-start: solid var(--sp) var(--color--primary-50);
|
||
|
|
||
|
&.is-active-menu-parent {
|
||
|
visibility: visible;
|
||
|
max-height: none;
|
||
|
margin-block-start: var(--sp1-5);
|
||
|
opacity: 1;
|
||
|
}
|
||
|
|
||
|
@media (--md) {
|
||
|
margin-inline-start: calc(-1 * var(--sp3));
|
||
|
padding-inline-start: var(--sp3);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
* Olives doesn't officially support nested tertiary submenus, but this
|
||
|
* ensures that it doesn't break all the way.
|
||
|
*
|
||
|
* @see https://www.drupal.org/project/drupal/issues/3221399
|
||
|
*/
|
||
|
.primary-nav__menu--level-2 .primary-nav__menu-item--has-children {
|
||
|
display: block;
|
||
|
}
|
||
|
|
||
|
.primary-nav__menu-link--level-2 {
|
||
|
font-size: 16px;
|
||
|
font-weight: normal;
|
||
|
line-height: var(--sp);
|
||
|
}
|
||
|
|
||
|
html:not(.js) {
|
||
|
& .primary-nav__menu--level-2 {
|
||
|
visibility: visible;
|
||
|
max-height: none;
|
||
|
opacity: 1;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
[dir="rtl"] {
|
||
|
& .primary-nav__menu-link-inner {
|
||
|
&::after {
|
||
|
transform-origin: right;
|
||
|
}
|
||
|
}
|
||
|
}
|