@import url(https://fonts.googleapis.com/css2?family=Poppins:wght@100;200;300;400;500;600&display=swap);
.light-mode,
:root {
  --icon-idle-color: #adadad;
  --button-font-size: 14px;
}
#new-chat,
#search-btn {
  width: 50px;
  height: 50px;
  color: var(--outgoing-chat-border);
}
#free-plan,
.forgot:hover,
.login-creds > span:hover,
.sec-cta:hover {
  text-decoration: underline;
}
#new-chat,
#search-btn {
  color: var(--outgoing-chat-border);
}
#card-icon,
.remember {
  align-content: center;
}
input[type="checkbox"]::before,
input[type="radio"]::before {
  transition: transform 120ms ease-in-out;
  align-self: center;
  transform: scale(0);
}
.percentage-number,
.progress-bar {
  transition: width 0.3s;
}
#card-icon,
.chat:hover
.chat-content:not(:has(.typing-animation), :has(.error), :has(.edit-actions))
.material-symbols-rounded,
.nav-link:hover .more {
  visibility: visible;
}
@font-face {
  font-family: "SF Pro";
  src: url("../fonts/SFPRODISPLAYMEDIUM.OTF")
  format("opentype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "SF Pro";
  src: url("../fonts/SFPRODISPLAYBOLD.OTF")
  format("opentype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "SF Pro";
  src: url("../fonts/SFPRODISPLAYREGULAR.OTF")
  format("opentype");
  font-weight: lighter;
  font-style: normal;
}
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  font-family: "SF Pro", sans-serif;
}
:root {
  --text-color: #ffffff;
  --subtitle-color: rgb(173, 173, 173, 0.6);
  --icon-color: #000;
  --icon-hover-bg: #fff;
  --placeholder-color: #676767;
  --theme-bg: #2f2f2f;
  --side-bar-bg: #171717;
  --outgoing-chat-bg: #303030;
  --incoming-chat-bg: #212121;
  --outgoing-chat-border: #9b9b9b;
  --incoming-chat-border: #444654;
  --border-color: hsla(0, 0%, 100%, 0.2);
  --buttons-hover: hsla(0, 0%, 100%, 0.03);
  --forms-ai-logo: url("../img/white_logo.png");
  --forms-ai-mini-logo: url("../img/white_mini_logo.png");
  --background-color: #212121;
}
.light-mode {
  --text-color: #343541;
  --subtitle-color: rgb(108, 108, 108, 0.8);
  --icon-color: #a9a9bc;
  --icon-hover-bg: #dcdcdc;
  --placeholder-color: #6c6c6c;
  --theme-bg: #f7f7f8;
  --side-bar-bg: #f9f9f9;
  --outgoing-chat-bg: hsla(0, 0%, 91%, 0.5);
  --incoming-chat-bg: #fff;
  --outgoing-chat-border: #343541;
  --incoming-chat-border: #d9d9e3;
  --border-color: rgba(0, 0, 0, 0.2);
  --buttons-hover: rgba(0, 0, 0, 0.03);
  --forms-ai-logo: url("../img/black_logo.png");
  --forms-ai-mini-logo: url("../img/black_mini_logo.png");
  --background-color: #ffffff;
}
.header,
body {
  background: var(--background-color);
}
body {
  display: flex;
  overflow: hidden;
}
.header {
  display: none;
  flex-direction: column;
  padding: 20px 10px;
  justify-content: center;
  align-items: flex-end;
}
button {
  outline: 0;
  border: 0;
}
#open,
#unopen {
  background-color: var(--icon-idle-color);
  padding: 10px;
  margin: 5px;
  border-radius: 5px;
  display: none;
  top: 0;
  position: absolute;
  z-index: 1000;
  cursor: pointer;
}
.error {
  padding: 20px 0 5px;
  font-size: 12px;
  color: red;
}
#open {
  left: 0;
}
#unopen {
  left: 270px;
}
.overlay {
  display: none;
  justify-content: center;
  align-items: center;
  top: 0;
  left: 0;
  position: absolute;
  width: 100vw;
  height: 100dvh;
  background-color: rgb(0, 0, 0, 0.7);
  z-index: 1000;
}
.controls {
  display: flex;
  justify-content: flex-end;
}
#search-btn {
  cursor: pointer;
  display: flex;
  border-radius: 100px;
  justify-content: center;
  align-items: center;
}
#new-chat:hover,
#search-btn:hover,
.check-options > label:hover,
.download-document > :hover,
.floating-menu > span:hover,
.idk:hover,
.radio-options > label:hover,
.side-cta:hover,
.templates > div:hover,
div.edit-actions > button:first-child:hover,
li#logout:hover,
li#plan:hover,
li#profile:hover {
  background-color: var(--buttons-hover);
}
.landing-title {
  font-size: 26px;
}
.login-popup {
  display: block;
  width: 400px;
  background-color: #fff;
  border-radius: 10px;
  padding: 20px;
}
.plan,
.plans-body,
.typing-controls,
label {
  display: flex;
}
.plans-popup {
  width: 600px;
  background-color: var(--theme-bg);
  border: 1px solid #3d3d3d;
  border-radius: 10px;
}
.plans-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 30px;
  border-bottom: 1px solid #3d3d3d;
  color: var(--text-color);
  font-size: 22px;
  font-weight: 800;
}
.plan,
.plan-left {
  flex-direction: column;
  border-right: 1px solid #3d3d3d;
}
.plan {
  width: 50%;
  padding: 20px 40px 40px;
  gap: 20px;
}
.plan-left,
.plan-right {
  width: 50%;
  padding: 20px 40px;
  gap: 20px;
  display: flex;
}
.plan > button.selected-plan {
  cursor: default;
  background-color: var(--placeholder-color);
  color: var(--border-color);
}
.plan:last-child {
  border-right: none;
}
.plan-left > span:first-child,
.plan-right > span:first-child,
.plan > span:first-child {
  font-weight: 600;
  font-size: 16px;
  color: var(--text-color);
}
.plan-left > span:nth-child(2),
.plan-right > span:nth-child(2),
.plan > span:nth-child(2) {
  font-weight: 400;
  font-size: 14px;
  color: var(--subtitle-color);
}
.plan > button {
  cursor: pointer;
  padding: 10px 0;
  border: 0;
  border-radius: 10px;
  font-weight: 500;
  font-size: 15px;
  color: var(--text-color);
  background-color: #1392ec;
}
.plan-left > ul,
.plan-right > ul,
.plan > ul {
  font-weight: 400;
  font-size: 14px;
  color: var(--text-color);
  line-height: 30px;
  list-style-type: "\2713";
}
.plan-left > ul > li,
.plan-right > ul > li,
.plan > ul > li,
.settings li:first-child {
  padding-left: 10px;
}
.chat .chat-details p,
.msg p:first-child {
  white-space: pre-wrap;
  line-height: 1.5rem;
  padding: 0 50px 0 10px;
  word-break: break-word;
}
.plan-left > button {
  padding: 10px 0;
  border: 0;
  border-radius: 10px;
  font-weight: 500;
  font-size: 15px;
  color: var(--border-color);
  background-color: #4b4b4b;
}
#checkout,
#inline-signup,
.plan-right > button {
  background-color: #1392ec;
}
.plan-right {
  flex-direction: column;
}
.plan-right > button {
  cursor: pointer;
  padding: 10px 20px;
  border: 0;
  border-radius: 10px;
  font-weight: 500;
  font-size: 15px;
  color: var(--text-color);
}
.recommended {
  border: 1px solid #1392ec;
  border-radius: 10px;
}
#logout-cancel,
#logout-confirm {
  padding: 10px 20px;
  border-radius: 10px;
  font-size: 16px;
  cursor: pointer;
}
.login-header {
  display: flex;
  justify-content: end;
  width: 100%;
}
.login-title,
.logout-title {
  position: relative;
  justify-content: center;
  font-size: 24px;
  font-weight: 800;
  margin-bottom: 35px;
  width: 100%;
  display: flex;
}
.login-body {
  padding-left: 40px;
  padding-right: 40px;
}
.logout-title {
  text-align: center;
}
.logout-cta {
  display: flex;
  gap: 12px;
  justify-content: center;
}
#logout-cancel {
  color: var(--text-color);
  background-color: #3284ff;
}
.login-body > input[type="email"] {
  margin-bottom: 20px;
}
.social-media {
  display: flex;
  flex-direction: column;
  margin-top: 30px;
  align-items: center;
}
.back {
  cursor: pointer;
  position: absolute;
  top: 10px;
  left: 0;
}
.email-prev {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 48px;
  width: 100%;
  font-size: 14px;
}
.edt-eml,
.forgot,
.remember,
.sm-btn {
  font-size: 12px;
}
.email-prev > span {
  font-weight: 700;
}
.email-prev > span > span,
.mnl-frm > div {
  font-size: 13px;
  font-weight: 300;
}
.edt-eml,
.login-creds > span {
  font-weight: 600;
}
.edt-eml {
  cursor: pointer;
  color: #3284ff;
}
.mnl-frm {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
.profile-settings > li,
.sets {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.login,
.sm-btn {
  align-items: center;
}
.remember {
  display: flex;
  gap: 4px;
}
.forgot {
  cursor: pointer;
}
.sm-btn {
  display: flex;
  width: 100%;
  cursor: pointer;
  padding: 10px;
  border: 1px solid #dcdcdc;
  border-radius: 5px;
  margin-bottom: 8px;
  gap: 10px;
}
.social-media .sm-btn > span {
  display: flex;
  justify-content: center;
  width: 100%;
}
.sm-btn:hover {
  background-color: #f9fafc;
}
.login-separator {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 20px 0;
  color: #adadad;
  font-size: 11px;
}
.login-separator > span {
  width: 24%;
  border: 1px solid #dcdcdc;
}
.login-body > input,
.mnl-frm > input {
  box-sizing: border-box;
  outline: 0;
  height: 50px;
  width: 100%;
  border: 0.5px solid #d8d8d8;
  border-radius: 10px;
  padding: 15px;
  font-size: 11px;
}
.login-body > input::placeholder {
  color: #8c8c8c;
  opacity: 1;
}
.login-body > input:active,
.login-body > input:hover {
  border: 0.5px solid #8b8b8b;
}
.login-cta,
.sec-cta {
  justify-content: center;
  margin: 20px 0;
  padding: 10px 20px;
  border-radius: 10px;
  width: 100%;
  display: flex;
  outline: 0;
}
.login-cta {
  cursor: pointer;
  background-color: #3284ff;
  color: #fff;
}
.login-creds > span,
.sec-cta {
  color: #3284ff;
  cursor: pointer;
}
.login-cta:hover {
  background: #3273ff;
}
.login-cta:disabled {
  background: #a4c9ff;
  color: #fff;
  border-color: transparent;
  cursor: not-allowed;
}
#history > li:hover,
.delete:disabled,
.login:hover,
.unsubscribe:disabled {
  background-color: var(--buttons-hover);
}
.sec-cta {
  background-color: #fff;
}
#logo > a > img,
.status {
  padding-bottom: 20px;
}
.login-creds {
  display: flex;
  justify-content: center;
  font-size: 11px;
  color: #adadad;
  gap: 5px;
  margin-bottom: 20px;
}
#history,
#history > li,
.login:hover,
.status {
  color: var(--text-color);
}
.conversations {
  overflow-y: scroll;
  scrollbar-width: none;
}
.status {
  padding-top: 20px;
}
.status-header {
  font-size: 14px;
  font-weight: 400;
}
#history,
.status-footer {
  font-size: 12px;
  font-weight: 100;
}
.status-limit {
  display: flex;
  height: 15px;
  width: 100%;
  border: solid 1px var(--border-color);
  border-radius: 100px;
  margin-top: 8px;
  margin-bottom: 8px;
}
.quota {
  min-height: 10px;
  border-radius: 100px;
  background-color: var(--incoming-chat-border);
}
.status-footer {
  display: flex;
  justify-content: space-between;
}
.login,
.side-cta {
  font-size: var(--button-font-size);
  font-weight: 400;
  text-transform: capitalize;
  text-align: center;
}
.status-footer > span:nth-child(2) {
  cursor: pointer;
  font-weight: 600;
  color: #1392ec;
}
.close {
  cursor: pointer;
}
.container {
  display: flex;
  position: relative;
  z-index: 0;
  height: 100dvh;
  width: 100vw;
  overflow: hidden;
}
.side-bar {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 30%;
  max-width: 260px;
  overflow-x: hidden;
  flex-shrink: 0;
  padding: 20px;
  background-color: var(--side-bar-bg);
}
.login {
  display: flex;
  cursor: pointer;
  color: var(--theme-bg);
  background-color: var(--text-color);
  padding: 10px 20px;
  border: 1px var(--placeholder-color);
  border-style: solid;
  border-radius: 50px;
  justify-content: center;
  gap: 8px;
  margin-bottom: 20px;
}
#history > li,
.delete-one,
.rename-one {
  cursor: pointer;
  align-items: center;
  display: flex;
}
#history {
  margin: 20px 10px 10px 5px;
  list-style: none;
  line-height: 30px;
}
#history > li {
  justify-content: space-between;
  font-size: 13px;
  font-weight: 200;
  padding: 0 0 0 10px;
}
#history > li:hover {
  border-radius: 8px;
}
#username-email,
.conversation-title {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.more {
  visibility: hidden;
  padding: 12px;
  color: var(--icon-idle-color);
}
.floating-menu {
  z-index: 1000;
  position: absolute;
  display: flex;
  flex-direction: column;
  background: #000;
  padding: 12px 10px;
  border-radius: 8px;
  border: 1px solid var(--border-color);
  background-color: var(--theme-bg);
  gap: 8px;
}
.delete-one,
.rename-one {
  gap: 12px;
  padding: 4px 12px;
  border-radius: 4px;
}
#new-chat,
.side-cta {
  cursor: pointer;
  align-items: center;
}
.delete-one {
  color: red;
}
#logo > a > img,
.profile-settings,
.settings-menu,
.side-cta {
  color: var(--text-color);
}
.side-cta {
  display: flex;
  padding: 10px 20px;
  border: 1px var(--placeholder-color);
  border-style: solid;
  border-radius: 10px;
  justify-content: center;
  gap: 8px;
}
#new-chat,
.settings {
  display: flex;
  padding: 10px;
}
#logo,
.btn {
  justify-content: center;
}
#logo {
  display: flex;
}
#logo > a > img {
  content: var(--forms-ai-logo);
  width: 100px;
}
#new-chat {
  border-radius: 100px;
  justify-content: center;
  justify-self: flex-end;
}
.settings-menu {
  display: flex;
  align-items: center;
  position: absolute;
  bottom: 70px;
  margin: 0 auto;
  width: 220px;
  border: 1px var(--placeholder-color);
  border-style: solid;
  border-radius: 10px;
  background-color: var(--side-bar-bg);
  font-size: 14px;
  font-weight: 200;
}
.chat-container .chat.outgoing,
.theme {
  background: var(--outgoing-chat-bg);
}
.settings {
  width: 100%;
  flex-direction: column;
  gap: 6px;
  list-style: none;
  height: 100%;
  line-height: 2;
}
.btn,
.delete,
.unsubscribe {
  cursor: pointer;
  height: 40px;
  font-weight: 400;
  display: flex;
  font-size: 14px;
}
hr {
  border: 0.5px solid;
  border-color: var(--border-color);
}
li#logout,
li#plan,
li#profile {
  cursor: pointer;
  background-color: var(--side-bar-bg);
  padding-left: 10px;
  border-radius: 5px;
}
.profile-settings {
  width: 100%;
  padding: 30px;
  list-style: none;
  line-height: 65px;
}
.btn {
  align-items: center;
  padding: 0 20px;
  background-color: var(--outgoing-chat-bg);
  border-radius: 5px;
}
.theme {
  padding: 12px;
  border-radius: 8px;
}
.delete,
.unsubscribe {
  justify-content: center;
  align-items: center;
  padding: 0 20px;
  background-color: red;
  border-radius: 5px;
  color: #fff;
}
.delete:disabled,
.unsubscribe:disabled {
  cursor: auto;
  color: rgb(255, 255, 255, 0.5);
}
#copy-document,
.chat .chat-details p,
.chat-container .chat,
.default-text,
.idk,
.templates > div > h3 {
  color: var(--text-color);
}
.body {
  display: flex;
  flex: 1 1 0%;
  flex-direction: column;
  overflow: hidden;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.chat-container,
.conversation {
  overflow-y: scroll;
  box-sizing: content-box;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
body::-webkit-scrollbar {
  display: none;
}
.chat-container {
  z-index: 0;
  flex: 1 1 0%;
  padding: 10px;
}
.chat-container::-webkit-scrollbar {
  display: none;
}
.conversation {
  max-width: 950px;
  display: flex;
  flex-direction: column;
  margin: 0 auto;
  height: 100%;
}
.conversation::-webkit-scrollbar {
  display: none;
}
.selected {
  cursor: default;
  background-color: var(--outgoing-chat-bg);
  border-radius: 10px;
}
.download-document > *,
.edit-message {
  background-color: var(--side-bar-bg);
}
.footer {
  display: flex;
  flex-direction: column;
  width: 100%;
}
.default-text {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  height: 100%;
  padding: 0 10px;
  text-align: center;
  font-weight: 200;
  gap: 40px;
}
.idk,
.templates > div {
  padding: 10px 20px;
  cursor: pointer;
}
.default-text h1 {
  font-size: 3.3rem;
}
.default-text p {
  margin-top: 10px;
  font-size: 1.1rem;
}
.default-text > img {
  content: var(--forms-ai-logo);
  width: 280px;
}
.templates {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  width: 80%;
  justify-content: center;
}
.templates > div {
  display: flex;
  flex-direction: column;
  text-align: left;
  width: 40%;
  border: 1px var(--placeholder-color);
  border-style: solid;
  border-radius: 10px;
  gap: 4px;
}
.templates > div > h3 {
  font-size: 14px;
}
#copy-document,
.templates > div > span {
  font-size: 12px;
}
#card-icon,
#free-plan,
.templates > div > span {
  color: var(--subtitle-color);
}
.chat-container .chat {
  padding: 25px 10px;
  display: flex;
  justify-content: center;
}
.chat.outgoing:first-child {
  padding: 16px;
}
.chat.outgoing {
  display: flex;
  align-self: flex-end;
  border-radius: 100px;
}
[id^="outgoing-"]:has(span.edit) {
  padding: 16px 44px 16px 16px;
}
[id^="outgoing-"]:not(:has(span.edit)) {
  padding: 16px 44px;
}
.chat-container .chat.incoming {
  background: var(--incoming-chat-bg);
}
.chat .chat-content {
  display: flex;
  max-width: 1200px;
  width: 100%;
  justify-content: space-between;
  align-items: flex-start;
}
span.material-symbols-rounded {
  user-select: none;
  cursor: pointer;
}
.chat .chat-content:not(:has(.user)) .material-symbols-rounded {
  cursor: pointer;
  font-size: 1.6rem;
  color: var(--icon-color);
  visibility: hidden;
}
.idk {
  border: 1px solid var(--border-color);
  border-radius: 10px;
  min-width: 127px;
}
.copy,
.edit {
  cursor: pointer;
  color: var(--icon-idle-color) !important;
}
.edit-message {
  outline: 0;
  border-radius: 10px;
  padding: 10px !important;
}
div.edit-actions {
  margin-top: 10px;
  display: flex;
  justify-content: end;
  gap: 10px;
}
div.edit-actions > button {
  padding: 8px 15px;
  border-radius: 1rem;
  cursor: pointer;
}
div.edit-actions > button:first-child {
  background-color: transparent;
  color: var(--text-color);
}
div.edit-actions > button:last-child:hover {
  background-color: var(--icon-hover-bg);
}
.chat .chat-details {
  display: flex;
  align-items: center;
  width: 100%;
}
img[alt="chatbot-img"] {
  height: 24px;
  align-self: flex-start;
  object-fit: cover;
  content: var(--forms-ai-mini-logo);
}
.chat .chat-details p {
  font-size: 1rem;
  font-weight: 200;
  outline: 0;
}
.chat .chat-details p.error {
  color: #e55865;
}
.chat .typing-animation {
  padding-left: 10px;
  display: inline-flex;
}
.typing-animation .typing-dot {
  height: 7px;
  width: 7px;
  border-radius: 50%;
  margin: 0 3px;
  opacity: 0.7;
  background: var(--text-color);
  animation: animateDots 1.5s var(--delay) ease-in-out infinite;
}
.typing-animation .typing-dot:first-child {
  margin-left: 0;
}
.download-document {
  display: flex;
  justify-content: flex-start;
  gap: 12px;
  margin-top: 20px;
}
.download-document > * {
  cursor: pointer;
  display: flex;
  justify-content: center;
  height: 60px !important;
  width: 60px !important;
  padding: 12px;
  border-radius: 1rem !important;
  border: solid 1px var(--border-color);
}
.card-holder-name,
.email-address {
  background-color: transparent;
  outline: 0;
}
#free-plan {
  cursor: pointer;
  margin-top: 20px;
  align-self: center;
}
#card-element,
#inline-signup,
.card-holder-name,
.email-address {
  color: var(--text-color);
  height: 48px;
}
.checkout-info {
  display: flex;
  width: 100%;
  padding-top: 30px;
  gap: 40px;
  color: whitesmoke;
  max-width: 500px;
  flex-direction: column;
}
.billing-details {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 50%;
}
.billing-address,
.inline-signup {
  display: flex;
  gap: 8px;
}
.billing-details > span,
.order-summary > span:first-child {
  font-size: 16px;
  font-weight: 600;
}
.check-options > label,
.radio-options > label,
.select-options > select {
  padding: 10px;
  max-width: 500px;
  font-size: 1rem;
  font-weight: 200;
  cursor: pointer;
}
.email-address {
  width: 100%;
  border-radius: 10px;
  padding: 0 12px;
  border: 1px solid #3d3d3d;
}
#inline-signup {
  cursor: pointer;
  width: 40%;
  padding: 10px;
  border-radius: 10px;
}
#checkout:disabled,
#inline-signup:disabled {
  cursor: default;
  background-color: var(--buttons-hover);
  color: var(--outgoing-chat-border);
}
#card-element {
  padding: 14px 10px;
  border: 1px solid #3d3d3d;
  border-radius: 10px;
}
#card-icon {
  padding-right: 10px;
  font-size: 24px;
}
.card-creds > input {
  height: 100%;
  border: none;
  outline: 0;
}
.card-number {
  width: 50%;
}
.card-cvv,
.card-expiry {
  width: 20%;
}
.card-holder-name {
  border-radius: 10px;
  padding: 0 12px;
  border: 1px solid #3d3d3d;
}
.billing-address {
  height: 48px;
  width: 100%;
  justify-content: space-between;
}
#country,
.zip-code {
  background-color: transparent;
  height: 100%;
  padding: 0 20px;
  width: 100%;
  color: var(--text-color);
  outline: 0;
}
.msg,
.order-summary {
  flex-direction: column;
  display: flex;
}
.zip-code {
  border-radius: 10px;
  border: 1px solid #3d3d3d;
}
#country {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  border-radius: 10px;
  background-image: linear-gradient(45deg, transparent 50%, gray 50%),
  linear-gradient(135deg, gray 50%, transparent 50%),
  linear-gradient(to right, #3d3d3d, #3d3d3d);
  background-position: calc(100% - 20px) calc(1em + 7px),
  calc(100% - 15px) calc(1em + 7px), calc(100% - 2.9em) 0;
  background-size: 5px 5px, 5px 5px, 1px 3.5em;
  background-repeat: no-repeat;
  border: 1px solid #3d3d3d;
}
.order-summary {
  justify-content: space-between;
  min-height: 190px;
}
#checkout {
  cursor: pointer;
  padding: 16px 40px;
  border: 0;
  border-radius: 10px;
  font-weight: 500;
  font-size: 15px;
  color: var(--text-color);
}
@keyframes animateDots {
  0%,
  44% {
    transform: translateY(0);
  }
  28% {
    opacity: 0.4;
    transform: translateY(-6px);
  }
  44% {
    opacity: 0.2;
  }
}
.msg {
  width: 100%;
  margin-bottom: 0;
}
.msg p:first-child {
  font-weight: 400 !important;
  font-size: 1rem;
  margin-bottom: 10px;
  color: var(--text-color);
}
.outgoing .msg p:first-child {
  padding: 0 12px;
  margin: 0;
  text-align: right;
}
.check-options,
.radio-options,
.select-options {
  display: flex;
  flex-direction: column;
  max-width: 500px;
  gap: 10px;
  padding-top: 10px;
}
.check-options > button,
.radio-options > button,
.select-options > button {
  cursor: pointer;
  width: 100px;
  margin-top: 10px;
  padding: 10px;
  border-radius: 1rem;
  color: var(--text-color);
  background-color: var(--border-color);
  align-self: flex-end;
}
.select-options > select {
  border: 1px solid var(--placeholder-color);
  border-radius: 10px;
  color: var(--text-color);
  background-color: var(--background-color);
  outline: 0;
}
.check-options > label,
.radio-options > label {
  border: 1px solid var(--placeholder-color);
  border-radius: 10px;
  color: var(--text-color);
}
input[type="checkbox"],
input[type="radio"] {
  display: flex;
  appearance: none;
  background-color: transparent;
  margin: 0 8px 0 4px;
  font: inherit;
  width: 1.15em;
  height: 1.15em;
}
input[type="checkbox"] {
  justify-content: center;
  accent-color: var(--text-color);
  border: 0.15em solid var(--text-color);
  border-radius: 20%;
}
.typing-textarea > textarea,
input[type="radio"] {
  justify-content: center;
  color: var(--text-color);
}
input[type="checkbox"]::before {
  content: "\2713";
  border-radius: 50%;
  color: #fff;
}
input[type="checkbox"]:checked::before,
input[type="radio"]:checked::before {
  transform: scale(1);
}
input[type="radio"] {
  border: 0.15em solid var(--text-color);
  border-radius: 50%;
}
input[type="radio"]::before {
  content: "";
  width: 0.65em !important;
  height: 0.65em !important;
  border-radius: 50%;
  box-shadow: inset 1em 1em var(--text-color);
}
.check-options > label:has(input[type="checkbox"]:checked),
.radio-options > label:has(input[type="radio"]:checked) {
  background-color: var(--border-color);
}
.check-options > button:disabled,
.radio-options > button:disabled {
  cursor: default;
  background-color: transparent;
  color: var(--subtitle-color);
}
.conversation-progress {
  overflow: hidden;
  height: 8px;
  width: 100%;
  max-width: 950px;
  border: solid 1px var(--border-color);
  border-radius: 100px;
}
.progress-bar {
  display: block;
  height: 8px;
  background-color: #3284ff;
}
.isolate,
.progress-percentage,
.typing-container,
.typing-content span,
.typing-textarea {
  display: flex;
  display: flex;
}
.progress-percentage {
  width: 100%;
  max-width: 950px;
  font-size: 14px;
  text-align: right;
  color: var(--text-color);
}
.typing-container {
  flex-direction: column;
  padding: 20px 10px;
  background: var(--background-color);
  justify-content: center;
  align-items: center;
  gap: 10px;
  width: 100%;
}
.typing-container .typing-content {
  display: flex;
  max-width: 950px;
  width: 100%;
  align-items: flex-end;
}
.typing-textarea {
  width: 100%;
  min-width: 600px;
  align-items: flex-end;
  justify-content: space-between;
  border: 1px solid #d9d9e3;
  border-color: var(--border-color);
  border-radius: 1rem;
  background: 0 0;
  box-sizing: border-box;
}
.typing-textarea > textarea {
  resize: none;
  height: 24px;
  width: 100%;
  font-size: 1rem;
  line-height: 22px;
  background: 0 0;
  margin: 15px 45px 15px 20px;
  border: none;
  outline: 0;
  overflow-y: hidden;
  scrollbar-width: none;
}
#send-btn {
  justify-content: center;
}
.typing-textarea > textarea::placeholder {
  font-size: 15px;
  font-weight: 300;
  color: var(--placeholder-color);
}
.typing-content span {
  width: 54px;
  height: 54px;
  border-radius: 4px;
  font-size: 1.35rem;
  align-items: center;
  justify-content: center;
  color: var(--icon-color);
}
.typing-textarea span {
  visibility: hidden;
  border-radius: 1rem;
  color: var(--text-color);
}
.typing-textarea textarea:valid ~ span {
  visibility: visible;
}
.typing-controls span {
  border-radius: 1rem;
  margin-left: 7px;
  font-size: 1.4rem;
  background: var(--icon-idle-color);
}
.typing-controls span:hover {
  background: var(--icon-hover-bg);
}
.isolate {
  isolation: isolate;
  flex-direction: column;
  gap: 10px;
  padding: 40px;
  margin-left: 10px;
  background-color: var(--theme-bg);
  border-radius: 12px;
}
.isolate > ul {
  padding-left: 40px;
}
@media screen and (max-width: 600px) {
  .plans-body,
  .templates {
    flex-direction: column;
  }
  #open,
  .templates {
    display: flex;
  }
  .container,
  .plan,
  .templates,
  .templates > div {
    width: 100%;
  }
  .typing-textarea {
    min-width: 300px;
  }
  .templates {
    flex-wrap: wrap;
    gap: 10px;
  }
  .header {
    padding: 5px;
  }
  .chat-header {
    justify-content: center;
  }
  .conversation {
    padding-top: 32px;
  }
  .default-text h1 {
    font-size: 2.3rem;
  }
  :where(.default-text p, textarea, .chat p) {
    font-size: 0.95rem !important;
  }
  .side-bar {
    display: none;
    overflow-x: initial;
  }
  .chat-container .chat,
  .isolate {
    padding: 20px 10px;
  }
  .chat-container .chat img {
    height: 24px;
    width: 24px;
  }
  .chat-container .chat p {
    padding: 0 20px;
  }
  .chat .chat-content:not(:has(.typing-animation), :has(.error)) span {
    visibility: visible;
  }
  .typing-container {
    padding: 15px 10px;
  }
  span.material-symbols-rounded {
    font-size: 1.25rem !important;
  }
  .plan {
    border-right: 0;
    border-bottom: 1px solid #3d3d3d;
  }
  .plan:last-child {
    border-bottom: 0;
  }
  .checkout-info {
    flex-direction: column;
    gap: 30px;
    min-height: 190px;
  }
}
.autoComplete_wrapper {
  display: inline-block;
  position: relative;
}
.autoComplete_wrapper > input {
  width: 370px;
  height: 40px;
  padding-left: 20px;
  font-size: 1rem;
  color: #7b7b7b;
  border-radius: 8px;
  border: 0;
  outline: 0;
  background-color: #f1f3f4;
}
.autoComplete_wrapper > input::placeholder {
  color: rgba(123, 123, 123, 0.5);
  transition: 0.3s;
}
.autoComplete_wrapper > ul {
  position: absolute;
  max-height: 226px;
  overflow-y: scroll;
  top: 100%;
  left: 0;
  right: 0;
  padding: 0;
  margin: 0.5rem 0 0;
  border-radius: 0.6rem;
  background-color: #fff;
  box-shadow: 0 3px 6px rgba(149, 157, 165, 0.15);
  border: 1px solid rgba(33, 33, 33, 0.07);
  z-index: 1000;
  outline: 0;
}
.autoComplete_wrapper > ul > li,
.no_result {
  margin: 0.3rem;
  padding: 0.3rem 0.5rem;
  list-style: none;
  text-align: left;
  font-size: 1rem;
  color: #212121;
  transition: 0.2s;
  border-radius: 0.35rem;
  background-color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.autoComplete_wrapper > ul:empty,
.autoComplete_wrapper > ul[hidden] {
  display: block;
  opacity: 0;
  transform: scale(0);
}
.autoComplete_wrapper > ul > li::selection {
  color: rgba(#fff, 0);
  background-color: rgba(#fff, 0);
}
.autoComplete_wrapper > ul > li:hover,
.autoComplete_wrapper > ul > li[aria-selected="true"] {
  background-color: rgba(123, 123, 123, 0.1);
}
.autoComplete_wrapper > ul > li:hover {
  cursor: pointer;
}
.autoComplete_wrapper > ul > li mark {
  background-color: transparent;
  color: #ff7a7a;
  font-weight: 700;
}
.autoComplete_wrapper > ul > li mark::selection {
  color: rgba(#fff, 0);
  background-color: rgba(#fff, 0);
}
@media only screen and (max-width: 600px) {
  .autoComplete_wrapper > input {
    width: 18rem;
  }
}
.no_result {
  outline: 0;
}
.calendar-container {
  margin-top: 10px;
  width: 300px;
  border-radius: 12px;
  border: 1px solid var(--border-color);
}
.calendar-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-radius: 12px 12px 0 0;
  padding: 10px;
  background-color: #f8f9fa;
  border-bottom: 1px solid #dee2e6;
}
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 1px;
  border-radius: 0 0 12px 12px;
  background-color: #fff;
  padding: 10px;
}
.calendar-cell {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 40px;
  cursor: pointer;
  border-radius: 4px;
  color: #343541;
}
.calendar-cell:hover:not(.disabled) {
  background-color: #f0f0f0;
}
.calendar-header-cell {
  font-weight: 700;
  color: #666;
  text-align: center;
  padding: 5px;
}
.today {
  border: 2px solid #007bff;
}
.selectedDate {
  background-color: #007bff;
  color: #fff;
}
.disabledDate {
  color: #ccc;
  cursor: default;
}
.month-selector {
  color: #343541;
  font-weight: 700;
  cursor: pointer;
}
#nextMonth,
#prevMonth {
  background: 0 0;
  border: none;
  font-size: 16px;
  cursor: pointer;
  padding: 5px 10px;
}
#nextMonth:hover,
#prevMonth:hover {
  background-color: #e9ecef;
  border-radius: 4px;
}
.loading-container {
  display: flex;
  margin-left: 10px;
}
.loading-text {
  color: var(--text-secondary, #666);
  font-size: 0.9rem;
  transition: opacity 0.3s;
}
.spinner {
  width: 24px;
  height: 24px;
  border: 4px solid var(--icon-idle-color);
  border-top-color: #007bff;
  border-radius: 50%;
  animation: 0.8s linear infinite spinner;
}
@keyframes spinner {
  to {
    transform: rotate(360deg);
  }
}
.progress-bar-container
{
  width: 100%;
  display: none;
  padding-left: 40px;
  padding-right: 10px;
}

.question-type-text
{
  margin-left: 10px;
}
.question-type-text label
{
  margin-bottom: 10px;
}
.question-footer
{
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  margin-top: 10px;
}
.pbutton,.nbutton {
  border: 1px solid var(--border-color);
  border-radius: 10px;
  padding: 10px 20px;
  cursor: pointer;
  display: flex;
  flex-wrap: nowrap;
  flex-direction: row;
  align-content: center;
  justify-content: center;
  align-items: center;
  gap: 5px;
}
.pbutton:hover,.nbutton:hover
{
  /*background-color: var(--buttons-hover);*/
  background-color: #3284ff;
}
.pbutton .material-symbols-rounded,.nbutton .material-symbols-rounded
{
  visibility: visible!important;
  color: white !important;
}
.pbutton.disabled,.nbutton.disabled
{
  cursor: not-allowed!important;
}
.pbutton.disabled .material-symbols-rounded,.nbutton.disabled .material-symbols-rounded
{
  cursor: not-allowed!important;
}
#conversation-title
{
  margin-bottom: 10px;
  color: white;
}
.rename-one
{
  color:white;
}
.payment-options .radio-options label {
  align-items: center;
  justify-content: space-between;
}
.radio-options>label {
  border: 1px solid #676767;
  border-radius: 10px;
  color: whitesmoke;
  padding: 10px;
  max-width: 500px;
  font-size: 1rem;
  font-weight: 200;
  cursor: pointer;
}
.radio-options label span {
  display: flex;
}
.notice {
  font-weight: normal !important;
  font-size: 12px !important;
}
#checkout:disabled, #checkout-modal:disabled {
  cursor: not-allowed;
  background-color: gray;
}
#checkout, #checkout-modal {
  cursor: pointer;
  padding: 16px 40px;
  border: 0;
  border-radius: 10px;
  font-weight: 500;
  font-size: 15px;
  color: whitesmoke;
}
.notice a {
  color: white;
  text-decoration: underline;
}
#in-chat-subscribe
{
  padding-top: 15px!important;
  padding-left: 10px!important;
}
#question-label
{
  margin-left: 10px;
  margin-bottom: 10px;
}