@charset "UTF-8";
:root {
  --main-black: #2B2626;
  --main-purple: #5F1AB2;
  --main-white: #FFFFFF;
  --line-1: #E6E6E6;
  --line-btn: #DCDCDC;
  --bg-main: #F7F7F7;
  --bg-card: #F7F7F7;
  --text-secondary: #A19AAA;
  --text-line-text: #626262;
  --success-color: #279251;
  --warning-color: #B2A03F;
  --error-color: #E32D2D;
  --error-bg: #ffeded;
  --success-bg: rgba(39, 146, 81, 0.1);
  --warning-bg: rgba(178, 160, 63, 0.1);
  --primary-bg: rgba(95, 26, 178, 0.06);
  --purple-bg: rgba(95, 26, 178, 0.05);
  --size-xs: 0.75rem;
  --size-s: 14px;
  --size-m: 1rem;
  --size-l: 1.125rem;
  --size-xl: 1.25rem;
  --size-2xl: 1.5rem;
  --border-radius: 1rem;
  --border-radius-s: .5rem;
  --header-height: 66px;
  --footer-height: 60px;
  --aside-width: 260px;
  --grid-block-gap: 40px;
  --grid-inline-gap: 28px;
  --aside-inline-padding: 20px;
  --input-height: 52px;
}
@media (max-width: 1199px) {
  :root {
    --aside-width: 240px;
    --header-height: 72px;
    --footer-height: auto;
    --grid-inline-gap: 0;
  }
}
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
button {
  background-color: transparent;
  cursor: pointer;
  border: none;
}
input, textarea, button, input::placeholder, textarea::placeholder {
  font-family: inherit;
  font-size: 1rem;
}
a {
  text-decoration: none;
  color: inherit;
}
li {
  list-style: none;
}
img {
  display: block;
  max-width: 100%;
}
h1, h2, h3, h4 {
  font-size: inherit;
  font-weight: inherit;
}
button {
  color: inherit;
}
input[type="search"]::-webkit-search-decoration, input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-results-button, input[type="search"]::-webkit-search-results-decoration {
  display: none;
}
@font-face {
  font-family: 'InterTight';
  src: url('/assets/ai/fonts/InterTight-Regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'InterTight';
  src: url('/assets/ai/fonts/InterTight-Medium.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'InterTight';
  src: url('/assets/ai/fonts/InterTight-SemiBold.ttf') format('truetype');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
html {
  font-size: 16px;
}
body {
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.2;
  font-family: 'InterTight', sans-serif;
  color: var(--main-black);
  background-color: var(--bg-main);
  display: flex;
  flex-direction: column;
  align-items: stretch;
  min-height: 100svh;
  padding: 14px 30px 24px 0;
  -ms-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}
@media (max-width: 1199px) {
  body {
    padding: 0 0 20px;
  }
}
body:has(.login-layout) {
  padding: 0;
}
body main {
  flex-grow: 1;
  display: grid;
  grid-template-columns: var(--aside-width) 1fr;
  grid-template-rows: var(--header-height) 1fr var(--footer-height);
  grid-gap: var(--grid-block-gap) var(--grid-inline-gap);
}
body main .aside {
  grid-column-start: 1;
  grid-row-start: 1;
  grid-row-end: 4;
}
@media (max-width: 1199px) {
  body main {
    grid-template-columns: 1fr;
  }
  body main .aside {
    grid-row-start: 2;
    grid-row-end: 2;
  }
}
body main.main-ai-chat {
  --main-padding: 38px;
  max-height: calc(100dvh - var(--main-padding));
  overflow: hidden;
}
@media (max-width: 1199px) {
  body main.main-ai-chat {
    --main-padding: 20px;
    max-height: calc(100dvh - var(--main-padding) + 150px);
  }
}
body:not(:has(footer)) main {
  grid-template-rows: var(--header-height) 1fr;
}
body:not(:has(footer)) main .aside {
  grid-column-start: 1;
  grid-row-start: 1;
  grid-row-end: 3;
}
@media (max-width: 1199px) {
  body:not(:has(footer)) main .aside {
    grid-row-start: 2;
    grid-row-end: 2;
  }
}
body b {
  font-weight: 600;
}
svg {
  width: var(--size-l);
  aspect-ratio: 1;
  vertical-align: middle;
}
.article-ai-chat {
  overflow: hidden;
}
.button {
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: max-content;
  font-size: var(--size-s);
  font-weight: 500;
  padding: 10px var(--size-2xl);
  border-radius: var(--border-radius-s);
  border: 1px solid var(--line-btn);
  background-color: var(--bg-card);
}
.button.button-l {
  color: var(--main-purple);
  font-size: var(--size-l);
  padding: 15px var(--size-xl);
  min-width: 270px;
}
.button.button-m {
  font-size: 1rem;
  padding: 1rem 1.5rem;
}
.button.button-primary {
  color: var(--main-white);
  background-color: var(--main-purple);
  border-color: var(--main-purple);
}
@media (hover: hover) {
  .button.button-primary:hover {
    color: var(--main-purple);
    background-color: transparent;
  }
}
.button.button-square {
  --button-font-size: var(--size-2xl);
  border-radius: 10px;
  color: var(--main-purple);
  border-color: var(--main-purple);
  background-color: transparent;
  padding: 0;
  aspect-ratio: 1;
  width: 42px;
  height: 42px;
  font-size: var(--button-font-size);
}
.button.button-square svg {
  height: var(--button-font-size);
  width: var(--button-font-size);
}
@media (hover: hover) {
  .button.button-square:hover {
    color: var(--main-white);
    background-color: var(--main-purple);
  }
}
.button.button-square:disabled, .button.button-square.disabled {
  color: var(--text-secondary);
  border-color: var(--text-secondary);
  pointer-events: none;
}
.button.button-circle {
  color: var(--main-black);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: transparent;
  padding: 0;
  width: 2rem;
  height: 2rem;
  aspect-ratio: 1;
  border-radius: 50%;
  border-color: var(--line-btn);
  font-size: var(--size-l);
}
@media (hover: hover) {
  .button.button-circle:hover {
    color: var(--main-purple);
    background-color: transparent;
    border-color: var(--main-purple);
  }
}
.button.button-secondary {
  color: var(--main-purple);
  border-color: var(--main-purple);
}
@media (hover: hover) {
  .button:hover {
    color: var(--main-white);
    background-color: var(--main-purple);
    border-color: var(--main-purple);
  }
}
.button:disabled {
  color: var(--text-secondary);
  pointer-events: none;
  filter: grayscale(1);
}
.chips {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  --chip-size: 38px;
}
.chips.chips-large {
  --chip-size: 52px;
  gap: var(--size-xl) var(--size-xs);
}
@media (max-width: 767px) {
  .chips.chips-large {
    gap: var(--size-m);
  }
}
.chips.chips-large .chips-item {
  font-size: var(--size-l);
  padding: 1rem;
}
.chips.chips-wp .chips-item {
  padding-inline: var(--size-m);
}
.chips.chips-center {
  justify-content: center;
}
@media (hover: hover) {
  .chips.chips-hover-purple .chips-item:hover {
    color: var(--main-white);
    background-color: var(--main-purple);
  }
}
.chips .chips-item {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: var(--chip-size);
  height: var(--chip-size);
  font-size: 15px;
  font-weight: 500;
  border-radius: var(--border-radius-s);
  border: 1px solid var(--line-btn);
}
.chips .chips-item.chips-item-primary {
  color: var(--main-purple);
  padding-inline: 50px;
}
@media (hover: hover) {
  .chips .chips-item:hover {
    color: var(--main-purple);
    border-color: var(--main-purple);
  }
}
.chips .chips-item:disabled {
  pointer-events: none;
  color: var(--text-secondary);
}
.chips .chips-item.active {
  color: var(--main-white);
  background-color: var(--main-purple);
  border-color: var(--main-purple);
}
.input-wrapper {
  position: relative;
}
.input-wrapper:has(.input-icon) .input {
  padding-right: 2.5rem;
}
.input-wrapper:has(.icon-after) .input {
  padding-right: 3rem;
}
.input-wrapper .icon-after {
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1.5rem;
  aspect-ratio: 1;
}
.input-wrapper .icon-after img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.input {
  font-size: 1rem;
  color: var(--main-black);
  background-color: var(--bg-card);
  border: 1px solid var(--line-btn);
  border-radius: var(--border-radius-s);
  height: var(--input-height);
  width: 100%;
  padding: 0.875rem 1rem;
  display: flex;
  align-items: center;
}
.input::placeholder {
  color: var(--text-secondary);
}
.input:focus {
  outline: none;
  border-color: var(--main-purple);
}
.input.input-error {
  border-color: var(--error-color);
  background-color: var(--error-bg);
}
.input-checkbox {
  --input-lh: 1.6;
  --input-fs: .875rem;
  cursor: pointer;
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: var(--input-fs);
  line-height: var(--input-lh);
}
@media (hover: hover) {
  .input-checkbox:hover input[type="checkbox"] {
    border-color: var(--main-purple);
  }
}
.input-checkbox input[type="checkbox"] {
  appearance: none;
  display: block;
  width: 1.25rem;
  height: 1.25rem;
  aspect-ratio: 1;
  flex-shrink: 0;
  border-radius: 0.25rem;
  border: 1px solid var(--line-1);
  transform: translateY(1.2px);
  position: relative;
}
.input-checkbox input[type="checkbox"]:checked {
  border-color: var(--main-purple);
  background-color: var(--main-purple);
}
.input-checkbox input[type="checkbox"]:checked::before {
  content: "✓";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: var(--main-white);
}
.input-agreement.error {
  color: var(--error-color);
}
.text {
  font-size: var(--size-m);
  font-weight: 400;
}
.text.small {
  font-size: var(--size-s);
}
@media (hover: hover) {
  .text.with-hover:hover {
    color: var(--main-purple);
  }
}
.color-primary {
  color: var(--main-purple);
}
.color-line-text {
  color: var(--text-line-text);
}
.color-secondary {
  color: var(--text-secondary);
}
.a-center {
  text-align: center;
}
h1, h2, h3, h4, h5, h6 {
  font-weight: 600;
  line-height: 1.2;
}
h1 {
  font-size: 28px;
}
@media (max-width: 767px) {
  h1 {
    font-size: 22px;
  }
}
h2 {
  font-size: 1.5rem;
}
@media (max-width: 767px) {
  h2 {
    font-size: 1.25rem;
  }
}
.flex {
  display: flex;
  align-items: stretch;
}
.flex.direction-column {
  flex-direction: column;
}
.flex.align-center {
  align-items: center;
}
.flex.align-end {
  align-items: flex-end;
}
.flex.align-start {
  align-items: flex-start;
}
.flex.justify-end {
  justify-content: flex-end;
}
.flex.justify-center {
  justify-content: center;
}
.flex.justify-start {
  justify-content: flex-start;
}
.flex.justify-sb {
  justify-content: space-between;
}
.flex.gap-m {
  gap: var(--size-m);
}
.flex.gap-s {
  gap: var(--size-s);
}
.flex.gap-xs {
  gap: var(--size-xs);
}
.flex.gap-l {
  gap: var(--size-l);
}
.flex.gap-xl {
  gap: var(--size-xl);
}
.flex.gap-2xl {
  gap: var(--size-2xl);
}
.accordions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 1.25rem;
}
.accordions .accordion .accordion-header {
  cursor: pointer;
}
.accordions .accordion .accordion-header .button-square {
  position: relative;
  color: var(--main-black);
  border-color: var(--line-1);
}
.accordions .accordion .accordion-header .button-square:hover {
  color: var(--main-purple);
  border-color: var(--main-purple);
  background-color: transparent;
}
.accordions .accordion .accordion-header .button-square span {
  position: absolute;
  width: 14px;
  height: 1px;
  border-radius: 2px;
  background-color: currentColor;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  transition: rotate 0.3s ease;
}
.accordions .accordion .accordion-header .button-square span:first-child {
  rotate: -90deg;
}
.accordions .accordion .accordion-content {
  overflow: hidden;
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.5s ease;
}
.accordions .accordion .accordion-content > * {
  min-height: 0;
}
.accordions .accordion.open .accordion-header .button-square {
  color: var(--main-purple);
  border-color: var(--main-purple);
}
.accordions .accordion.open .accordion-header .button-square span:first-child {
  rotate: -180deg;
}
.accordions .accordion.open .accordion-content {
  grid-template-rows: 1fr;
}
.informer {
  padding: var(--size-xs) var(--size-m);
  border-radius: 0 var(--border-radius-s) var(--border-radius-s) 0;
  background-color: var(--informer-background-color);
  margin: var(--size-xl) 0;
  overflow: hidden;
  position: relative;
}
.informer:before {
  content: '';
  position: absolute;
  width: 8px;
  height: 100%;
  top: 0;
  left: 0;
  bottom: 0;
  background-color: var(--informer-text-color);
  border-radius: 30px;
  translate: -50% 0;
}
.informer .informer-title {
  color: var(--informer-text-color);
  font-weight: 500;
  line-height: 1.2;
}
@media (max-width: 767px) {
  .informer .informer-title {
    font-size: var(--size-s);
  }
}
.informer .informer-content {
  margin-top: 1rem;
  line-height: 1.4;
}
@media (max-width: 767px) {
  .informer .informer-content {
    font-size: var(--size-s);
    margin-top: var(--size-s);
  }
}
.informer.informer-success {
  --informer-text-color: var(--success-color);
  --informer-background-color: var(--success-bg);
}
.informer.informer-primary {
  --informer-text-color: var(--main-purple);
  --informer-background-color: var(--primary-bg);
}
.informer.informer-warning {
  --informer-text-color: var(--warning-color);
  --informer-background-color: var(--warning-bg);
}
.dropdown {
  position: relative;
}
.dropdown-right .dropdown-list {
  right: 0;
}
.dropdown-left .dropdown-list {
  left: 0;
}
.dropdown-button {
  cursor: pointer;
}
.dropdown-button > * {
  pointer-events: none;
}
.dropdown-list {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  position: absolute;
  top: 100%;
  transform: translate(0, -5px);
  opacity: 0;
  visibility: hidden;
  overflow: hidden;
  min-width: 192px;
  max-height: 254px;
  transition: opacity 0.2s linear, transform 0.3s ease-in-out;
  z-index: 10;
  padding: 0.5rem 0 0.5rem 0.5rem;
  background-color: var(--main-white);
  border-radius: 1rem;
  border: 1px solid var(--line-1);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  color: var(--main-black);
}
.dropdown-list-wrapper {
  overflow: auto;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  padding-right: 0.5rem;
}
.dropdown-list-wrapper::-webkit-scrollbar {
  width: 6px;
  margin-right: 10px;
}
.dropdown-list-wrapper::-webkit-scrollbar-track {
  background-color: var(--main-white);
  width: 6px;
  border-radius: 8px;
}
.dropdown-list-wrapper::-webkit-scrollbar-thumb {
  background-color: var(--main-purple);
  width: 6px;
  border-radius: 8px;
}
.dropdown-list-wrapper > * {
  cursor: pointer;
  text-wrap: nowrap;
}
@media (hover: hover) {
  .dropdown-list-wrapper > *:hover {
    color: var(--main-blue);
  }
}
.dropdown .dropdown-item {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.5rem;
  font-weight: 500;
  font-size: var(--size-s);
  padding: 0.5rem;
  border-radius: 0.5rem;
}
@media (hover: hover) {
  .dropdown .dropdown-item:hover {
    background-color: rgba(237, 234, 234, 0.7);
  }
}
.dropdown .dropdown-item svg {
  color: var(--text-secondary);
  font-size: 20px;
  width: 20px;
  height: 20px;
}
.dropdown .dropdown-item-delete {
  color: var(--error-color);
}
.dropdown .dropdown-item-delete svg {
  color: var(--text-secondary);
}
.dropdown.dropdown-open .dropdown-list {
  opacity: 1;
  visibility: visible;
  transform: translate(0, 5px);
}
.list-pretty li {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.75rem;
}
.list-pretty li:before {
  content: '';
  flex-shrink: 0;
  width: 10px;
  aspect-ratio: 1;
  border-radius: 50%;
  background-color: var(--main-purple);
}
.list-pretty li:not(:last-child) {
  margin-bottom: 0.75rem;
}
*[data-tooltip] {
  position: relative;
}
@media (max-width: 1199px) {
  *[data-tooltip]:first-child:before {
    left: 0;
    transform: translate(0, 10%);
  }
  *[data-tooltip]:first-child:hover:before {
    transform: translate(0, 0);
  }
}
*[data-tooltip]:before {
  color: var(--main-black);
  content: attr(data-tooltip);
  position: absolute;
  background-color: var(--main-white);
  padding: 0.5rem 0.75rem;
  border: 1px solid var(--line-1);
  border-radius: 1rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  opacity: 0;
  visibility: hidden;
  z-index: 8;
  left: 50%;
  top: calc(100% + .5rem);
  transform: translate(-50%, -10%);
  font-size: 0.75rem;
  transition: transform 0.3s ease-in-out, opacity 0.3s ease;
  isolation: isolate;
}
*[data-tooltip]:hover:before {
  opacity: 1;
  visibility: visible;
  transform: translate(-50%, 0);
}
.login-layout {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.25rem 2rem;
  --layout-end-height: 2rem;
}
@media (max-width: 1199px) {
  .login-layout {
    padding: 1.25rem;
  }
}
.login-layout .login-layout-back {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  max-width: max-content;
}
@media (hover: hover) {
  .login-layout .login-layout-back:hover {
    color: var(--main-purple);
  }
  .login-layout .login-layout-back:hover .login-layout-back-icon {
    color: var(--main-purple);
    border-color: var(--main-purple);
  }
}
.login-layout .login-layout-back .login-layout-back-icon {
  width: var(--layout-end-height);
  aspect-ratio: 1;
  font-size: 1.125rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid var(--line-1);
}
.login-layout .login-layout-wrapper {
  flex-grow: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.login-layout .login-layout-inner {
  background-color: var(--main-white);
  padding: 2rem;
  border: 1px solid var(--line-1);
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 1.5rem;
  width: min(462px, calc(100vw - 40px));
  border-radius: 1rem;
  margin-top: calc(var(--layout-end-height) * -1);
}
@media (max-width: 1199px) {
  .login-layout .login-layout-inner {
    padding: 2rem 1.25rem;
  }
}
.login-layout .login-layout-inner h1 {
  font-size: 26px;
}
@media (max-width: 1199px) {
  .login-layout .login-layout-inner h1 {
    font-size: 1.25rem;
  }
}
.login-layout .login-layout-inner .button {
  min-width: 100%;
  width: 100%;
}
.login-layout .login-layout-inner.recover-password-message .button {
  margin-top: 30px;
}
@media (max-width: 1199px) {
  .login-layout .login-layout-inner.recover-password-message .button {
    margin-top: 0;
  }
}
.login-form, .recover-password-form, .register-form {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}
.login-form .button, .recover-password-form .button, .register-form .button {
  margin-top: 0.5rem;
}
.login-form .message-error, .recover-password-form .message-error, .register-form .message-error {
  margin-bottom: 1rem;
  color: var(--error-color);
}
.login-form, .register-form {
  gap: 1rem;
}
.recover-password-form {
  gap: 1.5rem;
}
.oauth {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.oauth .oauth-item {
  padding: 1.25rem;
  background-color: var(--bg-main);
  border-radius: 1rem;
}
@media (max-width: 1199px) {
  .oauth .oauth-item {
    padding: 0.75rem;
  }
}
@media (hover: hover) {
  .oauth .oauth-item:hover {
    background-color: var(--purple-bg);
  }
}
.oauth .oauth-item svg {
  font-size: 1.75rem;
}
.oauth .oauth-item svg, .oauth .oauth-item img {
  width: 1.75rem;
  aspect-ratio: 1;
}
.oauth .oauth-item img {
  object-fit: contain;
}
.oauth .oauth-item iframe {
  margin: 0;
  padding: 0;
  vertical-align: top;
}
.oauth .oauth-item.oauth-item-tg iframe {
  margin: -0.4rem;
}