.mb-20px {
  margin-bottom: 20px;
}

.ms-20px {
  margin-left: 20px;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

.content-blur {
  filter: blur(5px);
}

.whitespace-nowrap {
  white-space: nowrap !important;
}

.btn-group {
  height: 38px;
  border-radius: 50px;
  overflow: hidden;
}

.vcard-btn-group {
  width: 50px;
  height: 50px;
  color: #fb5253;
  border: 1px solid #fb5253;
  background-color: white;
  border-radius: 50px !important;
}

.sticky-vcard-div {
  position: fixed;
  bottom: 18px;
  left: 18px;
  right: auto;
  width: auto !important;
  padding: 0 !important;
  z-index: 99990;
}

.sticky-vcard4-div {
  bottom: 62px !important;
}

.sticky-vcard12-div {
  bottom: 66px !important;
}

.modal {
  z-index: 99999 !important;
  background-color: #00000080;
}
.modal .modal-dialog .modal-content {
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.1);
  border: none;
  border-radius: 0.475rem;
  outline: 0;
}
.modal .modal-dialog .modal-content .modal-header {
  padding: 22px;
  border-bottom: 1px solid #eff2f5;
}
.modal .modal-dialog .modal-content .modal-body {
  padding: 1.75rem;
}
.modal .modal-dialog .modal-content .modal-body .required:after {
  color: #f62947;
  content: "*";
  font-size: inherit;
  font-weight: 700;
  position: relative;
}
.modal .modal-dialog .modal-content .modal-body .input-box {
  background-color: #f5f8fa;
  border: unset;
  color: #5e6278;
  transition: all 0.2s ease;
  font-size: 1.1rem;
  line-height: 1.5;
  padding: 0.75rem 1rem;
  border-radius: 0.475rem;
}
.modal .modal-dialog .modal-content .modal-body .input-box:focus {
  box-shadow: unset;
  background-color: #eef3f7;
}
.modal .modal-dialog .modal-content .modal-footer {
  padding: 1.875rem;
}
.modal .modal-dialog .modal-content .modal-footer .btn {
  padding: 10px 20px !important;
  border-radius: 0.475rem !important;
}
.modal .modal-dialog .modal-content .modal-footer .submit-btn {
  background-color: #6571ff !important;
  border: unset;
  outline: unset;
  color: #fff;
  padding: 10px 20px !important;
  margin-top: 26px;
}
.modal .modal-dialog .modal-content .modal-footer .submit-btn:hover {
  background-color: #6571ff !important;
}
.modal .modal-dialog .modal-content .modal-footer .submit-btn:focus {
  box-shadow: unset;
}

.main-payment {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.main-payment .payment-section {
  box-shadow: 2px 0 8px 2px #dfdbdb;
}
@media (max-width: 576px) {
  .main-payment .payment-section .payment-heading {
    width: 100%;
    text-align: center;
  }
}
.main-payment .payment-section .payment-heading .payment-title {
  font-size: 67px;
  font-weight: bold;
  color: #f56758;
}
@media (max-width: 992px) {
  .main-payment .payment-section .payment-heading .payment-title {
    font-size: 55px;
  }
}
@media (max-width: 668px) {
  .main-payment .payment-section .payment-heading .payment-title {
    font-size: 45px;
  }
}
.main-payment .payment-section .payment-heading .payment-text {
  font-size: 30px;
  color: #595957;
  font-weight: 600;
}
@media (max-width: 992px) {
  .main-payment .payment-section .payment-heading .payment-text {
    font-size: 25px;
  }
}
@media (max-width: 668px) {
  .main-payment .payment-section .payment-heading .payment-text {
    font-size: 20px;
  }
}
.main-payment .payment-section .payment-heading .payment-btn {
  background: #f68880;
  color: white;
}

.main-payment-success {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.main-payment-success .payment-head {
  padding: 50px;
  box-shadow: 2px 0 8px 2px #ededed;
  border-radius: 10px;
  background: #fafcff;
}
@media (max-width: 455px) {
  .main-payment-success .payment-head {
    padding: 20px;
  }
}
.main-payment-success .payment-head .payment-details {
  padding: 30px;
}
@media (max-width: 350px) {
  .main-payment-success .payment-head .payment-details {
    padding: 10px;
  }
}
.main-payment-success .payment-head .payment-details .payment-info {
  text-align: center;
}
.main-payment-success .payment-head .payment-details .payment-info .payment-icon {
  font-size: 50px;
  color: #46ceac;
}
.main-payment-success .payment-head .payment-details .payment-info .payment-title {
  color: #46ceac;
}
@media (max-width: 992px) {
  .main-payment-success .payment-head .payment-details .payment-info .payment-title {
    font-size: 25px;
  }
}
.main-payment-success .payment-head .payment-text {
  color: #a2a8bb;
}
.main-payment-success .payment-head .payment-img {
  padding-left: 100px;
}
@media (max-width: 768px) {
  .main-payment-success .payment-head .payment-img {
    display: none;
    padding-left: 0;
  }
}

.btn-back {
  background-color: #46ceac;
  color: white;
}

.social-link-modal {
  display: flex;
}
@media (max-width: 450px) {
  .social-link-modal {
    display: block !important;
  }
}
.social-link-modal a {
  text-decoration: none !important;
}

input::-moz-placeholder {
  overflow: visible;
}

input::placeholder {
  overflow: visible;
}

.custom-nav-margin {
  margin-top: 121px !important;
}

.vcard-11-back {
  left: 875px !important;
  top: 51px !important;
}

.morecontent span {
  display: none;
  font-weight: 400 !important;
  -webkit-box-orient: vertical;
}

.morelink {
  cursor: pointer;
}

#toast-container > div {
  min-width: 400px !important;
}
@media (max-width: 575px) {
  #toast-container > div {
    min-width: 300px !important;
  }
}

