/* 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([disabled]) { pointer-events: none; cursor: default; -webkit-user-select: none; user-select: none; opacity: var(--calcite-ui-opacity-disabled); } :host { display: inline; } :host a, :host span { position: relative; display: flex; cursor: pointer; align-items: center; justify-content: center; border-radius: 0px; border-style: none; font-family: inherit; transition: all var(--calcite-animation-timing) ease-in-out 0s, outline 0s, outline-offset 0s; text-decoration: none; line-height: inherit; font-size: inherit; -webkit-appearance: none; } :host a:hover, :host span:hover { text-decoration: none; } :host a, :host span { outline-color: transparent; } :host a:focus, :host span:focus { outline: 2px solid var(--calcite-ui-brand); outline-offset: -2px; } calcite-icon { inline-size: 1em; block-size: 1em; min-inline-size: unset; min-block-size: unset; } .calcite-link--icon { vertical-align: text-top; transition: all var(--calcite-animation-timing) ease-in-out 0s, outline 0s, outline-offset 0s; margin-block-start: 0.125rem; } :host .calcite-link--icon.icon-start { margin-inline-end: 0.5rem; } :host .calcite-link--icon.icon-end { margin-inline-start: 0.5rem; } :host span, :host a { position: relative; display: inline; border-style: none; background-color: transparent; padding: 0px; color: var(--calcite-ui-text-link); transition: all var(--calcite-animation-timing) ease-in-out 0s, outline 0s, outline-offset 0s; line-height: inherit; white-space: initial; background-image: linear-gradient(currentColor, currentColor), linear-gradient(var(--calcite-link-blue-underline), var(--calcite-link-blue-underline)); background-position: 0% 100%, 100% 100%; background-repeat: no-repeat, no-repeat; background-size: 0% 1px, 100% 1px; } :host span:hover, :host span:focus, :host a:hover, :host a:focus { background-size: 100% 1px, 100% 1px; } :host span:active, :host a:active { background-size: 100% 2px, 100% 2px; } :host span.calcite--rtl, :host a.calcite--rtl { background-position: 100% 100%, 100% 100%; } :host([disabled]) ::slotted([calcite-hydrated][disabled]), :host([disabled]) [calcite-hydrated][disabled] { /* prevent opacity stacking */ opacity: 1; }