.kitt_IconContainer_cer12 {
  display: inline-block;
  vertical-align: middle;
  width: 20px;
  height: 20px;
  font-size: 20px;
  line-height: 25px;

  svg {
    width: 20px;
    height: 20px;

    * {
      fill: currentColor;
      transition: inherit;
    }
  }
}

/* Fixes icon misalignment when inlined inside a text element */
.kitt_InlineAlign_T9BgW {
  vertical-align: baseline;
  line-height: inherit;
  font-size: inherit;
  height: 1em;
}

.kitt_InlineAlignSub_8hHBI {
  vertical-align: sub;
}

.kitt_Loader_Vkg49 {

  svg {
    animation: kitt_spin_c7m6q 1.1s infinite linear;
  }
}

@keyframes kitt_spin_c7m6q {
  0% {
    transform: rotate(-1deg);
  }

  100% {
    transform: rotate(359deg);
  }
}

a,
.kitt_Link_ZEUEM {
  font-size: inherit;
  color: inherit;
  text-decoration: underline;
  transition: color 0.2s ease-in-out;
  cursor: pointer;
  margin: 0;

  &:hover,
  &:active,
  .kitt-hover & {
    text-decoration: none;
  }
}

/* don't impact kitt-universal links */
a:not([data-kitt-universal='true']),
.kitt_Link_ZEUEM {
  font-weight: 700 !important;
}

.kitt_NoBold_5REFf,
a:not([data-kitt-universal='true']).kitt_NoBold_5REFf {
  font-weight: inherit !important;
}

.kitt_NoUnderline_Jyg4Z {
  text-decoration: none;

  &:hover,
  &:active,
  .kitt-hover & {
    text-decoration: underline;
  }
}

.kitt_Disabled_qnp4j {
  cursor: not-allowed;

  &:hover,
  &:active,
  .kitt-hover & {
    color: var(--kitt-link-disabled-color);
  }
}

/* Mobile */

.kitt_Reset_6XgCv {
  margin: 0;
  padding: 0;
}

.kitt_base-header1_ZOxqc {
  font-family: var(--kitt-font-family-header);
  font-size: var(--font-size-base-header1);
  line-height: var(--line-height-base-header1);
}

.kitt_base-header2_3Ho8g {
  font-family: var(--kitt-font-family-header);
  font-size: var(--font-size-base-header2);
  line-height: var(--line-height-base-header2);
}

.kitt_base-header3_Wl9UT {
  font-family: var(--kitt-font-family-header);
  font-size: var(--font-size-base-header3);
  line-height: var(--line-height-base-header3);
}

.kitt_base-header4_tNE5q {
  font-family: var(--kitt-font-family-header);
  font-size: var(--font-size-base-header4);
  line-height: var(--line-height-base-header4);
}

.kitt_base-header5_4iUmv {
  font-family: var(--kitt-font-family-header);
  font-size: var(--font-size-base-header5);
  line-height: var(--line-height-base-header5);
}

.kitt_base-body-large_Bajd8 {
  font-family: var(--kitt-font-family-body);
  font-size: var(--font-size-base-body-large);
  line-height: var(--line-height-base-body-large);
}

.kitt_base-body-medium_Kog-p {
  font-family: var(--kitt-font-family-body);
  font-size: var(--font-size-body-medium);
  line-height: var(--line-height-body-medium);
}

.kitt_base-body_yNZdu {
  font-family: var(--kitt-font-family-body);
  font-size: var(--font-size-body);
  line-height: var(--line-height-body);
}

.kitt_base-body-small_k-Lly {
  font-family: var(--kitt-font-family-body);
  font-size: var(--font-size-body-small);
  line-height: var(--line-height-body-small);
}

.kitt_base-body-xsmall_TkuDI {
  font-family: var(--kitt-font-family-body);
  font-size: var(--font-size-body-xsmall);
  line-height: var(--line-height-body-xsmall);
}

@media (--small-breakpoint) {
  .kitt_small-header1_Hfy4e {
    font-family: var(--kitt-font-family-header);
    font-size: var(--font-size-base-header1);
    line-height: var(--line-height-base-header1);
  }

  .kitt_small-header2_bNZ5M {
    font-family: var(--kitt-font-family-header);
    font-size: var(--font-size-base-header2);
    line-height: var(--line-height-base-header2);
  }

  .kitt_small-header3_UlMuV {
    font-family: var(--kitt-font-family-header);
    font-size: var(--font-size-base-header3);
    line-height: var(--line-height-base-header3);
  }

  .kitt_small-header4_TcxNI {
    font-family: var(--kitt-font-family-header);
    font-size: var(--font-size-base-header4);
    line-height: var(--line-height-base-header4);
  }

  .kitt_small-header5_LrQfY {
    font-family: var(--kitt-font-family-header);
    font-size: var(--font-size-base-header5);
    line-height: var(--line-height-base-header5);
  }

  .kitt_small-body-large_9qSEd {
    font-family: var(--kitt-font-family-body);
    font-size: var(--font-size-base-body-large);
    line-height: var(--line-height-base-body-large);
  }

  .kitt_small-body-medium_HIZnN {
    font-family: var(--kitt-font-family-body);
    font-size: var(--font-size-body-medium);
    line-height: var(--line-height-body-medium);
  }

  .kitt_small-body_lul3w {
    font-family: var(--kitt-font-family-body);
    font-size: var(--font-size-body);
    line-height: var(--line-height-body);
  }

  .kitt_small-body-small_q-pfY {
    font-family: var(--kitt-font-family-body);
    font-size: var(--font-size-body-small);
    line-height: var(--line-height-body-small);
  }

  .kitt_small-body-xsmall_2APdC {
    font-family: var(--kitt-font-family-body);
    font-size: var(--font-size-body-xsmall);
    line-height: var(--line-height-body-xsmall);
  }
}

@media (--medium-breakpoint) {
  .kitt_medium-header1_f4Txr {
    font-family: var(--kitt-font-family-header);
    font-size: var(--font-size-medium-and-higher-header1);
    line-height: var(--line-height-medium-and-higher-header1);
  }

  .kitt_medium-header2_6xfcJ {
    font-family: var(--kitt-font-family-header);
    font-size: var(--font-size-medium-and-higher-header2);
    line-height: var(--line-height-medium-and-higher-header2);
  }

  .kitt_medium-header3_Z3IeT {
    font-family: var(--kitt-font-family-header);
    font-size: var(--font-size-medium-and-higher-header3);
    line-height: var(--line-height-medium-and-higher-header3);
  }

  .kitt_medium-header4_Cr53J {
    font-family: var(--kitt-font-family-header);
    font-size: var(--font-size-medium-and-higher-header4);
    line-height: var(--line-height-medium-and-higher-header4);
  }

  .kitt_medium-header5_iOPQj {
    font-family: var(--kitt-font-family-header);
    font-size: var(--font-size-medium-and-higher-header5);
    line-height: var(--line-height-medium-and-higher-header5);
  }

  .kitt_medium-body-large_goLq6 {
    font-family: var(--kitt-font-family-body);
    font-size: var(--font-size-medium-and-higher-body-large);
    line-height: var(--line-height-medium-and-higher-body-large);
  }

  .kitt_medium-body-medium_o-Poa {
    font-family: var(--kitt-font-family-body);
    font-size: var(--font-size-body-medium);
    line-height: var(--line-height-body-medium);
  }

  .kitt_medium-body_Sgn4J {
    font-family: var(--kitt-font-family-body);
    font-size: var(--font-size-body);
    line-height: var(--line-height-body);
  }

  .kitt_medium-body-small_d-HHC {
    font-family: var(--kitt-font-family-body);
    font-size: var(--font-size-body-small);
    line-height: var(--line-height-body-small);
  }

  .kitt_medium-body-xsmall_ehylu {
    font-family: var(--kitt-font-family-body);
    font-size: var(--font-size-body-xsmall);
    line-height: var(--line-height-body-xsmall);
  }
}

@media (--large-breakpoint) {
  .kitt_large-header1_ZrA5I {
    font-size: var(--font-size-medium-and-higher-header1);
    line-height: var(--line-height-medium-and-higher-header1);
  }

  .kitt_large-header2_Q-aJo {
    font-size: var(--font-size-medium-and-higher-header2);
    line-height: var(--line-height-medium-and-higher-header2);
  }

  .kitt_large-header3_woigo {
    font-size: var(--font-size-medium-and-higher-header3);
    line-height: var(--line-height-medium-and-higher-header3);
  }

  .kitt_large-header4_VcQyF {
    font-size: var(--font-size-medium-and-higher-header4);
    line-height: var(--line-height-medium-and-higher-header4);
  }

  .kitt_large-header5_U8N4m {
    font-size: var(--font-size-medium-and-higher-header5);
    line-height: var(--line-height-medium-and-higher-header5);
  }

  .kitt_large-body-large_UpYG8 {
    font-family: var(--kitt-font-family-body);
    font-size: var(--font-size-medium-and-higher-body-large);
    line-height: var(--line-height-medium-and-higher-body-large);
  }

  .kitt_large-body-medium_lU8Go {
    font-family: var(--kitt-font-family-body);
    font-size: var(--font-size-body-medium);
    line-height: var(--line-height-body-medium);
  }

  .kitt_large-body_jfWcU {
    font-family: var(--kitt-font-family-body);
    font-size: var(--font-size-body);
    line-height: var(--line-height-body);
  }

  .kitt_large-body-small_KfKZP {
    font-family: var(--kitt-font-family-body);
    font-size: var(--font-size-body-small);
    line-height: var(--line-height-body-small);
  }

  .kitt_large-body-xsmall_afY-K {
    font-family: var(--kitt-font-family-body);
    font-size: var(--font-size-body-xsmall);
    line-height: var(--line-height-body-xsmall);
  }
}

.kitt_black-bold_lF2gI {
  font-weight: var(--kitt-bold-font-weight);
  color: var(--kitt-main-black-color);
}

.kitt_black-regular_mV-Wn {
  font-weight: var(--kitt-regular-font-weight);
  color: var(--kitt-main-regular-color);
}

.kitt_black-anthracite-bold_bOqc- {
  font-weight: var(--kitt-bold-font-weight);
  color: var(--kitt-main-black-anthracite-color);
}

.kitt_black-anthracite-regular_UxFWd {
  font-weight: var(--kitt-regular-font-weight);
  color: var(--kitt-main-black-anthracite-color);
}

.kitt_black-light-bold_Nxdy2 {
  font-weight: var(--kitt-bold-font-weight);
  color: var(--kitt-main-black-light-color);
}

.kitt_black-light-regular_ay7jE {
  font-weight: var(--kitt-regular-font-weight);
  color: var(--kitt-main-black-light-color);
}

.kitt_white-bold_yFA-5 {
  font-weight: var(--kitt-bold-font-weight);
  color: var(--kitt-main-white-color);
}