.lightbox {
  display: flex;
  flex-direction: column-reverse;
}

.lb-data .lb-number {
  padding-bottom: 0 !important;
  padding-top: 1rem;
}

#wpNumber::-webkit-inner-spin-button {
  display: none;
}

#wpNumber {
  height: 30px;
}

.wp-number-container {
  position: fixed;
  z-index: 999999;
}

.input {
  background-color: white;
  border: none;
  border-bottom: 1px solid #CCC;
  color: #555;
  box-sizing: border-box;
  font-family: "Arvo";
  font-size: 18px;
  height: 50px;
  padding: 20px;
  position: relative;
  right: 132% !important;
  top: -182px !important;
  width: 160px;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.25);
  border-radius: 25px;
}
.input:focus {
  outline: none;
}

.input::-webkit-input-placeholder {
  color: #AAA;
}

.input:focus::-webkit-input-placeholder {
  color: #969696;
}

.input:focus + .underline {
  transform: scale(1);
}

.underline {
  display: inline-block;
  height: 2px;
  right: 238px;
  margin-top: -4px;
  position: absolute;
  top: -139px;
  transform: scale(0, 1);
  width: 132px;
}

.share-wp-btn-div {
  width: 40px;
  height: 40px;
  position: absolute;
  right: 5px;
  top: 5px;
}
.share-wp-btn-div .share-wp-btn {
  width: 40px;
  height: 40px;
  font-size: 18px;
}

.vcard-wp-btn {
  background-color: #18b718 !important;
  width: 50px;
  height: 50px;
  font-size: 15px;
  border: none;
}

.vcard11-sticky-btn {
  position: absolute;
  right: 22px;
  width: 40px;
  height: 40px;
  background-color: #18b718;
  top: 50%;
  z-index: 99999;
  font-size: 12px;
}
@media (max-width: 1199px) {
  .vcard11-sticky-btn {
    right: 25px;
  }
}

.vcard11-underline {
  position: absolute;
  background-color: #fd5479;
  display: inline-block;
  height: 2px;
  top: 39px;
  right: -44px;
  transform: scale(0, 1);
  transition: all 0.5s linear;
  width: 132px;
}
@media (min-width: 1199px) {
  .vcard11-underline {
    right: -63px;
  }
}

.vcard11-input:focus + .vcard11-underline {
  transform: scale(1) !important;
}

.vcard11-send-btn {
  background-image: linear-gradient(123.62deg, #f59c37 0%, #fd5479 100%);
  width: 40px !important;
  height: 40px !important;
  border-radius: 40px;
  color: white !important;
  margin-left: 300px !important;
}

.vcard11-input {
  background-color: white;
  border: none;
  border-bottom: 1px solid #CCC;
  color: #555;
  box-sizing: border-box;
  font-family: "Arvo";
  font-size: 18px;
  height: 50px;
  padding: 20px;
  position: relative;
  left: 70px !important;
  top: 0px !important;
  width: 160px;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.25);
  border-radius: 25px;
}
@media (min-width: 1199px) {
  .vcard11-input {
    left: 88px !important;
  }
}
.vcard11-input:focus {
  outline: none;
}

