@keyframes mdc-ripple-fg-radius-in {
  from {
    animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transform: translate(var(--mdc-ripple-fg-translate-start, 0)) scale(1);
  }
  to {
    transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1));
  }
}
@keyframes mdc-ripple-fg-opacity-in {
  from {
    animation-timing-function: linear;
    opacity: 0;
  }
  to {
    opacity: var(--mdc-ripple-fg-opacity, 0);
  }
}
@keyframes mdc-ripple-fg-opacity-out {
  from {
    animation-timing-function: linear;
    opacity: var(--mdc-ripple-fg-opacity, 0);
  }
  to {
    opacity: 0;
  }
}
.mdc-ripple-surface {
  --mdc-ripple-fg-size: 0;
  --mdc-ripple-left: 0;
  --mdc-ripple-top: 0;
  --mdc-ripple-fg-scale: 1;
  --mdc-ripple-fg-translate-end: 0;
  --mdc-ripple-fg-translate-start: 0;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  will-change: transform, opacity;
  position: relative;
  outline: none;
  overflow: hidden;
}

.mdc-ripple-surface::before, .mdc-ripple-surface::after {
  position: absolute;
  border-radius: 50%;
  opacity: 0;
  pointer-events: none;
  content: "";
}

.mdc-ripple-surface::before {
  transition: opacity 15ms linear, background-color 15ms linear;
  z-index: 1;
  /* @alternate */
  z-index: var(--mdc-ripple-z-index, 1);
}

.mdc-ripple-surface::after {
  z-index: 0;
  /* @alternate */
  z-index: var(--mdc-ripple-z-index, 0);
}

.mdc-ripple-surface.mdc-ripple-upgraded::before {
  transform: scale(var(--mdc-ripple-fg-scale, 1));
}

.mdc-ripple-surface.mdc-ripple-upgraded::after {
  top: 0;
  /* @noflip */ /*rtl:ignore*/
  left: 0;
  transform: scale(0);
  transform-origin: center center;
}

.mdc-ripple-surface.mdc-ripple-upgraded--unbounded::after {
  top: var(--mdc-ripple-top, 0);
  /* @noflip */ /*rtl:ignore*/
  left: var(--mdc-ripple-left, 0);
}

.mdc-ripple-surface.mdc-ripple-upgraded--foreground-activation::after {
  animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards;
}

.mdc-ripple-surface.mdc-ripple-upgraded--foreground-deactivation::after {
  animation: mdc-ripple-fg-opacity-out 150ms;
  transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1));
}

.mdc-ripple-surface::before, .mdc-ripple-surface::after {
  top: calc(50% - 100%);
  /* @noflip */ /*rtl:ignore*/
  left: calc(50% - 100%);
  width: 200%;
  height: 200%;
}

.mdc-ripple-surface.mdc-ripple-upgraded::after {
  width: var(--mdc-ripple-fg-size, 100%);
  height: var(--mdc-ripple-fg-size, 100%);
}

.mdc-ripple-surface[data-mdc-ripple-is-unbounded],
.mdc-ripple-upgraded--unbounded {
  overflow: visible;
}

.mdc-ripple-surface[data-mdc-ripple-is-unbounded]::before, .mdc-ripple-surface[data-mdc-ripple-is-unbounded]::after,
.mdc-ripple-upgraded--unbounded::before,
.mdc-ripple-upgraded--unbounded::after {
  top: calc(50% - 50%);
  /* @noflip */ /*rtl:ignore*/
  left: calc(50% - 50%);
  width: 100%;
  height: 100%;
}

.mdc-ripple-surface[data-mdc-ripple-is-unbounded].mdc-ripple-upgraded::before, .mdc-ripple-surface[data-mdc-ripple-is-unbounded].mdc-ripple-upgraded::after,
.mdc-ripple-upgraded--unbounded.mdc-ripple-upgraded::before,
.mdc-ripple-upgraded--unbounded.mdc-ripple-upgraded::after {
  top: var(--mdc-ripple-top, calc(50% - 50%));
  /* @noflip */ /*rtl:ignore*/
  left: var(--mdc-ripple-left, calc(50% - 50%));
  width: var(--mdc-ripple-fg-size, 100%);
  height: var(--mdc-ripple-fg-size, 100%);
}

.mdc-ripple-surface[data-mdc-ripple-is-unbounded].mdc-ripple-upgraded::after,
.mdc-ripple-upgraded--unbounded.mdc-ripple-upgraded::after {
  width: var(--mdc-ripple-fg-size, 100%);
  height: var(--mdc-ripple-fg-size, 100%);
}