.kitt_white-regular_-a5Gl {
  font-weight: var(--kitt-regular-font-weight);
  color: var(--kitt-main-white-color);
}

.kitt_white-light-bold_BpdM2 {
  font-weight: var(--kitt-bold-font-weight);
  color: var(--kitt-main-white-light-color);
}

.kitt_white-light-regular_y1UFP {
  font-weight: var(--kitt-regular-font-weight);
  color: var(--kitt-main-white-light-color);
}

.kitt_primary-bold_UJQOS {
  font-weight: var(--kitt-bold-font-weight);
  color: var(--kitt-primary-color);
}

.kitt_primary-regular_TNEPa {
  font-weight: var(--kitt-regular-font-weight);
  color: var(--kitt-primary-color);
}

.kitt_accent-bold_PSoG9 {
  font-weight: var(--kitt-bold-font-weight);
  color: var(--kitt-accent-color);
}

.kitt_accent-regular_3pmUR {
  font-weight: var(--kitt-regular-font-weight);
  color: var(--kitt-accent-color);
}

.kitt_success-bold_bkPDO {
  font-weight: var(--kitt-bold-font-weight);
  color: var(--kitt-success-color);
}

.kitt_success-regular_ptlbA {
  font-weight: var(--kitt-regular-font-weight);
  color: var(--kitt-success-color);
}

.kitt_danger-bold_KcPPU {
  font-weight: var(--kitt-bold-font-weight);
  color: var(--kitt-alert-color);
}

.kitt_danger-regular_1H3c5 {
  font-weight: var(--kitt-regular-font-weight);
  color: var(--kitt-alert-color);
}

.kitt_ResetButton_jAA-C {
  outline: none;
  border: none;
  border-radius: 0;
  background: transparent;
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: transparent;
  text-decoration: none;
  font-size: inherit;
}a.kitt_ResetButton_jAA-C,
a.kitt_ResetButton_jAA-C:visited,
a.kitt_ResetButton_jAA-C:active,
a.kitt_ResetButton_jAA-C:focus,
a.kitt_ResetButton_jAA-C:hover,
a.kitt_ResetButton_jAA-C:not(.btn):visited {
  text-decoration: none;
}button.kitt_ResetButton_jAA-C,
input[type='reset'].kitt_ResetButton_jAA-C,
input[type='button'].kitt_ResetButton_jAA-C {
  font-family: inherit;
  box-shadow: inherit;
  padding: 0;
  line-height: inherit;
}

.kitt_IconButton_hCaJH {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  cursor: pointer;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: transparent;
  transform: scale(1) translateZ(0);
  transition: all 200ms cubic-bezier(0.645, 0.045, 0.355, 1);

  /* Border displayed when disabled  */
  &::before {
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    top: 0;
    left: 0;
    opacity: 0;
    box-shadow: inset 0 0 0 2px var(--kitt-button-disabled-border-color);
    transition: opacity 200ms cubic-bezier(0.645, 0.045, 0.355, 1);
  }

  &:hover,
  .kitt-hover &,
  &:active,
  .kitt-active &,
  &:focus,
  .kitt-focus & {
    background-color: var(--kitt-button-default-hover-background-color);
  }

  &:hover,
  .kitt-hover & {
    @media (hover: none) and (pointer: coarse) {
      transform: scale(0.95);
    }

    @media (--medium-breakpoint) {
      transform: scale(1.05);
    }
  }

  &:active,
  .kitt-active & {
    transform: scale(0.95);
  }
}

.kitt_White_-Ctpo {
  &:hover,
  .kitt-hover &,
  &:active,
  .kitt-active &,
  &:focus,
  .kitt-focus & {
    background-color: var(--kitt-button-white-hover-background-color);
  }
}

.kitt_Disabled_lvDYY {
  cursor: not-allowed;
  background-color: var(--kitt-button-disabled-background-color);

  &::before {
    opacity: 1;
  }

  &:hover,
  .kitt-hover &,
  &:active,
  .kitt-active & {
    transform: scale(1);
    background-color: var(--kitt-button-disabled-background-color);
  }
}

.kitt_ResetButton_jAA-C {
  outline: none;
  border: none;
  border-radius: 0;
  background: transparent;
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: transparent;
  text-decoration: none;
  font-size: inherit;
}a.kitt_ResetButton_jAA-C,
a.kitt_ResetButton_jAA-C:visited,
a.kitt_ResetButton_jAA-C:active,
a.kitt_ResetButton_jAA-C:focus,
a.kitt_ResetButton_jAA-C:hover,
a.kitt_ResetButton_jAA-C:not(.btn):visited {
  text-decoration: none;
}button.kitt_ResetButton_jAA-C,
input[type='reset'].kitt_ResetButton_jAA-C,
input[type='button'].kitt_ResetButton_jAA-C {
  font-family: inherit;
  box-shadow: inherit;
  padding: 0;
  line-height: inherit;
}

.kitt_DismissButton_fffDS {
  /* Reset button */
  cursor: pointer;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background-color: transparent;
  transition-property: background;
  transition-duration: 200ms;
  transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1);

  &.kitt_Info_Ega-j:hover {
    background-color: var(--kitt-feedback-dismiss-background-info);
  }

  &.kitt_Confirmation_zutaT:hover {
    background-color: var(--kitt-feedback-dismiss-background-confirm);
  }

  &.kitt_Warning_Iwf19:hover {
    background-color: var(--kitt-feedback-dismiss-background-warning);
  }

  &.kitt_Error_XmET-:hover {
    background-color: var(--kitt-feedback-dismiss-background-error);
  }
}

.kitt_Icon_S64s6 {
  color: var(--kitt-main-black-color);
  height: 100%;
  width: 100%;
  padding: 10px;
  line-height: 1;

  &.kitt_Light_cMqAS {
    color: var(--kitt-main-white-color);
  }
}

.kitt_Alert_rSuKM {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  position: relative;
  padding: 18px 20px 17px;
  background: var(--kitt-feedback-info-color);
  box-shadow: var(--kitt-feedback-info-shadow);
}

.kitt_WithRadius_R5PxJ {
  border-radius: 20px;
}

.kitt_Content_PU6sn {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  width: 100%;
  font-weight: normal;

  /** Icon styling **/
  & > :first-child {
    margin: 1px 20px 0 0;
  }
}

.kitt_Alert_Success_CWAAn {
  background: var(--kitt-feedback-confirm-color);
  box-shadow: var(--kitt-feedback-confirm-shadow);
}

.kitt_Alert_Warning_nH1Sg {
  background: var(--kitt-feedback-warning-color);
  box-shadow: var(--kitt-feedback-warning-shadow);
}

.kitt_Alert_Danger_2mTnO {
  background: var(--kitt-feedback-error-color);
  box-shadow: var(--kitt-feedback-error-shadow);
}

.kitt_Text_doKh2 {
  width: calc(100% - 40px);
  text-align: left;
}

/** Alert with Button **/
.kitt_Dismissable_v2YEN {
  @media (--medium-breakpoint) {
    justify-content: space-between;
  }
}

.kitt_Dismissable_v2YEN .kitt_Text_doKh2 {
  @media (--medium-breakpoint) {
    width: calc(100% - 80px);
    padding-right: 15px;
  }
}

.kitt_Dismissable_v2YEN .kitt_Content_PU6sn {
  @media (--medium-breakpoint) {
    width: calc(100% - 40px);
  }
}

/* Center version */
.kitt_Center_5kDjY .kitt_Text_doKh2 {
  margin: 0;
  width: 100%;

  @media (--small-breakpoint) {
    text-align: center;
  }
}

.kitt_Center_5kDjY.kitt_Dismissable_v2YEN .kitt_Content_PU6sn {
  @media (--medium-breakpoint) {
    width: 100%;
    padding-left: 60px;
  }
}

.kitt_Center_5kDjY.kitt_Dismissable_v2YEN .kitt_Content_PU6sn .kitt_Text_doKh2 {
  @media (--medium-breakpoint) {
    width: calc(100% - 60px);
    padding: 0;
  }
}

.kitt_BaseDismiss_6--hE {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;

  &:focus {
    outline: none;
  }

  @media (--medium-breakpoint) {
    display: none;
  }
}

.kitt_MediumDismiss_Rsd4V {
  display: none;
  position: absolute;
  right: 10px;
  top: 10px;

  @media (--medium-breakpoint) {
    display: block;
  }
}

.kitt_AvatarWrapper_HVGpY {
  display: inline-block;
  border-radius: 10px;
  background-color: var(--kitt-avatar-default-background-color);
  height: 100%;
  width: 100%;
  overflow: hidden;

  img {
    width: 100%;
  }
}

.kitt_Light_p5R9Q {
  background-color: var(--kitt-avatar-light-background-color);
}

.kitt_TextAvatar_nULCX {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 300;
  color: var(--kitt-avatar-default-color);
  font-size: 13px;
}

.kitt_Light_p5R9Q.kitt_TextAvatar_nULCX {
  color: var(--kitt-avatar-light-color);
}

.kitt_Large_qZEhX {
  border-radius: 30px;
}

.kitt_DefaultAvatar_Uo4Rt {
  display: flex;
  height: 100%;
  width: 100%;

  svg {
    height: 45%;
    width: 45%;
    margin: auto;
  }
}

.kitt_ResetButton_jAA-C {
  outline: none;
  border: none;
  border-radius: 0;
  background: transparent;
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: transparent;
  text-decoration: none;
  font-size: inherit;
}a.kitt_ResetButton_jAA-C,
a.kitt_ResetButton_jAA-C:visited,
a.kitt_ResetButton_jAA-C:active,
a.kitt_ResetButton_jAA-C:focus,
a.kitt_ResetButton_jAA-C:hover,
a.kitt_ResetButton_jAA-C:not(.btn):visited {
  text-decoration: none;
}button.kitt_ResetButton_jAA-C,
input[type='reset'].kitt_ResetButton_jAA-C,
input[type='button'].kitt_ResetButton_jAA-C {
  font-family: inherit;
  box-shadow: inherit;
  padding: 0;
  line-height: inherit;
}

:root {
  --ornikar-kitt-buttons-transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1);
}

