.citizen-dropdown { .citizen-menu__card { z-index: @z-index-dropdown; content-visibility: hidden; min-width: 16rem; max-width: 80vw; transition-timing-function: var( --transition-timing-function-ease-in ); transition-duration: var( --transition-duration-base ); transition-property: transform, content-visibility; transition-behavior: allow-discrete; > * { opacity: 0; transition-timing-function: var( --transition-timing-function-ease-in ); transition-duration: var( --transition-duration-base ); transition-property: opacity; } &:empty { display: none; } .citizen-ui-icon { content-visibility: hidden; } } &-summary { cursor: pointer; // Icons have to use span inside label elements > span:not( .citizen-ui-icon ) { .sr-only; } &:hover { background-color: var( --background-color-button-quiet--hover ); > .citizen-ui-icon::before { opacity: var( --opacity-icon-base--hover ); } } &:active { background-color: var( --background-color-button-quiet--active ); > .citizen-ui-icon::before { opacity: var( --opacity-icon-base--selected ); } } // Remove Safari summary marker &::-webkit-details-marker { display: none; } // Reset hover styles if it is a touch device // This is dumb but hover:hover overrides active states @media ( hover: none ) { &:hover { background-color: transparent; .citizen-ui-icon::before { opacity: var( --opacity-icon-base ); } } } } &-details { &[ open ] { + .citizen-menu__card { content-visibility: visible; transition-timing-function: var( --transition-timing-function-ease-out ); transition-duration: var( --transition-duration-medium ); transform: none; > * { opacity: 1; transition-delay: var( --transition-delay-menu ); transition-timing-function: var( --transition-timing-function-ease-out ); transition-duration: var( --transition-duration-medium ); } .citizen-ui-icon { content-visibility: visible; } } > .citizen-dropdown-summary { background-color: var( --background-color-button-quiet--active ); &:hover { background-color: var( --background-color-button-quiet--hover ); } } } } .citizen-header__end & .citizen-menu__card { .citizen-header-card( end ); transform-origin: var( --transform-origin-offset-end ) var( --transform-origin-offset-end ); @media ( min-width: @min-width-breakpoint-desktop ) { transform-origin: var( --transform-origin-offset-start ) var( --transform-origin-offset-end ); } } @media ( max-width: @max-width-breakpoint-tablet ) { .citizen-menu__card { max-width: ~'calc( 100vw - var( --space-xs ) * 2 )'; } // Add dismiss affordnance backdrop &-details { &::before { content: ''; background: var( --background-color-backdrop-light ); -webkit-backdrop-filter: blur( 2px ); backdrop-filter: blur( 2px ); opacity: 0; transition-timing-function: var( --transition-timing-function-ease ); transition-duration: var( --transition-duration-base ); transition-property: opacity; } &[ open ] { &::before { position: fixed; inset: 0; z-index: @z-index-off-canvas-backdrop; opacity: 1; transition-duration: var( --transition-duration-medium ); } > .citizen-dropdown-summary { position: relative; // Slightly higher than the menu so it is not covered by the box shadow z-index: @z-index-off-canvas + @z-index-stacking-1; } + .citizen-menu__card { z-index: @z-index-off-canvas; } } } } } @media ( max-width: @max-width-breakpoint-tablet ) { /* HACK: Disable page from scolling when a dropdown menu is opened */ body:has( .citizen-dropdown-details[ open ] ) { overflow: hidden; } }