.vcard11-container {
  position: absolute;
  top: 50% !important;
  right: 200px !important;
  z-index: 999999;
}
@media (max-width: 1199px) {
  .vcard11-container {
    position: fixed;
    right: 180px !important;
  }
}
.vcard11-container .input {
  top: 0 !important;
}
.vcard11-container .share-wp-btn-div {
  top: 0 !important;
}
.vcard11-container .underline {
  top: 42.5px;
}

.vcard-bars-btn {
  z-index: 9 !important;
  width: 576px;
  display: flex;
  justify-content: flex-end;
}
.vcard-bars-btn .bars-btn {
  width: 60px;
  height: 60px;
  min-width: 60px;
  font-size: 12px;
  position: absolute;
  margin-right: 0.5rem !important;
  box-shadow: -3px 2px 15px #9e9e9ecc;
}

.sub-btn {
  display: flex;
  flex-direction: column;
  width: 100%;
  border-radius: 20px;
  position: relative;
  left: 0;
  top: 0;
}

.nav-tabs .dropdown-menu {
  min-width: 200px !important;
}

.link-text {
  font-size: 16px !important;
  font-weight: 500;
}
@media (max-width: 480px) {
  .link-text {
    font-size: 14px !important;
  }
}

.modal-backdrop.show {
  z-index: -1 !important;
}

.icon-search-container {
  background-color: white;
  display: inline-block;
  border-radius: 50px;
  height: 50px;
  width: 50px;
  overflow: hidden;
  position: relative;
  transition: width 0.2s ease-out;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}
.icon-search-container.active {
  width: 285px;
  outline: 1px solid green;
}
@media (max-width: 425px) {
  .icon-search-container.active {
    width: 260px;
  }
}
@media (max-width: 374px) {
  .icon-search-container.active {
    width: 220px;
  }
}
@media (max-width: 336px) {
  .icon-search-container.active {
    width: 200px;
  }
}
.icon-search-container.active .wp-btn {
  width: 40px;
  height: 40px;
  min-width: 40px;
  font-size: 14px;
  position: relative;
  top: 5px;
  left: 5px;
}
.icon-search-container.active .fa-times-circle {
  opacity: 1;
}
.icon-search-container.active .search-input {
  width: 200px;
}
.icon-search-container .fa-search {
  color: #2980b9;
  font-size: 30px;
  position: absolute;
  top: 7px;
  left: 8px;
  cursor: pointer;
}
.icon-search-container .fa-times-circle {
  opacity: 0;
  color: #d9d9d9;
  font-size: 20px;
  position: absolute;
  top: 12px;
  right: 8px;
  transition: opacity 0.2s ease-out;
  cursor: pointer;
}
.icon-search-container .search-input {
  position: absolute;
  cursor: default;
  left: 50px;
  top: 9px;
  width: 0;
  border: none;
  outline: none;
  font-size: 18px;
  line-height: 20px;
  background-color: rgba(255, 255, 255, 0);
  transition: width 0.2s ease-out;
}

.wp-btn {
  position: relative;
  z-index: 9;
  width: 50px;
  height: 50px;
  min-width: 50px;
  border-radius: 50%;
  background-color: #18b718;
  display: flex;
  justify-content: center;
  align-items: center;
}

#videobtn {
  background-color: #18b718;
  border: none;
}