.kitt_Button_3EIqL {
  /* Reset button */
  position: relative;
  display: inline-flex;
  border-radius: var(--kitt-button-border-radius);
  cursor: pointer;

  /* translateZ(0) for hardware acceleration */
  transform: scale(1) translateZ(0);
  max-width: 335px;
  min-height: 40px;
  min-width: var(--kitt-button-min-width);

  /* Simplifies the animation to just the front of the object – avoid blurry scale */
  backface-visibility: hidden;

  /* Transition */
  transition-property: transform, color, background, border-color;
  transition-duration: 200ms;
  transition-timing-function: var(--ornikar-kitt-buttons-transition-timing-function);

  /* Shadow
   * See https://tobiasahlin.com/blog/how-to-animate-box-shadow/
   * -> TL;DR: Animate the box-shadow property in CSS without causing re-paints on every frame
   * using opacity of a pseudo-element.
   *
   * before: for hover box-shadow
   * after: for active box-shadow
   *
   */
  &::before,
  &::after {
    content: '';

    /* avoid focus on active */
    z-index: -1;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    border-radius: var(--kitt-button-border-radius);
    opacity: 0;
    transition-property: opacity;
    transition-duration: 200ms;
    transition-timing-function: var(--ornikar-kitt-buttons-transition-timing-function);
  }

  /* Every button hover state */
  &:hover,
  &.kitt-hover {
    /* display hover box-shadow */
    &::before {
      opacity: 1;
    }

    /* This target ONLY smartphones and touchscreens
       -> As active doesn't work on iOS, we want
          to use hover state to scale down
       See https://medium.com/@ferie/detect-a-touch-device-with-only-css-9f8e30fa1134 */
    @media (hover: none) and (pointer: coarse) {
      transform: scale(0.95);
    }

    @media (--medium-breakpoint) {
      /* Scale up */
      transform: scale(1.05);
    }
  }

  /* Every button active state */
  &:active,
  &.kitt-active {
    /* Scale down */
    transform: scale(0.95);

    /* display active box-shadow */
    &::after {
      opacity: 1;
    }

    /* remove hover box-shadow */
    &::before {
      opacity: 0;
    }
  }

  /* Every button focus state */
  &:focus > .kitt_Content_LGs5p,
  &.kitt-focus > .kitt_Content_LGs5p {
    &::after {
      opacity: 1;
    }
  }
}

.kitt_Button_3EIqL > .kitt_Content_LGs5p {
  font-weight: 600;
  display: flex;
  padding: var(--kitt-button-padding);
  width: 100%;

  /* Shadow
   * See https://tobiasahlin.com/blog/how-to-animate-box-shadow/
   * -> TL;DR: Animate the box-shadow property in CSS without causing re-paints on every frame
   * using opacity of a pseudo-element.
   *
   */
  &::before,
  &::after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    opacity: 1;
    border-radius: var(--kitt-button-border-radius);
    transition-property: opacity;
    transition-duration: 200ms;
    transition-timing-function: var(--ornikar-kitt-buttons-transition-timing-function);
  }

  /* For focus border – in order to avoid button to move */
  &::after {
    top: -3px;
    left: -3px;
    right: -3px;
    bottom: -3px;
    opacity: 0;
    border-color: transparent;
    border-width: 3px;
    border-style: solid;
    border-radius: calc(var(--kitt-button-border-radius) + 3px);
  }

  &:focus {
    outline: none;
  }
}

.kitt_Button_3EIqL > .kitt_Content_LGs5p .kitt_Children_6xIlx {
  display: flex;
}

/* Remove box-shadow default content box shadow */
.kitt_Button_3EIqL:hover,
.kitt_Button_3EIqL.kitt-hover,
.kitt_Button_3EIqL:active,
.kitt_Button_3EIqL.kitt-active,
.kitt_Button_3EIqL:focus,
.kitt_Button_3EIqL.kitt-focus,
.kitt_Button_3EIqL.kitt_Disabled_cVEh5 {
  /* Content box-shadow */
  & > .kitt_Content_LGs5p::before {
    opacity: 0;
  }
}

/******** PRIMARY ********/
.kitt_Button_3EIqL.kitt_Primary_jss48 {
  background: var(--kitt-button-primary-background-color);
  color: var(--kitt-button-primary-color);

  /* Content box-shadow */
  & > .kitt_Content_LGs5p::before {
    box-shadow: var(--kitt-button-primary-shadow);
  }

  /* Hover state box-shadow */
  &::before {
    box-shadow: var(--kitt-button-primary-hover-shadow);
  }

  /* Active state box-shadow */
  &::after {
    box-shadow: var(--kitt-button-primary-active-shadow);
  }

  /* Hover + active states */
  &:hover,
  &.kitt-hover,
  &:active,
  &.kitt-active {
    background: var(--kitt-button-primary-hover-background-color);
  }

  /* Focus state */
  &:focus > .kitt_Content_LGs5p,
  &.kitt-focus > .kitt_Content_LGs5p {
    &::after {
      border-color: var(--kitt-button-primary-focus-border-color);
    }
  }
}

/******** SECONDARY (default) ********/
.kitt_Button_3EIqL.kitt_Secondary_U8y1X {
  background: var(--kitt-button-default-background-color);
  color: var(--kitt-button-default-color);

  /* Hover + active states */
  &:hover,
  &.kitt-hover,
  &:active,
  &.kitt-active {
    background: var(--kitt-button-default-hover-background-color);
  }

  /* Focus state */
  &:focus > .kitt_Content_LGs5p,
  &.kitt-focus > .kitt_Content_LGs5p {
    &::after {
      border-color: var(--kitt-button-default-focus-border-color);
    }
  }
}

/******** SECONDARY WHITE ********/
.kitt_Button_3EIqL.kitt_White_pV2DY {
  background: var(--kitt-button-white-background-color);
  color: var(--kitt-button-white-color);

  /* Hover + active states */
  &:hover,
  &.kitt-hover,
  &:active,
  &.kitt-active {
    background: var(--kitt-button-white-hover-background-color);
  }

  /* Focus state */
  &:focus > .kitt_Content_LGs5p,
  &.kitt-focus > .kitt_Content_LGs5p {
    &::after {
      border-color: var(--kitt-button-white-focus-border-color);
    }
  }
}

/******** ACCENT ********/
.kitt_Button_3EIqL.kitt_Accent_tG-1E {
  background: var(--kitt-button-accent-background-color);
  color: var(--kitt-button-accent-color);
  border: 3px solid var(--kitt-button-accent-border-color);

  & > .kitt_Content_LGs5p {
    padding: 4px 13px 5px;
  }

  /* Hover and active state */
  &:hover,
  &.kitt-hover,
  &:active,
  &.kitt-active {
    background: var(--kitt-button-accent-hover-background-color);
    border-color: var(--kitt-button-accent-hover-border-color);
  }

  /* Focus state */
  &:focus,
  &.kitt-focus {
    border-color: var(--kitt-button-accent-focus-border-color);
  }
}

/******** SUBTLE ********/
.kitt_Button_3EIqL.kitt_Subtle_JXSeV {
  background: transparent;
  color: var(--kitt-button-subtle-color);

  /* Hover state */
  &:hover,
  &.kitt-hover {
    color: var(--kitt-button-subtle-hover-color);
  }

  /* Active state */
  &:active,
  &.kitt-active {
    color: var(--kitt-button-subtle-active-color);
  }

  /* Focus state */
  &:focus > .kitt_Content_LGs5p,
  &.kitt-focus > .kitt_Content_LGs5p {
    &::after {
      border-color: var(--kitt-button-subtle-focus-border-color);
    }
  }
}

/******** SUBTLE DARK ********/
.kitt_Button_3EIqL.kitt_SubtleDark_jMdAl {
  background: transparent;
  color: var(--kitt-button-subtle-dark-color);

  /* Hover state */
  &:hover,
  &.kitt-hover {
    color: var(--kitt-button-subtle-dark-hover-color);
  }

  /* Active state */
  &:active,
  &.kitt-active {
    color: var(--kitt-button-subtle-dark-active-color);
  }

  /* Focus state */
  &:focus > .kitt_Content_LGs5p,
  &.kitt-focus > .kitt_Content_LGs5p {
    &::after {
      border-color: var(--kitt-button-subtle-dark-focus-border-color);
    }
  }
}

/******** Ghost Primary ********/
.kitt_Button_3EIqL.kitt_GhostPrimary_VY18- {
  background: var(--kitt-button-ghost-primary-background-color);
  color: var(--kitt-button-ghost-primary-color);

  &:hover,
  &.kitt-hover,
  &:active,
  &.kitt-active {
    background: var(--kitt-button-ghost-primary-hover-background-color);
  }

  /* Focus state */
  &:focus > .kitt_Content_LGs5p,
  &.kitt-focus > .kitt_Content_LGs5p {
    &::after {
      border-color: var(--kitt-button-ghost-primary-focus-border-color);
    }
  }
}

/******** Ghost Secondary ********/
.kitt_Button_3EIqL.kitt_GhostSecondary_rHGPL {
  background: var(--kitt-button-ghost-secondary-background-color);
  color: var(--kitt-button-ghost-secondary-color);

  &:hover,
  &.kitt-hover,
  &:active,
  &.kitt-active {
    background: var(--kitt-button-ghost-secondary-hover-background-color);
  }

  /* Focus state */
  &:focus > .kitt_Content_LGs5p,
  &.kitt-focus > .kitt_Content_LGs5p {
    &::after {
      border-color: var(--kitt-button-ghost-secondary-focus-border-color);
    }
  }
}

/******** Facebook ********/
.kitt_Facebook_qjzyu {
  background: var(--kitt-button-facebook-background-color);
  color: var(--kitt-button-facebook-color);

  /* Content box-shadow */
  & > .kitt_Content_LGs5p::before {
    box-shadow: var(--kitt-button-facebook-shadow);
  }

  /* Hover state box-shadow */
  &::before {
    box-shadow: var(--kitt-button-facebook-hover-shadow);
  }

  /* Active state box-shadow */
  &::after {
    box-shadow: var(--kitt-button-facebook-active-shadow);
  }

  /* Hover + active states */
  &:hover,
  &.kitt-hover,
  &:active,
  &.kitt-active {
    background: var(--kitt-button-facebook-hover-background-color);
  }

  /* Focus state */
  &:focus > .kitt_Content_LGs5p,
  &.kitt-focus > .kitt_Content_LGs5p {
    &::after {
      border-color: var(--kitt-button-facebook-focus-border-color);
    }
  }
}

/* Disabled */
.kitt_Button_3EIqL.kitt_Disabled_cVEh5 {
  background: var(--kitt-button-disabled-background-color);
  color: var(--kitt-button-disabled-color);
  border: 2px solid var(--kitt-button-disabled-border-color);
  cursor: not-allowed;

  & > .kitt_Content_LGs5p {
    padding: var(--kitt-button-padding-disabled);
  }

  /* Hover state */
  &:hover,
  &.kitt-hover {
    background: var(--kitt-button-disabled-background-color);
    border: 2px solid var(--kitt-button-disabled-border-color);
    color: var(--kitt-button-disabled-color);
    transform: none;

    /* Do not display box shadow */
    &::before {
      opacity: 0;
    }
  }

  /* Active state */
  &:active,
  &.kitt-active {
    background: var(--kitt-button-disabled-background-color);
    border: 2px solid var(--kitt-button-disabled-border-color);
    color: var(--kitt-button-disabled-color);
    transform: none;

    /* Do not display box shadow */
    &::after {
      opacity: 0;
    }
  }

  &:focus {
    border-color: var(--kitt-button-disabled-focus-border-color);
  }

  /* Focus state */
  &:focus > .kitt_Content_LGs5p,
  &.kitt-focus > .kitt_Content_LGs5p {
    &::after {
      border: none;
      background: transparent;
    }
  }
}

