heading#h-0001,
heading#h-0002,
heading#h-0003,
heading#h-0004,
heading#h-0005,
heading#h-0006,
heading#h-0007 {
  font-weight: bold;
  font-size: 1rem;
}

heading#h-0002,
heading#h-0003,
heading#h-0004,
heading#h-0005,
heading#h-0006,
heading#h-0007 {
  padding-top: 1rem;
  width: 100%;
  display: block;
}

.figure-callout {
  cursor: pointer;
}

#figures-wrapper {
  position: absolute;
  background: rgba(0, 0, 0, 0.8);
  z-index: 9999999999;
  left: 0;
  top: 100px;
  width: 100vw;
  min-height: 100vh;
}
#figures-wrapper #figures-container {
  max-height: 100vh;
  overflow: scroll;
  padding-bottom: 2rem;
}
#figures-wrapper .btn-close {
  filter: invert(1);
  opacity: 1;
  transform: scale(1.5);
}
#figures-wrapper .btn-close:hover {
  filter: invert(0.8);
}

.classification-tree .style-scope.concept-mention {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 3px !important;
}
.classification-tree svg.style-scope.iron-icon {
  width: 1rem !important;
  height: 1rem !important;
  color: var(--bs-primary) !important;
}

.more.style-scope.classification-viewer {
  display: none !important;
}

span.google-src-text.style-scope.patent-text {
  display: none !important;
}

/** tagging plugin */
.tags-height .ts-control > input {
  font-size: var(--bs-body-font-size) !important;
}
.tags-height .no-results {
  display: none !important;
}
.tags-height .ts-wrapper.multi .ts-control > div {
  padding: 6px 7px !important;
}
.tags-height .ts-wrapper.form-control,
.tags-height .ts-wrapper.form-select {
  align-items: baseline;
  min-height: 200px !important;
}
.tags-height .ts-control {
  display: flex !important;
  height: 200px !important;
  align-content: baseline !important;
}

.nav-tabs .nav-link.active,
.nav-tabs .nav-item.show .nav-link {
  background: #fff !important;
}

/**
 * Style for loading screen
 */
#loading-screen,
#progress-loading-screen {
  background: rgba(0, 0, 0, 0.8) !important;
  z-index: 999999999;
}
#loading-screen .spinner-grow,
#progress-loading-screen .spinner-grow {
  width: 10px;
  height: 10px;
}

/**
 * swal
 **/
.sa-button-container {
  display: flex;
  gap: 5px;
  justify-content: flex-end;
  padding: 1rem !important;
  border: solid 1px #dee2e6 !important;
}
.sa-button-container .btn,
.sa-button-container .sa-confirm-button-container {
  white-space: nowrap;
  font-size: 0.9rem !important;
  font-weight: 400 !important;
  line-height: 1.6 !important;
}

.sweet-alert {
  padding: 0 !important;
  border-radius: 0.5rem !important;
}
.sweet-alert .lead {
  font-size: 0.9rem !important;
  padding-left: 1rem !important;
  padding-right: 1rem !important;
}
.sweet-alert h2 {
  font-size: 1.125rem !important;
  padding-left: 1rem !important;
  padding-right: 1rem !important;
}
.sweet-alert .sa-icon {
  scale: 0.8;
  margin-bottom: 10px;
}

.patent-thumbnail {
  width: 100%;
  max-width: 200px;
}
.patent-thumbnail img {
  width: 100%;
  aspect-ratio: 1;
  -o-object-fit: contain;
     object-fit: contain;
  border: solid 1px var(--bs-border-color);
  border-radius: var(--bs-border-radius);
}

.figures-slider {
  width: 100%;
  max-width: 200px;
}
.figures-slider .figures-container {
  flex-wrap: nowrap;
  display: inline-flex;
}
.figures-slider .figure-small {
  width: 75px;
  overflow: scroll;
  margin-right: 5px;
}
.figures-slider .figure-small img {
  width: 75px;
  height: 80px;
  -o-object-fit: contain;
     object-fit: contain;
  border: solid 1px var(--bs-border-color);
  border-radius: var(--bs-border-radius);
}
.figures-slider::-webkit-scrollbar {
  display: none;
}

.swiper-button-next {
  right: 0;
  border-radius: 3px;
  background-color: rgba(0, 0, 0, 0.1);
}
.swiper-button-next::after {
  color: var(--bs-primary) !important;
  font-size: 20px;
}

.swiper-button-prev {
  left: 0;
  border-radius: 3px;
  background-color: rgba(0, 0, 0, 0.1);
}
.swiper-button-prev::after {
  color: var(--bs-primary) !important;
  font-size: 18px;
}

