:root {
  --color-background: #272727;
  --color-grey: #4f4f4f;
  --color-gradient-transparent-dark: linear-gradient(90deg, #1f4652 0%, #43254d 100%);
  --color-yellow: #fffc00;
  --color-orange: #d58402;
}

body {
  background: var(--color-background);
  color: var(--color-white);
  min-height: var(--screen-height, 100vh);
}

body::before {
  display: none;
}

body.asistent-personal::after {
  background: var(--color-black-dark);
}

body[data-scrolled] .top-bar {
  background: transparent;
}

.hover-underline:hover::after {
  background: var(--color-white);
}

.top-bar {
  width: 25rem;
  height: 100%;
  border-radius: 0 2rem 2rem 0;
  padding: 2rem;
}

.top-bar::before {
  content: "";
  position: fixed;
  height: 100%;
  width: inherit;
  z-index: -1;
  background: var(--color-gradient);
  opacity: 0.75;
  top: 0;
  left: 0;
  border-radius: inherit;
}

.top-bar .grid-container {
  margin: 0;
}

.top-bar .logo-container {
  color: var(--color-white);
  transition: var(--transition);
  max-width: 10rem;
}

.top-bar .logo-container svg * {
  fill: var(--color-white);
}

.top-bar .btn-close-menu {
  cursor: pointer;
  transition: var(--transition);
}

.top-bar .btn-close-menu svg {
  height: 1.5rem;
  width: 1.5rem;
  min-height: 1.5rem;
  min-width: 1.5rem;
}

.top-bar .btn-close-menu svg * {
  fill: var(--color-white);
}

.top-bar .cta--top-bar {
  background: var(--color-background);
  padding: 1rem;
  border-radius: 2rem;
}

.top-bar .cta--top-bar svg {
  height: 1.25rem;
  width: 1.25rem;
}

.cta--top-bar__checkbox {
  height: 1rem;
  width: 1rem;
  border: solid 0.0625rem var(--color-white);
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.cta--top-bar__checkbox svg {
  height: 0.75rem;
  width: 1rem;
  transition: var(--transition);
  opacity: 0;
}

.cta--top-bar__checkbox[data-active] svg {
  opacity: 1;
}

.cta--top-bar {
  padding: 1rem 2rem !important;
  background: var(--color-gradient-transparent-dark) !important;
}

.account-menu-container {
  background: var(--color-background);
  padding: 2rem;
  border-radius: 2rem;
  transition: var(--transition);
}

.account-menu,
.account-menu .account-menu__submenu {
  list-style-type: none;
}

.account-menu .account-menu__item {
  position: relative;
}

.account-menu .account-menu__item:has(.account-menu__submenu)::before {
  content: "";
  position: absolute;
  left: 0.625rem;
  transform: translateX(-50%);
  top: 1.25rem;
  height: calc(100% - 1.25rem - 0.625rem);
  width: 0.0625rem;
  background: var(--color-grey);
}

.account-menu .account-menu__item > a {
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  white-space: nowrap;
  transition: var(--transition);
  position: relative;
}

.account-menu .account-menu__item svg {
  height: 1.25rem;
  width: 1.25rem;
  min-height: 1.25rem;
  min-width: 1.25rem;
  transition: var(--transition);
}

.account-menu .account-menu__submenu {
  padding-left: 2rem;
  margin-top: 0.5rem;
  transition: var(--transition);
  overflow: hidden;
}

.account-menu .account-menu__submenu .account-menu__submenu__item {
  position: relative;
}

.account-menu .account-menu__submenu .account-menu__submenu__item[data-active] .hover-underline::after {
  transform: scaleX(1);
  background: var(--color-white);
}

.account-menu .account-menu__submenu .account-menu__submenu__item::before {
  content: "";
  position: absolute;
  left: 0;
  top: calc(50% + 0.125rem);
  transform: translate(-100%, -50%);
  height: 0.0625rem;
  width: 1.375rem;
  background: var(--color-grey);
}

.account-menu .account-menu__submenu .account-menu__submenu__item > * {
  font-size: 0.875rem;
  color: var(--color-white);
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  padding: 0;
  margin: 0;
  background-color: transparent;
  outline: 0;
  border: 0;
  cursor: pointer;
}

.account-menu .account-menu__submenu .account-menu__submenu__item + .account-menu__submenu__item {
  margin-top: 0.5rem;
}

body[data-scroll-y-dir-thresholed="down"] .top-bar:not([data-autohide="false"]) {
  transform: none !important;
}

.account-content-container {
  width: calc(100vw - 25rem);
  margin-left: 25rem;
  transition: var(--transition);
  --grid-container-max-width: 75rem;
}

.account-content-container__header {
  position: sticky;
  top: 0;
  left: 0;
  padding: 2rem 0;
}

.account-content-container--personal-assistant {
  height: var(--screen-height, 100vh);
}

.account-content-container--personal-assistant .h1 {
  font-size: 4rem;
}

.account-content-container .search-bar .search-bar__option {
  background: var(--color-grey);
}

.account-content-container .search-bar .search-bar__option svg * {
  fill: var(--color-white);
}

.account-content-container .input-bar {
  color: var(--color-white);
  background: var(--color-grey);
  padding: 0.75rem 1.5rem;
}

.account-content-container .input-bar input::placeholder {
  color: var(--color-white);
}

.account-content-container--chatroom {
  min-height: var(--screen-height, 100vh);
  padding-top: 0 !important;
}

.account-content-container--chatroom .search-bar-container {
  position: fixed;
  padding-bottom: 1rem;
  bottom: 0;
  width: calc(100% - 25rem);
  left: 25rem;
  background: var(--color-background);
  z-index: 99;
  transition: var(--transition);
}

.account-content-container--chatroom .search-bar-container[data-hidden] {
  transform: translateY(100%);
  opacity: 0;
  pointer-events: none;
}

.account-content-container--chatroom .search-bar-container .search-bar {
  width: 100%;
}

.account-content-container--chatroom .search-bar-container .input-bar {
  color: var(--color-white);
  background: var(--color-grey);
  padding: 0.75rem 1.5rem;
}

.account-content-container--chatroom .search-bar-container .input-bar input,
.account-content-container--chatroom .search-bar-container .input-bar input::placeholder {
  color: var(--color-white);
}

.account-content-container--chatroom .search-bar-container form[data-error-msg]::before {
  content: attr(data-error-msg);
  position: absolute;
  left: 2rem;
  top: 0;
  color: var(--color-error);
  transition: var(--transition);
}

.account-content-container--chatroom .search-bar-container form[data-error-msg][data-error-visible]::before {
  transform: translateY(-2rem);
}

.account-content-container--chatroom .search-bar-container form[data-error-msg] {
  animation: shake 500ms;
}

.account-content-container--chatroom .chat-suggestions {
  position: absolute;
  left: 0;
  top: 0;
  transition: var(--transition);
  opacity: 0;
  will-change: transform, opacity;
  pointer-events: none;
}

.search-bar-container:not([data-hidden]) .chat-suggestions[data-active] {
  transform: translateY(calc(-100% - 1rem));
  pointer-events: all;
  opacity: 1;
}

.account-content-container--chatroom .chat-suggestions .chat-suggestions__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1.5rem;
  gap: 0.5rem;
  border-radius: 2rem;
  position: relative;
}

.account-content-container--chatroom .chat-suggestions .chat-suggestions__item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  border-radius: inherit;
  background: var(--color-gradient-transparent-dark);
  height: 100%;
  width: 100%;
  z-index: -1;
  transition: var(--transition);
  opacity: 0.5;
}

