@postnord/web-components
Version:
PostNord Web Components
247 lines (245 loc) • 7.09 kB
CSS
/* Global utility variables */
/* Input styles */
/* Transition variables */
pn-radio-button {
position: relative;
display: inline-block;
}
pn-radio-button .pn-radio {
position: relative;
display: flex;
flex-wrap: wrap;
flex-direction: row;
}
pn-radio-button .pn-radio-label {
cursor: pointer;
color: #2d2013;
-webkit-tap-highlight-color: transparent;
}
pn-radio-button .pn-radio-helpertext {
color: #5e554a;
margin: 0 0 0.5em 0;
display: flex;
flex-direction: column;
}
pn-radio-button .pn-radio-helpertext:last-child {
margin: 0;
}
pn-radio-button .pn-radio-content {
display: flex;
flex-direction: column;
align-items: flex-start;
font-weight: 400;
line-height: 1.5;
flex: 1;
margin: 0 0 0 0.75em;
}
pn-radio-button .pn-radio-button {
display: flex;
gap: 0.75em;
padding: 0;
}
pn-radio-button .pn-radio-outer {
background-color: #ffffff;
border: 0.0625em solid #969087;
border-radius: 50%;
height: 1.5em;
width: 1.5em;
display: flex;
justify-content: center;
align-items: center;
outline: 0.2rem solid transparent;
outline-offset: 0.2rem;
transition-property: border-color, background-color, outline-color;
transition-duration: 0.2s;
transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
}
@media (prefers-reduced-motion: reduce) {
pn-radio-button .pn-radio-outer {
transition-duration: 0s;
transition-delay: 0s;
}
}
pn-radio-button .pn-radio-inner {
height: 0.75em;
width: 0.75em;
background-color: #005d92;
border-radius: 50%;
transform: scale(0);
transform-origin: center center;
transition-property: background-color, transform;
transition-duration: 0.2s;
transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
}
@media (prefers-reduced-motion: reduce) {
pn-radio-button .pn-radio-inner {
transition-duration: 0s;
transition-delay: 0s;
}
}
pn-radio-button .pn-radio[data-tile] {
padding: 1em;
border: 0.0625em solid #969087;
border-radius: 0.5em;
background-color: #ffffff;
outline: 0.2rem solid transparent;
outline-offset: 0.2rem;
transition-property: border-color, background-color, outline-color;
transition-duration: 0.2s;
transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
}
@media (prefers-reduced-motion: reduce) {
pn-radio-button .pn-radio[data-tile] {
transition-duration: 0s;
transition-delay: 0s;
}
}
pn-radio-button .pn-radio[data-tile] .pn-radio-outer {
outline: none;
}
pn-radio-button .pn-radio[data-invalid] {
border-color: #a70707;
}
pn-radio-button .pn-radio[data-invalid] .pn-radio-outer {
border-color: #a70707;
}
pn-radio-button .pn-radio[data-invalid] .pn-radio-inner {
background-color: #a70707;
}
pn-radio-button .pn-radio-container {
flex: 1 1 100%;
overflow: hidden;
visibility: hidden;
}
pn-radio-button .pn-radio-container[data-open] {
visibility: visible;
overflow: unset;
}
pn-radio-button .pn-radio-container[data-moving] {
visibility: visible;
overflow: hidden;
}
pn-radio-button .pn-radio-area {
padding: 0.75em 0 0 2.25em;
display: flex;
flex-direction: column;
flex-wrap: nowrap;
gap: 1em;
}
pn-radio-button .pn-radio > pn-icon {
margin-left: 0.75em;
}
pn-radio-button > input[type=radio] {
cursor: pointer;
opacity: 0;
position: absolute;
margin: 0;
z-index: 1;
top: 0;
left: 0;
font-size: 1em;
width: 1.5em;
height: 1.5em;
-webkit-tap-highlight-color: transparent;
}
pn-radio-button > input[type=radio][data-tile]:not([data-expand]) {
width: 100%;
height: 100%;
}
pn-radio-button > input[type=radio][data-expand] {
top: 1em;
left: 1em;
}
pn-radio-button > input[type=radio][aria-describedby] + .pn-radio[data-tile] .pn-radio-label {
font-weight: 500;
}
pn-radio-button > input[type=radio]:hover + .pn-radio[data-tile] {
border-color: #005d92;
background-color: #e0f8ff;
}
pn-radio-button > input[type=radio]:hover + .pn-radio[data-tile] .pn-radio-outer {
background-color: #e0f8ff;
}
pn-radio-button > input[type=radio]:hover + .pn-radio[data-tile][data-invalid] {
border-color: #a70707;
background-color: #fdefee;
}
pn-radio-button > input[type=radio]:hover + .pn-radio[data-tile][data-invalid] .pn-radio-outer {
background-color: #fdefee;
}
pn-radio-button > input[type=radio]:hover + .pn-radio[data-invalid] .pn-radio-outer {
border-color: #a70707;
background-color: #fdefee;
}
pn-radio-button > input[type=radio]:hover + .pn-radio .pn-radio-outer {
border-color: #005d92;
background-color: #e0f8ff;
}
pn-radio-button > input[type=radio]:checked:hover + .pn-radio[data-tile][data-invalid] {
border-color: #500715;
}
pn-radio-button > input[type=radio]:checked:hover + .pn-radio[data-invalid] > .pn-radio-button > .pn-radio-outer {
border-color: #500715;
}
pn-radio-button > input[type=radio]:focus-visible + .pn-radio .pn-radio-outer {
outline-color: #005d92;
}
pn-radio-button > input[type=radio]:focus-visible + .pn-radio[data-invalid] .pn-radio-outer {
outline-color: #a70707;
}
pn-radio-button > input[type=radio]:focus-visible + .pn-radio[data-tile] {
outline-color: #005d92;
border-color: #005d92;
}
pn-radio-button > input[type=radio]:focus-visible + .pn-radio[data-tile][data-invalid] {
outline-color: #a70707;
border-color: #a70707;
}
pn-radio-button > input[type=radio]:focus-visible + .pn-radio[data-tile] > .pn-radio-button > .pn-radio-outer {
outline: none;
}
pn-radio-button > input[type=radio]:checked + .pn-radio[data-tile] {
border-color: #005d92;
background-color: #e0f8ff;
}
pn-radio-button > input[type=radio]:checked + .pn-radio[data-tile][data-invalid] {
border-color: #a70707;
background-color: #fdefee;
}
pn-radio-button > input[type=radio]:checked + .pn-radio > .pn-radio-button > .pn-radio-outer {
border-color: #005d92;
}
pn-radio-button > input[type=radio]:checked + .pn-radio > .pn-radio-button > .pn-radio-outer > .pn-radio-inner {
transform: scale(1);
background-color: #005d92;
}
pn-radio-button > input[type=radio]:checked + .pn-radio[data-invalid] > .pn-radio-button > .pn-radio-outer {
border-color: #a70707;
}
pn-radio-button > input[type=radio]:checked + .pn-radio[data-invalid] > .pn-radio-button > .pn-radio-outer > .pn-radio-inner {
background-color: #a70707;
}
pn-radio-button > input[type=radio]:disabled {
pointer-events: none;
}
pn-radio-button > input[type=radio]:disabled + .pn-radio .pn-radio-label {
pointer-events: none;
}
pn-radio-button > input[type=radio]:disabled + .pn-radio[data-tile] {
background-color: #f3f2f2;
border-color: #f3f2f2;
}
pn-radio-button > input[type=radio]:disabled + .pn-radio[data-tile] > pn-icon .pn-icon-svg path {
fill: #5e554a;
}
pn-radio-button > input[type=radio]:disabled + .pn-radio[data-tile] > .pn-radio-content > .pn-radio-label {
color: #5e554a;
}
pn-radio-button > input[type=radio]:disabled + .pn-radio > .pn-radio-button > .pn-radio-outer {
background-color: #f3f2f2;
border-color: #969087;
outline: none;
}
pn-radio-button > input[type=radio]:disabled + .pn-radio > .pn-radio-button > .pn-radio-outer > .pn-radio-inner {
background-color: #969087;
}