.vanilla-lightbox.show {
  z-index: 999;
}

.small-image-container img {
  width: 100%;
  max-width: 200px;
  height: 140px;
  -o-object-fit: contain;
     object-fit: contain;
}

@media screen and (max-width: 550px) {
  .xs-border-none {
    border: 0 !important;
  }
  .figures-slider {
    width: 100%;
  }
}
.nav-wrap {
  overflow: auto;
}
.nav-wrap .nav-tabs {
  min-width: 750px;
}

.expandable {
  max-height: 250px !important;
  overflow: hidden;
  position: relative;
}
.expandable::after {
  content: "";
  height: 0px;
  width: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  box-shadow: 0px 0px 20px 15px #fff;
}
.expandable.expand {
  max-height: 100% !important;
  box-shadow: none;
}
.expandable.expand::after {
  box-shadow: none !important;
}

@keyframes skeleton-loading {
  0% {
    background-color: hsl(200, 20%, 80%);
  }
  100% {
    background-color: hsl(200, 20%, 95%);
  }
}
.placeholder {
  display: flex;
  border-radius: 4px;
  height: 18px;
  width: 50px;
  animation: skeleton-loading 1s linear infinite alternate;
}

.container-md {
  max-width: 980px;
}

.bg {
  background-image: url(/assets/images/bg.svg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
}

.navbar.public {
  position: fixed;
  width: 100%;
  top: 0;
  z-index: 99;
}
.navbar .nav-link {
  font-weight: 500 !important;
}
.navbar .nav-link:hover {
  color: var(--bs-primary) !important;
}

/**
 * Add bouncing animation .cta svg
 **/
@keyframes bounce {
  0%, 20%, 50%, 80%, 100% {
    transform: translateY(0);
  }
  40% {
    transform: translateY(-6px);
  }
  60% {
    transform: translateY(-3px);
  }
}
.cta {
  display: flex !important;
  justify-content: center !important;
  border-top: 2px solid rgba(107, 110, 115, 0.1) !important;
  margin-top: 100px !important;
  flex-direction: column !important;
  align-items: center !important;
  padding-top: 50px;
}
.cta a {
  display: flex !important;
  flex-direction: column !important;
  text-decoration: none !important;
}
.cta a svg {
  height: 24px;
}
.cta a svg:not(:first-child) {
  margin-top: -11px !important;
}

.patent-tab-group {
  max-width: 100%;
  overflow: auto;
}

.tab-list-patent {
  display: flex;
  flex-wrap: nowrap;
}
.tab-list-patent li a {
  white-space: nowrap;
}

@media (min-width: 576px) {
  .border-md-end {
    border-right: 1px solid #dee2e6 !important;
  }
}

.w-0 {
  width: 0px;
}

.navbar.landing:has(.show) {
  background: #fff !important;
}

@keyframes skeleton-loading {
  0% {
    background-color: hsl(200, 20%, 80%);
  }
  100% {
    background-color: hsl(200, 20%, 95%);
  }
}
.content-placeholder-parent {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  justify-content: flex-start;
  align-items: center;
}
.content-placeholder-parent .content-placeholder {
  width: 100%;
  max-width: 100%;
  height: 10px;
  border-radius: 0.5rem;
  background: #f8f9fa;
  animation: skeleton-loading 1s linear infinite alternate;
}

.search-wrap {
  max-width: 980px;
}

.sweet-alert.show-input {
  padding-top: 30px !important;
}

.image-drawings {
  height: 150px;
  width: 150px;
}
@media screen and (max-width: 550px) {
  .image-drawings {
    height: 100px;
    width: 48%;
  }
}

.dropdpwn-no-caret.dropdown-toggle {
  border-left: 1px solid rgba(255, 255, 255, 0.1);
}
.dropdpwn-no-caret.dropdown-toggle::after {
  display: none !important;
}

#helpdesk {
  position: fixed;
  z-index: 9999;
  bottom: 10px;
  right: 10px;
}

.floating-chat {
  z-index: 999;
  position: fixed;
  bottom: 20px;
  right: 50px;
}
.floating-chat.show {
  display: block !important;
}
.floating-chat.show .chat-form {
  display: block;
}
.floating-chat.show .chat-icon-show {
  display: block;
}
.floating-chat.show .chat-icon-hide {
  display: none;
}
.floating-chat .btn-trigger {
  height: 55px;
  width: 55px;
  position: relative;
  z-index: 12;
  display: flex;
  justify-content: center;
  align-items: center;
}
.floating-chat .btn-trigger i {
  font-size: 32px;
}
.floating-chat .chat-form {
  position: absolute;
  bottom: 70px;
  width: 360px;
  right: 0;
  border: 1px solid rgba(0, 0, 0, 0.125);
  box-shadow: 0px 0px 20px 1px rgba(var(--raw-rgb-primary), 0.2);
  display: none;
}
.floating-chat .chat-form .chat-container {
  max-width: 500px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}