.account-content-container--chatroom .chat-suggestions .chat-suggestions__item svg {
  height: 1.25rem;
  width: 1.25rem;
  min-height: 1.25rem;
  min-width: 1.25rem;
}

.account-content-container--chatroom .chat-suggestions .chat-suggestions__item svg * {
  fill: var(--color-white);
}

.account-content-container--chatroom .chat-notification {
  position: absolute;
  top: 0;
  left: 50%;
  z-index: -2;
  background: var(--color-yellow);
  width: calc(100% - 4rem);
  max-width: 25rem;
  transform: translate(-50%, 0);
  opacity: 0;
  pointer-events: none;
  will-change: transform, opacity;
  font-size: 0.75rem;
  color: var(--color-black-dark);
  border-radius: 0.75rem 0.75rem 0 0;
  font-weight: 700;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.3rem 0.5rem;
  border: solid 0.125rem var(--color-orange);
  border-bottom: none;
  line-height: 1.25;
  transition: var(--transition);
}

.account-content-container--chatroom .chat-notification img {
  height: 2rem;
  width: 2rem;
  min-height: 2rem;
  min-width: 2rem;
}

.account-content-container--chatroom .chat-notification[data-active] {
  opacity: 1;
  transform: translate(-50%, -100%);
}

.chatroom-top {
  padding: 1rem 0;
  border-bottom: solid 0.0625rem rgba(255, 255, 255, 0.1);
  position: sticky;
  top: 0;
  z-index: 999;
}

.chatroom-top::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  background: var(--color-background);
  opacity: 0.9;
  z-index: -1;
}

.chatroom-top img {
  height: 100%;
  width: 100%;
  border-radius: 50%;
  position: relative;
  z-index: 2;
  transition: var(--transition);
}