/* With icon */
.kitt_Button_3EIqL.kitt_OnlyIcon_vJ2bt {
  &.kitt_Accent_tG-1E .kitt_Content_LGs5p {
    padding: 4px 7px 5px;
  }

  .kitt_Content_LGs5p {
    padding: 10px;
    justify-content: center;
  }
}

.kitt_Icon_u7eKh {
  display: inline-flex;
  align-items: center;
  margin: 0 8px 0 0;

  /* Only icon */
  &:first-child:last-child {
    margin: 0;
  }
}

.kitt_IconRight_g9aTK .kitt_Icon_u7eKh {
  margin: 0 0 0 8px;
}

/* Size effects */
.kitt_Button_3EIqL.kitt_Large_PrkHo > .kitt_Content_LGs5p {
  padding: var(--kitt-button-padding-large);
}

.kitt_Button_3EIqL.kitt_XLarge_XBlLD > .kitt_Content_LGs5p {
  padding: var(--kitt-button-padding-xlarge);
}

.kitt_Button_3EIqL.kitt_Stretch_oAZoW {
  width: 100%;
  max-width: none;

  & > .kitt_Content_LGs5p {
    width: 100%;
    justify-content: center;
  }
}

.kitt_CheckboxContainer_2xkYt {
  cursor: pointer;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;

  &.kitt_AlignRight_Nh5nq {
    flex-flow: row-reverse;
  }
}

.kitt_CheckboxContainer_2xkYt input[type='checkbox'] {
  /* when display is equal to none, input cannot be focusable
  => better to use position absolute and opacity for accessibility */
  position: absolute;
  opacity: 0;
}

.kitt_Checkbox_S4DJ8 {
  height: 20px;
  width: 20px;
  float: left;
  margin: -1px 10px 0 0;
  position: relative;
  border-radius: 5px;
  border: 2px solid var(--kitt-checkbox-border-color);
  background-color: #fff;
  transition: all 0.2s ease-out;

  .kitt_AlignRight_Nh5nq & {
    margin-right: 0;
    margin-left: 10px;
  }

  .kitt_AlignBaseline_lSS3l & {
    align-self: baseline;
    margin-top: 2px;
  }

  &::after {
    content: '';
    position: absolute;
    top: -2px;
    left: -2px;
    bottom: -2px;
    right: -2px;
    opacity: 0;
    border-radius: 5px;
    transition: opacity 0.2s ease-in-out 0.05s;
    box-shadow: var(--kitt-checkbox-shadow);
  }

  svg {
    position: absolute;
    height: 20px;
    width: 20px;
    top: -2px;
    left: -2px;
  }

  &:focus {
    outline: none;
  }
}

.kitt_Unlabeled_484lf {
  padding: 0;
  width: 20px;
}

.kitt_Unlabeled_484lf .kitt_Checkbox_S4DJ8 {
  margin: 0;
}

.kitt_CheckboxContainer_2xkYt svg path {
  stroke: white;
  stroke-width: 2px;
  fill: transparent;
  stroke-dasharray: 27;
  stroke-dashoffset: 27;
  transition: stroke-dashoffset 200ms ease-in;
}

.kitt-focus .kitt_Checkbox_S4DJ8,
.kitt-hover .kitt_Checkbox_S4DJ8,
input:focus + .kitt_Checkbox_S4DJ8,
.kitt_CheckboxContainer_2xkYt:hover .kitt_Checkbox_S4DJ8 {
  border-color: var(--kitt-checkbox-focus-border-color);
}

.kitt-hover .kitt_Checkbox_S4DJ8::after,
.kitt_CheckboxContainer_2xkYt:hover .kitt_Checkbox_S4DJ8::after {
  opacity: 1;
}

.kitt_CheckboxContainer_2xkYt input:active + .kitt_Checkbox_S4DJ8::after {
  opacity: 0;
}

.kitt_CheckboxContainer_2xkYt .kitt_CheckboxChecked_RiwAh {
  border-color: var(--kitt-checkbox-checked-border-color);
  background-color: var(--kitt-checkbox-checked-background-color);

  path {
    transition: stroke-dashoffset 200ms ease-in;
    stroke-dashoffset: 0;
  }

  &::after {
    opacity: 1;
  }
}

.kitt_Label_KCzyj {
  flex: 1;
  color: var(--kitt-checkbox-label-color);
  font-weight: var(--kitt-checkbox-label-font-weight);
}

.kitt_ResetButton_jAA-C {
  outline: none;
  border: none;
  border-radius: 0;
  background: transparent;
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: transparent;
  text-decoration: none;
  font-size: inherit;
}a.kitt_ResetButton_jAA-C,
a.kitt_ResetButton_jAA-C:visited,
a.kitt_ResetButton_jAA-C:active,
a.kitt_ResetButton_jAA-C:focus,
a.kitt_ResetButton_jAA-C:hover,
a.kitt_ResetButton_jAA-C:not(.btn):visited {
  text-decoration: none;
}button.kitt_ResetButton_jAA-C,
input[type='reset'].kitt_ResetButton_jAA-C,
input[type='button'].kitt_ResetButton_jAA-C {
  font-family: inherit;
  box-shadow: inherit;
  padding: 0;
  line-height: inherit;
}

:root {
  --ornikar-kitt-dropdown-transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1);
}

.kitt_Dropdown_U38jj {
  display: inline-block;
  max-width: 100%;
  position: relative;
  text-align: left;

  &.kitt_Stretch_0D-mT {
    display: block;
  }
}

.kitt_DropdownButton_irKpb {
  /* Reset button */
  position: relative;
  display: inline-flex;
  border-radius: var(--kitt-button-border-radius);
  cursor: pointer;

  /* translateZ(0) for hardware acceleration */
  transform: scale(1) translateZ(0);
  min-height: 40px;
  min-width: 40px;
  background: var(--kitt-button-default-background-color);
  color: var(--kitt-button-default-color);

  /* Simplifies the animation to just the front of the object – avoid blurry scale */
  backface-visibility: hidden;

  /* Transition */
  transition-property: transform, color, background;
  transition-duration: 200ms;
  transition-timing-function: var(--ornikar-kitt-dropdown-transition-timing-function);

  /* Shadow
   * See https://tobiasahlin.com/blog/how-to-animate-box-shadow/
   * -> TL;DR: Animate the box-shadow property in CSS without causing re-paints on every frame
   * using opacity of a pseudo-element.
   *
   * before: for hover box-shadow
   * after: for active box-shadow
   *
   */
  &::before,
  &::after {
    content: '';

    /* avoid focus on active */
    z-index: -1;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    border-radius: var(--kitt-button-border-radius);
    opacity: 0;
    transition-property: opacity;
    transition-duration: 200ms;
    transition-timing-function: var(--ornikar-kitt-dropdown-transition-timing-function);
  }

  /* Every button hover state */
  &:hover,
  &.kitt-hover {
    background: var(--kitt-button-default-hover-background-color);

    /* display hover box-shadow */
    &::before {
      opacity: 1;
    }

    @media (--medium-breakpoint) {
      /* Scale up */
      transform: scale(1.05);
    }
  }

  /* Every button active state */
  &:active,
  &.kitt-active {
    background: var(--kitt-dropdown-default-active-background-color);

    /* Reset scale */
    transform: scale(1);

    /* remove hover box-shadow */
    &::before {
      opacity: 0;
    }
  }

  /* Every button focus state */
  &:focus > .kitt_Content_XW1c8,
  &.kitt-focus > .kitt_Content_XW1c8 {
    &::after {
      border-color: var(--kitt-button-default-focus-border-color);
      opacity: 1;
    }
  }
}

.kitt_DropdownButton_irKpb > .kitt_Content_XW1c8.kitt_OnlyIcon_xTMZE,
.kitt_DropdownButton_irKpb.kitt_Stretch_0D-mT > .kitt_Content_XW1c8.kitt_OnlyIcon_xTMZE {
  justify-content: flex-end;
}

.kitt_DropdownButton_irKpb > .kitt_Content_XW1c8 {
  font-weight: 600;
  display: flex;
  padding: var(--kitt-button-padding);
  width: 100%;
  justify-content: space-between;

  /* Shadow
   * See https://tobiasahlin.com/blog/how-to-animate-box-shadow/
   * -> TL;DR: Animate the box-shadow property in CSS without causing re-paints on every frame
   * using opacity of a pseudo-element.
   *
   */
  &::before,
  &::after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    opacity: 1;
    border-radius: var(--kitt-button-border-radius);
    transition-property: opacity;
    transition-duration: 200ms;
    transition-timing-function: var(--ornikar-kitt-dropdown-transition-timing-function);
  }

  /* For focus border – in order to avoid button to move */
  &::after {
    top: -3px;
    left: -3px;
    right: -3px;
    bottom: -3px;
    opacity: 0;
    border-color: transparent;
    border-width: 3px;
    border-style: solid;
    border-radius: calc(var(--kitt-button-border-radius) + 3px);
  }

  &:focus {
    outline: none;
  }
}

.kitt_DropdownButton_irKpb > .kitt_Content_XW1c8 .kitt_Children_e9My3 {
  display: flex;
  flex: 1;
}

/* Remove box-shadow default content box shadow */
.kitt_Button_FWuZY:hover,
.kitt_Button_FWuZY.kitt-hover,
.kitt_Button_FWuZY:active,
.kitt_Button_FWuZY.kitt-active,
.kitt_Button_FWuZY:focus,
.kitt_Button_FWuZY.kitt-focus,
.kitt_Button_FWuZY.kitt_Disabled_pQFPv {
  /* Content box-shadow */
  & > .kitt_Content_XW1c8::before {
    opacity: 0;
  }
}

/******** PRIMARY ********/
.kitt_DropdownButton_irKpb.kitt_Primary_Pzdsp {
  background: var(--kitt-button-primary-background-color);
  color: #fff;

  /* Content box-shadow */
  & > .kitt_Content_XW1c8::before {
    box-shadow: var(--kitt-button-primary-shadow);
  }

  /* Hover state box-shadow */
  &::before {
    box-shadow: var(--kitt-button-primary-hover-shadow);
  }

  /* Active state box-shadow */
  &::after {
    box-shadow: var(--kitt-button-primary-active-shadow);
  }

  /* Hover state */
  &:hover,
  &.kitt-hover {
    background: var(--kitt-button-primary-hover-background-color);
  }

  &:active,
  &.kitt-active {
    background: var(--kitt-dropdown-primary-active-background-color);
  }

  /* Focus state */
  &:focus > .kitt_Content_XW1c8,
  &.kitt-focus > .kitt_Content_XW1c8 {
    &::after {
      border-color: var(--kitt-button-primary-focus-border-color);
    }
  }
}

.kitt_Icon_tcmR1 {
  display: inline-flex;
  align-items: center;
  margin: 0 0 0 8px;

  /* Only icon */
  &:first-child:last-child {
    margin: 0;
  }
}