.sub-btn-div {
  position: absolute;
  top: -55px;
  width: 100%;
  right: 75px;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

.sub-btn-div-left {
  position: absolute;
  top: -55px;
  width: 100%;
  right: -75px !important;
  display: flex;
  flex-direction: column;
  align-items: flex-start !important;
}

.stickyIcon {
  margin-top: 30px;
}

.vcard11-icon-container {
  z-index: 9;
  position: absolute;
  right: 15px;
  top: 50%;
}

.vcard11-wp-btn {
  background-image: linear-gradient(123.62deg, #f59c37 0%, #fd5479 100%);
}

.card11-add-btn {
  width: 185px !important;
}

.audio-image {
  max-width: 100%;
  border-radius: 10px;
}

audio {
  width: 100%;
}

.object-fit-cover {
  -o-object-fit: cover;
     object-fit: cover;
}

.install-app {
  background-color: #FFD700;
  /* Yellow color */
  color: #000;
  /* Black text color */
  border: none;
  padding-left: 10px;
  padding-right: 10px;
  padding-top: 10px;
  padding-bottom: 10px;
  cursor: pointer;
  transition: background-color 0.3s ease, color 0.3s ease;
}

.install-app:hover {
  background-color: #0000FF;
  /* Blue color on hover */
  color: #FFF;
  /* White text color on hover */
}

/* VCardNEO shared polish for all public digital cards */
:root {
  --vneo-ink: #172033;
  --vneo-muted: #667085;
  --vneo-red: #e4232f;
  --vneo-teal: #11a8a5;
  --vneo-line: rgba(23, 32, 51, 0.12);
  --vneo-shadow: 0 18px 50px rgba(17, 24, 39, 0.16);
}

.dropdown-menu.lang-hover-list,
.language .dropdown-menu,
.lang-hover-list {
  border: 1px solid var(--vneo-line) !important;
  border-radius: 12px !important;
  padding: 8px !important;
  min-width: 210px !important;
  background: rgba(255, 255, 255, 0.98) !important;
  box-shadow: var(--vneo-shadow) !important;
  backdrop-filter: blur(12px);
}

.lang-head {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  border-radius: 999px !important;
  border: 1px solid rgba(255, 255, 255, 0.42);
  background: rgba(15, 23, 42, 0.72);
  color: #fff !important;
  font-weight: 700;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.2);
}

.lang-hover-list li,
.language .dropdown-menu li {
  border-radius: 10px !important;
  overflow: hidden;
}

.lang-hover-list li a,
.language .dropdown-menu li a {
  display: flex !important;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  padding: 9px 12px !important;
  color: var(--vneo-ink) !important;
  font-weight: 700;
  text-decoration: none !important;
}

.lang-hover-list li:hover,
.lang-hover-list li.active,
.language .dropdown-menu li:hover,
.language .dropdown-menu li.active {
  background: #f3f6fb !important;
}

.lang-hover-list img,
.language .dropdown-menu img {
  width: 22px !important;
  height: 22px !important;
  border-radius: 50%;
  object-fit: cover;
}

.add-contact-btn,
.install-app,
.share-wp-btn,
.vcard-btn-group,
.vcard-wp-btn,
.stickyIcon,
[class*="sticky-btn"] {
  transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease !important;
}

.add-contact-btn,
.install-app {
  border-radius: 999px !important;
  border: 0 !important;
  font-weight: 800 !important;
  letter-spacing: 0 !important;
  box-shadow: 0 14px 34px rgba(17, 24, 39, 0.18) !important;
}

.install-app {
  background: linear-gradient(135deg, var(--vneo-red), #ff6b35) !important;
  color: #fff !important;
}

.ios-install-guide {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: grid;
  place-items: end center;
  padding: 18px;
}

.ios-install-guide.d-none {
  display: none !important;
}

.ios-install-guide-open {
  overflow: hidden;
}

.ios-install-guide__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.58);
  backdrop-filter: blur(8px);
}

.ios-install-guide__panel {
  position: relative;
  width: min(420px, 100%);
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.7);
  background: #fff;
  color: var(--vneo-ink);
  box-shadow: 0 24px 80px rgba(15, 23, 42, 0.28);
  padding: 24px;
  animation: iosInstallSlideUp 0.22s ease-out;
}

.ios-install-guide__close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 50%;
  background: #f3f6fb;
  color: var(--vneo-ink);
  font-size: 24px;
  line-height: 1;
}

.ios-install-guide__icon {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--vneo-red), #ff6b35);
  color: #fff;
  font-size: 34px;
  font-weight: 800;
  margin-bottom: 14px;
}

.ios-install-guide h3 {
  margin: 0 34px 8px 0;
  color: var(--vneo-ink);
  font-size: 22px;
  line-height: 1.2;
  font-weight: 800;
}

.ios-install-guide p {
  margin: 0 0 16px;
  color: var(--vneo-muted);
  font-size: 15px;
  line-height: 1.5;
}

.ios-install-guide ol {
  margin: 0 0 18px;
  padding-left: 22px;
}

.ios-install-guide li {
  margin-bottom: 9px;
  color: var(--vneo-ink);
  font-weight: 700;
}

.ios-install-guide__button {
  width: 100%;
  min-height: 48px;
  border: 0;
  border-radius: 999px;
  background: var(--vneo-ink);
  color: #fff;
  font-weight: 800;
}