.chatroom-top .chatroom-top-image {
  position: relative;
  height: 4rem;
  width: 4rem;
  transition: var(--transition);
}

.chatroom-top .chatroom-top-image::before {
  content: "";
  position: absolute;
  z-index: 1;
  height: 100%;
  width: 100%;
  border-radius: 50%;
  left: 0;
  top: 0;
  transform: scale(0.9);
  background: var(--color-gradient);
  transition: var(--transition);
}

.chatroom-top .chatroom-top-image[data-active]:before {
  transform: scale(1.1);
  animation: rotate 2000ms infinite ease-in-out;
}

@keyframes rotate {
  from {
    transform: scale(1.1);
  }

  to {
    transform: scale(1.1) rotate(360deg);
  }
}

.message-container {
  position: relative;
  border-radius: 1.5rem;
  opacity: 0;
  transition: var(--transition);
}

.account-content-container--favorite-messages .message-container {
  opacity: 1;
}

.message-container:has(.message--user) {
  justify-content: flex-end;
  display: flex;
}

.message-container .message__link {
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-top: 1rem;
  padding: 0.75rem;
  border-radius: 1.5rem;
  position: relative;
  background: var(--color-background);
  max-width: 50rem;
}

.message-container .message__link .cta {
  padding: 0.25rem 0.5rem;
  border-radius: 0.5rem;
}

.message-container .message__link::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  background: var(--color-gradient-transparent-dark);
  transition: var(--transition);
  z-index: 1;
  border-radius: inherit;
  opacity: 0;
}

.message-container .message__link * {
  position: relative;
  z-index: 2;
}

.message-container .message__link::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  height: calc(100% + 0.25rem);
  width: calc(100% + 0.25rem);
  transform: translate(-50%, -50%);
  border-radius: inherit;
  background: var(--color-gradient);
  z-index: -1;
}

.message-container .message__link .message__link__title {
  font-weight: 700;
  font-size: 1.125rem;
  margin-bottom: 0.5rem;
}

.message-container .message__link img {
  aspect-ratio: 1/1;
  border-radius: 0.625rem;
  max-width: 7.5rem;
}

.message-container .message__link .message__link__description {
  line-height: 1.75;
}

.message-container .event-purchase-plan {
  border-radius: 1.5rem;
  max-width: 50rem;
  margin-top: 1rem;
  background: var(--color-background);
  position: relative;
  padding: 2rem 1rem;
}

.message-container .event-purchase-plan .cta.cta--border-gradient--2::before {
  z-index: 0;
}

.message-container .event-purchase-plan a {
  text-decoration: none;
}

.message-container .event-purchase-plan::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  height: calc(100% + 0.25rem);
  width: calc(100% + 0.25rem);
  z-index: -2;
  transform: translate(-50%, -50%);
  background: var(--color-gradient);
  border-radius: inherit;
}

.message {
  padding: 0.75rem 1.5rem;
  display: inline-block;
  max-width: 50rem;
  border-radius: 1.5rem;
  transition: var(--transition);
  word-break: normal;
  overflow-wrap: break-word;
}

.message.message--assistant > *:not(:first-child) {
  margin-top: 1rem;
}

.message .trigger {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  transition: var(--transition);
  font-weight: 700;
  cursor: pointer;
}

.message .content .trigger {
  margin: 1rem 0;
}

.message .trigger .trigger-decoration {
  height: 1.75rem;
  width: 1.75rem;
  transition: var(--transition);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.message .trigger .trigger-decoration div {
  position: absolute;
  height: 100%;
  width: 0.0625rem;
  background: var(--color-gradient);
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) rotate(45deg) scaleY(0.5);
  transition: var(--transition);
}

.message .trigger .trigger-decoration::before,
.message .trigger .trigger-decoration::after {
  content: "";
  position: absolute;
  background-image: url("../../images/arrow-down.svg");
  background-size: 100% 100%;
  background-repeat: no-repeat;
  height: 0.5rem;
  width: 0.5rem;
  left: 0;
  bottom: 0;
  transform: translate(100%, -100%);
  transition: var(--transition);
}

.message .trigger .trigger-decoration::after {
  background-image: url("../../images/arrow-up.svg");
  left: auto;
  bottom: auto;
  right: 0;
  top: 0;
  transform: translate(-100%, 100%);
}

.message .trigger[data-active] .trigger-decoration div {
  transform: translate(-50%, -50%) rotate(45deg);
}

.message .trigger[data-active] .trigger-decoration::before {
  transform: translate(50%, -50%);
}

.message .trigger[data-active] .trigger-decoration::after {
  transform: translate(-50%, 50%);
}