/* With avatar */
.kitt_DropdownButton_irKpb.kitt_WithAvatar_YA2Sh {
  &:hover {
    /* do not display hover box-shadow */
    &::before {
      opacity: 0;
    }
  }

  &:active,
  &.kitt-active {
    /* do not display active box-shadow */
    &::after {
      opacity: 0;
    }
  }

  &.kitt_Stretch_0D-mT {
    width: auto;

    @media (--medium-breakpoint) {
      width: 100%;
    }
  }

  .kitt_Content_XW1c8 {
    padding: 0;
    display: inline-flex;
    align-items: center;

    .kitt_Children_e9My3,
    .kitt_Icon_tcmR1 {
      display: none;

      @media (--medium-breakpoint) {
        display: inline-flex;
        align-items: center;
      }
    }

    /* No box-shadow */
    &::before {
      opacity: 0;
    }

    @media (--medium-breakpoint) {
      padding: 4px 16px 4px 4px;

      /* Reset box shadow after medium */
      &::before {
        opacity: 1;
      }

      .kitt_Icon_tcmR1 {
        display: inline-flex;
      }
    }
  }

  @media (--medium-breakpoint) {
    &:hover,
    &.kitt-hover {
      /* reset hover box-shadow */
      &::before {
        opacity: 1;
      }
    }

    &:active,
    &.kitt-active {
      /* Remove hover box shadow */
      &::before {
        opacity: 0;
      }

      /* reset active box-shadow */
      &::after {
        opacity: 1;
      }
    }
  }
}

.kitt_DropdownButton_irKpb.kitt_Stretch_0D-mT {
  width: 100%;
  max-width: none;

  & > .kitt_Content_XW1c8 {
    width: 100%;
    justify-content: center;
  }
}

.kitt_ButtonLabel_EJOCT {
  display: flex;
  align-items: center;
  overflow: hidden;
  vertical-align: text-top;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
}

.kitt_Avatar_mRlLa {
  margin: 0;
  height: 40px;
  width: 40px;

  @media (--medium-breakpoint) {
    height: 32px;
    width: 32px;
    margin-right: 8px;
  }
}

.kitt_Popover_H9LM3 {
  z-index: 1;
  position: absolute;
  top: 50px;
  min-width: 220px;
  padding: 10px 0;
  border-radius: 10px;
  background: #fff;
  box-shadow: var(--kitt-options-container-shadow);
}

.kitt_PopoverTop_rJXcs {
  top: auto;
  bottom: 50px;
}

.kitt_PopoverBottom_FXhe- {
  top: 50px;
}

.kitt_PopoverLeft_s4UTR {
  left: 0;
}

.kitt_PopoverRight_9baMP {
  right: 0;
}

.kitt_PopoverEnter_ZBmnH {
  opacity: 0;
  transform: translateY(-10px);
}

.kitt_PopoverEnterFromTop_Bw0aP {
  opacity: 0;
  transform: translateY(10px);
}

.kitt_PopoverEnterActive_d3GTO {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 250ms ease-in-out, transform 250ms ease-in-out;
}

.kitt_PopoverExit_3c9uJ {
  opacity: 1;
  transform: translateY(0);
}

.kitt_PopoverExitActive_Pfc64 {
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 250ms ease-out, transform 250ms ease-out;
}

.kitt_PopoverTop_rJXcs.kitt_PopoverExitActive_Pfc64 {
  transform: translateY(-10px);
}

.kitt_Large_qKWZ- {
  width: 100%;
}

.kitt_DropdownItem_VTDm2 {
  cursor: pointer;
  list-style: none;
  width: 100%;
  padding: 2.5px 20px;
  box-sizing: border-box;
  text-decoration: none;
  color: var(--black-bold-color);
  font-weight: var(--kitt-options-item-dropdown-font-weight);

  &:visited {
    color: var(--black-bold-color);
  }

  &:hover {
    background: var(--kitt-options-item-hover-background-color);
  }

  &:focus {
    background: var(--kitt-options-item-focus-background-color);
    outline: none;
  }

  &:active {
    background: var(--kitt-options-item-active-background-color);
  }

  &.kitt_ActiveItem_igbh4 {
    background: var(--kitt-options-item-selected-background-color);
  }

  &:hover,
  &:focus,
  &:active,
  &.kitt_ActiveItem_igbh4 {
    color: var(--kitt-options-item-event-color);
    font-weight: var(--kitt-options-item-event-font-weight);
  }

  @media (pointer: coarse) {
    padding: 15px 20px;
  }
}

.kitt_Item_bk--P a {
  display: block;
  text-decoration: none;
}

.kitt_DropdownSelect_dbFvD {
  position: relative;
}

.kitt_Select_0RbB8 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  outline: 0;
  border: 0;
  border-radius: 3px;
  background: 0 0;
  opacity: 0;

  /* ios zoom if font-size too small */
  font-size: 16px;

  @media (min-width: 768px) {
    display: none;
  }
}

.kitt_Highlight_mRgNW {
  padding: 20px;
  background-color: var(--kitt-highlight-background-color);

  @media (--small-breakpoint) {
    border-radius: 20px;
  }
}

.kitt_Dark_iyDHw {
  background-color: var(--kitt-highlight-dark-background-color);
  border: solid 2px var(--kitt-highlight-dark-border-color);
  border-radius: 20px;
}

.kitt_ResetButton_jAA-C {
  outline: none;
  border: none;
  border-radius: 0;
  background: transparent;
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: transparent;
  text-decoration: none;
  font-size: inherit;
}a.kitt_ResetButton_jAA-C,
a.kitt_ResetButton_jAA-C:visited,
a.kitt_ResetButton_jAA-C:active,
a.kitt_ResetButton_jAA-C:focus,
a.kitt_ResetButton_jAA-C:hover,
a.kitt_ResetButton_jAA-C:not(.btn):visited {
  text-decoration: none;
}button.kitt_ResetButton_jAA-C,
input[type='reset'].kitt_ResetButton_jAA-C,
input[type='button'].kitt_ResetButton_jAA-C {
  font-family: inherit;
  box-shadow: inherit;
  padding: 0;
  line-height: inherit;
}

.kitt_InputIcon_JINTY {
  z-index: 1;
  position: absolute;
  top: 5px;
  right: 10px;
  width: 30px;
  height: 30px;
  padding: 0;
  text-align: center;
  color: var(--kitt-input-icon-color-default);
}

.kitt_WithCursor_HP4Wl {
  cursor: pointer;
}

/*
 * Disabled
 */

.kitt_DisabledIcon_fqAb- {
  color: var(--kitt-input-icon-color-disabled);
  cursor: not-allowed;
}

/*
 * Valid state icon color
 */
.kitt_ValidStateIconColor_E3AmM {
  color: var(--kitt-input-icon-color-valid);
}

/*
 * Invalid state icon color
 */
.kitt_InvalidStateIconColor_kXHPe {
  color: var(--kitt-input-icon-color-invalid);
}

.kitt_Input_nELih {
  /* see input in inputStyle.js */
  position: relative;
  color: var(--kitt-input-color);
  width: 100%;
  padding: 0 15px;
  outline: 0;
  border: 2px solid var(--kitt-input-border-color);
  box-sizing: border-box;
  transition: border-color 0.2s ease-in-out, color 0.2s ease-in-out;
  font-family: inherit;
  font-weight: var(--kitt-input-font-weight);
  font-size: inherit;
  height: 40px;
  border-radius: inherit;
  box-shadow: none;
  overflow: hidden;

  /** Move to reset inputs ? */
  &::-ms-clear,
  &::-ms-reveal {
    display: none;
  }

  &:-ms-input-placeholder {
    color: var(--kitt-input-placeholder-color);
  }

  &:disabled {
    /* see :disabled in inputStyle.js */
    cursor: not-allowed;
    background-color: var(--kitt-input-disabled-background-color);
    font-weight: var(--kitt-input-disabled-font-weight);

    &:hover {
      border: 2px solid var(--kitt-input-disabled-border-color);
    }
  }

  &:hover,
  .kitt-hover & {
    border: 2px solid var(--kitt-input-hover-border-color);
  }

  &.kitt_WithIcon_9vXmR {
    padding-right: 40px;
  }

  & ~ .kitt_StateIcon_Su1s- + .kitt_InputIcon_ngg49 {
    opacity: 0;
    transition: opacity 0s 150ms;
  }

  &:focus,
  .kitt-focus & {
    border-color: var(--kitt-input-focus-border-color);

    & + .kitt_InputShadow_uQNKZ {
      opacity: 1;
    }

    & ~ .kitt_InputIcon_ngg49 {
      opacity: 1;
      transition: opacity 0s 0s;
    }
  }
}

/** Reset Input */
input[type='text'].kitt_Input_nELih,
input[type='password'].kitt_Input_nELih,
input[type='email'].kitt_Input_nELih,
input[type='tel'].kitt_Input_nELih,
input[type='number'].kitt_Input_nELih {
  appearance: none;
}

/** Remove input[number] spinners */
input[type='number'].kitt_Input_nELih {
  -moz-appearance: textfield;
}

input[type='number'].kitt_Input_nELih::-webkit-inner-spin-button,
input[type='number'].kitt_Input_nELih::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.kitt_Input_nELih::placeholder {
  /* see ::placeholder in inputStyle.js */
  color: var(--kitt-input-placeholder-color);
  font-weight: var(--kitt-input-placeholder-font-weight);
}

.kitt_InputContainer_ICACJ {
  position: relative;
  z-index: 0;
  border-radius: var(--kitt-input-border-radius);
  width: 100%;
}

.kitt_InputShadow_uQNKZ {
  z-index: -1;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: inherit;
  box-shadow: var(--kitt-input-shadow);
  opacity: 0;
  transition: opacity 0.2s ease-in-out;
}

/*
 * Disabled state
 */
.kitt_Disabled_8INnN {
  color: var(--kitt-input-disabled-color);
  cursor: not-allowed;
}

.kitt_InputAutocomplete_WEfaY {
  position: relative;
}

.kitt_Results_QM33n {
  position: absolute;
  z-index: 1;
  width: 100%;
  padding: 16px 0 15px;
  margin: 0;
  margin-top: 5px;
  box-shadow: var(--kitt-options-container-shadow);
  border-radius: 10px;
  background: #fff;
}

.kitt_Item_BqoLq {
  padding: 7px 12px;
  list-style-type: none;
  cursor: pointer;
  transition: background 0.2s ease-in-out;
  font-weight: var(--kitt-options-item-font-weight);

  &.kitt_Highlighted_uiw6G,
  &:hover,
  &:focus,
  &:active {
    color: var(--kitt-options-item-event-color);
    font-weight: var(--kitt-options-item-event-font-weight);
  }

  &:hover {
    background: var(--kitt-options-item-hover-background-color);
  }

  &.kitt_Highlighted_uiw6G {
    background: var(--kitt-options-item-selected-background-color);
  }

  &:focus {
    background: var(--kitt-options-item-focus-background-color);
  }

  &:active {
    background: var(--kitt-options-item-active-background-color);
  }

  &:nth-of-type(1) {
    border-top: none;
  }
}