.floating-chat .chat-icon-show {
  display: none;
}
.floating-chat .chat-icon-hide {
  display: block;
}
@media (max-width: 767.98px) {
  .floating-chat {
    bottom: 20px;
    right: 20px;
  }
  .floating-chat .chat-form {
    position: fixed;
    top: 0;
    height: 100%;
    left: 0;
    width: 100vw;
  }
}

#helpdesk {
  position: fixed;
  z-index: 9999;
  bottom: 10px;
  right: 10px;
}

.floating-chat {
  z-index: 999;
  position: fixed;
  bottom: 20px;
  right: 50px;
}
.floating-chat.show {
  display: block !important;
}
.floating-chat.show .chat-form {
  display: block;
}
.floating-chat.show .chat-icon-show {
  display: block;
}
.floating-chat.show .chat-icon-hide {
  display: none;
}
.floating-chat .btn-trigger {
  height: 55px;
  width: 55px;
  position: relative;
  z-index: 12;
  display: flex;
  justify-content: center;
  align-items: center;
}
.floating-chat .btn-trigger i {
  font-size: 32px;
}
.floating-chat .chat-form {
  position: absolute;
  bottom: 70px;
  width: 360px;
  right: 0;
  border: 1px solid rgba(0, 0, 0, 0.125);
  box-shadow: 0px 0px 20px 1px rgba(var(--raw-rgb-primary), 0.2);
  display: none;
}
.floating-chat .chat-form .chat-container {
  max-width: 500px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}
.floating-chat .chat-icon-show {
  display: none;
}
.floating-chat .chat-icon-hide {
  display: block;
}
@media (max-width: 767.98px) {
  .floating-chat {
    bottom: 20px;
    right: 20px;
  }
  .floating-chat .chat-form {
    position: fixed;
    top: 0;
    height: 100%;
    left: 0;
    width: 100vw;
  }
}

body {
  padding: 0 !important;
  margin: 0 !important;
}

.loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.9);
  z-index: 9999;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}

.progress-loading {
  width: 300px;
}

.drawing-image-link {
  width: 100%;
  max-height: 465px;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center;
     object-position: center;
}