.message .content {
  overflow: hidden;
  transition: var(--transition);
  margin-top: 0 !important;
}

.message .trigger[data-active] + .content {
  margin-top: 1rem !important;
}

.message .content li + li {
  margin-top: 0.5rem;
}

.message .trigger[data-active]::after {
  transform: rotateX(180deg);
}

.message p + p {
  margin-top: 0.625rem;
}

.message p + ul,
.message ul + p {
  margin-top: 1rem;
}

.message * {
  z-index: 3;
  position: relative;
}

.message.message--user {
  background: var(--color-grey);
}

.message.message--assistant {
  position: relative;
  animation: gradientShift 10s linear infinite;
  background: var(--color-background);
}

.message.message--assistant::after {
  content: "";
  position: absolute;
  inset: 0;
  padding: 0.125rem;
  border-radius: 1.5rem;
  background: var(--color-gradient);
  mask: linear-gradient(white, white) content-box, linear-gradient(white, white);
  mask-composite: exclude;
  -webkit-mask: linear-gradient(white, white) content-box, linear-gradient(white, white);
  -webkit-mask-composite: xor;
  pointer-events: none;
}

.message.message--assistant::before {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  background: var(--color-gradient-transparent-dark);
  z-index: -1;
  left: 0;
  top: 0;
  border-radius: inherit;
  transition: var(--transition);
  opacity: 0;
}

.message-container:has(.message-assistant-disclaimer) {
  max-height: 20rem;
  overflow-y: scroll;
}

.message-assistant-disclaimer::after {
  display: none;
}

.message-container:has(.message-assistant-disclaimer)::-webkit-scrollbar {
  display: none;
}

.message.message--assistant[data-text-loading]::before,
.message.message--assistant.message-assistant-disclaimer::before {
  opacity: 1;
}

.message .meal-plan-el {
  text-decoration: none;
}

.message-container a {
  text-decoration: underline;
}

.form-generate-plan input {
  color: black !important;
}

.disclaimer-actions {
  position: fixed;
  left: calc(50% + 12.5rem);
  bottom: 1rem;
  display: flex;
  align-items: center;
  white-space: nowrap;
  width: 100%;
  max-width: 20rem;
  gap: 0.5rem;
  transform: translate(-50%, 150%);
  transition: var(--transition);
  opacity: 0;
  pointer-events: none;
  will-change: transform, opacity;
}

.disclaimer-actions[data-active] {
  transform: translate(-50%, 0);
  opacity: 1;
  pointer-events: all;
}

.disclaimer-actions .button-disclaimer-decline {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-grey);
  height: 3rem;
  height: 3rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  cursor: pointer;
  transition: var(--transition);
}

.disclaimer-actions .button-disclaimer-decline::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  height: calc(100% + 0.25rem);
  width: calc(100% + 0.25rem);
  background: var(--color-gradient);
  z-index: -1;
  border-radius: inherit;
}

.disclaimer-actions .button-disclaimer-decline svg {
  height: 1.25rem;
  width: 1.25rem;
  position: relative;
  z-index: 9999;
}

@keyframes pulse {
  0% {
    width: 100%;
    height: 100%;
  }

  50% {
    width: calc(100% - 2rem);
    height: calc(100% - 2rem);
  }

  100% {
    width: 100%;
    height: 100%;
  }
}

.message--pending {
  position: relative;
  white-space: nowrap;
  /* background: var(--color-grey); */
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background-image: linear-gradient(var(--color-black), var(--color-black)), var(--color-gradient);
  background-origin: border-box;
  background-clip: padding-box, border-box;
}

.message--pending div {
  width: 8px;
  height: 8px;
  background: var(--color-gradient);
  border-radius: 50%;
  animation: jump 1s infinite ease-in-out;
}

.message--pending div:nth-child(1) {
  animation-delay: 0s;
}

.message--pending div:nth-child(2) {
  animation-delay: 0.2s;
}

.message--pending div:nth-child(3) {
  animation-delay: 0.4s;
}

@keyframes jump {
  0%,
  100% {
    transform: translateY(0.125rem);
    opacity: 0.3;
  }

  50% {
    transform: translateY(-0.125rem);
    opacity: 1;
  }
}

@keyframes bounce {
  0%,
  80%,
  100% {
    transform: scale(0.8);
    opacity: 0.3;
  }

  40% {
    transform: scale(1.2);
    opacity: 1;
  }
}

.message-container:has(.message[data-visible]) {
  opacity: 1 !important;
}

.message[data-visible] {
  transform: none !important;
  opacity: 1 !important;
}

.message-options {
  position: absolute;
  left: 0.5rem;
  bottom: 0;
  display: flex;
  gap: 0.5rem;
  transition: var(--transition);
  z-index: 9;
  opacity: 0;
  pointer-events: none;
}