@keyframes iosInstallSlideUp {
  from {
    opacity: 0;
    transform: translateY(18px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.add-contact-btn:hover,
.install-app:hover,
.share-wp-btn:hover,
.vcard-btn-group:hover,
.vcard-wp-btn:hover,
[class*="sticky-btn"]:hover {
  transform: translateY(-2px);
  filter: saturate(1.08);
}

.icon-search-container {
  border: 1px solid var(--vneo-line);
  box-shadow: 0 14px 34px rgba(17, 24, 39, 0.14);
}

.icon-search-container.active {
  outline: 0;
  width: min(285px, calc(100vw - 34px));
}

.icon-search-container .search-input,
#wpNumber {
  font-size: 16px !important;
}

.modal .modal-dialog .modal-content {
  border-radius: 16px !important;
  overflow: hidden;
  box-shadow: 0 28px 80px rgba(17, 24, 39, 0.24) !important;
}

.modal .modal-dialog .modal-content .modal-header {
  background: linear-gradient(135deg, #f8fafc, #eef4f7);
}

.modal .modal-dialog .modal-content .modal-header .modal-title {
  color: var(--vneo-ink);
  font-weight: 900;
}

.modal .modal-dialog .modal-content .modal-body .form-control,
.modal .modal-dialog .modal-content .modal-body .input-box {
  border: 1px solid #d9e0ea !important;
  border-radius: 12px !important;
  background: #f8fafc !important;
}

.modal .modal-dialog .modal-content .modal-footer .submit-btn,
.modal .modal-dialog .modal-content .modal-footer .btn-primary {
  border-radius: 999px !important;
  background: linear-gradient(135deg, var(--vneo-red), #ff6b35) !important;
  border: 0 !important;
  font-weight: 800;
}

.share {
  border-radius: 14px;
}

.share:hover {
  transform: translateY(-2px);
}

@media (max-width: 575px) {
  .lang-head {
    min-height: 40px;
    padding: 8px 12px !important;
    font-size: 13px !important;
  }

  .dropdown-menu.lang-hover-list,
  .language .dropdown-menu,
  .lang-hover-list {
    min-width: min(230px, calc(100vw - 32px)) !important;
    max-height: 60vh;
    overflow-y: auto;
  }

  .add-contact-btn,
  .install-app {
    min-height: 44px;
    padding: 10px 16px !important;
  }

  .modal .modal-dialog {
    margin: 14px !important;
  }
}

.vneo-ai-chat {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 99998;
  font-family: inherit;
}

.vneo-ai-chat__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: min(154px, calc((100vw - 52px) / 2));
  height: 46px;
  min-height: 46px;
  max-width: none;
  padding: 7px 14px 7px 8px;
  border: 0;
  border-radius: 999px;
  color: #ffffff;
  background: linear-gradient(135deg, #111827, #e4232f 58%, #00a6a6);
  box-shadow: 0 18px 42px rgba(17, 24, 39, 0.26), 0 0 0 1px rgba(255, 255, 255, 0.12) inset;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: 0;
}

.vneo-ai-chat__button span:last-child {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.vneo-ai-chat__spark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 30px;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  color: #111827;
  background: #d8f35f;
  font-size: 12px;
  font-weight: 900;
}

.vneo-ai-chat__orb {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 42px;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  color: #111827;
  background: #d8f35f;
  font-size: 13px;
  font-weight: 900;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.18);
}

.add-to-contact-section {
  pointer-events: none;
  position: fixed !important;
  right: 18px !important;
  bottom: 18px !important;
  left: 18px !important;
  width: auto !important;
  padding: 0 !important;
  z-index: 99990 !important;
}

.add-to-contact-section .add-contact-btn,
.add-contact-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 7px !important;
  width: min(360px, calc(100vw - 36px)) !important;
  min-width: 0 !important;
  max-width: none !important;
  height: 54px !important;
  min-height: 54px !important;
  padding: 10px 24px !important;
  border-radius: 999px !important;
  line-height: 1.2 !important;
  text-align: center !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  pointer-events: auto;
  font-size: 16px !important;
  font-weight: 850 !important;
  letter-spacing: 0 !important;
  box-shadow: 0 16px 34px rgba(17, 24, 39, 0.2) !important;
}

.add-contact-btn i {
  flex: 0 0 auto;
  font-size: 14px !important;
}

.vneo-ai-chat__panel {
  position: absolute;
  right: 0;
  bottom: 66px;
  width: min(360px, calc(100vw - 24px));
  overflow: hidden;
  border: 1px solid rgba(17, 24, 39, 0.12);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 26px 70px rgba(17, 24, 39, 0.24);
}

.vneo-ai-chat__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px 16px;
  color: #ffffff;
  background: linear-gradient(135deg, #111827, #c1121f);
}

.vneo-ai-chat__header strong,
.vneo-ai-chat__header span {
  display: block;
  line-height: 1.25;
}

.vneo-ai-chat__header strong {
  font-size: 15px;
  font-weight: 900;
}

.vneo-ai-chat__header span {
  opacity: 0.82;
  font-size: 12px;
}

.vneo-ai-chat__close {
  width: 34px;
  height: 34px;
  border: 1px solid rgba(255, 255, 255, 0.25);
  border-radius: 50%;
  color: #ffffff;
  background: rgba(255, 255, 255, 0.14);
  font-size: 24px;
  line-height: 1;
}

.vneo-ai-chat__messages {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 320px;
  min-height: 160px;
  padding: 14px;
  overflow-y: auto;
  background: #f7f9fb;
}

.vneo-ai-chat__prompts {
  padding: 0 14px 14px;
  background: #f7f9fb;
}

.vneo-ai-chat__prompts > span {
  display: block;
  margin-bottom: 8px;
  color: #667085;
  font-size: 12px;
  font-weight: 800;
}

.vneo-ai-chat__prompts > div {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.vneo-ai-chat__prompt {
  min-height: 34px;
  padding: 7px 10px;
  border: 1px solid rgba(17, 24, 39, 0.1);
  border-radius: 999px;
  color: #253044;
  background: #ffffff;
  font-size: 12px;
  font-weight: 800;
  box-shadow: 0 8px 18px rgba(17, 24, 39, 0.06);
}

.vneo-ai-chat__prompt:hover {
  border-color: rgba(228, 35, 47, 0.35);
  color: #111827;
  background: #fff8f8;
}

.vneo-ai-chat__message {
  max-width: 88%;
  padding: 10px 12px;
  border-radius: 14px;
  font-size: 14px;
  line-height: 1.45;
  color: #111827;
  background: #ffffff;
  box-shadow: 0 8px 22px rgba(17, 24, 39, 0.08);
  white-space: pre-wrap;
}

.vneo-ai-chat__message--user {
  align-self: flex-end;
  color: #ffffff;
  background: #c1121f;
}

.vneo-ai-chat__form {
  display: flex;
  gap: 8px;
  padding: 12px;
  border-top: 1px solid #e5e7eb;
  background: #ffffff;
}

.vneo-ai-chat__form input {
  min-width: 0;
  flex: 1;
  height: 42px;
  border: 1px solid #d8dee8;
  border-radius: 999px;
  padding: 0 14px;
  color: #111827;
  background: #ffffff;
  font-size: 14px;
  outline: none;
}

.vneo-ai-chat__form input:focus {
  border-color: #c1121f;
  box-shadow: 0 0 0 3px rgba(193, 18, 31, 0.12);
}

.vneo-ai-chat__form button {
  height: 42px;
  border: 0;
  border-radius: 999px;
  padding: 0 15px;
  color: #ffffff;
  background: #111827;
  font-size: 13px;
  font-weight: 800;
}

.vneo-ai-chat__form--loading button,
.vneo-ai-chat__form--loading input {
  opacity: 0.68;
  pointer-events: none;
}

@media (max-width: 575px) {
  .vneo-ai-chat {
    right: 12px;
    bottom: 76px;
    left: auto;
  }

  .vneo-ai-chat__button {
    margin-left: auto;
    width: min(142px, calc((100vw - 40px) / 2));
    height: 44px;
    min-height: 44px;
    padding: 7px 12px 7px 7px;
  }

  .vneo-ai-chat__panel {
    right: 0;
    bottom: 64px;
    width: min(360px, calc(100vw - 24px));
  }

  .vneo-ai-chat__messages {
    max-height: 46vh;
  }

  .sticky-vcard-div,
  .add-to-contact-section {
    z-index: 99990 !important;
    left: 12px !important;
    right: 12px !important;
    bottom: 82px !important;
    padding: 0 !important;
  }

  .add-to-contact-section .add-contact-btn,
  .add-contact-btn {
    width: min(360px, calc(100vw - 24px)) !important;
    height: 52px !important;
    min-height: 52px !important;
    padding: 10px 22px !important;
    font-size: 15px !important;
  }
}

/* Final language switcher override: remove template button backgrounds. */
.language,
.vcard11-language {
  position: fixed !important;
  top: 8px !important;
  right: 8px !important;
  z-index: 9992 !important;
  width: max-content !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1 !important;
}

.language .lang-head,
.language ul .lang-list .lang-head,
.vcard11-language .dropbtn,
.top-header .vcard11-language .dropbtn,
.city-lang {
  --bs-btn-bg: transparent !important;
  --bs-btn-border-color: transparent !important;
  --bs-btn-hover-bg: transparent !important;
  --bs-btn-hover-border-color: transparent !important;
  --bs-btn-active-bg: transparent !important;
  --bs-btn-active-border-color: transparent !important;
  width: 32px !important;
  min-width: 32px !important;
  max-width: 32px !important;
  height: 32px !important;
  min-height: 32px !important;
  padding: 0 !important;
  margin: 0 !important;
  gap: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  outline: 0 !important;
  color: transparent !important;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  text-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: visible !important;
  font-size: 0 !important;
  line-height: 1 !important;
  appearance: none !important;
  -webkit-appearance: none !important;
}

.language .lang-list,
.language ul .lang-list,
.vcard-three .language ul .lang-list {
  width: 32px !important;
  min-width: 32px !important;
  max-width: 32px !important;
  height: 32px !important;
  min-height: 32px !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  outline: 0 !important;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  display: block !important;
  overflow: visible !important;
}

.language .lang-list:hover,
.language .lang-list:focus,
.language .lang-list:active,
.language ul .lang-list:hover,
.language ul .lang-list:focus,
.language ul .lang-list:active,
.vcard-three .language ul .lang-list:hover,
.vcard-three .language ul .lang-list:focus,
.vcard-three .language ul .lang-list:active {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
}

.language .lang-list .lang-hover-list,
.language .lang-list .dropdown-menu,
.vcard-three .language ul .lang-list .lang-hover-list {
  width: auto !important;
  min-width: 158px !important;
  max-width: min(220px, calc(100vw - 24px)) !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 8px !important;
  margin-top: 8px !important;
  background: rgba(255, 255, 255, .98) !important;
  box-shadow: 0 14px 34px rgba(15, 23, 42, .18) !important;
  border-radius: 10px !important;
}

.language .lang-head:hover,
.language .lang-head:focus,
.language .lang-head:active,
.language ul .lang-list .lang-head:hover,
.language ul .lang-list .lang-head:focus,
.language ul .lang-list .lang-head:active,
.vcard11-language .dropbtn:hover,
.vcard11-language .dropbtn:focus,
.vcard11-language .dropbtn:active,
.top-header .vcard11-language .dropbtn:hover,
.top-header .vcard11-language .dropbtn:focus,
.top-header .vcard11-language .dropbtn:active,
.city-lang:hover,
.city-lang:focus,
.city-lang:active {
  color: transparent !important;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

.language .lang-head i,
.language ul .lang-list .lang-head i,
.vcard11-language .dropbtn i,
.top-header .vcard11-language .dropbtn i,
.city-lang i,
.vcard11-language .dropbtn .fa-sort-down {
  display: none !important;
}

.language .lang-head::before,
.language ul .lang-list .lang-head::before,
.vcard11-language .dropbtn::before,
.top-header .vcard11-language .dropbtn::before,
.city-lang::before {
  content: "" !important;
  width: 32px !important;
  height: 32px !important;
  display: block !important;
  flex: 0 0 32px !important;
  background: url("../img/translate-language-icon.svg") center / contain no-repeat !important;
}

.language .lang-head::after,
.language ul .lang-list .lang-head::after,
.city-lang::after {
  display: none !important;
}

@media (min-width: 1200px) {
  .vcard11-language .dropbtn.d-xl-block {
    display: inline-flex !important;
  }

  .vcard11-language .dropbtn.d-xl-none {
    display: none !important;
  }
}

@media (min-width: 992px) {
  .vcard11-language .dropbtn.d-lg-block {
    display: inline-flex !important;
  }

  .vcard11-language .dropbtn.d-lg-none {
    display: none !important;
  }
}

@media (max-width: 991.98px) {
  .vcard11-language .dropbtn.d-lg-none {
    display: inline-flex !important;
  }

  .vcard11-language .dropbtn.d-lg-block {
    display: none !important;
  }
}

@media (max-width: 1199.98px) {
  .language .lang-head,
  .language ul .lang-list .lang-head,
  .vcard11-language .dropbtn,
  .top-header .vcard11-language .dropbtn,
  .city-lang {
    width: 32px !important;
    min-width: 32px !important;
    max-width: 32px !important;
    height: 32px !important;
    min-height: 32px !important;
    padding: 0 !important;
    font-size: 0 !important;
  }

  .vcard11-language .dropbtn.d-xl-none {
    display: inline-flex !important;
  }

  .vcard11-language .dropbtn.d-xl-block {
    display: none !important;
  }
}

/* Strong template-wide language icon reset. Must stay at the end of the file. */
html body [class] [class] .language ul .lang-list,
html body [class] .language ul .lang-list,
html body .language ul .lang-list,
html body .language .lang-list,
html body .vcard11-language {
  width: 32px !important;
  min-width: 32px !important;
  max-width: 32px !important;
  height: 32px !important;
  min-height: 32px !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  outline: 0 !important;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  overflow: visible !important;
}

html body [class] [class] .language ul .lang-list:hover,
html body [class] [class] .language ul .lang-list:focus,
html body [class] [class] .language ul .lang-list:active,
html body [class] .language ul .lang-list:hover,
html body [class] .language ul .lang-list:focus,
html body [class] .language ul .lang-list:active,
html body .language ul .lang-list:hover,
html body .language ul .lang-list:focus,
html body .language ul .lang-list:active {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
}

html body [class] [class] .language ul .lang-list .lang-head,
html body [class] .language ul .lang-list .lang-head,
html body .language ul .lang-list .lang-head,
html body .language .lang-head,
html body .vcard11-language .dropbtn,
html body .top-header .vcard11-language .dropbtn,
html body .city-lang {
  width: 32px !important;
  min-width: 32px !important;
  max-width: 32px !important;
  height: 32px !important;
  min-height: 32px !important;
  padding: 0 !important;
  margin: 0 !important;
  gap: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  outline: 0 !important;
  color: transparent !important;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  text-shadow: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: visible !important;
  font-size: 0 !important;
  line-height: 1 !important;
}

html body [class] [class] .language ul .lang-list .lang-head:hover,
html body [class] [class] .language ul .lang-list .lang-head:focus,
html body [class] [class] .language ul .lang-list .lang-head:active,
html body [class] .language ul .lang-list .lang-head:hover,
html body [class] .language ul .lang-list .lang-head:focus,
html body [class] .language ul .lang-list .lang-head:active,
html body .language ul .lang-list .lang-head:hover,
html body .language ul .lang-list .lang-head:focus,
html body .language ul .lang-list .lang-head:active,
html body .vcard11-language .dropbtn:hover,
html body .vcard11-language .dropbtn:focus,
html body .vcard11-language .dropbtn:active,
html body .city-lang:hover,
html body .city-lang:focus,
html body .city-lang:active {
  color: transparent !important;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
}

html body [class] [class] .language ul .lang-list .lang-head i,
html body [class] .language ul .lang-list .lang-head i,
html body .language ul .lang-list .lang-head i,
html body .vcard11-language .dropbtn i,
html body .city-lang i {
  display: none !important;
}

html body [class] [class] .language ul .lang-list .lang-head::before,
html body [class] .language ul .lang-list .lang-head::before,
html body .language ul .lang-list .lang-head::before,
html body .language .lang-head::before,
html body .vcard11-language .dropbtn::before,
html body .top-header .vcard11-language .dropbtn::before,
html body .city-lang::before {
  content: "" !important;
  width: 32px !important;
  height: 32px !important;
  display: block !important;
  flex: 0 0 32px !important;
  background: url("../img/translate-language-icon.svg") center / contain no-repeat !important;
}

html body [class] [class] .language ul .lang-list .lang-head::after,
html body [class] .language ul .lang-list .lang-head::after,
html body .language ul .lang-list .lang-head::after,
html body .language .lang-head::after,
html body .city-lang::after {
  display: none !important;
}

html body [class] [class] .language ul .lang-list .lang-hover-list,
html body [class] [class] .language ul .lang-list .dropdown-menu,
html body [class] .language ul .lang-list .lang-hover-list,
html body [class] .language ul .lang-list .dropdown-menu,
html body .language ul .lang-list .lang-hover-list,
html body .language ul .lang-list .dropdown-menu {
  width: auto !important;
  min-width: 158px !important;
  max-width: min(220px, calc(100vw - 24px)) !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 8px !important;
  margin-top: 8px !important;
  background: rgba(255, 255, 255, .98) !important;
  background-color: rgba(255, 255, 255, .98) !important;
  box-shadow: 0 14px 34px rgba(15, 23, 42, .18) !important;
  border-radius: 10px !important;
}
