/* mixins & extensions */ @keyframes in { 0% { opacity: 0; } 100% { opacity: 1; } } @keyframes in-down { 0% { opacity: 0; transform: translate3D(0, -5px, 0); } 100% { opacity: 1; transform: translate3D(0, 0, 0); } } @keyframes in-up { 0% { opacity: 0; transform: translate3D(0, 5px, 0); } 100% { opacity: 1; transform: translate3D(0, 0, 0); } } @keyframes in-scale { 0% { opacity: 0; transform: scale3D(0.95, 0.95, 1); } 100% { opacity: 1; transform: scale3D(1, 1, 1); } } :root { --calcite-animation-timing: calc(150ms * var(--calcite-internal-duration-factor)); --calcite-internal-duration-factor: var(--calcite-duration-factor, 1); --calcite-internal-animation-timing-fast: calc(100ms * var(--calcite-internal-duration-factor)); --calcite-internal-animation-timing-medium: calc(200ms * var(--calcite-internal-duration-factor)); --calcite-internal-animation-timing-slow: calc(300ms * var(--calcite-internal-duration-factor)); } .calcite-animate { opacity: 0; animation-fill-mode: both; animation-duration: var(--calcite-animation-timing); } .calcite-animate__in { animation-name: in; } .calcite-animate__in-down { animation-name: in-down; } .calcite-animate__in-up { animation-name: in-up; } .calcite-animate__in-scale { animation-name: in-scale; } @media (prefers-reduced-motion: reduce) { :root { --calcite-internal-duration-factor: 0.01; } } /** * Currently only used in Checkbox. */ :root { --calcite-floating-ui-transition: var(--calcite-animation-timing); } :host([hidden]) { display: none; } :host { display: flex; cursor: pointer; align-self: stretch; font-weight: var(--calcite-font-weight-normal); transition: background-color var(--calcite-internal-animation-timing-fast) ease-in-out, border-color var(--calcite-animation-timing) ease-in-out; } :host label { pointer-events: none; margin: 0.125rem; box-sizing: border-box; display: flex; flex: 1 1 0%; align-items: center; color: var(--calcite-ui-text-3); transition: background-color var(--calcite-internal-animation-timing-fast) ease-in-out, border-color var(--calcite-internal-animation-timing-fast) ease-in-out, color var(--calcite-internal-animation-timing-fast) ease-in-out; } .label--horizontal { justify-content: center; } :host { outline-color: transparent; } :host(:focus) { outline: 2px solid var(--calcite-ui-brand); outline-offset: -1px; } .label--scale-s { padding-inline: 0.5rem; font-size: var(--calcite-font-size--2); line-height: 1rem; padding-block: 0.125rem; } .label--scale-m { padding-inline: 0.75rem; font-size: var(--calcite-font-size--1); line-height: 1rem; padding-block: 0.375rem; } .label--scale-l { padding-inline: 1rem; padding-block: 0.625rem; font-size: var(--calcite-font-size-0); line-height: 1.25rem; } :host(:hover) label { background-color: var(--calcite-ui-foreground-2); color: var(--calcite-ui-text-1); } :host(:active) label { background-color: var(--calcite-ui-foreground-3); } :host([checked]) label { cursor: default; border-color: var(--calcite-ui-brand); background-color: var(--calcite-ui-brand); color: var(--calcite-ui-background); } :host([checked]) .label--outline { border-color: var(--calcite-ui-brand); background-color: var(--calcite-ui-foreground-1); box-shadow: inset 0 0 0 1px var(--calcite-ui-brand); color: var(--calcite-ui-brand); } ::slotted(input) { display: none; } @media (forced-colors: active) { :host([checked]) label { background-color: highlight; } :host([checked]) .label--outline { outline: 2px solid transparent; outline-offset: 2px; } :host([checked]) label:not([class~=label--outline]) .radio-group-item-icon { color: highlightText; } } .radio-group-item-icon { position: relative; margin: 0px; display: inline-flex; line-height: inherit; } :host([icon-position=start]) .label--scale-s .radio-group-item-icon { margin-inline-end: 0.5rem; } :host([icon-position=end]) .label--scale-s .radio-group-item-icon { margin-inline-end: unset; margin-inline-start: 0.5rem; } :host([icon-position=start]) .label--scale-m .radio-group-item-icon { margin-inline-end: 0.75rem; } :host([icon-position=end]) .label--scale-m .radio-group-item-icon { margin-inline-end: unset; margin-inline-start: 0.75rem; } :host([icon-position=start]) .label--scale-l .radio-group-item-icon { margin-inline-end: 1rem; } :host([icon-position=end]) .label--scale-l .radio-group-item-icon { margin-inline-end: unset; margin-inline-start: 1rem; } :host([icon-start]) .label--scale-s .radio-group-item-icon { margin-inline-end: 0.5rem; } :host([icon-end]) .label--scale-s .radio-group-item-icon { margin-inline-start: 0.5rem; } :host([icon-start]) .label--scale-m .radio-group-item-icon { margin-inline-end: 0.75rem; } :host([icon-end]) .label--scale-m .radio-group-item-icon { margin-inline-start: 0.75rem; } :host([icon-start]) .label--scale-l .radio-group-item-icon { margin-inline-end: 1rem; } :host([icon-end]) .label--scale-l .radio-group-item-icon { margin-inline-start: 1rem; }