.message-options .trigger-feedback {
  opacity: 0.5;
  transition: var(--transition);
  cursor: pointer;
  display: flex;
  align-items: center;
  line-height: 1;
  gap: 0.5rem;
}

.message-options .trigger-feedback svg {
  height: 1.125rem;
  width: 1.125rem;
  min-height: 1.125rem;
  min-width: 1.125rem;
}

.message-container[data-active] .message-options {
  transform: translateY(calc(100% + 0.625rem));
  opacity: 1;
  pointer-events: all;
}

.button-add-to-favorites {
  padding: 0;
  background: transparent;
  border: none;
  outline: none;
  position: relative;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  line-height: 1;
}

.button-add-to-favorites div {
  opacity: 0.5;
  transition: var(--transition);
}

.button-add-to-favorites::before,
.button-add-to-favorites::after {
  content: "";
  height: 100%;
  width: 100%;
  display: block;
  left: 0;
  top: 0;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  transition: var(--transition);
  height: 1.125rem;
  width: 1.125rem;
  min-height: 1.125rem;
  min-width: 1.125rem;
}

.button-add-to-favorites::after {
  background-image: url("../../images/message-favorite.png");
  position: absolute;
  left: 0;
  top: 0;
}

.button-add-to-favorites::before {
  background-image: url("../../images/message-favorite-active.png");
  opacity: 0;
}

.button-add-to-favorites[data-active]::before {
  opacity: 1;
}

.button-delete-from-favorites {
  opacity: 0.5;
  transition: var(--transition);
}

.button-delete-from-favorites svg {
  height: 1rem;
  width: 1rem;
}