.btn.btn-primary {
  background: linear-gradient(90deg, #ee4c2c 0%, #fc690d 100%) !important;
  transition: all 0.3s ease-in-out !important;
}
.btn.btn-primary:hover {
  background: linear-gradient(90deg, #ee4c2c 0%, #fc690d 80%) !important;
}

.text-title {
  font-size: 50px !important;
  font-weight: 700 !important;
}

.text-subtitle {
  font-size: 28px !important;
  font-weight: 600 !important;
}

.form-control-input-base-prompt {
  background: rgba(184, 184, 184, 0.5) !important;
  border-radius: 20px !important;
  background-color: rgba(184, 184, 184, 0.5) !important;
  padding: 20px;
  resize: none;
}
.form-control-input-base-prompt:focus {
  background: rgba(184, 184, 184, 0.5) !important;
}
.form-control-input-base-prompt::-moz-placeholder {
  color: #777777 !important;
}
.form-control-input-base-prompt::placeholder {
  color: #777777 !important;
}

.btn-start-search-span {
  border-radius: var(--bs-border-radius) !important;
}

@media screen and (min-width: 767px) {
  .navbar-nav {
    flex-direction: row !important;
  }
  .navbar-nav .nav-link:not(.btn) {
    color: rgb(var(--bs-secondary-rgb)) !important;
    padding-top: 0 !important;
  }
  .navbar-nav.navbar-left .nav-item:not(:first-child) {
    position: relative;
    display: flex;
    align-items: center;
  }
  .navbar-nav.navbar-left .nav-item:not(:first-child)::before {
    content: "";
    width: 1px;
    height: 10px;
    background-color: rgba(var(--bs-secondary-rgb), 0.2);
    position: absolute;
    left: -2px;
    top: 50%;
    transform: translateY(-50%);
  }
  .navbar-nav.navbar-left .nav-item:not(:first-child) .nav-link {
    padding-top: 0 !important;
  }
}
.fs-8 {
  font-size: 8px !important;
}

.fs-9 {
  font-size: 9px !important;
}

.fs-10 {
  font-size: 10px !important;
}

.fs-11 {
  font-size: 11px !important;
}

.fs-12 {
  font-size: 12px !important;
}

.fs-13 {
  font-size: 13px !important;
}

.fs-14 {
  font-size: 14px !important;
}

.fs-15 {
  font-size: 15px !important;
}

.fs-16 {
  font-size: 16px !important;
}

.fs-17 {
  font-size: 17px !important;
}

.fs-18 {
  font-size: 18px !important;
}

.fs-19 {
  font-size: 19px !important;
}

.fs-20 {
  font-size: 20px !important;
}

.fs-21 {
  font-size: 21px !important;
}

.fs-22 {
  font-size: 22px !important;
}

.fs-23 {
  font-size: 23px !important;
}

.fs-24 {
  font-size: 24px !important;
}

.fs-25 {
  font-size: 25px !important;
}

.fs-26 {
  font-size: 26px !important;
}

.fs-27 {
  font-size: 27px !important;
}

.fs-28 {
  font-size: 28px !important;
}

.fs-29 {
  font-size: 29px !important;
}

.fs-30 {
  font-size: 30px !important;
}

.fs-31 {
  font-size: 31px !important;
}

.fs-32 {
  font-size: 32px !important;
}

.fs-33 {
  font-size: 33px !important;
}

.fs-34 {
  font-size: 34px !important;
}

.fs-35 {
  font-size: 35px !important;
}

.fs-36 {
  font-size: 36px !important;
}

.fs-37 {
  font-size: 37px !important;
}

.fs-38 {
  font-size: 38px !important;
}

.fs-39 {
  font-size: 39px !important;
}

.fs-40 {
  font-size: 40px !important;
}

.fs-41 {
  font-size: 41px !important;
}

.fs-42 {
  font-size: 42px !important;
}

.fs-43 {
  font-size: 43px !important;
}

.fs-44 {
  font-size: 44px !important;
}

.fs-45 {
  font-size: 45px !important;
}

.fs-46 {
  font-size: 46px !important;
}

.fs-47 {
  font-size: 47px !important;
}

.fs-48 {
  font-size: 48px !important;
}

.fs-49 {
  font-size: 49px !important;
}

.fs-50 {
  font-size: 50px !important;
}

.fs-51 {
  font-size: 51px !important;
}

.fs-52 {
  font-size: 52px !important;
}

.fs-53 {
  font-size: 53px !important;
}

.fs-54 {
  font-size: 54px !important;
}

.fs-55 {
  font-size: 55px !important;
}

.fs-56 {
  font-size: 56px !important;
}

.fs-57 {
  font-size: 57px !important;
}

.fs-58 {
  font-size: 58px !important;
}

.fs-59 {
  font-size: 59px !important;
}

.fs-60 {
  font-size: 60px !important;
}

.text-xs {
  font-size: 12px !important;
}

.text-sm {
  font-size: 14px !important;
}

.text-lg {
  font-size: 18px !important;
}

.main-footer {
  background: linear-gradient(to right, #ef4d2d, #fc690e);
}
.main-footer.auth {
  background: #fff !important;
  border-top: unset !important;
}
.main-footer.auth li a {
  color: #333333 !important;
}
.main-footer.auth .copy {
  background-color: #fff7f4 !important;
}
.main-footer.auth .copy * {
  color: #fc690d !important;
}
.main-footer * {
  color: #fff !important;
}
.main-footer p,
.main-footer span {
  opacity: 0.8;
}
.main-footer .about {
  max-width: 322px;
}
.main-footer .about img {
  filter: brightness(0) invert(1);
  margin-bottom: 40px;
}
.main-footer .navs {
  display: flex;
  flex-direction: row;
  margin-left: auto;
  margin-top: 50px;
}
.main-footer .navs ul {
  display: flex;
  list-style: none;
  gap: 15px;
}
.main-footer .navs ul li a {
  text-decoration: none;
  font-weight: 600;
}
.main-footer .navs ul li a:hover {
  opacity: 0.8;
}
.main-footer .copy {
  background-color: rgba(0, 0, 0, 0.3);
  padding: 10px 20px;
  border-radius: 6.7px;
  display: flex;
  align-items: center;
}
.main-footer .copy ul {
  list-style: none;
  display: flex;
  gap: 8px;
}
.main-footer .copy ul li a {
  text-decoration: none;
}

.cursor-pointer {
  cursor: pointer;
}

@media screen and (min-width: 768px) {
  .w-md-auto {
    width: auto !important;
  }
}

.socialite-rows a {
  border: 1px solid #ebeff6 !important;
  padding: 8px 12px !important;
  color: #5c5c5c !important;
  border-radius: 10px !important;
}
.socialite-rows a:hover {
  background-color: transparent !important;
}
.socialite-rows a:hover svg {
  opacity: 0.8;
}

body.auth-page form {
  width: 450px !important;
}

@media screen and (min-width: 768px) {
  .navbar.public .navbar-nav {
    margin-top: 5px !important;
  }
  .navbar.public .navbar-nav a {
    font-weight: 600 !important;
  }
}
.material-field {
  position: relative;
  margin: 1.5rem 0;
}

.material-field input,
.material-field textarea {
  width: 100%;
  border: 1.8px solid #dddddd;
  border-radius: 4px;
  padding: 12px 40px 6px 12px !important;
  font-size: 16px;
  outline: none;
  background-color: #fff;
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
  resize: vertical;
  height: 56px;
}

.material-field textarea {
  height: auto;
  min-height: 56px;
}

.material-field label {
  position: absolute;
  left: 12px;
  top: -9px !important;
  background: #fff;
  color: #23262c;
  font-size: 13px;
  padding: 0 4px;
  pointer-events: none;
  transition: all 0.25s ease;
}

.material-field input:focus,
.material-field textarea:focus {
  border-color: var(--bs-primary);
  box-shadow: 0 0 0 3px rgba(13, 110, 253, 0.1);
}

.material-field input.is-invalid,
.material-field textarea.is-invalid {
  border-color: #dc3545;
  box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.1);
}

.material-field input.is-invalid + label,
.material-field textarea.is-invalid + label {
  color: #dc3545;
}

.material-input-error {
  font-size: 0.875rem;
  color: #dc3545;
  margin-top: 5px;
}

.material-field .toggle-password {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  border: none;
  background: none;
  cursor: pointer;
  color: #6c757d;
  font-size: 20px;
  padding: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.material-field .toggle-password:hover {
  color: var(--bs-primary);
}

.material-field .file-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  border: 1.8px solid #dddddd;
  border-radius: 4px;
  height: 56px;
  padding: 0 12px;
  cursor: pointer;
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}

.material-field .file-wrapper:hover {
  border-color: var(--bs-primary);
}

.material-field .file-wrapper input[type=file] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.material-field .file-label {
  color: #6c757d;
  flex: 1;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.material-field .file-btn {
  background: var(--bs-primary);
  color: #fff;
  padding: 6px 14px;
  border-radius: 4px;
  font-size: 14px;
  white-space: nowrap;
}

.form-check {
  padding-left: 0 !important;
}

.form-check .form-check-input {
  position: absolute;
  width: 20px;
  height: 20px;
  margin: 0;
  opacity: 0;
  cursor: pointer;
  z-index: 2; /* ensure it's above pseudo-elements */
}

.form-check .form-check-label {
  position: relative;
  padding-left: 28px;
  line-height: 20px;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

/* Make the pseudo elements ignore pointer events */
.form-check .form-check-label::before,
.form-check .form-check-label::after {
  pointer-events: none;
}

.form-check .form-check-label::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 20px;
  height: 20px;
  border-radius: 6px;
  border: 2px solid transparent;
  background: linear-gradient(#fff, #fff) padding-box, linear-gradient(45deg, #EE4C2C, #FC690D) border-box;
  transition: box-shadow 0.2s ease;
}

.form-check .form-check-input[type=radio] + .form-check-label::before {
  border-radius: 50%;
}

.form-check .form-check-label::after {
  content: "\eb7b";
  position: absolute;
  left: 0;
  top: 0;
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
  font-family: remixicon !important;
  background: linear-gradient(45deg, #EE4C2C, #FC690D);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  opacity: 0;
  transform: scale(0.9);
  transition: opacity 0.15s ease, transform 0.15s ease;
}

.form-check .form-check-input:checked + .form-check-label::after {
  opacity: 1;
  transform: scale(1);
}

.form-check .form-check-input[type=radio]:checked + .form-check-label::after {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: linear-gradient(45deg, #EE4C2C, #FC690D);
  left: 5px;
  top: 5px;
  transform: scale(1);
  opacity: 1;
}

.form-check .form-check-input:focus-visible + .form-check-label::before {
  box-shadow: 0 0 0 3px rgba(255, 134, 102, 0.35);
}

.form-check .form-check-input:disabled + .form-check-label {
  opacity: 0.6;
  cursor: not-allowed;
}

/* ==========================================================================
   1. Configuration & Helpers
   ========================================================================== */
#start-search .container, #why-choose .container, #smart .container {
  background-repeat: no-repeat;
  background-size: cover;
  border-radius: 20px;
}

/* ==========================================================================
   2. General & Typographic Styles
   ========================================================================== */
section h2 {
  font-size: 40px !important;
}
@media screen and (max-width: 767px) {
  section h2 {
    font-size: 28px !important;
  }
  section .text-subtitle,
  section h3,
  section h4 {
    font-size: 16px !important;
  }
}

/* ==========================================================================
   3. Section & Component Styles
   ========================================================================== */
#hero {
  background: url("/assets/images/home/background.png") no-repeat center/cover;
  padding-top: 13%;
}
@media screen and (max-width: 992px) {
  #hero {
    padding-top: 25%;
    min-height: unset;
    padding-bottom: 1rem;
  }
}
@media screen and (max-width: 767px) {
  #hero h1 {
    font-size: 32px !important;
  }
  #hero .cta {
    padding-top: 0 !important;
    border-top: unset !important;
    margin-top: 40px !important;
  }
}
@media screen and (max-width: 992px) {
  #hero .cta {
    padding-top: 5%;
  }
}
#hero .arrow-down-indicator {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 0.35rem;
}
#hero .arrow-down-indicator .arrow-item {
  display: inline-flex;
  opacity: 0.1;
  animation: 700ms ease-in-out infinite both;
}
#hero .arrow-down-indicator .arrow-item:not(:first-child) {
  margin-top: -18px;
}
#hero .arrow-down-indicator .arrow-item svg {
  display: block;
}
#hero .arrow-down-indicator .arrow-item:nth-child(1) {
  animation-name: arrow-seq-1;
}
#hero .arrow-down-indicator .arrow-item:nth-child(2) {
  animation-name: arrow-seq-2;
}
#hero .arrow-down-indicator .arrow-item:nth-child(3) {
  animation-name: arrow-seq-3;
}
#hero .arrow-down-indicator .arrow-item:nth-child(4) {
  animation-name: arrow-seq-4;
}

