@use 'iro-sass/src/index' as iro; @use '../functions' as fn; @include iro.props-namespace('menu') { @include iro.props-store(( --dims: ( --header: ( --font-size: fn.global-dim(--font-size --50), ), --separator: fn.global-dim(--size --150), --item: ( --pad-x: fn.global-dim(--size --150), --pad-y: fn.global-dim(--size --100), --rounding: 3px, ), ), ), 'dims'); @include iro.props-store(( --colors: ( --header: ( --label: fn.global-color(--fg-hi), ), --item: ( --hover: ( --bg: fn.global-color(--obj-hi), --label: fn.global-color(--fg-lo), ), --disabled: ( --label: fn.global-color(--fg-hi3), ), --key-focus: ( --bg: fn.global-color(--obj-hi), --label: fn.global-color(--fg-lo), --border: fn.global-color(--focus --fill), --shadow: fn.global-color(--focus --shadow), ), ), ), ), 'colors'); @include iro.bem-object(iro.props-namespace()) { @include iro.bem-elem('header') { padding: fn.dim(--item --pad-y) fn.dim(--item --pad-x); color: fn.color(--header --label); font-size: fn.dim(--header --font-size); font-weight: 500; letter-spacing: .5px; text-transform: uppercase; } @include iro.bem-elem('item') { display: block; box-sizing: border-box; width: 100%; padding: calc(fn.dim(--item --pad-y) - 2px) calc(fn.dim(--item --pad-x) - 2px); border: 2px solid transparent; border-radius: fn.dim(--item --rounding); color: fn.color(--item --disabled --label); &:link, &:visited, &:enabled { color: currentColor; @include iro.bem-multi('&:hover, &:active', 'is' 'selected') { background-color: fn.color(--item --hover --bg); color: fn.color(--item --hover --label); } @include iro.bem-at-theme('keyboard') { &:focus { border-radius: 2px; border-color: fn.color(--item --key-focus --border); background-color: fn.color(--item --key-focus --bg); box-shadow: fn.color(--item --key-focus --shadow); color: fn.color(--item --key-focus --label); } } } } @include iro.bem-elem('separator') { height: fn.dim(--separator); } @include iro.bem-elem('icon-slot') { display: flex; justify-content: center; width: 1em; } } }