@keyframes loading-spin {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

.mark-as-favorite {
  height: 1.25rem;
  width: 1.25rem;
  cursor: pointer;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mark-as-favorite svg {
  position: absolute;
  transition: var(--transition);
  height: 1.5rem;
  width: 1.5rem;
}

.mark-as-favorite svg.liked {
  opacity: 0;
}

.mark-as-favorite[data-active] svg.liked {
  opacity: 1;
}

.account-content-container--favorite-messages {
  padding: 10vh 0;
}

.account-content-container--favorite-messages .message {
  max-width: unset;
}

.account-content-container--chatroom .message {
  opacity: 0;
  transform: translateX(-100%) scale(0);
  will-change: transform;
}

.account-content-container--chatroom .message.message--user {
  transform: translateX(100%) scale(0);
}

.account-content-container--chatroom .message.message--info {
  opacity: 1;
  border-radius: 1rem;
  border: solid 0.125rem rgba(0, 119, 255, 1);
  background: linear-gradient(90deg, rgba(0, 119, 255, 0.25) 0%, rgba(0, 26, 255, 0.25) 100%);
}

.account-content-container--chatroom .message.message--info--1 {
  transform-origin: top;
  transform: translate(0, 0) scaleY(0);
}

.account-content-container--chatroom .message.message--info--2 {
  transform-origin: top;
  transform: translate(0, 0) scale(0);
}

.account-content-container--chatroom .message.message--info--3 {
  transform-origin: top;
  transform: translate(0, 0) scaleY(0);
}

/* .account-content-container--chatroom .message.message--info--4 {
  transform-origin: top;
  transform: translate(0, 0) scaleY(0);
} */

.btn-buy-plan {
  white-space: nowrap;
  will-change: transform;
  z-index: 999;
  text-align: center;
  transition: var(--transition);
  border-radius: 2rem 2rem 1rem 1rem;
}

.not-cnt {
  position: fixed;
  display: flex;
  left: 0;
  align-items: center;
  justify-content: center;
  width: 100%;
  bottom: 0;
  padding: 0.25rem;
  background: rgba(0, 0, 0, 0.5);
  gap: 0.5rem;
  z-index: 9999999;
  color: black;
  flex-wrap: wrap;
}

/* .btn-buy-plan .cta.cta--background-gradient {
    padding: .5rem .5rem .5rem 2rem;
}

.btn-buy-plan .cta.cta--border-gradient {
    padding: .75rem;
} */

.btn-buy-plan .btn-buy-plan__info {
  transition: var(--transition);
  will-change: transform;
  position: relative;
  color: var(--color-grey);
  z-index: -1;
  border-radius: 2rem;
  font-size: 0.75rem;
}

.btn-buy-plan[data-active] .btn-buy-plan__info {
  transform: none;
}

.lg-ntr {
  height: 2rem;
}

.lg-ntr path:not(.grad) {
  fill: var(--color-white);
}

.account-content-container--profile {
  min-height: var(--screen-height, 100vh);
  padding: 15vh 0;
}

.account-content-container--profile .form input,
.account-content-container--profile .form textarea,
.account-content-container--profile .form select {
  background: var(--color-grey);
}

.account-content-container--profile .form.form--1 .label-virtual-cnt .label-virtual {
  color: var(--color-white);
  opacity: 0.5;
}

.modal-calculator {
  color: var(--color-black);
}

/* START CHAT INPUT */

.ntr-chat-input label {
  height: 100%;
  border-radius: 1rem;
  position: relative;
  background: var(--color-background);
  display: flex;
  align-items: center;
  padding: 0 1rem 0 1.5rem;
}

.ntr-chat-input label:not(.custom-checkbox)::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  height: calc(100% + 0.2rem);
  width: calc(100% + 0.2rem);
  border-radius: 1rem;
  background: var(--color-gradient);
  z-index: -1;
}

.ntr-chat-input label input {
  width: 100%;
  outline: none;
  border: none;
  background: transparent;
  pointer-events: none;
}

.ntr-chat-input .label-virtual {
  position: absolute;
  top: 0;
  left: 1.5rem;
  transform: translateY(-2rem);
}

.ntr-chat-input label input::placeholder {
  opacity: 0;
}

.ntr-chat-input label[data-chat-snackbar-message]::after {
  content: attr(data-chat-snackbar-message);
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
  transition: var(--transition);
  left: 1.5rem;
}

.ntr-chat-input label[data-chat-snackbar-message-visible][data-chat-snackbar-message]::after {
  transform: translateY(-2rem);
}

.ntr-chat-input label[data-chat-snackbar-message][data-chat-snackbar-message-type="neutral"]::after {
  background: var(--color-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.ntr-chat-input label[data-chat-snackbar-message][data-chat-snackbar-message-type="error"]::after {
  color: var(--color-red);
}

.ntr-chat-input label[data-chat-snackbar-message][data-chat-snackbar-message-type="success"]::after {
  color: var(--color-green);
}

/* END CHAT INPUT */

/* START CTA */

.account-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  position: relative;
  border-radius: 1rem;
  padding: 1rem;
  line-height: 1;
  transition: var(--transition);
  cursor: pointer;
  pointer-events: all;
}

button.account-cta {
  background: transparent;
  border: none;
  outline: none;
}

button.account-cta[data-loading="true"]::after {
  display: none;
}

.account-cta::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  background: var(--color-gradient);
  z-index: -1;
  border-radius: inherit;
  opacity: 0.5;
  transition: var(--transition);
}

.account-cta.account-cta--2::before,
button.account-cta[disabled]::before {
  opacity: 0.25;
}

/* END CTA */

.datepicker-custom .datepicker-picker .datepicker-main .datepicker-view .days .datepicker-grid .datepicker-cell.today {
  color: var(--color-white);
}

/* START FEEDBACK */

.popup-custom {
  position: fixed;
  left: calc(50% + 12.5rem);
  top: 50%;
  transform: translate(-50%, 100vh);
  transition: var(--transition);
  background: var(--color-white);
  padding: 2rem;
  max-width: 40rem;
  border-radius: 1rem;
  opacity: 0;
  z-index: 99999999;
  color: var(--color-black);
  will-change: transform, opacity;
}

.popup-custom[data-active] {
  transform: translate(-50%, -50%);
  opacity: 1;
}

.popup-custom .tool-hide {
  position: absolute;
  right: 0.5rem;
  top: 0.5rem;
  height: 2rem;
  cursor: pointer;
  width: 2rem;
}

.popup-custom .form input,
.popup-custom .form textarea {
  background: var(--color-grey-light);
}

#modal.modal-pop-up--create-account .modal__content {
  color: var(--color-black);
}

#modal.modal-pop-up--create-account .modal__content img.asteptam {
  max-width: 12.5rem;
}

#modal.modal-pop-up--create-account .modal__content .benefits {
  cursor: pointer;
  position: relative;
}

#modal.modal-pop-up--create-account .modal__content .benefits .benefits__content {
  position: absolute;
  left: 50%;
  top: 100%;
  transform: translate(-50%, 0);
  padding: 0.5rem;
  border-radius: 0.625rem;
  width: 20rem;
  font-size: 0.875rem;
  background: var(--color-grey-light);
  transition: var(--transition);
  pointer-events: none;
  opacity: 0;
}

#modal.modal-pop-up--create-account .modal__content .benefits[data-active] .benefits__content {
  opacity: 1;
}

#modal.modal-pop-up--create-account .modal__content .benefits img {
  height: 1.5rem;
  width: 1.5rem;
}

/* END FEEDBACK */