#smart .container {
  background-image: linear-gradient(to top, rgba(252, 105, 13, 0.2), transparent);
}
@media screen and (min-width: 768px) {
  #smart .container .wrapper {
    padding-top: 100px;
  }
}
#smart .container .wrapper .row {
  align-items: center;
  justify-content: center;
}
#smart .container .wrapper .text-group {
  padding-right: 100px;
}
@media screen and (max-width: 767px) {
  #smart .container .wrapper .text-group {
    padding-right: 0 !important;
  }
}
#smart .container .wrapper .text-group h2 {
  font-size: 40px;
  font-weight: 900 !important;
}
#smart .container .wrapper img {
  max-height: 490px;
  max-width: 424px;
}
@media screen and (max-width: 767px) {
  #smart .container .wrapper img {
    height: 100%;
    width: 100%;
    -o-object-fit: contain;
       object-fit: contain;
  }
}
#smart .container .progress-group {
  width: 100%;
  gap: 20px;
  justify-content: center;
  align-items: center;
}
#smart .container .progress-group span {
  white-space: nowrap;
}
#smart .container .progress-group .progress-itm {
  width: 100%;
  display: flex;
  height: 5px;
  background: rgba(107, 110, 115, 0.1);
}
#smart .container .progress-group .progress-itm .progress-inner {
  height: 5px;
  background: linear-gradient(90deg, #ee4c2c 0%, #fc690d 100%);
  width: 0;
  transition: width 0.4s ease;
}

