    :root {
      --bs-font-sans-serif: "Noto Sans", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Liberation Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
      --bs-body-font-size: 1.5rem;
    }

    h1,
    h2,
    h3,
    h4,
    h5,
    h6 {
      font-weight: 700;
      margin-bottom: 1.5rem;
      margin-top: 1.5rem;
    }

    p {
      margin-bottom: 1rem;
    }

    .object-cover {
      object-fit: cover;
    }

    .behind {
      z-index: -999;
    }

    .video-overlay {
      content: '';
      position: absolute;
      height: 100%;
      width: 100%;
      background: rgba(0, 0, 0, 0.6);
      top: 0;
      left: 0;
      z-index: -1;
    }

    .hero {
      /* min-height: 100vh; */
    }

    .logo {
      max-width: 150px;
      width: 100%;
      height: auto;
    }

    .navbar {
      background: rgba(255, 255, 255, 0);
      transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
      transition-timing-function: cubic-bezier(.4, 0, .2, 1);
      transition-duration: .5s;
    }

    .navbar a {
      color: #212529;
      font-weight: 700;
    }

    .nav-link {
      padding-left: 0.1rem !important;
      padding-right: 0.1rem !important;
      margin-left: 0.5rem;
      margin-right: 0.5rem;
    }

    .nav-link:hover,
    .nav-link:focus {
      color: #6366f1;
    }

    .navbar .logo.dark {
      display: none;
    }

    .navbar.scrolled {
      background: rgba(255, 255, 255, 1);
      border-bottom: 1px solid #ececec;
    }

    .navbar.scrolled a {
      color: #212529;
    }


    .navbar .navbar-toggler-icon {
      background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%280, 0, 0, 0.55%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")
    }

    .navbar.scrolled .nav-link:hover,
    .navbar.scrolled .nav-link:focus {
      color: #6366f1
    }

    @media (min-width: 768px) {
      .nav-link.active {
        border-bottom: 1px solid #000;
        padding-bottom: 3px;
      }
      .py-md-7 {
        padding-top: 7rem !important;
        padding-bottom: 7rem !important;
      }
    }

    @media (max-width: 767px) {
      .navbar .navbar-nav {
        background: #fff;
        padding: 15px;
        margin-top: 20px;
        border-radius: 5px;
        border: 1px solid #ececec;
      }
    }

    .navbar.scrolled button {
      visibility: visible;
    }

    footer a {
      color: #fff;
    }

    footer a:hover {
      color: #c7d2fe;
    }

    .btn-primary {
      background: linear-gradient(45deg, #3edd90, #00a7d9);
      border: none;
      font-weight: 700;
      padding: 15px 30px 15px 30px;
      position: relative;
      z-index: 1;
      border-radius: 5px;
    }

    .btn-primary:hover::before {
      opacity: 1;
    }

    .btn-primary::before {
      position: absolute;
      content: '';
      top: 0;
      right: 0;
      bottom: 0;
      left: 0;
      background: linear-gradient(45deg, #3ab67a, #048ab3);
      z-index: -1;
      transition: opacity 0.1s linear;
      opacity: 0;
      border-radius: 5px;
    }

    .navbar .outline-button {
      background: rgba(0, 0, 0, 0);
      border: 1px solid #212529;
      color: #212529;
      font-weight: 700;
      padding: 8px 15px;
      position: relative;
      z-index: 1;
      border-radius: 5px;
      text-decoration: none;
      margin-left: 10px;
      transition: color 0.5s ease;
      transition: border-color 0.5s ease;
    }
    .navbar .outline-button:hover {
      color: #fff;
      border-color: #6366f1;
    }

    .navbar .outline-button::before {
      position: absolute;
      content: '';
      top: 0;
      right: 0;
      bottom: 0;
      left: 0;
      background: #6366f1;
      border: 1px solid #212529;
      z-index: -1;
      opacity: 0;
      border-radius: 5px;
      transition: opacity 0.5s ease;
    }

    .navbar .outline-button:hover::before {
      opacity: 1;
    }

    .navbar.scrolled .outline-button {
      color: #fff;
      background: #000;
      border: none;
      margin-left: 12px;
      font-weight: 700;
      padding: 8px 15px;
      position: relative;
      z-index: 1;
      border-radius: 5px;
      text-decoration: none;
    }

    .navbar.scrolled .outline-button:hover::before {
      opacity: 1;
    }

    .navbar.scrolled .outline-button::before {
      position: absolute;
      border: none;
      margin-left: 1px;
      content: '';
      top: 0;
      right: 0;
      bottom: 0;
      left: 0;
      background: #6366f1;
      z-index: -1;
      transition: opacity 0.5s ease;
      opacity: 0;
      border-radius: 5px;
    }

    .navbar-toggler:focus {
      box-shadow: none;
    }

    .badge {
      background: #f8f9fa;
      border: #e6e9ee 1px solid;
      color: #000;
      font-weight: 400;
      padding: 0.325rem 0.75rem;
      font-size: 0.875rem;
      border-radius: 100px;
    }

    .badge-green {
      background: #ddffea;
      border:  #cbefde 1px solid;
    }

    .bg-yellow {
      background-color: #ffffff;
    }

    /* Subtle edge lines like Baseten */
    .hero .container-fluid > .row {
      position: relative;
    }

    .hero .container-fluid > .row::before {
      content: '';
      position: absolute;
      left: 50%;
      top: 0;
      bottom: 0;
      width: 1px;
    }

    @media (max-width: 991px) {
      .hero .container-fluid > .row::before {
        display: none;
      }
    }

    .hero {
      border-bottom: 1px dashed rgba(0,0,0,0.08);
      background-image:
        radial-gradient(circle, rgba(0,0,0,0.06) 1px, transparent 1px),
        linear-gradient(rgba(0,0,0,0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0,0,0,0.025) 1px, transparent 1px);
      background-size: 40px 40px, 40px 40px, 40px 40px;
      background-position: 0 0, 0 0, 0 0;
    }

    .bg-grey {
      background-color: #f8f9fa;
    }
    .bg-light-grey {
      background-color: #f8f9fa;
    }

    .bg-light-purple {
      background-color: #e0e7ff;
    }

    .full-height {
      min-height: 100vh;
    }

    .subdued {
      color: #8a8a8a;
    }

    .highlight {
      background-color: #e0e7ff;
    }

    .highlight-green {
      background-color: #08f972;
      padding: 0 0.15em;
    }

    .bg-dark .highlight {
      background-color: #6366f1
    }

    .card-dark {
      background-color: #313131;
      color: #fff;
      border-radius: 5px;
      padding: 30px;
    }

    .card {
      border-radius: 10px;
      padding: 60px 30px;
      width: 100%;
      height: auto;
    }

    .card-mini {
      border-radius: 10px;
      padding: 24px 16px;
      width: 100%;
      font-weight: 600;
      font-size: 0.95rem;
      border: 1px solid #e6e9ee;
    }

    .card-bordered {
      border: 1px solid #e6e9ee;
      color: #212529;
    }

    .card-shadowed {
      box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);    
    }

    @media (max-width: 767px) {
      .card {
        border-radius: 10px;
        padding: 40px 15px;
        width: 100%;
      }
  
    }


    .review-star {
      display: inline-block;
      width: 20px;
      height: auto;
      margin-right: 3px;
    }

    .review-star:last-child {
      margin-right: 0px;
    }

    .btn:focus, .btn-primary:focus {
      box-shadow: none;
    }

    .display-6 {
      line-height: 1.4;
    }

    p {
      margin-bottom: 1.2em;
    }

    .py-6 {
      padding-top: 6rem;
      padding-bottom: 6rem;
    }

    .pt-6 {
      padding-top: 6rem;
    }

    .pb-6 {
      padding-bottom: 6rem;
    }

    .py-7 {
      padding-top: 7rem;
      padding-bottom: 7rem;
    }

    .pt-7 {
      padding-top: 7rem;
    }

    .pb-7 {
      padding-bottom: 7rem;
    }

    .py-8 {
      padding-top: 8rem;
      padding-bottom: 8rem;
    }

    .pt-8 {
      padding-top: 8rem;
    }

    .pb-8 {
      padding-bottom: 8rem;
    }


    @property --border-gradient-angle {
      syntax: "<angle>";
      inherits: true;
      initial-value: 0turn
  }
    .button-highlight {
      --outer-radius: 10px;
      --border-size: 2px;
      --inner-radius: calc(var(--outer-radius) - var(--border-size));
      background-image: conic-gradient(from var(--border-gradient-angle) at 50% 50%, transparent, #08f972 14%, transparent 17%);
      border-radius: var(--outer-radius);
      background-size: contain;
      padding: var(--border-size);
      animation-name: buttonBorderSpin;
      animation-play-state: running;
      animation-duration: 6s;
      animation-timing-function: linear;
      animation-iteration-count: infinite;
      animation-direction: normal;
      max-width: 100%;
    }

    @keyframes buttonBorderSpin {
      0% {
          --border-gradient-angle: 0turn
      }
  
      to {
          --border-gradient-angle: 1turn
      }
  }

  @keyframes buttonBorderPulse {
    0%, 100% {
      background: rgba(8, 249, 114, 0.1);
    }
    50% {
      background: rgba(8, 249, 114, 1);
    }
  }
  
  .button-highlight:hover {
    animation-name: buttonBorderPulse;
    animation-duration: 2s;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
  }

  .before,
  .after {
    margin: 0;
  }

  .before figcaption,
  .after figcaption {
    background: rgba(236,236,236,0.8);
    border-radius: 4px;
    color: #212529;
    padding: 12px;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    line-height: 100%;
  }

  .before figcaption {
    left: 12px;
  }

  .after figcaption {
    right: 12px;
  }

  img-comparison-slider:focus {
    outline: none;
  }
  img-comparison-slider img, img.rounded{
    border-radius: 10px;
  }

  .blaze-pagination {
    display: flex;
    gap: 15px;
  }
  
  .blaze-pagination button {
    font-size: 0;
    width: 15px;
    height: 15px;
    border-radius: 50%;
    outline: none;
    border: none;
    background: #212529;
    cursor: pointer;
    transition: transform 200ms ease, background-color 300ms ease;
  }
  
  .blaze-pagination button.active {
    background: #a5b4fc;
    transform: scale(1.3);
  }
  
  .blaze-next,
  .blaze-prev {
    border: none;
    font-size: 0;
    width: 20px;
    height: 20px;
    background: none;
    cursor: pointer;
    background-position: center;
    background-size: 100%;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' height='24' viewBox='0 0 24 24' width='24'%3E%3Cpath d='M0 0h24v24H0z' fill='none'/%3E%3Cpath fill='%23a5b4fc' d='M11.67 3.87L9.9 2.1 0 12l9.9 9.9 1.77-1.77L3.54 12z'/%3E%3C/svg%3E");
  }

  .blaze-next {
    transform: rotate(180deg);
  }
  
  /* for loop: false */
  .blaze-slider.start .blaze-prev,
  .blaze-slider.end .blaze-next {
    opacity: 0.5;
    cursor: not-allowed;
  }
  .controls {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
  }
    

  .blaze-slider {
    max-width: calc(100vw - 41px);
  }

  .display-7 {
    font-size: 2rem;
  }

  .demo {
    display: block;
    position: relative;
    width: 100%;
    max-width: 250px;
    aspect-ratio: 1 / 1.97;
    background: #fff;
  }

  .demo .mockup {
    position: absolute;
    top: 0;
    left: 0;
  }

  .demo .content {
    position: absolute;
    top: 0;
    left: 0;
  }

  .demo.after .content {
    opacity: 0;
    animation: fadeInAfterDelayFast 8s infinite forwards;
  }

  .demo.before .content {
    opacity: 0;
    animation: fadeInAfterDelaySlow 8s infinite forwards;
  }

  .demo.before .overlay-hero {
    position: absolute;
    width: 100%;
    top: 18%;
    aspect-ratio: 1 / 0.85; 
    background-color: #ffffff;
    opacity: 1;
    animation: fadeOutAfterDelayHero 8s infinite forwards;
  }

  .demo.before .overlay-main {
    position: absolute;
    width: 100%;
    top: 61%;
    aspect-ratio: 1 / 0.77; 
    background-color: #ffffff;
    opacity: 1;
    animation: fadeOutAfterDelayMain 8s infinite forwards;
  }


  @keyframes fadeInAfterDelayFast {
    0% {
      opacity: 0;
    }
    5% {
      opacity: 0;
    }
    10% {
      opacity: 1;
    }
    100% {
      opacity: 1;
    }
  }

  @keyframes fadeInAfterDelaySlow {
    0% {
      opacity: 0;
    }
    20% {
      opacity: 0;
    }
    30% {
      opacity: 1;
    }
    100% {
      opacity: 1;
    }
  }


  @keyframes fadeOutAfterDelayHero {
    0% {
      opacity: 1;
    }
    40% {
      opacity: 1;
    }
    50% {
      opacity: 0;
    }
    100% {
      opacity: 0;
    }
  }

  @keyframes fadeOutAfterDelayMain {
    0% {
      opacity: 1;
    }
    50% {
      opacity: 1;
    }
    60% {
      opacity: 0;
    }
    100% {
      opacity: 0;
    }
  }

.demo .lds-spinner {
  top: calc( 50% - 25px );
  left: calc( 50% - 25px );  
  animation: fadeOutAfterDelayMain 8s infinite forwards;
}

.lazyload-mockup {
  position: relative;
  max-width: 700px;
}

.lazyload-mockup .lds-spinner {
  top: calc(85% - 25px);
  left: calc( 50% - 25px );  
}
  
.lds-spinner,
.lds-spinner div,
.lds-spinner div:after {
  box-sizing: border-box;
}
.lds-spinner {
  display: inline-block;
  position: absolute;
  top: calc( 50% - 25px );
  left: calc( 50% - 25px );
  width: 50px;
  height: 50px;
  opacity: 1;
}
.lds-spinner div {
  transform-origin: 25px 25px;
  animation: lds-spinner 1.2s linear infinite;
}
.lds-spinner div:after {
  content: " ";
  display: block;
  position: absolute;
  top: 2.0px;
  left: 23.0px;
  width: 4.0px;
  height: 11.0px;
   border-radius: 20%;
  background: currentColor;
}
.lds-spinner div:nth-child(1) {
  transform: rotate(0deg);
  animation-delay: -1.1s;
}
.lds-spinner div:nth-child(2) {
  transform: rotate(30deg);
  animation-delay: -1s;
}
.lds-spinner div:nth-child(3) {
  transform: rotate(60deg);
  animation-delay: -0.9s;
}
.lds-spinner div:nth-child(4) {
  transform: rotate(90deg);
  animation-delay: -0.8s;
}
.lds-spinner div:nth-child(5) {
  transform: rotate(120deg);
  animation-delay: -0.7s;
}
.lds-spinner div:nth-child(6) {
  transform: rotate(150deg);
  animation-delay: -0.6s;
}
.lds-spinner div:nth-child(7) {
  transform: rotate(180deg);
  animation-delay: -0.5s;
}
.lds-spinner div:nth-child(8) {
  transform: rotate(210deg);
  animation-delay: -0.4s;
}
.lds-spinner div:nth-child(9) {
  transform: rotate(240deg);
  animation-delay: -0.3s;
}
.lds-spinner div:nth-child(10) {
  transform: rotate(270deg);
  animation-delay: -0.2s;
}
.lds-spinner div:nth-child(11) {
  transform: rotate(300deg);
  animation-delay: -0.1s;
}
.lds-spinner div:nth-child(12) {
  transform: rotate(330deg);
  animation-delay: 0s;
}
@keyframes lds-spinner {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

img-comparison-slider{
  position:relative
}

.btn-dark {
  color: #fff;
  background: #000;
  border: none;
  font-weight: 700;
  padding: 8px 15px;
  position: relative;
  z-index: 1;
  border-radius: 5px;
  text-decoration: none;
  transition: background-color 0.3s ease;
  display: inline-block;
}

.btn-dark:hover {
  background: #6366f1;
  color: #fff;
}

.btn-outline {
  color: #000;
  background: transparent;
  border: 1px solid #000;
  font-weight: 700;
  padding: 8px 20px;
  border-radius: 5px;
  text-decoration: none;
  transition: all 0.3s ease;
  display: inline-block;
}

.btn-outline:hover {
  background: #000;
  color: #fff;
}

.btn-link {
  color: #000;
  background: transparent;
  border: none;
  font-weight: 600;
  padding: 12px 0;
  text-decoration: none;
  transition: color 0.3s ease;
  display: inline-flex;
  align-items: center;
  letter-spacing: 0.02em;
}

.btn-link:hover {
  color: #6366f1;
}

.icon-wrapper {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.icon-wrapper img {
  filter: brightness(0) saturate(100%) invert(40%) sepia(95%) saturate(1000%) hue-rotate(215deg) brightness(95%) contrast(95%);
}

.user-avatar {
  border-radius: 50%;
  max-width: 28px;
  border: 3px solid #fff;
  margin-left: -12px;
}

a {
  color: #000;
  text-decoration: none;
  transition: color 0.3s ease;
}

a:hover {
  color: #6366f1;
}

.arrow::after {
  content: " →";
}

/* Client Logo Wall */
.logo-wall-section {
  border-bottom: 1px dashed rgba(0,0,0,0.08);
}

.logo-grid-cell {
  border: 1px dashed rgba(0,0,0,0.08);
  padding: 12px 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  position: relative;
  transition: background-color 0.2s ease;
}

.logo-grid-cell:hover {
  background-color: #e0e7ff;
}

/* Desktop: 4-column layout - extend grid lines to left edge (first cell in each row) */
@media (min-width: 768px) {
  .row.g-0 > div:nth-child(4n+1) .logo-grid-cell::before {
    content: '';
    position: absolute;
    left: -100vw;
    top: -1px;
    width: 100vw;
    height: calc(100% + 2px);
    border-top: 1px dashed rgba(0,0,0,0.08);
    border-bottom: 1px dashed rgba(0,0,0,0.08);
  }

  /* Extend grid lines to right edge - last cell in each row (desktop: 4 cols) */
  .row.g-0 > div:nth-child(4n) .logo-grid-cell::after {
    content: '';
    position: absolute;
    right: -100vw;
    top: -1px;
    width: 100vw;
    height: calc(100% + 2px);
    border-top: 1px dashed rgba(0,0,0,0.08);
    border-bottom: 1px dashed rgba(0,0,0,0.08);
  }
}

/* Mobile: 2 columns - extend grid lines to edges */
@media (max-width: 767px) {
  .row.g-0 > div:nth-child(2n+1) .logo-grid-cell::before {
    content: '';
    display: block;
    position: absolute;
    left: -100vw;
    top: -1px;
    width: 100vw;
    height: calc(100% + 2px);
    border-top: 1px dashed rgba(0,0,0,0.08);
    border-bottom: 1px dashed rgba(0,0,0,0.08);
  }

  .row.g-0 > div:nth-child(2n) .logo-grid-cell::after {
    content: '';
    display: block;
    position: absolute;
    right: -100vw;
    top: -1px;
    width: 100vw;
    height: calc(100% + 2px);
    border-top: 1px dashed rgba(0,0,0,0.08);
    border-bottom: 1px dashed rgba(0,0,0,0.08);
  }
}

.logo-img {
  max-width: 50px;
  height: auto;
  opacity: 0.7;
  transition: opacity 0.3s ease;
  object-fit: contain;
}

.logo-img:hover {
  opacity: 1;
}

@media (min-width: 768px) {
  .logo-img {
    max-width: 70px;
  }

  .logo-grid-cell {
    padding: 15px 25px;
    min-height: 60px;
  }
}