.kitt_ItemUserInputtedValue_XLtC5 {
  display: none;
}

.kitt_EmptyList_H6kNg {
  cursor: default;
  list-style-type: none;
}

.kitt_Wrapper_XbsRd {
  display: inline-flex;

  input {
    text-align: center;
  }

  input[type='number']::-webkit-inner-spin-button,
  input[type='number']::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
  }

  input[type='number'] {
    -moz-appearance: textfield;
  }
}

.kitt_DayAndMonth_dhPt0 {
  margin-right: 0.8rem;
  width: 62px;
}

.kitt_Year_7fITN {
  width: 79px;
}

.kitt_Adaptive_mTbdG {
  display: flex;

  .kitt_DayAndMonth_dhPt0,
  .kitt_Year_7fITN {
    width: calc((100% - 1.6rem) / 3);
  }

  input {
    width: 100%;
  }
}

.kitt_InputPasswordContainer_eigXd {
  position: relative;

  &::-ms-clear,
  &::-ms-reveal {
    display: none;
  }
}

.kitt_Address_ME5M9 {
  display: flex;
  align-items: flex-start;

  > *:nth-of-type(1) {
    margin-right: 10px;
  }

  @media (max-width: 639px) {
    .kitt_AddressTexts_21lpl > * {
      display: block;
    }
  }
}

.kitt_SecondaryText_f-eS0 {
  color: var(--kitt-main-light-color);

  @media (min-width: 640px) {
    margin-left: 8px;
  }
}

.kitt_ManualAddressLiOverride_su8Nf {
  margin-top: 10px;
  color: var(--kitt-main-light-color);
  background-color: transparent;

  &:nth-child(2) {
    margin-top: 0;
  }

  &:hover,
  &.kitt_ManualAddressLiOverrideSelected_08xdI,
  &.kitt_ManualAddressLiOverrideHighlighted_vUQ3E {
    color: var(--kitt-options-item-event-color);
  }

  &.kitt_ManualAddressLiOverrideHighlighted_vUQ3E {
    background-color: var(--kitt-options-item-selected-background-color);
  }
}

.kitt_ManualAddress_NxFfL {
  transition: color 0.2s ease-in-out;
  display: flex;

  & > *:nth-of-type(1) {
    margin-right: 10px;
  }
}

.kitt_InputFeedback_wgMWM {
  color: var(--kitt-input-feedback-color-default);

  &:empty {
    display: none;
  }
}

.kitt_Valid_2CrIH {
  color: var(--kitt-input-feedback-color-valid);
}

.kitt_Invalid_hcjPH {
  color: var(--kitt-input-feedback-color-invalid);
}

.kitt_InputTag_F9PZr {
  /* Transition */
  transition-property: color, background;
  transition-duration: 200ms;
  transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1);
  display: inline-flex;
  align-items: center;
  border-radius: 10px;
  background-color: var(--kitt-input-tag-default-background-color);
  color: var(--kitt-input-tag-default-color);
  padding: 0 8px;
  min-height: 24px;
}

.kitt_Success_tlBBP {
  background-color: var(--kitt-input-tag-success-background-color);
  color: var(--kitt-input-tag-success-color);
}

.kitt_Danger_OVX7k {
  background-color: var(--kitt-input-tag-danger-background-color);
  color: var(--kitt-input-tag-danger-color);
}

.kitt_Icon_Ditek {
  display: inline-flex;
  margin-right: 5px;
  width: 13.5px;
  height: 16px;

  > svg {
    width: 13.5px;
    height: 16px;
  }
}

.kitt_Text_VG8Dq {
  white-space: nowrap;
}

.kitt_InputHidden_o-B-q,
input[type='file'].kitt_InputHidden_o-B-q {
  display: none;
}

.kitt_InputFileContainer_3h7Cu label {
  margin: 0;
}

.kitt_DefaultMarker_anMlg {
  position: relative;
  width: 40px;
  height: 40px;

  /* Since the shadow is baked in the picture, we need to translate it to align the marker's pin */
  svg {
    transform: translate(7px, 6px);
    transform-origin: center;
  }
}

.kitt_PositionMarker_CM9qk > svg {
  /* Since the shadow is baked in the picture, we need to translate it to align the marker's pin */

  /* And the marker need to be centered on the position */
  transform: translateY(calc(50% + 5px));
}

.kitt_LargeMarker_5evFl {
  width: 54px;
  height: 56px;

  svg {
    transform: translate(9px, 7px);
  }
}

.kitt_MapContainer_4ixyM {
  display: flex;
  flex: 1;
}

.kitt_Standalone_-fI3Y {
  height: 100%;
  width: 100%;
  position: relative;
}

.kitt_Standalone_-fI3Y > canvas {
  display: block;
  width: 100%;
  height: 100%;
}

/**
 * Large Loader
 */

/** Gunmetal circle animation **/
@keyframes kitt_init_3cVOp {
  /**
   * 169.64 is the perimeter of each svg circle with a 27 radius
   * P = 2 * Pi * radius
   */
  0% {
    stroke-dashoffset: 169.64px;
  }

  /* Edges needs a px value */
  100% {
    /* stylelint-disable */
    stroke-dashoffset: 0;
    /* stylelint-enable */
  }
}

/** Blaze circle animation **/
@keyframes kitt_offset_CKsiX {
  0% {
    stroke-dashoffset: 169.64px;
  }

  /**
   * 34 equals 20% of this radius and represent the min offset part of the animated circle
   */
  100% {
    stroke-dashoffset: 34px;
  }
}

@keyframes kitt_rotation_Sk0hr {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

.kitt_LargeLoader_8mMH5 {
  width: 60px;
  height: 60px;

  /* Needed to make the animation starting from the top of the circles */
  transform: scale(-1) rotate(90deg);
}

.kitt_LargeLoader_8mMH5 circle,
.kitt_LargeLoader_8mMH5 g {
  transform-origin: center center;
}

.kitt_LargeLoader_8mMH5 circle {
  stroke-width: 3px;
  stroke-dasharray: 169.64px;
  stroke-dashoffset: 169.64px;
  stroke-linecap: round;
}

.kitt_Fill_AiPfT {
  transform-origin: center center;
  animation: kitt_rotation_Sk0hr 1.8s linear 0.5s infinite;

  circle {
    stroke: var(--kitt-primary-color);
    animation: kitt_offset_CKsiX 1.8s cubic-bezier(0.39, 0.575, 0.565, 1) 0.5s infinite alternate,
      kitt_rotation_Sk0hr 2.16s linear 0.5s infinite;
  }
}

.kitt_Base_49ovt circle {
  stroke: var(--kitt-separator-color);
  animation: kitt_init_3cVOp 1s cubic-bezier(0.39, 0.575, 0.565, 1) 0.5s forwards;
}

/*
 * Targets IE 11
 */
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
  .kitt_LargeLoader_8mMH5 svg {
    display: none;
  }

  .kitt_LargeLoader_8mMH5 {
    border-radius: 50%;

    &::after {
      content: '';
      left: 0;
      top: 0;
      width: calc(100% - 6px);
      height: calc(100% - 6px);
      border-radius: 50%;
      display: block;
      position: absolute;
      animation: kitt_rotation_Sk0hr 2s linear 0.5s infinite;
      border: 3px solid var(--kitt-primary-color);
      border-bottom-color: var(--kitt-separator-color);
      transform-origin: center center;
    }
  }
}

.kitt_MenuTitle_tsnWh {
  margin-bottom: 10px;
}

.kitt_MenuItem_3B--3 {
  border-radius: var(--kitt-menu-item-border-radius);
  background: transparent;
  font-size: var(--font-size-body);
  font-weight: 700;
  list-style: none;
  cursor: pointer;
  transition: background 200ms ease-out;
  line-height: 20px;

  a {
    display: inline-block;
    box-sizing: border-box;
    width: 100%;
    padding: 10px 20px;
    border-radius: var(--kitt-menu-item-border-radius);
    text-decoration: none;
    color: var(--kitt-main-light-color);
    transition: box-shadow 200ms ease-out, color 200ms ease-out;

    &:visited {
      color: var(--kitt-main-light-color);
    }

    &:focus {
      outline: none;
      box-shadow: inset 0 0 0 3px var(--kitt-menu-item-focus-border-color);
    }

    &:focus:active {
      border: none;
    }

    &:hover {
      color: var(--kitt-main-black-color);
    }
  }
}

.kitt_MenuItemSelected_Cr54s {
  background: var(--kitt-menu-item-selected-background-color);
  box-shadow: var(--kitt-menu-item-selected-shadow);

  a,
  a:visited {
    color: var(--kitt-main-black-color);
  }
}

.kitt_Overlay_YBK-m {
  background-color: var(--kitt-overlay-dark-color);
  position: fixed;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

body.modal-open {
  overflow: hidden;
}

body.ios-body-freeze {
  position: fixed;
  width: 100%;
}

.kitt_Hidden_mn0g0 {
  display: none;
}

/* Responsible of centering the modal inside the page */
.kitt_ModalContainer_3Ga0q {
  position: fixed;

  /* used when content overflows the modal body, for instance dropdowns */

  /* Must be greater than the navbar z-index */
  z-index: 3000;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;

  /* Nice bouncy scroll on ios */
  -webkit-overflow-scrolling: touch;

  @media (--small-breakpoint) {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 80px 16px;
    overflow: auto;
  }

  @media (max-height: 400px) and (--small-breakpoint) {
    padding: 16px;
  }
}

/* responsible for the modal content layout */
.kitt_ContentLayout_UOcN1 {
  width: 100%;
  height: 100%;
  z-index: 2;
  position: relative;
  max-height: 100%;
  max-width: 100%;
  background: #fff;
  display: flex;
  flex-direction: column;

  @media (--small-breakpoint) {
    justify-content: center;
    height: auto;
    max-width: 540px;
    border-radius: 20px;
    margin: auto;
    box-shadow: var(--kitt-depth-card-medium);
  }
}

.kitt_Header_ucxFh {
  position: relative;
  z-index: 1;
  padding: 8px;
  display: flex;
  flex: 0 0 auto;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--kitt-separator-color);
  min-height: 57px;
}

.kitt_Body_OjBvX {
  padding: 24px 16px;
  flex-grow: 1;
  overflow-y: auto;

  @media (--small-breakpoint) {
    flex-grow: 0;
    padding: 24px;
  }
}

.kitt_Footer_CQVAZ {
  padding: 16px;
  flex: 0 0 auto;

  @media (--small-breakpoint) {
    border-top: 1px solid var(--kitt-separator-color);
    padding: 8px;
  }
}