@media screen and (max-width: 767px) {
  #swipper-smart img {
    max-width: 80% !important;
    max-height: unset !important;
    -o-object-fit: contain !important;
       object-fit: contain !important;
    margin: 50px auto;
  }
}

#how-it-works {
  padding: 150px 0;
}
@media screen and (max-width: 767px) {
  #how-it-works {
    padding: 50px 0;
  }
}
#how-it-works p {
  line-height: 1.5;
}

#why-choose .container {
  background-image: linear-gradient(to bottom, rgba(252, 105, 13, 0.2), transparent);
  padding-bottom: 50px;
}
@media screen and (min-width: 768px) {
  #why-choose .container {
    padding: 100px;
  }
}
@media screen and (max-width: 767px) {
  #why-choose .container {
    padding: 100px 20px 50px 20px !important;
  }
}
#why-choose .container img {
  height: 100px;
}

@media screen and (min-width: 768px) {
  #start-search {
    margin-bottom: 150px;
  }
}
#start-search .container {
  background-image: linear-gradient(to top, rgba(252, 105, 13, 0.2), transparent);
  padding-top: 50px;
}
@media screen and (min-width: 768px) {
  #start-search .container {
    padding: 100px;
  }
}
@media screen and (max-width: 767px) {
  #start-search .container {
    padding: 50px 20px 100px 20px !important;
    border-radius: 0 !important;
  }
  #start-search .container a {
    width: 50%;
    flex: 0 0 50%;
  }
}
#start-search .container img {
  height: 500px;
}
@media screen and (max-width: 767px) {
  #start-search .container img {
    width: 100% !important;
    height: unset !important;
  }
}