.mdc-ripple-surface::before, .mdc-ripple-surface::after {
  background-color: #000;
  /* @alternate */
  background-color: var(--mdc-ripple-color, #000);
}

.mdc-ripple-surface:hover::before, .mdc-ripple-surface.mdc-ripple-surface--hover::before {
  opacity: 0.04;
  /* @alternate */
  opacity: var(--mdc-ripple-hover-opacity, 0.04);
}

.mdc-ripple-surface.mdc-ripple-upgraded--background-focused::before, .mdc-ripple-surface:not(.mdc-ripple-upgraded):focus::before {
  transition-duration: 75ms;
  opacity: 0.12;
  /* @alternate */
  opacity: var(--mdc-ripple-focus-opacity, 0.12);
}

.mdc-ripple-surface:not(.mdc-ripple-upgraded)::after {
  transition: opacity 150ms linear;
}

.mdc-ripple-surface:not(.mdc-ripple-upgraded):active::after {
  transition-duration: 75ms;
  opacity: 0.12;
  /* @alternate */
  opacity: var(--mdc-ripple-press-opacity, 0.12);
}

.mdc-ripple-surface.mdc-ripple-upgraded {
  --mdc-ripple-fg-opacity:var(--mdc-ripple-press-opacity, 0.12);
}

/**
    Applies all the outline properties useful to show a dashed-focus ring around a component.
    TODO: replace `$border-radius: 0.1rem` with semantic border-radius but keep in mind some components that must stay at 2px border-radius: checkbox, radio, links, ...
 */
:host {
  display: inline-block;
  --wcs-button-color: var(--wcs-button-plain-color-default);
  --wcs-button-plain-color-default: var(--wcs-semantic-color-foreground-action-primary-default);
  --wcs-button-color-disabled: var(--wcs-semantic-color-text-disabled);
  --wcs-button-stroked-color-default: var(--wcs-semantic-color-foreground-action-secondary-default);
  --wcs-button-clear-color-default: var(--wcs-semantic-color-foreground-action-tertiary-default);
  --wcs-button-focus-outline-color: var(--wcs-semantic-color-border-focus-base);
  --wcs-button-focus-outline-border-width: var(--wcs-semantic-border-width-large);
  --wcs-button-background-color: var(--wcs-button-plain-background-color-default);
  --wcs-button-plain-background-color-default: var(--wcs-semantic-color-background-action-primary-default);
  --wcs-button-plain-background-color-disabled: var(--wcs-semantic-color-background-action-primary-disabled);
  --wcs-button-stroked-background-color-default: var(--wcs-semantic-color-background-action-secondary-default);
  --wcs-button-stroked-background-color-disabled: var(--wcs-semantic-color-background-action-secondary-disabled);
  --wcs-button-clear-background-color-default: var(--wcs-semantic-color-background-action-tertiary-default);
  --wcs-button-clear-background-color-disabled: var(--wcs-semantic-color-background-action-tertiary-disabled);
  --wcs-button-ripple-color: var(--wcs-button-plain-ripple-color-default);
  --wcs-button-plain-ripple-color-default: var(--wcs-semantic-color-ripple-action-primary);
  --wcs-button-stroked-ripple-color-default: var(--wcs-semantic-color-ripple-action-secondary);
  --wcs-button-clear-ripple-color-default: var(--wcs-semantic-color-ripple-action-tertiary);
  --wcs-button-border-radius: var(--wcs-button-border-radius-default);
  --wcs-button-border-radius-default: var(--wcs-semantic-border-radius-base);
  --wcs-button-border-radius-rounded: var(--wcs-semantic-border-radius-full);
  --wcs-button-stroked-border-color: var(--wcs-button-stroked-border-color-default);
  --wcs-button-stroked-border-width: var(--wcs-semantic-border-width-default);
  --wcs-button-stroked-border-color-default: var(--wcs-semantic-color-border-action-secondary-default);
  --wcs-button-stroked-border-color-disabled: var(--wcs-semantic-color-border-action-secondary-disabled);
  --wcs-button-height-s: var(--wcs-semantic-size-s);
  --wcs-button-font-size-s: var(--wcs-semantic-font-size-label-2);
  --wcs-button-padding-size-s: calc(1.5 * var(--wcs-semantic-spacing-base));
  --wcs-button-height-m: var(--wcs-semantic-size-m);
  --wcs-button-font-size-m: var(--wcs-semantic-font-size-label-1);
  --wcs-button-padding-size-m: calc(2 * var(--wcs-semantic-spacing-base));
  --wcs-button-height-l: var(--wcs-semantic-size-l);
  --wcs-button-font-size-l: var(--wcs-semantic-font-size-label-1);
  --wcs-button-padding-size-l: calc(3 * var(--wcs-semantic-spacing-base));
  --wcs-button-font-weight: var(--wcs-semantic-font-weight-medium);
}

.wcs-inner-button:focus-visible {
  outline: var(--wcs-button-focus-outline-border-width) dashed var(--wcs-button-focus-outline-color);
  outline-offset: var(--wcs-semantic-spacing-small);
  border-radius: var(--wcs-button-border-radius);
}

:host([mode=clear]) {
  --wcs-button-stroked-border-color: transparent;
}
:host([mode=clear]) .wcs-inner-button {
  box-shadow: none;
}

:host([mode=stroked]) {
  --wcs-button-color: var(--wcs-button-stroked-color-default);
  --wcs-button-background-color: transparent;
}
:host([mode=stroked]) .wcs-inner-button::before, :host([mode=stroked]) .wcs-inner-button::after {
  --wcs-button-ripple-color: var(--wcs-button-stroked-ripple-color-default);
}

:host([mode=clear]) {
  --wcs-button-color: var(--wcs-button-clear-color-default);
  --wcs-button-background-color: transparent;
}
:host([mode=clear]) .wcs-inner-button::before, :host([mode=clear]) .wcs-inner-button::after {
  --wcs-button-ripple-color: var(--wcs-button-clear-ripple-color-default);
}

:host([size=l]) {
  --wcs-button-padding: 0 var(--wcs-button-padding-size-l);
  --wcs-button-height: var(--wcs-button-height-l);
  --wcs-button-min-width: var(--wcs-button-height-l);
  --wcs-button-font-size: var(--wcs-button-font-size-l);
}
:host([size=l]):host([shape=round]) ::slotted(wcs-mat-icon), :host([size=l]):host([shape=square]) ::slotted(wcs-mat-icon) {
  margin: calc(-1 * var(--wcs-button-padding-size-l));
}

:host, :host([size=m]) {
  --wcs-button-padding: 0 var(--wcs-button-padding-size-m);
  --wcs-button-height: var(--wcs-button-height-m);
  --wcs-button-min-width: var(--wcs-button-height-m);
  --wcs-button-font-size: var(--wcs-button-font-size-m);
}
:host:host([shape=round]) ::slotted(wcs-mat-icon), :host:host([shape=square]) ::slotted(wcs-mat-icon), :host([size=m]):host([shape=round]) ::slotted(wcs-mat-icon), :host([size=m]):host([shape=square]) ::slotted(wcs-mat-icon) {
  margin: calc(-1 * var(--wcs-button-padding-size-m));
}

:host([size=s]) {
  --wcs-button-padding: 0 var(--wcs-button-padding-size-s);
  --wcs-button-height: var(--wcs-button-height-s);
  --wcs-button-min-width: var(--wcs-button-height-s);
  --wcs-button-font-size: var(--wcs-button-font-size-s);
}
:host([size=s]):host([shape=round]) ::slotted(wcs-mat-icon), :host([size=s]):host([shape=square]) ::slotted(wcs-mat-icon) {
  margin: calc(-1 * var(--wcs-button-padding-size-s));
}

:host([shape=round]) {
  --wcs-button-border-radius: var(--wcs-button-border-radius-rounded);
}

:host([shape=square]) {
  --wcs-button-padding: 0;
}

:host([shape=normal]) .wcs-inner-button {
  min-width: var(--wcs-button-min-width, unset);
  min-height: var(--wcs-button-height, unset);
}

:host([mode=stroked]) .wcs-inner-button {
  box-shadow: inset 0 0 0 var(--wcs-button-stroked-border-width) var(--wcs-button-stroked-border-color);
}

:host([loading]) {
  position: relative;
}
:host([loading]) .wcs-inner-button > *:not(wcs-spinner) {
  visibility: hidden;
  opacity: 0;
}
:host([loading]) wcs-spinner {
  --wcs-spinner-dashed-background-circle: var(--wcs-button-color);
  --wcs-spinner-rotating-circle-color: var(--wcs-button-color);
  height: calc(var(--wcs-button-height) / 2);
  width: calc(var(--wcs-button-min-width) / 2);
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}

:host([disabled]), :host([loading]) {
  cursor: not-allowed;
}
:host([disabled]) .wcs-inner-button, :host([loading]) .wcs-inner-button {
  opacity: 1;
  cursor: default;
  pointer-events: none;
}

:host([disabled]) {
  --wcs-button-color: var(--wcs-button-color-disabled);
  --wcs-button-background-color: var(--wcs-button-plain-background-color-disabled);
}

:host([mode=stroked][disabled]) {
  --wcs-button-stroked-border-color: var(--wcs-button-stroked-border-color-disabled);
  --wcs-button-background-color: var(--wcs-button-stroked-background-color-disabled);
}

:host([mode=clear][disabled]) {
  --wcs-button-background-color: var(--wcs-button-clear-background-color-disabled);
}

.wcs-inner-button {
  --mdc-ripple-fg-size: 0;
  --mdc-ripple-left: 0;
  --mdc-ripple-top: 0;
  --mdc-ripple-fg-scale: 1;
  --mdc-ripple-fg-translate-end: 0;
  --mdc-ripple-fg-translate-start: 0;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  will-change: transform, opacity;
  --mdc-ripple-focus-opacity: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  font-family: var(--wcs-font-sans-serif);
  background-color: var(--wcs-button-background-color);
  color: var(--wcs-button-color);
  padding: var(--wcs-button-padding);
  border-radius: var(--wcs-button-border-radius);
  border: none;
  overflow: hidden;
  outline: 0;
  text-transform: none;
  margin: 0;
  cursor: pointer;
  font-weight: var(--wcs-button-font-weight);
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  user-select: none;
  font-size: var(--wcs-button-font-size);
  line-height: 1.5;
  height: var(--wcs-button-height);
  min-width: var(--wcs-button-min-width);
  transition: color 175ms ease-in-out, background-color 175ms ease-in-out;
}
.wcs-inner-button::before, .wcs-inner-button::after {
  position: absolute;
  border-radius: 50%;
  opacity: 0;
  pointer-events: none;
  content: "";
}
.wcs-inner-button::before {
  transition: opacity 15ms linear, background-color 15ms linear;
  z-index: 1;
  /* @alternate */
  z-index: var(--mdc-ripple-z-index, 1);
}
.wcs-inner-button::after {
  z-index: 0;
  /* @alternate */
  z-index: var(--mdc-ripple-z-index, 0);
}
.wcs-inner-button.mdc-ripple-upgraded::before {
  transform: scale(var(--mdc-ripple-fg-scale, 1));
}
.wcs-inner-button.mdc-ripple-upgraded::after {
  top: 0;
  /* @noflip */ /*rtl:ignore*/
  left: 0;
  transform: scale(0);
  transform-origin: center center;
}
.wcs-inner-button.mdc-ripple-upgraded--unbounded::after {
  top: var(--mdc-ripple-top, 0);
  /* @noflip */ /*rtl:ignore*/
  left: var(--mdc-ripple-left, 0);
}
.wcs-inner-button.mdc-ripple-upgraded--foreground-activation::after {
  animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards;
}
.wcs-inner-button.mdc-ripple-upgraded--foreground-deactivation::after {
  animation: mdc-ripple-fg-opacity-out 150ms;
  transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1));
}
.wcs-inner-button::before, .wcs-inner-button::after {
  top: calc(50% - 100%);
  /* @noflip */ /*rtl:ignore*/
  left: calc(50% - 100%);
  width: 200%;
  height: 200%;
}
.wcs-inner-button.mdc-ripple-upgraded::after {
  width: var(--mdc-ripple-fg-size, 100%);
  height: var(--mdc-ripple-fg-size, 100%);
}
.wcs-inner-button:hover::before, .wcs-inner-button.mdc-ripple-surface--hover::before {
  opacity: 0.1;
  /* @alternate */
  opacity: var(--mdc-ripple-hover-opacity, 0.1);
}
.wcs-inner-button.mdc-ripple-upgraded--background-focused::before, .wcs-inner-button:not(.mdc-ripple-upgraded):focus::before {
  transition-duration: 75ms;
  opacity: 0.2;
  /* @alternate */
  opacity: var(--mdc-ripple-focus-opacity, 0.2);
}
.wcs-inner-button:not(.mdc-ripple-upgraded)::after {
  transition: opacity 150ms linear;
}
.wcs-inner-button:not(.mdc-ripple-upgraded):active::after {
  transition-duration: 75ms;
  opacity: 0.3;
  /* @alternate */
  opacity: var(--mdc-ripple-press-opacity, 0.3);
}
.wcs-inner-button.mdc-ripple-upgraded {
  --mdc-ripple-fg-opacity: var(--mdc-ripple-press-opacity, 0.3);
}
.wcs-inner-button::before, .wcs-inner-button::after {
  background-color: white;
  /* @alternate */
  background-color: var(--mdc-ripple-color, white);
}
.wcs-inner-button::before, .wcs-inner-button::after {
  background-color: var(--wcs-button-ripple-color);
}

a {
  text-decoration: none;
  box-sizing: border-box;
}

button::-moz-focus-inner,
a::-moz-focus-inner {
  border: 0;
}