.kitt_Title_B0kGN {
  padding-left: 8px;

  @media (--small-breakpoint) {
    padding-left: 16px;
  }
}

.kitt_Fullscreen_dm3-d {
  padding: 0;

  .kitt_ContentLayout_UOcN1 {
    height: 100%;
    max-width: none;
    max-height: none;
  }

  .kitt_Body_OjBvX {
    flex-grow: 1;
  }

  @media (--small-breakpoint) {
    padding: 16px;
  }
}

.kitt_Left_KzsXg,
.kitt_Right_yx-Zm {
  align-self: flex-start;
}

.kitt_Left_KzsXg {
  margin-right: 8px;
}

.kitt_Right_yx-Zm {
  margin-left: 8px;
}

.kitt_FullHeight_aSC7F {
  .kitt_ContentLayout_UOcN1 {
    height: 100%;
    max-height: none;
  }

  .kitt_Body_OjBvX {
    flex-grow: 1;
  }
}

.kitt_EnterActive_4Hi7J,
.kitt_ExitActive_HRzvx {
  transition: all 400ms cubic-bezier(0.77, 0, 0.175, 1);
}

.kitt_Enter_a4am3 {
  opacity: 0;
  transform: rotateZ(5deg) translateY(50px) scale(0.8);
}

.kitt_EnterActive_4Hi7J {
  opacity: 1;
  transform: rotateZ(0) translateY(0) scale(1);
}

.kitt_Exit_8ygdY {
  opacity: 1;
  transform: rotateZ(0) translateY(0) scale(1);
}

.kitt_ExitActive_HRzvx {
  opacity: 0;
  transform: rotateZ(5deg) translateY(50px) scale(0.8);
}

.kitt_SlideInFromRightEnter_BT7cM {
  transform: translateX(100%);
}

.kitt_SlideInFromRightEnterActive_1XdW0 {
  transform: translateX(0);
  transition: transform 600ms cubic-bezier(0.77, 0, 0.175, 1);
}

.kitt_SlideInFromRightExit_WABmq {
  transform: translateX(0);
}

.kitt_SlideInFromRightExitActive_PzSFQ {
  transform: translateX(100%);
  transition: transform 600ms cubic-bezier(0.77, 0, 0.175, 1);
}

.kitt_SlideInFromBottomEnter_ubJCs {
  transform: translateY(100%);
}

.kitt_SlideInFromBottomEnterActive_SiH-y {
  transform: translateY(0);
  transition: transform 600ms cubic-bezier(0.77, 0, 0.175, 1);
}

.kitt_SlideInFromBottomExit_eKxL0 {
  transform: translateY(0);
}

.kitt_SlideInFromBottomExitActive_hLj-f {
  transform: translateY(100%);
  transition: transform 600ms cubic-bezier(0.77, 0, 0.175, 1);
}

.kitt_FadeInEnter_OMsWu {
  opacity: 0;
}

.kitt_FadeInEnterActive_LOb6- {
  opacity: 1;
  transition: opacity 250ms ease-in;
}

.kitt_FadeInExit_lPCcP {
  opacity: 1;
}

.kitt_FadeInExitActive_jpMdl {
  opacity: 0;
  transition: opacity 250ms ease-out;
}

.kitt_Items_z2SbV {
  display: flex;
  justify-content: space-between;
  margin: 0;
  padding: 0;
}

.kitt_Item_AqQ4W {
  position: relative;
  z-index: 0;
  padding: 23px 10px 0;
  list-style: none;
  color: var(--kitt-main-black-color);
  font-weight: 700;
  text-align: center;
  transition: color 200ms ease-in;
  flex: 1 1 0;

  .kitt_ActiveItem_1Ksyc ~ & {
    color: var(--kitt-main-light-color);

    &::after {
      content: none;
    }
  }

  &:first-child {
    padding-left: 0;
  }

  &:last-child {
    padding-right: 0;
  }

  /**
    * - before the bar background
    * - after contains the filled bar itself
    */
  &::after,
  &::before {
    content: '';
    position: absolute;
    height: 8px;
    width: 100%;
    left: 0;
    top: 0;
  }

  &::before {
    background: var(--kitt-separator-color);
  }

  &::after {
    background: var(--kitt-primary-color);
  }

  /**
    * The first step is slighlty off the left, and must have rounded borders
    */
  &:first-child::before,
  &:first-child::after {
    left: 50%;
    border-top-left-radius: 10px;
    border-bottom-left-radius: 10px;
  }

  /**
    * The last step is slighlty off the right, and must have rounded borders
    */
  &:last-child::before,
  &:last-child::after {
    right: 50%;
    left: auto;
    border-top-right-radius: 10px;
    border-bottom-right-radius: 10px;
  }
}

.kitt_ActiveItem_1Ksyc {
  color: var(--kitt-primary-color);
  font-weight: 700;

  &::after {
    z-index: 1;
    width: 50%;
    border-top-right-radius: 10px;
    border-bottom-right-radius: 10px;
    background: var(--kitt-primary-color);
  }

  /**
    * When the first step is active, we don't want the width to be a fixed small progress,
    * and not a relative percent-based value
    */
  &:first-child::after {
    width: 15px;
  }

  /**
    * When the last step is active, we want the bar to be fully filled
    */
  &:last-child::after {
    width: 100%;
  }
}

.kitt_AloneItem_5rkoM {
  &::before {
    display: none;
  }

  /**
    * Selector needed to override previous selector's styles' definition
    */
  &:last-child::after {
    width: 16px;
    right: calc(50% - 8px);
  }
}

/**
  * We need to hide the second bar and put the border-radius on the first bar
  */
.kitt_OnlyWithOneOtherItem_YYmbY:first-child::before {
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
}

.kitt_OnlyWithOneOtherItem_YYmbY:last-child::before {
  display: none;
}

/**
 * Vertical Mode : The container is not flex anymore, and the steps simply stack
 */
.kitt_VerticalItems_MO9nQ {
  display: block;

  /**
   * We flex the item to be able to center the content vertically
   */
  .kitt_Item_AqQ4W {
    display: flex;
    align-items: center;
    text-align: left;
    padding: 10px 0 10px 30px;

    &:last-child {
      margin-bottom: 0;
      padding-bottom: 0;
    }

    &:first-child {
      padding-top: 0;
    }

    &::after,
    &::before {
      height: 100%;
      width: 8px;
      left: 0;
      top: 0;
    }

    &::before {
      background: var(--kitt-separator-color);
    }

    &::after {
      background: var(--kitt-primary-color);
    }

    &:first-child::before,
    &:first-child::after {
      top: 40%;
      border-top-left-radius: 10px;
      border-top-right-radius: 10px;
    }

    &:last-child::before,
    &:last-child::after {
      bottom: 40%;
      top: auto;
      border-radius: 0 10px 10px;
    }

    @media (--small-breakpoint) {
      padding: 22px 0 23px 30px;

      &:first-child::before,
      &:first-child::after {
        top: calc(40% - 5px);
      }

      &:last-child::before,
      &:last-child::after {
        bottom: calc(40% - 5px);
      }
    }
  }

  .kitt_ActiveItem_1Ksyc {
    &::after {
      height: 50%;
      border-radius: 0 0 10px 10px;
      background: var(--kitt-primary-color);
    }

    &:first-child::after {
      height: 40%;
    }

    &:last-child::after {
      height: 100%;
    }

    @media (--small-breakpoint) {
      &:first-child::after {
        top: calc(40% - 5px);
      }
    }
  }

  .kitt_AloneItem_5rkoM {
    &:last-child::after {
      top: 0;
      border-radius: 10px;
    }
  }
}

.kitt_Dotted_L0Wr9 {
  justify-content: center;
}

.kitt_Dotted_L0Wr9 .kitt_Item_AqQ4W {
  position: relative;
  width: 8px;
  height: 8px;
  flex: none;
  padding: 15px 0 0;
  margin-right: 10px;

  &::before,
  &::after {
    width: 8px;
    height: 8px;
    left: calc(50% - 4px);
    border-radius: 50%;
  }

  &::after {
    background-color: var(--kitt-main-black-color);
  }

  &:last-of-type {
    margin-right: 0;
  }
}

.kitt_Dotted_L0Wr9 .kitt_Item_AqQ4W span {
  position: absolute;
  margin-top: 10px;

  /* Arbitrary value */
  width: 200px;
  left: calc(50% - 100px);
  text-align: center;
  display: none;
}

.kitt_Dotted_L0Wr9 .kitt_ActiveItem_1Ksyc {
  color: var(--kitt-primary-color);

  &::after {
    background-color: var(--kitt-primary-color);
  }
}

.kitt_Dotted_L0Wr9 .kitt_ActiveItem_1Ksyc span {
  display: block;
}

.kitt_VerticalItems_MO9nQ.kitt_Dotted_L0Wr9 .kitt_Item_AqQ4W {
  padding: 0;
  margin-bottom: 20px;

  &:last-of-type::before,
  &:last-of-type::after,
  &:first-child::before,
  &:first-child::after {
    border-radius: 50%;
    top: 0;
    bottom: 0;
    height: 8px;
  }

  &:last-of-type {
    margin-bottom: 0;
  }
}

.kitt_VerticalItems_MO9nQ.kitt_Dotted_L0Wr9 .kitt_Item_AqQ4W span {
  top: calc(50% - 10px);
  left: 28px;
  text-align: left;
  margin-top: 0;
}

.kitt_RadioBehaviourContainer_s--cr {
  position: relative;
}

input[type='radio'].kitt_InputRadioHidden_lKmIZ {
  outline: 0;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  height: 0;
  width: 0;
  margin: 0;
  padding: 0;
  border: 0;
  opacity: 0;
}

.kitt_RadioContainer_dHMKl {
  cursor: pointer;
  margin: 0;
  padding: 10px 0;
  display: flex;
  align-items: flex-start;
  flex-direction: row;

  &.kitt_AlignRight_1Uvlo {
    flex-direction: row-reverse;
  }
}

.kitt_RadioContainer_dHMKl:hover .kitt_OuterRadio_PTGIz,
.kitt_OuterRadio_PTGIz.kitt_Checked_55ktg {
  border-color: var(--kitt-radio-checked-border-color);

  &::after {
    opacity: 1;
  }
}

.kitt_RadioContainer_dHMKl input:active + .kitt_OuterRadio_PTGIz::after {
  opacity: 0;
}

.kitt_OuterRadio_PTGIz {
  position: relative;
  margin: 2px 10px 0 0;
  height: 22px;
  width: 22px;
  border-radius: 50%;
  background-color: #fff;
  border: 2px solid var(--kitt-radio-border-color);
  transition: border-color 0.2s ease-in-out;

  .kitt_AlignRight_1Uvlo & {
    margin: 0 0 0 10px;
  }

  &.kitt_Checked_55ktg {
    background-color: var(--kitt-radio-checked-background-color);
  }

  &::after {
    content: '';
    position: absolute;
    opacity: 0;
    border-radius: 50%;
    transition: opacity 0.2s ease-in-out 0.05s;
    height: 100%;
    width: 100%;
    box-shadow: var(--kitt-radio-shadow);

    /** Apply border on pseudo element, so that the block is the exact
     * same size as its parent.
     */
    top: -2px;
    left: -2px;
    border: 2px solid transparent;
  }
}