/* ==========================================================================
   4. Miscellaneous & Overrides
   ========================================================================== */
.btn-start-search-dropdown {
  position: relative;
}
.btn-start-search-dropdown::after {
  content: "";
  position: absolute;
  top: 50%;
  left: -5px;
  transform: translateY(-50%);
  width: 1px;
  height: 25px;
  background-color: rgba(var(--bs-secondary-rgb), 0.2);
}
@media screen and (max-width: 767px) {
  .btn-start-search-dropdown {
    margin-left: auto !important;
  }
  .row {
    margin-right: unset !important;
  }
  .feature-itm {
    padding: 20px 0;
  }
}

/* ==========================================================================
   5. Animations
   ========================================================================== */
@keyframes arrow-seq-1 {
  0%, 19.999% {
    opacity: 0.1;
  }
  20%, 20.499% {
    opacity: 0.1;
  }
  22.44%, 96.34% {
    opacity: 1;
  }
  100% {
    opacity: 0.1;
  }
}
@keyframes arrow-seq-2 {
  0%, 39.999% {
    opacity: 0.1;
  }
  40%, 40.499% {
    opacity: 0.1;
  }
  42.44%, 96.34% {
    opacity: 1;
  }
  100% {
    opacity: 0.1;
  }
}
@keyframes arrow-seq-3 {
  0%, 59.999% {
    opacity: 0.1;
  }
  60%, 60.499% {
    opacity: 0.1;
  }
  62.44%, 96.34% {
    opacity: 1;
  }
  100% {
    opacity: 0.1;
  }
}
@keyframes arrow-seq-4 {
  0%, 79.999% {
    opacity: 0.1;
  }
  80%, 80.499% {
    opacity: 0.1;
  }
  82.44%, 96.34% {
    opacity: 1;
  }
  100% {
    opacity: 0.1;
  }
}
#faqs-main {
  padding-top: 120px !important;
}
#faqs-main .accordion {
  margin-top: 50px;
}
#faqs-main .accordion-body {
  background-color: #fff !important;
  border: 0 !important;
}
#faqs-main .accordion-button {
  background-color: #fff !important;
  border: 0 !important;
  font-weight: bold !important;
  color: var(--bs-body-color) !important;
}
#faqs-main .accordion-button::after {
  display: none !important;
}
#faqs-main .accordion-button .icon {
  color: #000;
  opacity: 0.5 !important;
}
#faqs-main .accordion-item {
  margin-bottom: 20px;
  border-radius: 7px;
  border: 1px solid #f5f5f6;
}
#faqs-main .accordion-item:has(.show) {
  border-bottom: 2px solid var(--bs-primary) !important;
}
#faqs-main .accordion-item:has(.show) .icon .icon-plus {
  display: none;
}
#faqs-main .accordion-item:has(.show) .icon .icon-minus {
  display: block;
}
#faqs-main .accordion-item:not(:has(.show)) .icon .icon-plus {
  display: block;
}
#faqs-main .accordion-item:not(:has(.show)) .icon .icon-minus {
  display: none;
}

.navbar-header.scroll {
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}

.contact-page .contact-header {
  background-image: url("/assets/images/contact/header.png");
  height: 170px;
  display: flex;
  align-items: center;
}

.main-contact {
  background: linear-gradient(to bottom, rgba(252, 104, 14, 0.05), rgba(252, 104, 14, 0), rgba(252, 104, 14, 0), rgba(252, 104, 14, 0), rgba(252, 104, 14, 0));
  padding-bottom: 70px;
}

.navbar-responsive li {
  width: 100% !important;
}