body:has(.trigger-pop-up-create-account.add-to-favs) #modal .modal__content .messages-limit,
body:has(.trigger-pop-up-create-account.messages-limit) #modal .modal__content .add-to-favs {
  display: none;
}

body:has(.plan-change[data-active]) #overlay {
  background-color: rgba(39, 39, 39, 0.98);
}

.plan-change {
  max-width: 30rem;
}

.plan-change .tool-hide {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: calc(100% - 2rem);
  left: 1rem;
  top: 1.4rem;
}

.plan-change .tool-hide svg {
  height: 1.5rem;
  width: 1.5rem;
}

.plan-image {
  display: block;
  position: relative;
  cursor: pointer;
  overflow: visible;
  transition: var(--transition);
}

.plan-image img {
  border-radius: inherit;
}

/* .plan-change .plan-image::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  height: 99%;
  width: 99%;
  background: var(--color-gradient);
  border-radius: inherit;
  z-index: -1;
  transition: var(--transition);
} */

.plan-change__confirmation {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  background: rgba(0, 0, 0, 0.95);
  border-radius: inherit;
  transition: var(--transition);
  display: flex;
  align-items: center;
  z-index: 99;
  justify-content: center;
  padding: 1rem;
  opacity: 0;
  pointer-events: none;
}

.plan-change__confirmation .account-cta {
  pointer-events: none;
}

.plan-change__confirmation[data-active],
.plan-change__confirmation[data-active] .account-cta {
  opacity: 1;
  pointer-events: all;
}

.plan-change__confirmation__image {
  display: none;
}

.plan-change__confirmation[data-id-plan-current="1"] .plan-change__confirmation__image[data-id="1"],
.plan-change__confirmation[data-id-plan-current="2"] .plan-change__confirmation__image[data-id="2"],
.plan-change__confirmation[data-id-plan-current="3"] .plan-change__confirmation__image[data-id="3"] {
  display: block;
}

.cta--table {
  width: 100%;
  padding: 0.5rem 0.5rem !important;
}

.section--plan .cta--table div {
  background: var(--color-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

@keyframes bounce {
  from {
    transform: translateY(-25%);
  }
  to {
    transform: translateY(25%);
  }
}

.plan-switch .hand-svg * {
  fill: var(--color-white);
}

body:has(.account-content-container--shop) .datepicker-custom {
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%);
  width: calc(100% - 1.875rem);
  transition: var(--transition);
  opacity: 0;
  pointer-events: none;
}

.datepicker-custom.active {
  opacity: 1 !important;
  pointer-events: all !important;
}

@media (min-width: 1023px) {
  .plan-change .plan-image:hover {
    transform: scale(1.05);
  }

  .plan-change {
    background: var(--color-black-dark);
    color: var(--color-white);
    padding-top: 4rem;
  }

  .top-bar .btn-close-menu:hover {
    transform: scale(1.1);
  }

  .top-bar[data-minified] .account-menu .account-menu__item:hover > a div {
    opacity: 1;
    transition: var(--transition);
    pointer-events: all;
  }

  .top-bar[data-minified] .logo-container {
    width: 0rem;
  }

  .top-bar[data-minified] .logo-btn-container {
    justify-content: center;
  }

  .top-bar[data-minified] {
    width: 5.375rem;
    padding: 2rem 0;
  }

  .top-bar[data-minified] .account-menu {
    width: 1.5rem;
  }

  .top-bar[data-minified] .account-menu .account-menu__submenu {
    height: 0;
    width: 0;
  }

  .top-bar[data-minified] .account-menu .account-menu__item > a {
    gap: 0;
    position: relative;
  }

  .top-bar[data-minified] .account-menu .account-menu__item > a div {
    opacity: 0;
    position: absolute;
    top: 0;
    right: 0;
    padding: 0.5rem;
    line-height: 1;
    transform: translate(100%, -50%);
    background: var(--color-grey);
    border-radius: 1rem 1rem 1rem 0;
    pointer-events: none;
  }

  .top-bar[data-minified] .account-menu .account-menu__item > a div::after {
    display: none;
  }

  .top-bar[data-minified] .account-menu-container {
    padding: 1rem;
  }

  /* .top-bar[data-minified] .account-menu .account-menu__item > a svg {
        height: 2rem;
        width: 2rem;
    } */

  body:has(.top-bar[data-minified]) .account-content-container {
    width: calc(100vw - 5.375rem);
  }

  body:has(.top-bar[data-minified]) .account-content-container--chatroom .search-bar-container,
  body:has(.top-bar[data-minified]) .ntr-plan__chat {
    width: calc(100% - 5.375rem);
    left: 5.375rem;
  }

  .top-bar[data-minified] .cta--top-bar {
    padding: 1rem !important;
    gap: 0 !important;
  }

  .top-bar[data-minified] .cta--top-bar svg {
    height: 1.25rem;
    width: 1.25rem;
    min-height: 1.25rem;
    min-width: 1.25rem;
  }

  .top-bar[data-minified] .cta--top-bar .cta--top-bar__text {
    white-space: nowrap;
    opacity: 0;
    width: 0;
    pointer-events: none;
  }

  .top-bar[data-minified] .cta--top-bar .cta--top-bar__checkbox {
    border: none;
  }

  .message-options .trigger-feedback:hover {
    opacity: 1;
  }

  .button-add-to-favorites:hover::after {
    opacity: 0;
  }

  .button-add-to-favorites:hover::before,
  .button-add-to-favorites:hover div {
    opacity: 1;
  }

  .button-delete-from-favorites:hover {
    opacity: 1;
  }

  body:has(.top-bar[data-minified]) .ntr-feedback-popup,
  body:has(.top-bar[data-minified]) .ntr-plan__progress {
    left: 50%;
  }

  #modal.modal-pop-up--create-account .modal__content {
    width: 40rem;
  }

  .account-content-container--chatroom .chat-suggestions .chat-suggestions__item:hover::before {
    opacity: 1;
  }

  .message-container .message__link:hover::before {
    opacity: 1;
  }

  /* .disclaimer-actions .button-disclaimer-decline:hover{
        transform: scale(1.05);
    } */

  .account-cta:hover::before {
    opacity: 1;
  }
}

