@font-face {
  font-family: 'Rubik';
  src: url(/assets/fonts/Rubik-Regular.ttf) format('truetype');
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'Rubik';
  src: url(/assets/fonts/Rubik-Italic.ttf) format('truetype');
  font-weight: normal;
  font-style: italic;
}
@font-face {
  font-family: 'Rubik';
  src: url(/assets/fonts/Rubik-Medium.ttf) format('truetype');
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: 'Rubik';
  src: url(/assets/fonts/Rubik-MediumItalic.ttf) format('truetype');
  font-weight: 500;
  font-style: italic;
}
@font-face {
  font-family: 'Rubik';
  src: url(/assets/fonts/Rubik-SemiBold.ttf) format('truetype');
  font-weight: 600;
  font-style: normal;
}
@font-face {
  font-family: 'Rubik';
  src: url(/assets/fonts/Rubik-SemiBoldItalic.ttf) format('truetype');
  font-weight: 600;
  font-style: italic;
}
@font-face {
  font-family: 'Rubik';
  src: url(/assets/fonts/Rubik-Bold.ttf) format('truetype');
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: 'Rubik';
  src: url(/assets/fonts/Rubik-BoldItalic.ttf) format('truetype');
  font-weight: bold;
  font-style: italic;
}
*,
*:before,
*:after {
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
}
html,
body {
  line-height: 1.2;
  margin: 0;
  padding: 0;
}
div,
span,
object,
iframe,
img,
table,
caption,
thead,
tbody,
tfoot,
tr,
tr,
td,
article,
aside,
canvas,
details,
figure,
hgroup,
menu,
nav,
footer,
header,
section,
summary,
mark,
audio,
video {
  border: 0;
  margin: 0;
  padding: 0;
}
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
  -webkit-transition: "color 9999s ease-out, background-color 9999s ease-out";
  -webkit-transition-delay: 9999s;
}
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
address,
cit,
code,
del,
dfn,
em,
ins,
q,
samp,
small,
strong,
sub,
sup,
b,
i,
hr,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
legend,
label {
  border: 0;
  font-size: 100%;
  vertical-align: baseline;
  margin: 0;
  padding: 0;
}
article,
aside,
canvas,
figure,
figure img,
figcaption,
hgroup,
footer,
header,
nav,
section,
audio,
video {
  display: block;
}
table {
  border-collapse: separate;
  border-spacing: 0;
}
table caption,
table th,
table td {
  text-align: left;
  vertical-align: middle;
}
a img {
  border: 0;
}
button {
  background: none;
  border: 0;
  padding: 0;
  margin: 0;
  color: #fff;
  cursor: pointer;
}
a {
  text-decoration: none;
}
.ant-picker-content td {
  text-align: center;
}
.toggler {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 48px;
  min-width: 160px;
  border: 1px solid #4fbebd;
  border-radius: 8px;
  cursor: pointer;
}
@media (max-width: 1400px) {
  .toggler {
    height: 40px;
  }
}
@media (max-width: 576px) {
  .toggler {
    min-width: 100%;
    margin-top: 8px;
    font-size: 14px;
    font-weight: 500;
  }
}
.toggler:hover {
  border-color: #a7Baff;
}
.toggler .toggler-icon {
  width: 24px;
  height: 24px;
  margin-right: 8px;
  stroke: #2e384d;
}
.toggler .toggler-icon--up {
  transform: rotate(180deg);
}
.toggler .toggler-text {
  font-weight: 600;
}
@media (max-width: 1400px) {
  .toggler .toggler-text {
    font-size: 14px;
  }
}
.toggler--small {
  height: 36px;
  font-size: 14px;
}
.toggler--small .toggler-icon {
  width: 20px;
  height: 20px;
}
.toggler--right-icon .toggler-icon {
  margin-right: 0;
  margin-left: 8px;
}
.select-list {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  left: 0;
  z-index: 1;
  padding: 6px;
  background-color: #fff;
  border-radius: 8px;
  box-shadow: 0px 1px 16px -1px rgba(129, 160, 255, 0.08), 0px 3px 8px -2px #e9eeff;
}
.select-list .select-item {
  display: flex;
  align-items: center;
  margin-bottom: 4px;
  border-radius: 8px;
  padding: 5px 10px;
  height: 40px;
  cursor: pointer;
}
@media (max-width: 576px) {
  .select-list .select-item {
    font-size: 14px;
    height: 36px;
  }
}
.select-list .select-item--active {
  background-color: #eff5ff;
}
.select-list .select-item--active .select-item-label {
  color: #2e384d;
}
.select-list .select-item--disabled {
  cursor: unset;
  opacity: 0.5;
}
.select-list .select-item:last-child {
  margin-bottom: 0;
}
.select-list .select-item-label {
  color: #667085;
}
.select-list .select-item-icon {
  margin-left: auto;
  color: #52c0cf;
  flex-shrink: 0;
}
.header-icon-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  margin-right: 18px;
  background: #eef9fb;
  border-radius: 8px;
}
@media (max-width: 1400px) {
  .header-icon-wrapper {
    width: 40px;
    height: 40px;
    margin-right: 14px;
  }
}
@media (max-width: 576px) {
  .header-icon-wrapper {
    width: 32px;
    height: 32px;
    margin-right: 12px;
  }
}
.header-icon-wrapper .header-icon {
  width: 24px;
  height: 24px;
}
@media (max-width: 576px) {
  .header-icon-wrapper .header-icon {
    width: 16px;
    height: 16px;
  }
}
.notification {
  transform: translateY(80px);
  padding-bottom: 16px;
  box-shadow: none;
}
.notification.ant-notification-notice {
  width: 356px !important;
}
.notification .ant-notification-notice-icon {
  font-size: 20px;
}
.notification .ant-notification-notice-message {
  font-size: 14px !important;
  font-weight: 600 !important;
}
.notification--success {
  background: #ecfdf3;
  border: 1px solid #027a48;
}
.notification--success .notification__icon {
  color: #027a48;
}
.notification--success .notification__close-icon {
  stroke: #027a48;
}
.notification--error {
  background: #fef3f2;
  border: 1px solid #b42318;
  font-size: 14px;
}
.notification--error .notification__icon {
  color: #b42318;
}
.notification--error .notification__close-icon {
  stroke: #b42318;
}
.notification__close-icon {
  width: 20px;
  height: 20px;
}
body {
  font-family: Rubik, sans-serif;
  overflow: hidden;
  position: relative;
}
input {
  font-family: Rubik, sans-serif;
}
.app {
  --scrollbar-width: 8px;
}
.app__main {
  display: flex;
}
.app__content {
  flex: 1;
  height: calc(100vh - 73px);
  position: relative;
  overflow-y: scroll;
  overflow-x: hidden;
}
.app__content--person,
.app__content--single,
.app__content--params {
  background-color: #f2f6ff;
  border-left: 1px solid #3355912b;
}
.app__content::-webkit-scrollbar-track {
  background-color: transparent;
}
.app__content::-webkit-scrollbar {
  width: var(--scrollbar-width);
}
.app__content::-webkit-scrollbar-thumb {
  border-radius: 8px;
  background-color: #bfbfbf;
}
@media (max-width: 768px) {
  .app__content {
    padding-left: var(--scrollbar-width);
    height: calc(100vh - 126px);
  }
  .app__content--short {
    height: calc(100vh - 148px);
  }
}
.icon {
  fill: currentColor;
}
.side-indent {
  max-width: 1200px;
  margin: 0 auto;
}
.modal-open {
  overflow: hidden;
}
.ant-tabs-nav {
  margin: 0 0 10px 0 !important;
}
.ant-input-affix-wrapper,
.ant-input,
.ant-picker {
  border-radius: 8px !important;
}
.ant-input-affix-wrapper:hover,
.ant-input:hover,
.ant-picker:hover {
  border-color: #4fbebd !important;
}
.ant-input-affix-wrapper:focus,
.ant-input:focus,
.ant-picker:focus,
.ant-input-affix-wrapper-focused,
.ant-input-focused,
.ant-picker-focused {
  border-color: #4fbebd !important;
  box-shadow: 0 0 0 2px #d1e9ff !important;
}
.ant-tabs {
  font-family: Rubik, sans-serif !important;
}
.ant-tabs-tab:hover {
  color: #4fbebd !important;
}

