@font-face {
  font-display: swap;
  font-family: 'Wix Madefor Text';
  font-style: normal;
  font-weight: 500;
  src: url('/assets/fonts/wix-madefor-500.woff2') format('woff2');
}

@font-face {
  font-display: swap;
  font-family: 'Open sans';
  font-style: normal;
  font-weight: 400;
  src: url('/assets/fonts/open-sans-regular.woff2') format('woff2');
}

:root {
  /* Указываем браузеру, что поддерживаем обе темы */
  /* TODO: */
  color-scheme: light dark;

  --fs-base-unitless: 14;
  --fs-base: calc(var(--fs-base-unitless) * 1px);

  /* #region sizes */
  /*  Адаптивные размеры (для шрифтов, отступов и тд) */
  --size-13: calc(13 / var(--fs-base-unitless) * 1rem);
  --size-16: calc(16 / var(--fs-base-unitless) * 1rem);
  --size-17: calc(17 / var(--fs-base-unitless) * 1rem);
  --size-18: calc(18 / var(--fs-base-unitless) * 1rem);
  --size-22: calc(22 / var(--fs-base-unitless) * 1rem);
  --size-30: calc(30 / var(--fs-base-unitless) * 1rem);
  --size-32: calc(32 / var(--fs-base-unitless) * 1rem);
  --size-35: calc(35 / var(--fs-base-unitless) * 1rem);
  --size-38: calc(38 / var(--fs-base-unitless) * 1rem);
  --size-58: calc(58 / var(--fs-base-unitless) * 1rem);
    --size-62: calc(62 / var(--fs-base-unitless) * 1rem);
  --size-80: calc(80 / var(--fs-base-unitless) * 1rem);
  --size-148: calc(148 / var(--fs-base-unitless) * 1rem);
  --size-500: calc(500 / var(--fs-base-unitless) * 1rem);
  /* #endregion */

  /* #region colors */
  /* Определение цветов через light-dark(светлый, темный) */
  --bg-color: light-dark(#ffffff, #000);

  --text-color: light-dark(#000000, #ffffff);
  --accent-color: light-dark(rgb(17, 120, 36), rgb(17, 120, 36));
  --accent-color-hover: light-dark(rgb(11, 79, 23), rgb(20, 140, 42));
  --switch-bg: light-dark(rgb(215, 215, 215), rgb(42, 42, 42));

  /* #endregion */
}

body {
  background-color: var(--bg-color);
  height: 100vh;
  width: 100vw;
  margin: 0;
  box-sizing: border-box;
}

@keyframes rotate {
  from {
    transform: rotate(0);
  }

  to {
    transform: rotate(360deg);
  }
}

#app {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;

  /* .wrap { */
  .wrap--column {
    box-sizing: border-box;
    padding: var(--size-30);
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .wrap--row {
    box-sizing: border-box;
    padding: var(--size-30);
    display: flex;
    flex-direction: row;
    align-items: center;

    @media (max-width: 768px) {
      flex-direction: column-reverse;
    }

    /* } */
  }

  .title {
    font-weight: 500;
    font-size: var(--size-32);
    line-height: var(--size-38);
    margin: 0 0 var(--size-16);
    text-align: center;
    font-family: 'Wix Madefor Text', Arial, sans-serif;
  }

  .text {
    text-align: center;
    font-weight: 400;
    font-size: var(--size-16);
    line-height: var(--size-22);
    font-family: 'Open sans', Arial, sans-serif;
  }

  .email {
    font-family: 'Open sans', Arial, sans-serif;
    color: var(--accent-color);
    text-decoration: none;
    transition: color 0.3s ease-in-out;
  }

  .icon {
    margin-top: var(--size-80);
  }

  .loader {
    animation: rotate 1.8s linear infinite;
    width: var(--size-80);
    width: var(--size-80);
  }

  .train {
    width: 100%;
    max-width: var(--size-500);
    box-sizing: border-box;
    padding: var(--size-30);
  }

  .text-block {
    flex-basis: 50%;
  }

  .lang-switch {
    background-color: var(--switch-bg);
    position: fixed;
    top: 10px;
    right: 10px;
    border-radius: var(--size-148);
    width: var(--size-62);
    height: var(--size-30);
    cursor: pointer;
    border: none;
    padding: 0 9px;
    box-sizing: border-box;

    .lang-wrap {
      display: flex;
      flex-direction: row;
      align-items: center;
      justify-content: space-between;
    }

    img {
      pointer-events: none;
      width: var(--size-17);
      height: var(--size-17);
    }

    span {
      pointer-events: none;
      font-size: var(--size-13);
      line-height: var(--size-18);
      padding-left: 4px;
    }
  }
}

@media (max-width: 1024px) {
  :root {
    --fs-base-unitless: 16;
  }
}

@media (max-width: 768px) {
  :root {
    --fs-base-unitless: 18;
  }

  .train {
    padding: var(--size-22) 0 0;
  }

}

@media (pointer: fine) {
  .email:hover {
    color: var(--accent-color-hover);
  }
}