@media (max-width: 63.9375rem) {
  .lg-ntr {
    height: 1.25rem;
  }

  .top-bar {
    width: 100%;
    border-radius: 0;
    padding: 0.75rem 0;
    background: var(--color-grey);
    z-index: 9999;
    transform: translateX(100%);
  }

  .top-bar .btn-close-menu {
    transform: translateX(-100vw);
  }

  .top-bar[data-minified],
  .top-bar[data-minified] .btn-close-menu {
    transform: none !important;
  }

  .top-bar[data-minified] {
    overflow-y: scroll;
  }

  body[data-scrolled] .top-bar {
    background: var(--color-grey);
  }

  .top-bar .logo-container * {
    height: 3rem;
  }

  body[data-scroll-y-dir-thresholed="down"] .top-bar[data-minified]:not([data-autohide="false"]) {
    transform: none !important;
  }

  .account-content-container {
    width: 100%;
    padding-bottom: 12.5vh;
    padding-top: 10vh;
    margin-left: 0;
  }

  .account-content-container .account-content-container__header {
    padding-top: 1.5rem;
  }

  .account-content-container--chatroom .chat-suggestions .chat-suggestions__item {
    padding: 0.5rem 1rem;
  }

  .account-content-container--personal-assistant {
    padding-top: 15vh;
  }

  .account-content-container--plan {
    padding-top: 0;
  }

  .account-content-container--chatroom .search-bar-container {
    width: 100%;
    left: 0;
    bottom: 0;
    padding: 0.25rem 0;
    background: rgba(39, 39, 39, 0.9);
  }

  .message {
    border-radius: 2rem;
    padding: 0.5rem 1rem;
  }

  .message-photo {
    height: 2.5rem;
    width: 2.5rem;
  }

  .account-content-container--personal-assistant .h1 {
    font-size: 2rem;
  }

  body[data-scroll-y-dir-thresholed="down"] .top-bar:not([data-autohide="false"]) {
    transform: translate(100%, 0) !important;
  }

  .chatroom-top .chatroom-top-image {
    height: 3rem;
    width: 3rem;
  }

  .popup-custom {
    left: 1rem;
    max-width: calc(100% - 2rem);
    transform: translateY(100vh);
    padding: 2rem;
  }

  .popup-custom[data-active] {
    transform: translateY(-50%);
  }

  .message-container .message__link .message__link__title {
    font-size: 1rem;
  }

  .message-container .message__link img {
    max-width: 5rem;
  }

  .message-container .message__link .message__link__description {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    overflow: hidden;
    font-size: 0.875rem;
  }

  .disclaimer-actions[data-active] {
    left: 50%;
    width: calc(100% - 1.875rem);
    max-width: unset;
  }

  #modal.modal-pop-up--create-account .modal__content img.asteptam {
    max-width: 9rem;
  }

  .popup-custom.plan-change {
    background: transparent;
    height: 100vh;
    width: 100%;
    color: var(--color-white);
    padding: 10vh 0 2rem 0;
  }

  .popup-custom.plan-change .tool-hide {
    left: 0;
    top: 1rem;
    width: 100%;
  }
}

/*SERBAN*/
.messages {
  padding-bottom: 7.5rem;
}