.login {
  display: flex;
  min-height: 100vh;
  width: 100%;
  background: linear-gradient(to right, #f2f6ff, #eef9fb);
}
.login__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 40px;
}
.login__content .login__title {
  font-size: 32px;
  font-weight: 700;
  color: #2e384d;
  margin-bottom: 16px;
}
.login__content .login__subtitle {
  font-size: 18px;
  color: #335591;
  margin-bottom: 32px;
  text-align: center;
}
.login__content .login__button {
  width: 200px;
  height: 48px;
  font-size: 16px;
  font-weight: 600;
  background-color: #4fbebd;
}
.login__content .login__button:hover {
  background-color: #3b9f9e;
}
.login__preview {
  flex: 1;
  position: relative;
}
.login__preview .login__preview-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(/assets/images/login-preview-light-e4e0649f5006b34e86db.jpg) no-repeat center / cover;
}
@media (max-width: 768px) {
  .login {
    flex-direction: column;
  }
  .login__content {
    padding: 20px;
  }
  .login__content .login__title {
    font-size: 24px;
  }
  .login__content .login__subtitle {
    font-size: 16px;
  }
  .login__content .login__button {
    width: 100%;
  }
  .login__preview {
    display: none;
  }
}

.errorBlock {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.errorBlock__image {
  width: 152px;
  height: 118px;
  margin-bottom: 24px;
  background: url(/assets/images/error-cloud-c181493a3bfcc46de308.png) no-repeat center center / contain;
}
.errorBlock__code {
  font-weight: 600;
  color: #52c0cf;
  line-height: 24pxs;
}
.errorBlock__title {
  margin-bottom: 16px;
  font-size: 18px;
  line-height: 30px;
  font-weight: 600;
  text-align: center;
}
.errorBlock__description {
  max-width: 420px;
  margin-bottom: 32px;
  line-height: 24px;
  text-align: center;
}

.error {
  padding: 16px 16px 80px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-height: calc(100vh - 74px);
}
@media (max-width: 768px) {
  .error {
    min-height: calc(100vh - 130px);
    padding: 16px;
  }
}

.main {
  min-height: 100vh;
}
.main__header {
  color: white;
  padding: 0 20px;
  font-size: 20px;
  background-color: #026373;
  display: flex;
  align-items: center;
}
.main__header-profile {
  display: flex;
  align-items: center;
  margin-left: auto;
  color: white;
  cursor: pointer;
}
.main__header-profile:hover {
  background-color: #026373;
}
.main__header-profile span {
  margin-right: 10px;
}
.main__header-profile .main__header-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  object-fit: cover;
}
.main__header-logo {
  width: 45px;
  height: 45px;
  flex-shrink: 0;
  margin-right: 20px;
}

.HeaderLogo__logo {
  width: 45px;
  height: 45px;
  flex-shrink: 0;
}

.AuthMain__loading {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100vh;
  width: 100%;
  background-color: #fff;
  animation: pulse 0.8s infinite;
}
.app {
  width: 100%;
}
.app__main {
  padding: 0px;
}
/* Heart Pulse Animation */
@keyframes pulse {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.4);
  }
  100% {
    transform: scale(1);
  }
}