#app.search-page {
  background-image: url(/assets/images/dashboard/square-line.svg);
  min-height: 100vh;
  background-repeat: no-repeat;
  background-size: cover;
  display: flex;
  flex-direction: column;
}
#app.search-page main {
  margin-top: auto !important;
  margin-bottom: auto !important;
}
#app.search-page .text-group h1 {
  font-size: 72px;
  font-weight: 700;
}
@media screen and (max-width: 1200px) {
  #app.search-page .text-group h1 {
    font-size: 56px;
  }
}
@media screen and (max-width: 767px) {
  #app.search-page .text-group h1 {
    font-size: 40px;
  }
}
@media screen and (max-width: 575px) {
  #app.search-page .text-group h1 {
    font-size: 24px;
  }
}
#app.search-page .text-group p {
  font-size: 32px;
}
@media screen and (max-width: 1200px) {
  #app.search-page .text-group p {
    font-size: 24px;
  }
}
@media screen and (max-width: 767px) {
  #app.search-page .text-group p {
    font-size: 16px;
  }
}
@media screen and (max-width: 575px) {
  #app.search-page .text-group p {
    font-size: 12px;
  }
}
#app #mainNav .nav-item:not(:first-child) {
  margin-left: 10px;
  padding-left: 7px;
}
#app #mainNav .nav-item:not(:first-child)::before {
  content: "";
  width: 1px;
  height: 10px;
  background-color: rgba(var(--bs-secondary-rgb), 0.2);
  position: absolute;
  left: 0px;
  top: 50%;
  transform: translateY(-50%);
}
#app #mainNav .nav-item:not(:first-child) .nav-link {
  padding-top: 0 !important;
}
#app #mainNav .nav-item {
  position: relative;
  display: flex;
  align-items: center;
}
#app #mainNav .nav-item .nav-link.active {
  background: linear-gradient(90deg, #ee4c2c 0%, #fc690d 100%) !important;
  color: #fff !important;
  border-radius: 8px;
  padding: 6px 10px !important;
}
#app .card-patent {
  border-radius: 16px !important;
}
#app .card-patent .patent-tab-group .tab-list-patent {
  padding-bottom: 8px;
  border-color: rgba(0, 0, 0, 0.06) !important;
}
#app .card-patent .patent-tab-group .tab-list-patent .nav-item .nav-link.active {
  border-top-left-radius: 16px !important;
  border-top-right-radius: 16px !important;
  color: var(--bs-primary) !important;
  background-color: rgb(252, 219, 213) !important;
  border: 0 !important;
  font-weight: 600;
  position: relative;
}
#app .card-patent .patent-tab-group .tab-list-patent .nav-item .nav-link.active::after {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: var(--bs-primary);
}
#app .card-patent .patent-tab-group .tab-list-patent .nav-item .nav-link:not(.active) {
  color: rgb(77, 77, 77) !important;
}
#app #search-description textarea {
  resize: none;
  border-radius: 20px;
  background-color: rgb(245, 245, 246) !important;
}
#app .action-headers .btn {
  font-size: 12px;
  text-transform: uppercase !important;
  font-weight: 700 !important;
}

#public-nav {
  transition: background-color 0.2s ease, border-color 0.2s ease;
}
#public-nav .navbar-brand img {
  height: 32px;
  width: auto;
  transition: filter 0.2s ease;
}
#public-nav .navbar-nav {
  align-items: center;
  gap: 12px;
}
#public-nav .nav-link {
  font-weight: 600;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  transition: color 0.2s ease;
}
#public-nav .navbar-toggler {
  border: 0;
  width: 40px;
  height: 40px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(0, 0, 0, 0.05);
  transition: background-color 0.2s ease, color 0.2s ease;
}
#public-nav .navbar-toggler:focus {
  box-shadow: none;
}
#public-nav .navbar-toggler:hover {
  background-color: rgba(0, 0, 0, 0.12);
}
#public-nav .navbar-toggler .navbar-toggler-icon {
  filter: brightness(0);
}
@media (min-width: 768px) {
  #public-nav .navbar-toggler {
    display: none;
  }
}
#public-nav.bg-black {
  background-color: rgba(8, 9, 12, 0.98) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
#public-nav.bg-black .navbar-brand img {
  filter: brightness(0) invert(1);
}
#public-nav.bg-black .navbar-toggler {
  background-color: rgba(255, 255, 255, 0.08);
}
#public-nav.bg-black .navbar-toggler:hover {
  background-color: rgba(255, 255, 255, 0.18);
}
#public-nav.bg-black .navbar-toggler .navbar-toggler-icon {
  filter: brightness(0) invert(1);
}
#public-nav.bg-black .nav-link {
  color: rgba(255, 255, 255, 0.82) !important;
}
#public-nav.bg-black .nav-link:hover, #public-nav.bg-black .nav-link:focus {
  color: #fff !important;
}
#public-nav.bg-black .nav-link.active {
  background: #000 !important;
  background-color: #fff !important;
  color: #000 !important;
}
#public-nav.bg-black .btn.btn-primary, #public-nav.bg-black .btn.btn-secondary {
  color: #fff;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
}