.kitt_InnerRadio_ccGzS {
  margin: 6px;
  height: 6px;
  width: 6px;
  border-radius: 50%;
  background-color: #fff;
}

.kitt_RadioLabel_WI6TQ {
  flex: 1;
  color: var(--kitt-radio-label-color);
  font-weight: var(--kitt-radio-label-font-weight);
}

.kitt_TextArea_Y9Jlf {
  display: block;
  color: var(--kitt-input-color);
  width: 100%;
  padding: 9px 15px;
  outline: 0;
  border-radius: inherit;
  border: 2px solid var(--kitt-input-border-color);
  box-sizing: border-box;
  font-family: inherit;
  font-size: inherit;
  font-weight: var(--kitt-input-font-weight);
  appearance: none;
  transition: border-color 0.2s ease-in-out;
  resize: vertical;

  &:hover,
  .kitt-hover & {
    border: 2px solid var(--kitt-input-hover-border-color);
  }

  &:focus,
  .kitt-focus & {
    border-color: var(--kitt-input-focus-border-color);

    & + .kitt_TextAreaShadow_xFJqU {
      opacity: 1;
    }
  }

  &::placeholder {
    color: var(--kitt-input-placeholder-color);
    font-weight: var(--kitt-input-placeholder-font-weight);
  }

  &:disabled {
    cursor: not-allowed;
    background-color: var(--kitt-input-disabled-background-color);
    font-weight: var(--kitt-input-disabled-font-weight);

    &:hover {
      border: 2px solid var(--kitt-input-disabled-border-color);
    }
  }

  &.kitt_WithDefaultHeight_NHwv8 {
    height: 100px;
  }

  &.kitt_WithIcon_wpnmh {
    padding-right: 40px;
  }
}

.kitt_TextAreaShadow_xFJqU {
  content: '';
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: inherit;
  box-shadow: var(--kitt-input-shadow);
  opacity: 0;
  transition: opacity 0.2s ease-in-out;
}

.kitt_Container_0QCRB {
  position: relative;
  border-radius: 10px;
}

.kitt_Disabled_pVNff {
  color: var(--kitt-input-disabled-color);
  cursor: not-allowed;
}

.kitt_Container_IoY-S {
  display: inline-block;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;

  @media (--medium-breakpoint) {
    position: relative;
  }
}

.kitt_Tooltip_7u3Gc.kitt_Visible_7evQ-,
.kitt_Container_IoY-S:hover .kitt_Tooltip_7u3Gc,
.kitt_Container_IoY-S:active .kitt_Tooltip_7u3Gc {
  opacity: 0.95;
  visibility: visible;
}

.kitt_Tooltip_7u3Gc {
  position: absolute;
  left: 20px;
  right: 20px;
  text-align: center;
  opacity: 0;
  cursor: auto;
  visibility: hidden;
  transition: all ease-in-out 200ms;
  z-index: 1;
  white-space: normal;

  @media (--medium-breakpoint) {
    width: 300px;
  }
}

.kitt_Content_trnAs {
  background-color: var(--kitt-tooltip-background-color);
  border-radius: 10px;
  padding: 6px 15px;
}

.kitt_Top_0qVF5 {
  transform: translateY(-100%);
  padding-bottom: 10px;

  @media (--medium-breakpoint) {
    left: 50%;
    right: auto;
    bottom: 100%;
    transform: translateX(-50%);
  }
}

.kitt_Bottom_dHtK6 {
  transform: translateY(25px);
  padding-top: 10px;

  @media (--medium-breakpoint) {
    left: 50%;
    right: auto;
    top: 100%;
    transform: translateX(-50%);
  }
}

.kitt_Right_FgqJe {
  transform: translateY(-100%);
  padding-bottom: 10px;

  @media (--medium-breakpoint) {
    padding-left: 10px;
    padding-bottom: 0;
    left: 100%;
    top: 50%;
    transform: translateY(-50%);
  }
}

.kitt_Left_CrKJ0 {
  transform: translateY(-100%);
  padding-bottom: 10px;

  @media (--medium-breakpoint) {
    padding-right: 10px;
    padding-bottom: 0;
    right: 100%;
    left: auto;
    top: 50%;
    transform: translateY(-50%);
  }
}

.kitt_FullWidth_g-be- {
  left: 0;
  right: 0;

  @media (--medium-breakpoint) {
    left: 50%;
    right: auto;
    width: 100%;
  }
}

.kitt_RadioButtonContainer_iD7Nn {
  position: relative;
  display: inline-block;
}

.kitt_RadioButton_V0VQK {
  border-radius: inherit;
  position: relative;
  transition: all 0.2s ease-in-out;
  padding: 5px 18px 6px;
  color: var(--kitt-radio-button-label-color);
  cursor: pointer;
  outline: 0;
  font-weight: var(--kitt-radio-button-label-font-weight);
  line-height: 25px;
  border: 2px solid var(--kitt-radio-button-border-color);
  border-right-width: 0;

  .kitt_RadioButtonContainer_iD7Nn:first-of-type & {
    border-radius: var(--kitt-radio-button-border-radius) 0 0 var(--kitt-radio-button-border-radius);
  }

  .kitt_RadioButtonContainer_iD7Nn:last-of-type & {
    border-right-width: 2px;
    border-radius: 0 var(--kitt-radio-button-border-radius) var(--kitt-radio-button-border-radius) 0;
  }

  &::after {
    position: absolute;
    border-radius: inherit;
    content: '';
    box-shadow: var(--kitt-radio-button-shadow);
    opacity: 0;
    transition: opacity 0.2s ease-in-out 0.05s;

    /** Apply border on pseudo element, so that the block is the exact
     * same size as its parent.
     */
    top: -2px;
    right: -2px;
    bottom: -2px;
    left: -2px;
  }
}

.kitt_RadioButtonContainer_iD7Nn.kitt_WithFocus_CLCLo .kitt_RadioButton_V0VQK,
.kitt_RadioButtonContainer_iD7Nn:hover .kitt_RadioButton_V0VQK,
.kitt_RadioButtonContainer_iD7Nn.kitt_Checked_HSkzv .kitt_RadioButton_V0VQK {
  border-color: var(--kitt-radio-button-checked-border-color);

  &::after {
    opacity: 1;
  }
}

.kitt_RadioButtonContainer_iD7Nn::after {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  border-left: 2px solid var(--kitt-radio-button-checked-border-color);
  opacity: 0;
  transition: opacity 0.2s ease-in-out;

  .kitt_RadioButtonContainer_iD7Nn.kitt_WithFocus_CLCLo + &,
  .kitt_RadioButtonContainer_iD7Nn:hover + &,
  .kitt_RadioButtonContainer_iD7Nn.kitt_Checked_HSkzv + & {
    opacity: 1;
  }
}

.kitt_RadioButtonContainer_iD7Nn input:active + .kitt_RadioButton_V0VQK::after {
  opacity: 0;
}

.kitt_RadioButtonContainer_iD7Nn.kitt_Checked_HSkzv .kitt_RadioButton_V0VQK {
  background-color: var(--kitt-radio-button-checked-background-color);
  color: white;
}

.kitt_Stretch_dSWZf {
  display: flex;
}

.kitt_Stretch_dSWZf .kitt_RadioButtonContainer_iD7Nn {
  flex-grow: 1;
  flex-basis: 0;
}

.kitt_Stretch_dSWZf .kitt_RadioButton_V0VQK {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  height: 100%;
}

.kitt_Map_WHL3u {
  position: relative;
}

.kitt_Map_WHL3u img {
  display: block;
  width: 100%;
  height: auto;
}

.kitt_Standalone_6ZUfH {
  box-shadow: 0 5px 20px 0 color(var(--kitt-depth-base-color) a(10%));
}

.kitt_Rounded_lfuHt {
  overflow: hidden;
  border-radius: 20px;
}

.kitt_PlaceholderContent_F168m {
  position: relative;
  width: 100%;
  height: 100%;

  svg {
    width: auto;
    height: 100%;
  }
}

.kitt_LoaderIcon_7LT31,
.kitt_LoadingError_VOOwv {
  position: absolute;
}

.kitt_LoaderIcon_7LT31 {
  width: 20px;
  height: 20px;
  top: calc(50% - 10px);
  left: calc(50% - 10px);
  font-size: 0;
  color: #fff;
}

.kitt_LoadingError_VOOwv {
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  user-select: none;

  & > div {
    color: var(--kitt-main-black-color);
    margin-bottom: 10px;
  }

  a > * {
    display: inline-block;
    vertical-align: middle;
  }

  span {
    margin-left: 10px;
  }
}

/*
 * Map Markers
 */
.kitt_MarkerContainer_Wrl5R {
  position: absolute;
  top: calc(50% - 40px);
  left: calc(50% - 20px);
  overflow: visible;
  transform: scale(0) skew(40deg, 20deg);
  transform-origin: bottom center;
  transition: transform 0.2s cubic-bezier(0.18, 0.89, 0.32, 1.28) 0.2s;
}

.kitt_LargeContainer_1qz0A {
  /* Large Marker is only considered when the viewport width is above mobile */
  @media (--small-breakpoint) {
    width: 54px;
    height: 56px;
    top: calc(50% - 56px);
    left: calc(50% - 28px);
  }
}

.kitt_PositionContainer_Vixhk {
  height: 43px;
  width: 43px;
  top: calc(50% - 17.5px);
  left: calc(50% - 21.5px);
}

.kitt_AnimatedMarker_oTHaW {
  transform: scale(1) skew(0deg, 0deg);
}

.kitt_MapPicture_FS4is {
  position: relative;
}

.kitt_Magnify_-Vu0p {
  position: absolute;
  bottom: 10px;
  right: 10px;
}

.kitt_UnloadedMap_gldCx {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  overflow: hidden;
  visibility: visible;
  background: var(--kitt-map-image-placeholder-background-color);
}

.kitt_UnloadedMapEnter_mx9GR {
  opacity: 0;
  transform: scale(1);
}

.kitt_UnloadedMapEnterActive_Cgx6q {
  opacity: 1;
  transition: opacity 200ms ease-in-out;
}

.kitt_UnloadedMapExit_op62H {
  opacity: 1;
  transform: scale(1);
}

.kitt_UnloadedMapExitActive_Q1Pbl {
  opacity: 0;
  transform: scale(1.2);
  transition: opacity 200ms ease-in-out;
}

.kitt_RemoveAfterTweak_IisEi {
  transition: opacity 200ms ease-in-out;
}

.kitt_Label_cUIXK {
  margin: 0;
  display: inline-block;
}
