
/* Fonts */
:root {
  --default-font: "Open Sans",  system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  --heading-font: "Jost",  sans-serif;
  --nav-font: "Poppins",  sans-serif;
}

/* Global Colors - The following color variables are used throughout the website. Updating them here will change the color scheme of the entire website */
:root { 
  --background-color: #ffffff; /* Background color for the entire website, including individual sections */
  --default-color: #444444; /* Default color used for the majority of the text content across the entire website */
  --heading-color: #37517e; /* Color for headings, subheadings and title throughout the website */
  --accent-color: #47b2e4; /* Accent color that represents your brand on the website. It's used for buttons, links, and other elements that need to stand out */
  --surface-color: #ffffff; /* The surface color is used as a background of boxed elements within sections, such as cards, icon boxes, or other elements that require a visual separation from the global background. */
  --contrast-color: #ffffff; /* Contrast color for text, ensuring readability against backgrounds of accent, heading, or default colors. */
}

/* Nav Menu Colors - The following color variables are used specifically for the navigation menu. They are separate from the global colors to allow for more customization options */
:root {
  --nav-color: #ffffff;  /* The default color of the main navmenu links */
  --nav-hover-color: #47b2e4; /* Applied to main navmenu links when they are hovered over or active */
  --nav-mobile-background-color: #ffffff; /* Used as the background color for mobile navigation menu */
  --nav-dropdown-background-color: #ffffff; /* Used as the background color for dropdown items that appear when hovering over primary navigation items */
  --nav-dropdown-color: #444444; /* Used for navigation links of the dropdown items in the navigation menu. */
  --nav-dropdown-hover-color: #47b2e4; /* Similar to --nav-hover-color, this color is applied to dropdown navigation links when they are hovered over. */
}

/* Color Presets - These classes override global colors when applied to any section or element, providing reuse of the sam color scheme. */

.light-background {
  --background-color: #f5f6f8;
  --surface-color: #ffffff;
}

.dark-background {
  --background-color: #37517e;
  --default-color: #ffffff;
  --heading-color: #ffffff;
  --surface-color: #4668a2;
  --contrast-color: #ffffff;
}

/* Smooth scroll */
:root {
  scroll-behavior: smooth;
}

/*--------------------------------------------------------------
# General Styling & Shared Classes
--------------------------------------------------------------*/
body {
  color: var(--default-color);
  background-color: var(--background-color);
  font-family: var(--default-font);
}

a {
  color: var(--accent-color);
  text-decoration: none;
  transition: 0.3s;
}

a:hover {
  color: color-mix(in srgb, var(--accent-color), transparent 25%);
  text-decoration: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--heading-color);
  font-family: var(--heading-font);
}

/* PHP Email Form Messages
------------------------------*/
.php-email-form .error-message {
  display: none;
  background: #df1529;
  color: #ffffff;
  text-align: left;
  padding: 15px;
  margin-bottom: 24px;
  font-weight: 600;
}

.php-email-form .sent-message {
  display: none;
  color: #ffffff;
  background: #059652;
  text-align: center;
  padding: 15px;
  margin-bottom: 24px;
  font-weight: 600;
}

.php-email-form .loading {
  display: none;
  background: var(--surface-color);
  text-align: center;
  padding: 15px;
  margin-bottom: 24px;
}

.php-email-form .loading:before {
  content: "";
  display: inline-block;
  border-radius: 50%;
  width: 24px;
  height: 24px;
  margin: 0 10px -6px 0;
  border: 3px solid var(--accent-color);
  border-top-color: var(--surface-color);
  animation: php-email-form-loading 1s linear infinite;
}

@keyframes php-email-form-loading {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

/*--------------------------------------------------------------
# Global Header
--------------------------------------------------------------*/
.header {
  --background-color: #3d4d6a;
  --heading-color: #ffffff;
  color: var(--default-color);
  background-color: var(--background-color);
  padding: 15px 0;
  transition: all 0.5s;
  z-index: 997;
}

.header .logo {
  line-height: 1;
}

.header .logo img {
  max-height: 46px;
  margin-right: 8px;
}

.header .logo h1 {
  font-size: 30px;
  margin: 0;
  font-weight: 500;
  color: var(--heading-color);
  letter-spacing: 2px;
  text-transform: uppercase;
}

.header .btn-getstarted,
.header .btn-getstarted:focus {
  color: var(--contrast-color);
  background: var(--accent-color);
  font-size: 15px;
  padding: 8px 25px;
  margin: 0 -20px 0 30px;
  border-radius: 50px;
  transition: 0.3s;
}

.header .btn-getstarted:hover,
.header .btn-getstarted:focus:hover {
  color: var(--contrast-color);
  background: color-mix(in srgb, var(--accent-color), transparent 15%);
}

@media (max-width: 1200px) {
  .header .logo {
    order: 1;
  }

  .header .btn-getstarted {
    order: 2;
    margin: 0 15px 0 0;
    padding: 6px 15px;
  }

  .header .navmenu {
    order: 3;
  }
}

/* Index Page Header
------------------------------*/
.index-page .header {
  --background-color: rgba(255, 255, 255, 0);
  --heading-color: #ffffff;
  --nav-color: #ffffff;
}

/* Index Page Header on Scroll
------------------------------*/
.index-page.scrolled .header {
  --background-color: rgba(40, 58, 90, 0.9);
}

/*--------------------------------------------------------------
# Navigation Menu
--------------------------------------------------------------*/

.hero-subtitle {
      font-size: clamp(14px, 1.5vw, 17px);
      font-weight: 400;
      color: rgba(255,255,255,0.72);
      line-height: 1.65;
      max-width: 520px;
    }

    /* ===== SECTION 2 — WHY NGMB ===== */
    .why {
      background: #f7f8fc;
      padding: 80px 72px;
    }

    .why-inner {
      display: flex;
      align-items: flex-start;
      gap: 80px;
      max-width: 1280px;
      margin: 0 auto;
    }

    .why-left {
      flex: 0 0 400px;
      max-width: 400px;
    }

    .section-badge {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      background: #fff0ec;
      color: #d94f1e;
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 1.2px;
      text-transform: uppercase;
      padding: 6px 14px;
      border-radius: 50px;
      margin-bottom: 22px;
    }

    .section-badge::before {
      content: '';
      width: 7px;
      height: 7px;
      background: #d94f1e;
      border-radius: 50%;
      flex-shrink: 0;
    }

    .section-heading {
      font-size: clamp(32px, 3.5vw, 52px);
      font-weight: 900;
      line-height: 1.08;
      letter-spacing: -0.5px;
      margin-bottom: 24px;
    }

    .section-heading .dark {
      color: #111c4e;
    }

    .section-heading .orange {
      color: #d94f1e;
    }

    .why-body {
      font-size: 15px;
      color: #444;
      line-height: 1.75;
    }

    .why-body p + p {
      margin-top: 14px;
    }

    /* Benefits grid */
    .why-right {
      flex: 1;
    }

    .benefits-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
    }

    .benefit-card {
      background: #ffffff;
      border: 1px solid #e8eaf0;
      border-radius: 14px;
      padding: 24px 22px;
      transition: box-shadow 0.2s, transform 0.2s;
    }

    .benefit-card:hover {
      box-shadow: 0 8px 30px rgba(0,0,0,0.08);
      transform: translateY(-2px);
    }

    .benefit-icon {
      font-size: 28px;
      margin-bottom: 12px;
      display: block;
    }

    .benefit-title {
      font-size: 15px;
      font-weight: 700;
      color: #111c4e;
      margin-bottom: 6px;
    }

    .benefit-desc {
      font-size: 13.5px;
      color: #666;
      line-height: 1.6;
    }

    /* ===== SECTION 3 — CURRENT OPENINGS ===== */
    .openings {
      background: #ffffff;
      padding: 80px 72px;
    }

    .openings-inner {
      max-width: 1280px;
      margin: 0 auto;
    }

    .openings-header {
      margin-bottom: 40px;
    }

    .job-list {
      display: flex;
      flex-direction: column;
      gap: 14px;
    }

    .job-card {
      background: #ffffff;
      border: 1.5px solid #e2e5f0;
      border-radius: 12px;
      padding: 22px 28px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 20px;
      transition: border-color 0.2s, box-shadow 0.2s;
      cursor: pointer;
    }

    .job-card:hover {
      border-color: #a0a8d0;
      box-shadow: 0 4px 20px rgba(0,0,0,0.06);
    }

    .job-card.active {
      border-color: #1a2a6c;
      box-shadow: 0 0 0 1px #1a2a6c;
    }

    .job-info {
      flex: 1;
    }

    .job-title {
      font-size: 15.5px;
      font-weight: 700;
      color: #111c4e;
      margin-bottom: 10px;
    }

    .job-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }

    .tag {
      display: inline-block;
      font-size: 12px;
      font-weight: 500;
      padding: 4px 12px;
      border-radius: 6px;
      background: #f0f1f7;
      color: #444;
    }

    .tag.type {
      background: #fff0ec;
      color: #d94f1e;
      font-weight: 600;
    }

    .btn-apply {
      display: inline-block;
      background: #d94f1e;
      color: #ffffff;
      font-family: 'Barlow', sans-serif;
      font-size: 14px;
      font-weight: 700;
      padding: 11px 22px;
      border-radius: 8px;
      border: none;
      cursor: pointer;
      white-space: nowrap;
      transition: background 0.2s, transform 0.15s;
      flex-shrink: 0;
    }

    .btn-apply:hover {
      background: #c04419;
      transform: translateY(-1px);
    }

    .btn-apply:active {
      transform: translateY(0);
    }
/* Desktop Navigation */
@media (min-width: 1200px) {
  .navmenu {
    padding: 0;
  }

  .navmenu ul {
    margin: 0;
    padding: 0;
    display: flex;
    list-style: none;
    align-items: center;
  }

  .navmenu li {
    position: relative;
  }

  .navmenu a,
  .navmenu a:focus {
    color: var(--nav-color);
    padding: 18px 15px;
    font-size: 15px;
    font-family: var(--nav-font);
    font-weight: 400;
    display: flex;
    align-items: center;
    justify-content: space-between;
    white-space: nowrap;
    transition: 0.3s;
  }

  .navmenu a i,
  .navmenu a:focus i {
    font-size: 12px;
    line-height: 0;
    margin-left: 5px;
    transition: 0.3s;
  }

  .navmenu li:last-child a {
    padding-right: 0;
  }

  .navmenu li:hover>a,
  .navmenu .active,
  .navmenu .active:focus {
    color: var(--nav-hover-color);
  }

  .navmenu .dropdown ul {
    margin: 0;
    padding: 10px 0;
    background: var(--nav-dropdown-background-color);
    display: block;
    position: absolute;
    visibility: hidden;
    left: 14px;
    top: 130%;
    opacity: 0;
    transition: 0.3s;
    border-radius: 4px;
    z-index: 99;
    box-shadow: 0px 0px 30px rgba(0, 0, 0, 0.1);
  }

  .navmenu .dropdown ul li {
    min-width: 200px;
  }

  .navmenu .dropdown ul a {
    padding: 10px 20px;
    font-size: 15px;
    text-transform: none;
    color: var(--nav-dropdown-color);
  }

  .navmenu .dropdown ul a i {
    font-size: 12px;
  }

  .navmenu .dropdown ul a:hover,
  .navmenu .dropdown ul .active:hover,
  .navmenu .dropdown ul li:hover>a {
    color: var(--nav-dropdown-hover-color);
  }

  .navmenu .dropdown:hover>ul {
    opacity: 1;
    top: 100%;
    visibility: visible;
  }

  .navmenu .dropdown .dropdown ul {
    top: 0;
    left: -90%;
    visibility: hidden;
  }

  .navmenu .dropdown .dropdown:hover>ul {
    opacity: 1;
    top: 0;
    left: -100%;
    visibility: visible;
  }

  .navmenu .megamenu {
    position: static;
  }

  .navmenu .megamenu ul {
    margin: 0;
    padding: 10px;
    background: var(--nav-dropdown-background-color);
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.1);
    position: absolute;
    top: 130%;
    left: 0;
    right: 0;
    visibility: hidden;
    opacity: 0;
    display: flex;
    transition: 0.3s;
    border-radius: 4px;
    z-index: 99;
  }

  .navmenu .megamenu ul li {
    flex: 1;
  }

  .navmenu .megamenu ul li a,
  .navmenu .megamenu ul li:hover>a {
    padding: 10px 20px;
    font-size: 15px;
    color: var(--nav-dropdown-color);
  }

  .navmenu .megamenu ul li a:hover,
  .navmenu .megamenu ul li .active,
  .navmenu .megamenu ul li .active:hover {
    color: var(--nav-dropdown-hover-color);
  }

  .navmenu .megamenu:hover>ul {
    opacity: 1;
    top: 100%;
    visibility: visible;
  }

  .navmenu .dd-box-shadow {
    box-shadow: 0px 0px 30px rgba(0, 0, 0, 0.1);
  }
}

/* Mobile Navigation */
@media (max-width: 1199px) {
  .mobile-nav-toggle {
    color: var(--nav-color);
    font-size: 28px;
    line-height: 0;
    margin-right: 10px;
    cursor: pointer;
    transition: color 0.3s;
  }

  .navmenu {
    padding: 0;
    z-index: 9997;
  }

  .navmenu ul {
    display: none;
    list-style: none;
    position: absolute;
    inset: 60px 20px 20px 20px;
    padding: 10px 0;
    margin: 0;
    border-radius: 6px;
    background-color: var(--nav-mobile-background-color);
    overflow-y: auto;
    transition: 0.3s;
    z-index: 9998;
    box-shadow: 0px 0px 30px rgba(0, 0, 0, 0.1);
  }

  .navmenu a,
  .navmenu a:focus {
    color: var(--nav-dropdown-color);
    padding: 10px 20px;
    font-family: var(--nav-font);
    font-size: 17px;
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: space-between;
    white-space: nowrap;
    transition: 0.3s;
  }

  .navmenu a i,
  .navmenu a:focus i {
    font-size: 12px;
    line-height: 0;
    margin-left: 5px;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: 0.3s;
    background-color: color-mix(in srgb, var(--accent-color), transparent 90%);
  }

  .navmenu a i:hover,
  .navmenu a:focus i:hover {
    background-color: var(--accent-color);
    color: var(--contrast-color);
  }

  .navmenu a:hover,
  .navmenu .active,
  .navmenu .active:focus {
    color: var(--nav-dropdown-hover-color);
  }

  .navmenu .active i,
  .navmenu .active:focus i {
    background-color: var(--accent-color);
    color: var(--contrast-color);
    transform: rotate(180deg);
  }

  .navmenu .dropdown ul {
    position: static;
    display: none;
    z-index: 99;
    padding: 10px 0;
    margin: 10px 20px;
    background-color: var(--nav-dropdown-background-color);
    border: 1px solid color-mix(in srgb, var(--default-color), transparent 90%);
    box-shadow: none;
    transition: all 0.5s ease-in-out;
  }

  .navmenu .dropdown ul ul {
    background-color: rgba(33, 37, 41, 0.1);
  }

  .navmenu .dropdown>.dropdown-active {
    display: block;
    background-color: rgba(33, 37, 41, 0.03);
  }

  .mobile-nav-active {
    overflow: hidden;
  }

  .mobile-nav-active .mobile-nav-toggle {
    color: #fff;
    position: absolute;
    font-size: 32px;
    top: 15px;
    right: 15px;
    margin-right: 0;
    z-index: 9999;
  }

  .mobile-nav-active .navmenu {
    position: fixed;
    overflow: hidden;
    inset: 0;
    background: rgba(33, 37, 41, 0.8);
    transition: 0.3s;
  }

  .mobile-nav-active .navmenu>ul {
    display: block;
  }
}

/*--------------------------------------------------------------
# Global Footer
--------------------------------------------------------------*/
.footer {
  color: var(--default-color);
  background-color: var(--background-color);
  font-size: 14px;
  padding-bottom: 50px;
  position: relative;
}

.footer .footer-newsletter {
  background-color: color-mix(in srgb, var(--heading-color), transparent 95%);
  padding: 50px 0;
}

.footer .footer-newsletter h4 {
  font-size: 24px;
}

.footer .footer-newsletter .newsletter-form {
  margin-top: 30px;
  margin-bottom: 15px;
  padding: 6px 8px;
  position: relative;
  background-color: color-mix(in srgb, var(--background-color), transparent 50%);
  border: 1px solid color-mix(in srgb, var(--default-color), transparent 90%);
  box-shadow: 0px 2px 25px rgba(0, 0, 0, 0.1);
  display: flex;
  transition: 0.3s;
  border-radius: 50px;
}

.footer .footer-newsletter .newsletter-form:focus-within {
  border-color: var(--accent-color);
}

.footer .footer-newsletter .newsletter-form input[type=email] {
  border: 0;
  padding: 4px;
  width: 100%;
  background-color: color-mix(in srgb, var(--background-color), transparent 50%);
  color: var(--default-color);
}

.footer .footer-newsletter .newsletter-form input[type=email]:focus-visible {
  outline: none;
}

.footer .footer-newsletter .newsletter-form input[type=submit] {
  border: 0;
  font-size: 16px;
  padding: 0 20px;
  margin: -7px -8px -7px 0;
  background: var(--accent-color);
  color: var(--contrast-color);
  transition: 0.3s;
  border-radius: 50px;
}

.footer .footer-newsletter .newsletter-form input[type=submit]:hover {
  background: color-mix(in srgb, var(--accent-color), transparent 20%);
}

.footer .footer-top {
  padding-top: 50px;
}

.footer .social-links a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--default-color), transparent 50%);
  font-size: 16px;
  color: color-mix(in srgb, var(--default-color), transparent 20%);
  margin-right: 10px;
  transition: 0.3s;
}

.footer .social-links a:hover {
  color: var(--accent-color);
  border-color: var(--accent-color);
}

.footer h4 {
  font-size: 16px;
  font-weight: bold;
  position: relative;
  padding-bottom: 12px;
}

.footer .footer-links {
  margin-bottom: 30px;
}

.footer .footer-links ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer .footer-links ul i {
  margin-right: 3px;
  font-size: 12px;
  line-height: 0;
  color: var(--accent-color);
}

.footer .footer-links ul li {
  padding: 10px 0;
  display: flex;
  align-items: center;
}

.footer .footer-links ul li:first-child {
  padding-top: 0;
}

.footer .footer-links ul a {
  display: inline-block;
  color: color-mix(in srgb, var(--default-color), transparent 20%);
  line-height: 1;
}

.footer .footer-links ul a:hover {
  color: var(--accent-color);
}

.footer .footer-about a {
  color: var(--heading-color);
  font-size: 18px;
  font-weight: 600;
  text-transform: uppercase;
  font-family: var(--heading-font);
}

.footer .footer-contact p {
  margin-bottom: 5px;
}

.footer .copyright {
  padding-top: 25px;
  padding-bottom: 25px;
  border-top: 1px solid color-mix(in srgb, var(--default-color), transparent 90%);
}

.footer .copyright p {
  margin-bottom: 0;
}

.footer .credits {
  margin-top: 6px;
  font-size: 13px;
}
.footer-certificates{
    display:flex;
    gap:12px;
    margin-top:15px;
    align-items:center;
}

.footer-certificates img{
    width:65px;
    height:65px;
    object-fit:contain;
    border-radius:8px;
    transition:.3s;
    cursor:pointer;
}

.footer-certificates img:hover{
    transform:scale(1.08);
}

/*--------------------------------------------------------------
# Preloader
--------------------------------------------------------------*/
#preloader {
  position: fixed;
  inset: 0;
  z-index: 999999;
  overflow: hidden;
  background: var(--background-color);
  transition: all 0.6s ease-out;
}

#preloader:before {
  content: "";
  position: fixed;
  top: calc(50% - 30px);
  left: calc(50% - 30px);
  border: 6px solid #ffffff;
  border-color: var(--accent-color) transparent var(--accent-color) transparent;
  border-radius: 50%;
  width: 60px;
  height: 60px;
  animation: animate-preloader 1.5s linear infinite;
}
.why {
        padding: 56px 24px;
      }

      .why-inner {
        flex-direction: column;
        gap: 40px;
      }

      .why-left {
        flex: none;
        max-width: 100%;
      }

      .benefits-grid {
        grid-template-columns: 1fr 1fr;
      }

      .openings {
        padding: 56px 24px;
      }

@keyframes animate-preloader {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

/*--------------------------------------------------------------
# Scroll Top Button
--------------------------------------------------------------*/
.scroll-top {
  position: fixed;
  visibility: hidden;
  opacity: 0;
  right: 15px;
  bottom: -15px;
  z-index: 99999;
  background-color: var(--accent-color);
  width: 44px;
  height: 44px;
  border-radius: 50px;
  transition: all 0.4s;
}

.scroll-top i {
  font-size: 24px;
  color: var(--contrast-color);
  line-height: 0;
}

.scroll-top:hover {
  background-color: color-mix(in srgb, var(--accent-color), transparent 20%);
  color: var(--contrast-color);
}

.scroll-top.active {
  visibility: visible;
  opacity: 1;
  bottom: 15px;
}

/*--------------------------------------------------------------
# Disable aos animation delay on mobile devices
--------------------------------------------------------------*/
@media screen and (max-width: 768px) {
  [data-aos-delay] {
    transition-delay: 0 !important;
  }
}

/*--------------------------------------------------------------
# Global Page Titles & Breadcrumbs
--------------------------------------------------------------*/
.page-title {
  --background-color: color-mix(in srgb, var(--default-color), transparent 96%);
  color: var(--default-color);
  background-color: var(--background-color);
  padding: 20px 0;
  position: relative;
}

.page-title h1 {
  font-size: 28px;
  font-weight: 700;
  margin: 0;
}

.page-title .breadcrumbs ol {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 0 0 10px 0;
  margin: 0;
  font-size: 14px;
}

.page-title .breadcrumbs ol li+li {
  padding-left: 10px;
}

.page-title .breadcrumbs ol li+li::before {
  content: "/";
  display: inline-block;
  padding-right: 10px;
  color: color-mix(in srgb, var(--default-color), transparent 70%);
}

/*--------------------------------------------------------------
# Global Sections
--------------------------------------------------------------*/
section,
.section {
  color: var(--default-color);
  background-color: var(--background-color);
  padding: 60px 0;
  scroll-margin-top: 88px;
  overflow: clip;
}

@media (max-width: 1199px) {

  section,
  .section {
    scroll-margin-top: 66px;
  }
}

/*--------------------------------------------------------------
# Global Section Titles
--------------------------------------------------------------*/
.section-title {
  text-align: center;
  padding-bottom: 60px;
  position: relative;
}

.section-title h2 {
  font-size: 32px;
  font-weight: 700;
  margin-bottom: 20px;
  padding-bottom: 20px;
  text-transform: uppercase;
  position: relative;
}

.section-title h2:before {
  content: "";
  position: absolute;
  display: block;
  width: 160px;
  height: 1px;
  background: color-mix(in srgb, var(--default-color), transparent 60%);
  left: 0;
  right: 0;
  bottom: 1px;
  margin: auto;
}

.section-title h2::after {
  content: "";
  position: absolute;
  display: block;
  width: 60px;
  height: 3px;
  background: var(--accent-color);
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}

.section-title p {
  margin-bottom: 0;
}

/*--------------------------------------------------------------
# Hero Section
--------------------------------------------------------------*/
.hero {
  width: 100%;
  min-height: 80vh;
  position: relative;
  padding: 120px 0 60px 0;
  display: flex;
  align-items: center;
}

.hero h1 {
  margin: 0;
  font-size: 38px;
  font-weight: 700;
  line-height: 56px;
}
.hero h2 {
  margin: 0;
  font-size: 30px;
  font-weight: 700;
  line-height: 56px;
}

.hero p {
  color: color-mix(in srgb, var(--default-color), transparent 30%);
  margin: 5px 0 30px 0;
  font-size: 22px;
  line-height: 1.3;
  font-weight: 600;
}

.hero .btn-get-started {
  color: var(--contrast-color);
  background: var(--accent-color);
  font-family: var(--heading-font);
  font-weight: 500;
  font-size: 15px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 12px 28px;
  border-radius: 50px;
  transition: 0.5s;
}

.hero .btn-get-started:hover {
  color: var(--contrast-color);
  background: color-mix(in srgb, var(--accent-color), transparent 15%);
}

.hero .btn-watch-video {
  font-size: 16px;
  transition: 0.5s;
  margin-left: 25px;
  color: var(--default-color);
  font-weight: 600;
}

.hero .btn-watch-video i {
  color: var(--contrast-color);
  font-size: 32px;
  transition: 0.3s;
  line-height: 0;
  margin-right: 8px;
}

.hero .btn-watch-video:hover {
  color: var(--accent-color);
}

.hero .btn-watch-video:hover i {
  color: color-mix(in srgb, var(--accent-color), transparent 15%);
}

.hero .animated {
  animation: up-down 2s ease-in-out infinite alternate-reverse both;
}

@media (max-width: 640px) {
  .hero h1 {
    font-size: 28px;
    line-height: 36px;
  }

  .hero p {
    font-size: 18px;
    line-height: 24px;
    margin-bottom: 30px;
  }

  .hero .btn-get-started,
  .hero .btn-watch-video {
    font-size: 13px;
  }
}

@keyframes up-down {
  0% {
    transform: translateY(10px);
  }

  100% {
    transform: translateY(-10px);
  }
}

/*--------------------------------------------------------------
# Clients Section
--------------------------------------------------------------*/
.clients {
  padding: 12px 0;
}

.clients .swiper {
  padding: 10px 0;
}

.clients .swiper-wrapper {
  height: auto;
}

.clients .swiper-slide img {
  transition: 0.3s;
  padding: 0 10px;
}

.clients .swiper-slide img:hover {
  transform: scale(1.1);
}

/*--------------------------------------------------------------
# About Section
--------------------------------------------------------------*/
.about ul {
  list-style: none;
  padding: 0;
}

.about ul li {
  padding-bottom: 5px;
  display: flex;
  align-items: center;
}

.about ul i {
  font-size: 20px;
  padding-right: 4px;
  color: var(--accent-color);
}

.about .read-more {
  color: var(--accent-color);
  font-family: var(--heading-font);
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  padding: 8px 28px;
  border-radius: 5px;
  transition: 0.3s;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--accent-color);
}

.about .read-more i {
  font-size: 18px;
  margin-left: 5px;
  line-height: 0;
  transition: 0.3s;
}

.about .read-more:hover {
  background: var(--accent-color);
  color: var(--contrast-color);
}

.about .read-more:hover i {
  transform: translate(5px, 0);
}

/*--------------------------------------------------------------
# Why Us Section
--------------------------------------------------------------*/
.why-us {
  padding: 30px 0;
}

.why-us .content h3 {
  font-weight: 400;
  font-size: 34px;
}

.why-us .content p {
  color: color-mix(in srgb, var(--default-color), transparent 30%);
}

.why-us .faq-container .faq-item {
  background-color: var(--surface-color);
  position: relative;
  padding: 20px;
  margin-bottom: 20px;
  box-shadow: 0px 5px 25px 0px rgba(0, 0, 0, 0.1);
  overflow: hidden;
}

.why-us .faq-container .faq-item:last-child {
  margin-bottom: 0;
}

.why-us .faq-container .faq-item h3 {
  font-weight: 500;
  font-size: 17px;
  line-height: 24px;
  margin: 0 30px 0 0;
  transition: 0.3s;
  cursor: pointer;
}

.why-us .faq-container .faq-item h3 span {
  color: var(--accent-color);
  padding-right: 5px;
  font-weight: 600;
}

.why-us .faq-container .faq-item h3:hover {
  color: var(--accent-color);
}

.why-us .faq-container .faq-item .faq-content {
  display: grid;
  grid-template-rows: 0fr;
  transition: 0.3s ease-in-out;
  visibility: hidden;
  opacity: 0;
}

.why-us .faq-container .faq-item .faq-content p {
  margin-bottom: 0;
  overflow: hidden;
}

.why-us .faq-container .faq-item .faq-icon {
  position: absolute;
  top: 22px;
  left: 20px;
  font-size: 22px;
  line-height: 0;
  transition: 0.3s;
  color: var(--accent-color);
}

.why-us .faq-container .faq-item .faq-toggle {
  position: absolute;
  top: 20px;
  right: 20px;
  font-size: 16px;
  line-height: 0;
  transition: 0.3s;
  cursor: pointer;
}

.why-us .faq-container .faq-item .faq-toggle:hover {
  color: var(--accent-color);
}

.why-us .faq-container .faq-active h3 {
  color: var(--accent-color);
}

.why-us .faq-container .faq-active .faq-content {
  grid-template-rows: 1fr;
  visibility: visible;
  opacity: 1;
  padding-top: 10px;
}

.why-us .faq-container .faq-active .faq-toggle {
  transform: rotate(90deg);
  color: var(--accent-color);
}

.why-us .why-us-img {
  display: flex;
  align-items: center;
  justify-content: center;
}

.why-us .why-us-img img {
  max-height: 70%;
}

/*--------------------------------------------------------------
# Skills Section
--------------------------------------------------------------*/
.skills .content h3 {
  font-size: 2rem;
  font-weight: 700;
}

.skills .content p {
  color: color-mix(in srgb, var(--default-color), transparent 30%);
}

.skills .content p:last-child {
  margin-bottom: 0;
}

.skills .content ul {
  list-style: none;
  padding: 0;
}

.skills .content ul li {
  padding-bottom: 10px;
}

.skills .progress {
  height: 60px;
  display: block;
  background: none;
  border-radius: 0;
}

.skills .progress .skill {
  color: var(--default-color);
  padding: 0;
  margin: 0 0 6px 0;
  text-transform: uppercase;
  display: block;
  font-weight: 600;
  font-family: var(--heading-font);
}

.skills .progress .skill .val {
  float: right;
  font-style: normal;
}

.skills .progress-bar-wrap {
  background: color-mix(in srgb, var(--heading-color), transparent 90%);
  height: 10px;
}

.skills .progress-bar {
  width: 1px;
  height: 10px;
  transition: 0.9s;
  background-color: var(--heading-color);
}

/*--------------------------------------------------------------
# Services Section
--------------------------------------------------------------*/
.services .service-item {
  background-color: var(--surface-color);
  box-shadow: 0px 5px 90px 0px rgba(0, 0, 0, 0.1);
  padding: 50px 30px;
  transition: all ease-in-out 0.4s;
  height: 100%;
}

.services .service-item .icon {
  margin-bottom: 10px;
}

.services .service-item .icon i {
  color: var(--accent-color);
  font-size: 36px;
  transition: 0.3s;
}

.services .service-item h4 {
  font-weight: 700;
  margin-bottom: 15px;
  font-size: 20px;
}

.services .service-item h4 a {
  color: var(--heading-color);
  transition: ease-in-out 0.3s;
}

.services .service-item p {
  line-height: 24px;
  font-size: 14px;
  margin-bottom: 0;
}

.services .service-item:hover {
  transform: translateY(-10px);
}

.services .service-item:hover h4 a {
  color: var(--accent-color);
}

/*--------------------------------------------------------------
# Work Process Section
--------------------------------------------------------------*/
.work-process .steps-item {
  background: var(--surface-color);
  border-radius: 20px;
  height: 100%;
  transition: all 0.3s ease-in-out;
  box-shadow: 0 5px 20px color-mix(in srgb, var(--default-color), transparent 92%);
}

.work-process .steps-item .steps-image {
  border-radius: 20px 20px 0 0;
  overflow: hidden;
}

.work-process .steps-item:hover {
  transform: translateY(-10px);
  box-shadow: 0 15px 30px color-mix(in srgb, var(--accent-color), transparent 85%);
}

.work-process .steps-item:hover .steps-number {
  background: var(--accent-color);
  color: var(--contrast-color);
}

.work-process .steps-item:hover .steps-image img {
  transform: scale(1.1);
}

.work-process .steps-image {
  position: relative;
  height: 280px;
}

.work-process .steps-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}

.work-process .steps-content {
  position: relative;
  padding: 40px 30px 30px;
}

.work-process .steps-content .steps-number {
  position: absolute;
  left: 30px;
  top: -30px;
  width: 60px;
  height: 60px;
  background: var(--accent-color);
  color: var(--contrast-color);
  border-radius: 50%;
  font-family: var(--heading-font);
  font-size: 24px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease-in-out;
}

.work-process .steps-content h3 {
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 15px;
}

.work-process .steps-content p {
  font-size: 15px;
  color: color-mix(in srgb, var(--default-color), transparent 20%);
  margin-bottom: 25px;
}

.work-process .steps-features .feature-item {
  display: flex;
  align-items: center;
  margin-bottom: 12px;
}

.work-process .steps-features .feature-item:last-child {
  margin-bottom: 0;
}

.work-process .steps-features .feature-item i {
  color: var(--accent-color);
  font-size: 18px;
  margin-right: 10px;
}

.work-process .steps-features .feature-item span {
  font-size: 14px;
  color: color-mix(in srgb, var(--default-color), transparent 15%);
}

@media (max-width: 1199px) {
  .work-process .steps-image {
    height: 240px;
  }

  .work-process .steps-content {
    padding: 35px 25px 25px;
  }

  .work-process .steps-content h3 {
    font-size: 22px;
  }
}

@media (max-width: 991px) {
  .work-process .steps-item {
    margin-bottom: 30px;
  }

  .work-process .steps-image {
    height: 220px;
  }

  .work-process .steps-content {
    padding: 30px 20px 20px;
  }

  .work-process .steps-content .steps-number {
    width: 50px;
    height: 50px;
    font-size: 20px;
    left: 25px;
    top: -25px;
  }

  .work-process .steps-content h3 {
    font-size: 20px;
    margin-bottom: 12px;
  }

  .work-process .steps-content p {
    font-size: 14px;
    margin-bottom: 20px;
  }
}

/*--------------------------------------------------------------
# Call To Action Section
--------------------------------------------------------------*/
.call-to-action {
  padding: 120px 0;
  position: relative;
  clip-path: inset(0);
}

.call-to-action img {
  position: fixed;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
}

.call-to-action:before {
  content: "";
  background: color-mix(in srgb, var(--background-color), transparent 35%);
  position: absolute;
  inset: 0;
  z-index: 2;
}

.call-to-action .container {
  position: relative;
  z-index: 3;
}

.call-to-action h3 {
  color: var(--default-color);
  font-size: 28px;
  font-weight: 700;
}

.call-to-action p {
  color: var(--default-color);
}

.call-to-action .cta-btn {
  font-family: var(--heading-font);
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 12px 40px;
  border-radius: 50px;
  transition: 0.5s;
  margin: 10px;
  border: 2px solid var(--contrast-color);
  color: var(--contrast-color);
}

.call-to-action .cta-btn:hover {
  background: var(--accent-color);
  border: 2px solid var(--accent-color);
}

/*--------------------------------------------------------------
# Portfolio Section
--------------------------------------------------------------*/
.portfolio .portfolio-filters {
  padding: 0;
  margin: 0 auto 20px auto;
  list-style: none;
  text-align: center;
}

.portfolio .portfolio-filters li {
  cursor: pointer;
  display: inline-block;
  padding: 8px 20px 10px 20px;
  margin: 0;
  font-size: 15px;
  font-weight: 500;
  line-height: 1;
  margin-bottom: 5px;
  border-radius: 50px;
  transition: all 0.3s ease-in-out;
  font-family: var(--heading-font);
}

.portfolio .portfolio-filters li:hover,
.portfolio .portfolio-filters li.filter-active {
  color: var(--contrast-color);
  background-color: var(--accent-color);
}

.portfolio .portfolio-filters li:first-child {
  margin-left: 0;
}

.portfolio .portfolio-filters li:last-child {
  margin-right: 0;
}

@media (max-width: 575px) {
  .portfolio .portfolio-filters li {
    font-size: 14px;
    margin: 0 0 10px 0;
  }
}

.portfolio .portfolio-item {
  position: relative;
  overflow: hidden;
}

.portfolio .portfolio-item .portfolio-info {
  opacity: 0;
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: -100%;
  z-index: 3;
  transition: all ease-in-out 0.5s;
  background: color-mix(in srgb, var(--background-color), transparent 10%);
  padding: 15px;
}

.portfolio .portfolio-item .portfolio-info h4 {
  font-size: 18px;
  font-weight: 600;
  padding-right: 50px;
}

.portfolio .portfolio-item .portfolio-info p {
  color: color-mix(in srgb, var(--default-color), transparent 30%);
  font-size: 14px;
  margin-bottom: 0;
  padding-right: 50px;
}

.portfolio .portfolio-item .portfolio-info .preview-link,
.portfolio .portfolio-item .portfolio-info .details-link {
  position: absolute;
  right: 50px;
  font-size: 24px;
  top: calc(50% - 14px);
  color: color-mix(in srgb, var(--default-color), transparent 30%);
  transition: 0.3s;
  line-height: 0;
}

.portfolio .portfolio-item .portfolio-info .preview-link:hover,
.portfolio .portfolio-item .portfolio-info .details-link:hover {
  color: var(--accent-color);
}

.portfolio .portfolio-item .portfolio-info .details-link {
  right: 14px;
  font-size: 28px;
}

.portfolio .portfolio-item:hover .portfolio-info {
  opacity: 1;
  bottom: 0;
}

/*--------------------------------------------------------------
# Team Section
--------------------------------------------------------------*/
.team .team-member {
  background-color: var(--surface-color);
  box-shadow: 0px 2px 15px rgba(0, 0, 0, 0.1);
  position: relative;
  border-radius: 5px;
  transition: 0.5s;
  padding: 30px;
  height: 100%;
}

@media (max-width: 468px) {
  .team .team-member {
    flex-direction: column;
    justify-content: center !important;
    align-items: center !important;
  }
}

.team .team-member .pic {
  overflow: hidden;
  width: 150px;
  border-radius: 50%;
  flex-shrink: 0;
}

.team .team-member .pic img {
  transition: ease-in-out 0.3s;
}

.team .team-member:hover {
  transform: translateY(-10px);
}

.team .team-member .member-info {
  padding-left: 30px;
}

@media (max-width: 468px) {
  .team .team-member .member-info {
    padding: 30px 0 0 0;
    text-align: center;
  }
}

.team .team-member h4 {
  font-weight: 700;
  margin-bottom: 5px;
  font-size: 20px;
}

.team .team-member span {
  display: block;
  font-size: 15px;
  padding-bottom: 10px;
  position: relative;
  font-weight: 500;
}

.team .team-member span::after {
  content: "";
  position: absolute;
  display: block;
  width: 50px;
  height: 1px;
  background: color-mix(in srgb, var(--default-color), transparent 85%);
  bottom: 0;
  left: 0;
}

@media (max-width: 468px) {
  .team .team-member span::after {
    left: calc(50% - 25px);
  }
}

.team .team-member p {
  margin: 10px 0 0 0;
  font-size: 14px;
}

.team .team-member .social {
  margin-top: 12px;
  display: flex;
  align-items: center;
  justify-content: start;
  width: 100%;
}

@media (max-width: 468px) {
  .team .team-member .social {
    justify-content: center;
  }
}

.team .team-member .social a {
  background: color-mix(in srgb, var(--default-color), transparent 94%);
  transition: ease-in-out 0.3s;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50px;
  width: 36px;
  height: 36px;
}

.team .team-member .social a i {
  color: color-mix(in srgb, var(--default-color), transparent 20%);
  font-size: 16px;
  margin: 0 2px;
}

.team .team-member .social a:hover {
  background: var(--accent-color);
}

.team .team-member .social a:hover i {
  color: var(--contrast-color);
}

.team .team-member .social a+a {
  margin-left: 8px;
}

/*--------------------------------------------------------------
# Pricing Section
--------------------------------------------------------------*/
.pricing .pricing-item {
  background-color: var(--surface-color);
  box-shadow: 0 3px 20px -2px rgba(0, 0, 0, 0.1);
  border-top: 4px solid var(--background-color);
  padding: 60px 40px;
  height: 100%;
  border-radius: 5px;
}

.pricing h3 {
  font-weight: 600;
  margin-bottom: 15px;
  font-size: 20px;
}

.pricing h4 {
  color: var(--accent-color);
  font-size: 48px;
  font-weight: 400;
  font-family: var(--heading-font);
  margin-bottom: 0;
}

.pricing h4 sup {
  font-size: 28px;
}

.pricing h4 span {
  color: color-mix(in srgb, var(--default-color), transparent 50%);
  font-size: 18px;
}

.pricing ul {
  padding: 20px 0;
  list-style: none;
  color: color-mix(in srgb, var(--default-color), transparent 30%);
  text-align: left;
  line-height: 20px;
}

.pricing ul li {
  padding: 10px 0;
  display: flex;
  align-items: center;
}

.pricing ul i {
  color: #059652;
  font-size: 24px;
  padding-right: 3px;
}

.pricing ul .na {
  color: color-mix(in srgb, var(--default-color), transparent 60%);
}

.pricing ul .na i {
  color: color-mix(in srgb, var(--default-color), transparent 60%);
}

.pricing ul .na span {
  text-decoration: line-through;
}

.pricing .buy-btn {
  color: var(--accent-color);
  display: inline-block;
  padding: 8px 35px 10px 35px;
  border-radius: 50px;
  transition: none;
  font-size: 16px;
  font-weight: 500;
  font-family: var(--heading-font);
  transition: 0.3s;
  border: 1px solid var(--accent-color);
}

.pricing .buy-btn:hover {
  background: var(--accent-color);
  color: var(--contrast-color);
}

.pricing .featured {
  border-top-color: var(--accent-color);
}

.pricing .featured .buy-btn {
  background: var(--accent-color);
  color: var(--contrast-color);
}

@media (max-width: 992px) {
  .pricing .box {
    max-width: 60%;
    margin: 0 auto 30px auto;
  }
}

@media (max-width: 767px) {
  .pricing .box {
    max-width: 80%;
    margin: 0 auto 30px auto;
  }
}

@media (max-width: 420px) {
  .pricing .box {
    max-width: 100%;
    margin: 0 auto 30px auto;
  }
}

/*--------------------------------------------------------------
# Testimonials Section
--------------------------------------------------------------*/
.testimonials .section-header {
  margin-bottom: 40px;
}

.testimonials .testimonials-carousel,
.testimonials .testimonials-slider {
  overflow: hidden;
}

.testimonials .testimonial-item {
  text-align: center;
}

.testimonials .testimonial-item .testimonial-img {
  width: 120px;
  border-radius: 50%;
  border: 4px solid var(--background-color);
  margin: 0 auto;
}

.testimonials .testimonial-item h3 {
  font-size: 20px;
  font-weight: bold;
  margin: 10px 0 5px 0;
}

.testimonials .testimonial-item h4 {
  font-size: 14px;
  color: color-mix(in srgb, var(--default-color), transparent 40%);
  margin: 0 0 15px 0;
}

.testimonials .testimonial-item .stars {
  margin-bottom: 15px;
}

.testimonials .testimonial-item .stars i {
  color: #ffc107;
  margin: 0 1px;
}

.testimonials .testimonial-item .quote-icon-left,
.testimonials .testimonial-item .quote-icon-right {
  color: color-mix(in srgb, var(--accent-color), transparent 50%);
  font-size: 26px;
  line-height: 0;
}

.testimonials .testimonial-item .quote-icon-left {
  display: inline-block;
  left: -5px;
  position: relative;
}

.testimonials .testimonial-item .quote-icon-right {
  display: inline-block;
  right: -5px;
  position: relative;
  top: 10px;
  transform: scale(-1, -1);
}

.testimonials .testimonial-item p {
  font-style: italic;
  margin: 0 auto 15px auto;
}

.testimonials .swiper-wrapper {
  height: auto;
}

.testimonials .swiper-pagination {
  margin-top: 20px;
  position: relative;
}

.testimonials .swiper-pagination .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  opacity: 1;
  background-color: color-mix(in srgb, var(--default-color), transparent 85%);
}

.testimonials .swiper-pagination .swiper-pagination-bullet-active {
  background-color: var(--accent-color);
}

@media (min-width: 992px) {
  .testimonials .testimonial-item p {
    width: 80%;
  }
}

/*--------------------------------------------------------------
# Faq 2 Section
--------------------------------------------------------------*/
.faq-2 .faq-container {
  margin-top: 15px;
}

.faq-2 .faq-container .faq-item {
  background-color: var(--surface-color);
  position: relative;
  padding: 20px;
  margin-bottom: 20px;
  overflow: hidden;
}

.faq-2 .faq-container .faq-item:last-child {
  margin-bottom: 0;
}

.faq-2 .faq-container .faq-item h3 {
  font-weight: 600;
  font-size: 18px;
  line-height: 24px;
  margin: 0 30px 0 32px;
  transition: 0.3s;
  cursor: pointer;
}

.faq-2 .faq-container .faq-item h3 span {
  color: var(--accent-color);
  padding-right: 5px;
}

.faq-2 .faq-container .faq-item h3:hover {
  color: var(--accent-color);
}

.faq-2 .faq-container .faq-item .faq-content {
  display: grid;
  grid-template-rows: 0fr;
  transition: 0.3s ease-in-out;
  visibility: hidden;
  opacity: 0;
}

.faq-2 .faq-container .faq-item .faq-content p {
  margin-bottom: 0;
  overflow: hidden;
}

.faq-2 .faq-container .faq-item .faq-icon {
  position: absolute;
  top: 22px;
  left: 20px;
  font-size: 20px;
  line-height: 0;
  transition: 0.3s;
  color: var(--accent-color);
}

.faq-2 .faq-container .faq-item .faq-toggle {
  position: absolute;
  top: 20px;
  right: 20px;
  font-size: 16px;
  line-height: 0;
  transition: 0.3s;
  cursor: pointer;
}

.faq-2 .faq-container .faq-item .faq-toggle:hover {
  color: var(--accent-color);
}

.faq-2 .faq-container .faq-active h3 {
  color: var(--accent-color);
}

.faq-2 .faq-container .faq-active .faq-content {
  grid-template-rows: 1fr;
  visibility: visible;
  opacity: 1;
  padding-top: 10px;
}

.faq-2 .faq-container .faq-active .faq-toggle {
  transform: rotate(90deg);
  color: var(--accent-color);
}

/*--------------------------------------------------------------
# Subscribe Section
--------------------------------------------------------------*/
.subscribe .container {
  padding: 80px 80px 0 80px;
  background: color-mix(in srgb, var(--default-color), transparent 96%);
  border-radius: 15px;
}

@media (max-width: 992px) {
  .subscribe .container {
    padding: 60px 60px 0 60px;
  }
}

@media (max-width: 575px) {
  .subscribe .container {
    padding: 25px 15px 0 15px;
    border-radius: 0;
  }
}

.subscribe .cta-content h2 {
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 1rem;
}

.subscribe .cta-content p {
  font-size: 1.1rem;
  margin-bottom: 2rem;
}

.subscribe .cta-form .form-control {
  height: 50px;
  border-radius: 25px 0 0 25px;
  border: 1px solid var(--accent-color);
  padding-left: 20px;
}

.subscribe .cta-form .form-control:focus {
  box-shadow: none;
  border-color: var(--accent-color);
}

.subscribe .cta-form .btn {
  height: 50px;
  border-radius: 0 25px 25px 0;
  background-color: var(--accent-color);
  border-color: var(--accent-color);
  color: var(--contrast-color);
  padding: 0 30px;
  font-weight: 600;
  transition: all 0.3s ease;
}

.subscribe .cta-form .btn:hover {
  background-color: color-mix(in srgb, var(--accent-color), black 10%);
  border-color: color-mix(in srgb, var(--accent-color), black 10%);
}

@media (max-width: 575px) {
  .subscribe .cta-form .btn {
    padding: 0 15px;
  }
}

@media (max-width: 991px) {
  .subscribe .cta-content {
    text-align: center;
    margin-bottom: 2rem;
  }

  .subscribe .cta-image {
    text-align: center;
  }
}

/*--------------------------------------------------------------
# Recent Blog Postst Section
--------------------------------------------------------------*/
.recent-blog-postst .post-item {
  background: var(--surface-color);
  box-shadow: 0px 2px 20px rgba(0, 0, 0, 0.1);
  transition: 0.3s;
}

.recent-blog-postst .post-item .post-img img {
  transition: 0.5s;
}

.recent-blog-postst .post-item .post-date {
  position: absolute;
  right: 0;
  bottom: 0;
  background-color: var(--accent-color);
  color: var(--contrast-color);
  text-transform: uppercase;
  font-size: 13px;
  padding: 6px 12px;
  font-weight: 500;
}

.recent-blog-postst .post-item .post-content {
  padding: 30px;
}

.recent-blog-postst .post-item .post-title {
  color: var(--heading-color);
  font-size: 20px;
  font-weight: 700;
  transition: 0.3s;
  margin-bottom: 15px;
}

.recent-blog-postst .post-item .meta i {
  font-size: 16px;
  color: var(--accent-color);
}

.recent-blog-postst .post-item .meta span {
  font-size: 15px;
  color: color-mix(in srgb, var(--default-color), transparent 50%);
}

.recent-blog-postst .post-item hr {
  color: color-mix(in srgb, var(--default-color), transparent 80%);
  margin: 20px 0;
}

.recent-blog-postst .post-item .readmore {
  display: flex;
  align-items: center;
  font-weight: 600;
  line-height: 1;
  transition: 0.3s;
  color: color-mix(in srgb, var(--default-color), transparent 40%);
}

.recent-blog-postst .post-item .readmore i {
  line-height: 0;
  margin-left: 6px;
  font-size: 16px;
}

.recent-blog-postst .post-item:hover .post-title,
.recent-blog-postst .post-item:hover .readmore {
  color: var(--accent-color);
}

.recent-blog-postst .post-item:hover .post-img img {
  transform: scale(1.1);
}

/*--------------------------------------------------------------
# Contact Section
--------------------------------------------------------------*/
.contact .info-wrap {
  background-color: var(--surface-color);
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.1);
  border-top: 3px solid var(--accent-color);
  border-bottom: 3px solid var(--accent-color);
  padding: 30px;
  height: 100%;
}

@media (max-width: 575px) {
  .contact .info-wrap {
    padding: 20px;
  }
}

.contact .info-item {
  margin-bottom: 40px;
}

.contact .info-item i {
  font-size: 20px;
  color: var(--accent-color);
  background: color-mix(in srgb, var(--accent-color), transparent 92%);
  width: 44px;
  height: 44px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50px;
  transition: all 0.3s ease-in-out;
  margin-right: 15px;
}

.contact .info-item h3 {
  padding: 0;
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 5px;
}

.contact .info-item p {
  padding: 0;
  margin-bottom: 0;
  font-size: 14px;
}

.contact .info-item:hover i {
  background: var(--accent-color);
  color: var(--contrast-color);
}

.contact .php-email-form {
  background-color: var(--surface-color);
  height: 100%;
  padding: 30px;
  border-top: 3px solid var(--accent-color);
  border-bottom: 3px solid var(--accent-color);
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.1);
}

@media (max-width: 575px) {
  .contact .php-email-form {
    padding: 20px;
  }
}

.contact .php-email-form input[type=text],
.contact .php-email-form input[type=email],
.contact .php-email-form textarea {
  font-size: 14px;
  padding: 10px 15px;
  box-shadow: none;
  border-radius: 0;
  color: var(--default-color);
  background-color: color-mix(in srgb, var(--background-color), transparent 50%);
  border-color: color-mix(in srgb, var(--default-color), transparent 80%);
}

.contact .php-email-form input[type=text]:focus,
.contact .php-email-form input[type=email]:focus,
.contact .php-email-form textarea:focus {
  border-color: var(--accent-color);
}

.contact .php-email-form input[type=text]::placeholder,
.contact .php-email-form input[type=email]::placeholder,
.contact .php-email-form textarea::placeholder {
  color: color-mix(in srgb, var(--default-color), transparent 70%);
}

.contact .php-email-form button[type=submit] {
  color: var(--contrast-color);
  background: var(--accent-color);
  border: 0;
  padding: 10px 30px;
  transition: 0.4s;
  border-radius: 50px;
}

.contact .php-email-form button[type=submit]:hover {
  background: color-mix(in srgb, var(--accent-color), transparent 25%);
}

/*--------------------------------------------------------------
# Portfolio Details Section
--------------------------------------------------------------*/
.portfolio-details .portfolio-details-slider img {
  width: 100%;
}

.portfolio-details .portfolio-details-slider .swiper-pagination {
  margin-top: 20px;
  position: relative;
}

.portfolio-details .portfolio-details-slider .swiper-pagination .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  background-color: color-mix(in srgb, var(--default-color), transparent 85%);
  opacity: 1;
}

.portfolio-details .portfolio-details-slider .swiper-pagination .swiper-pagination-bullet-active {
  background-color: var(--accent-color);
}

.portfolio-details .portfolio-info {
  background-color: var(--surface-color);
  padding: 30px;
  box-shadow: 0px 0 30px rgba(0, 0, 0, 0.1);
}

.portfolio-details .portfolio-info h3 {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid color-mix(in srgb, var(--default-color), transparent 85%);
}

.portfolio-details .portfolio-info ul {
  list-style: none;
  padding: 0;
  font-size: 15px;
}

.portfolio-details .portfolio-info ul li+li {
  margin-top: 10px;
}

.portfolio-details .portfolio-description {
  padding-top: 30px;
}

.portfolio-details .portfolio-description h2 {
  font-size: 26px;
  font-weight: 700;
  margin-bottom: 20px;
}

.portfolio-details .portfolio-description p {
  padding: 0;
  color: color-mix(in srgb, var(--default-color), transparent 30%);
}

/*--------------------------------------------------------------
# Service Details Section
--------------------------------------------------------------*/
.service-details .services-list {
  background-color: var(--surface-color);
  padding: 10px 30px;
  border: 1px solid color-mix(in srgb, var(--default-color), transparent 90%);
  margin-bottom: 20px;
}

.service-details .services-list a {
  display: block;
  line-height: 1;
  padding: 8px 0 8px 15px;
  border-left: 3px solid color-mix(in srgb, var(--default-color), transparent 70%);
  margin: 20px 0;
  color: color-mix(in srgb, var(--default-color), transparent 20%);
  transition: 0.3s;
}

.service-details .services-list a.active {
  color: var(--heading-color);
  font-weight: 700;
  border-color: var(--accent-color);
}

.service-details .services-list a:hover {
  border-color: var(--accent-color);
}

.service-details .services-img {
  margin-bottom: 20px;
}

.service-details h3 {
  font-size: 26px;
  font-weight: 700;
}

.service-details h4 {
  font-size: 20px;
  font-weight: 700;
}

.service-details p {
  font-size: 15px;
}

.service-details ul {
  list-style: none;
  padding: 0;
  font-size: 15px;
}

.service-details ul li {
  padding: 5px 0;
  display: flex;
  align-items: center;
}

.service-details ul i {
  font-size: 20px;
  margin-right: 8px;
  color: var(--accent-color);
}

/*--------------------------------------------------------------
# Blog Posts Section
--------------------------------------------------------------*/
.blog-posts article {
  background-color: var(--surface-color);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
  padding: 30px;
  height: 100%;
}

.blog-posts .post-img {
  max-height: 440px;
  margin: -30px -30px 0 -30px;
  overflow: hidden;
}

.blog-posts .title {
  font-size: 24px;
  font-weight: 700;
  padding: 0;
  margin: 30px 0;
}

.blog-posts .title a {
  color: var(--heading-color);
  transition: 0.3s;
}

.blog-posts .title a:hover {
  color: var(--accent-color);
}

.blog-posts .meta-top {
  margin-top: 20px;
  color: color-mix(in srgb, var(--default-color), transparent 40%);
}

.blog-posts .meta-top ul {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  align-items: center;
  padding: 0;
  margin: 0;
}

.blog-posts .meta-top ul li+li {
  padding-left: 20px;
}

.blog-posts .meta-top i {
  font-size: 16px;
  margin-right: 8px;
  line-height: 0;
  color: color-mix(in srgb, var(--default-color), transparent 20%);
}

.blog-posts .meta-top a {
  color: color-mix(in srgb, var(--default-color), transparent 40%);
  font-size: 14px;
  display: inline-block;
  line-height: 1;
}

.blog-posts .content {
  margin-top: 20px;
}

.blog-posts .content .read-more {
  text-align: right;
}

.blog-posts .content .read-more a {
  background: var(--accent-color);
  color: var(--contrast-color);
  display: inline-block;
  padding: 8px 30px;
  transition: 0.3s;
  font-size: 14px;
  border-radius: 4px;
}

.blog-posts .content .read-more a:hover {
  background: color-mix(in srgb, var(--accent-color), transparent 20%);
}

/*--------------------------------------------------------------
# Pagination 2 Section
--------------------------------------------------------------*/
.pagination-2 {
  padding-top: 0;
  color: color-mix(in srgb, var(--default-color), transparent 40%);
}

.pagination-2 ul {
  display: flex;
  padding: 0;
  margin: 0;
  list-style: none;
}

.pagination-2 li {
  margin: 0 5px;
  transition: 0.3s;
}

.pagination-2 li a {
  color: color-mix(in srgb, var(--default-color), transparent 40%);
  padding: 7px 16px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.pagination-2 li a.active,
.pagination-2 li a:hover {
  background: var(--accent-color);
  color: var(--contrast-color);
}

.pagination-2 li a.active a,
.pagination-2 li a:hover a {
  color: var(--contrast-color);
}

/*--------------------------------------------------------------
# Blog Details Section
--------------------------------------------------------------*/
.blog-details {
  max-width: 1000px;
  margin: 0 auto;
}

.blog-details .hero-img {
  position: relative;
  width: 100%;
  height: 500px;
  margin: 0 auto 3rem;
  border-radius: 16px;
  overflow: hidden;
}

.blog-details .hero-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.blog-details .hero-img .meta-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 2rem;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.7), transparent);
}

.blog-details .hero-img .meta-overlay .meta-categories .category {
  color: var(--contrast-color);
  background-color: var(--accent-color);
  padding: 0.4rem 1rem;
  border-radius: 30px;
  font-size: 0.9rem;
  text-decoration: none;
  transition: all 0.3s ease;
}

.blog-details .hero-img .meta-overlay .meta-categories .category:hover {
  background-color: color-mix(in srgb, var(--accent-color), transparent 15%);
}

.blog-details .hero-img .meta-overlay .meta-categories .divider {
  color: var(--contrast-color);
  margin: 0 0.75rem;
}

.blog-details .hero-img .meta-overlay .meta-categories .reading-time {
  color: var(--contrast-color);
  font-size: 0.9rem;
}

.blog-details .hero-img .meta-overlay .meta-categories .reading-time i {
  margin-right: 0.3rem;
}

@media (max-width: 768px) {
  .blog-details .hero-img {
    height: 350px;
    margin-top: -30px;
    margin-bottom: 2rem;
  }
}

.blog-details .article-content {
  padding: 0 1rem;
}

.blog-details .article-content .content-header {
  margin-bottom: 3rem;
}

.blog-details .article-content .content-header .title {
  font-size: 2.8rem;
  line-height: 1.2;
  margin-bottom: 2rem;
  font-weight: 700;
  color: var(--heading-color);
}

@media (max-width: 768px) {
  .blog-details .article-content .content-header .title {
    font-size: 2rem;
  }
}

.blog-details .article-content .content-header .author-info {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid color-mix(in srgb, var(--default-color), transparent 90%);
}

.blog-details .article-content .content-header .author-info .author-details {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.blog-details .article-content .content-header .author-info .author-details .author-img {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  object-fit: cover;
}

.blog-details .article-content .content-header .author-info .author-details .info h4 {
  margin: 0;
  font-size: 1.1rem;
  color: var(--heading-color);
}

.blog-details .article-content .content-header .author-info .author-details .info .role {
  font-size: 0.9rem;
  color: color-mix(in srgb, var(--default-color), transparent 30%);
}

.blog-details .article-content .content-header .author-info .post-meta {
  color: color-mix(in srgb, var(--default-color), transparent 30%);
  font-size: 0.95rem;
}

.blog-details .article-content .content-header .author-info .post-meta i {
  margin-right: 0.3rem;
}

.blog-details .article-content .content-header .author-info .post-meta .divider {
  margin: 0 0.75rem;
}

.blog-details .article-content .content {
  font-size: 1.15rem;
  line-height: 1.8;
  color: color-mix(in srgb, var(--default-color), transparent 10%);
}

.blog-details .article-content .content .lead {
  font-size: 1.3rem;
  color: var(--heading-color);
  margin-bottom: 2rem;
  font-weight: 500;
}

.blog-details .article-content .content h2 {
  font-size: 2rem;
  color: var(--heading-color);
  margin: 3rem 0 1.5rem;
}

.blog-details .article-content .content p {
  margin-bottom: 1.5rem;
}

.blog-details .article-content .content ul {
  margin-bottom: 2rem;
  padding-left: 1.2rem;
}

.blog-details .article-content .content ul li {
  margin-bottom: 0.75rem;
  position: relative;
}

.blog-details .article-content .content .content-image {
  margin: 2.5rem 0;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08);
}

.blog-details .article-content .content .content-image.right-aligned {
  float: right;
  max-width: 450px;
  margin: 1rem 0 2rem 2rem;
}

@media (max-width: 768px) {
  .blog-details .article-content .content .content-image.right-aligned {
    float: none;
    max-width: 100%;
    margin: 2rem 0;
  }
}

.blog-details .article-content .content .content-image img {
  width: 100%;
  height: auto;
}

.blog-details .article-content .content .content-image figcaption {
  padding: 1rem;
  text-align: center;
  font-size: 0.9rem;
  color: color-mix(in srgb, var(--default-color), transparent 30%);
  background-color: color-mix(in srgb, var(--surface-color), transparent 50%);
}

.blog-details .article-content .content .highlight-box {
  background: color-mix(in srgb, var(--accent-color), transparent 95%);
  border-radius: 12px;
  padding: 2rem;
  margin: 2.5rem 0;
}

.blog-details .article-content .content .highlight-box h3 {
  color: var(--heading-color);
  margin-bottom: 1.5rem;
  font-size: 1.5rem;
}

.blog-details .article-content .content .highlight-box .trend-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.blog-details .article-content .content .highlight-box .trend-list li {
  display: flex;
  align-items: center;
  margin-bottom: 1rem;
  padding: 0.5rem 0;
}

.blog-details .article-content .content .highlight-box .trend-list li i {
  color: var(--accent-color);
  font-size: 1.5rem;
  margin-right: 1rem;
}

.blog-details .article-content .content .highlight-box .trend-list li span {
  color: var(--heading-color);
  font-weight: 500;
}

.blog-details .article-content .content .content-grid {
  margin: 3rem 0;
}

.blog-details .article-content .content .content-grid .info-card {
  background: var(--surface-color);
  border-radius: 12px;
  padding: 2rem;
  height: 100%;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.05);
  transition: transform 0.3s ease;
}

.blog-details .article-content .content .content-grid .info-card:hover {
  transform: translateY(-5px);
}

.blog-details .article-content .content .content-grid .info-card i {
  font-size: 2rem;
  color: var(--accent-color);
  margin-bottom: 1rem;
}

.blog-details .article-content .content .content-grid .info-card h4 {
  color: var(--heading-color);
  margin-bottom: 1rem;
  font-size: 1.3rem;
}

.blog-details .article-content .content .content-grid .info-card p {
  margin: 0;
  font-size: 1rem;
  line-height: 1.6;
}

.blog-details .article-content .content blockquote {
  position: relative;
  margin: 3rem 0;
  padding: 2rem 3rem;
  background: var(--surface-color);
  border-radius: 12px;
  box-shadow: 0 3px 15px rgba(0, 0, 0, 0.05);
}

.blog-details .article-content .content blockquote::before {
  content: '"';
  position: absolute;
  top: -20px;
  left: 20px;
  font-size: 8rem;
  color: color-mix(in srgb, var(--accent-color), transparent 85%);
  font-family: serif;
  line-height: 1;
}

.blog-details .article-content .content blockquote p {
  font-size: 1.3rem;
  font-style: italic;
  color: var(--heading-color);
  margin: 0 0 1rem;
  position: relative;
}

.blog-details .article-content .content blockquote cite {
  font-style: normal;
  color: color-mix(in srgb, var(--default-color), transparent 30%);
  font-size: 0.95rem;
  display: block;
}

.blog-details .article-content .meta-bottom {
  margin-top: 4rem;
  padding-top: 2rem;
  border-top: 1px solid color-mix(in srgb, var(--default-color), transparent 90%);
  display: grid;
  gap: 2rem;
}

.blog-details .article-content .meta-bottom h4 {
  color: var(--heading-color);
  font-size: 1.1rem;
  margin-bottom: 1rem;
}

.blog-details .article-content .meta-bottom .tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.blog-details .article-content .meta-bottom .tags .tag {
  background: color-mix(in srgb, var(--accent-color), transparent 90%);
  color: var(--accent-color);
  padding: 0.5rem 1rem;
  border-radius: 30px;
  font-size: 0.9rem;
  text-decoration: none;
  transition: all 0.3s ease;
}

.blog-details .article-content .meta-bottom .tags .tag:hover {
  background: var(--accent-color);
  color: var(--contrast-color);
}

.blog-details .article-content .meta-bottom .social-links {
  display: flex;
  gap: 1rem;
}

.blog-details .article-content .meta-bottom .social-links a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent-color), transparent 90%);
  color: var(--accent-color);
  transition: all 0.3s ease;
}

.blog-details .article-content .meta-bottom .social-links a:hover {
  background: var(--accent-color);
  color: var(--contrast-color);
  transform: translateY(-2px);
}

.blog-details .article-content .meta-bottom .social-links a i {
  font-size: 1.2rem;
}

/*--------------------------------------------------------------
# Blog Comments Section
--------------------------------------------------------------*/
.blog-comments {
  padding: 20px 0;
}

.blog-comments .comments-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 40px;
  padding-bottom: 20px;
  border-bottom: 1px solid color-mix(in srgb, var(--default-color), transparent 92%);
}

.blog-comments .comments-header .title {
  color: var(--heading-color);
  font-size: 32px;
  font-weight: 700;
  font-family: var(--heading-font);
  margin: 0;
}

.blog-comments .comments-header .comments-stats {
  background: color-mix(in srgb, var(--default-color), transparent 95%);
  padding: 8px 20px;
  border-radius: 30px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.blog-comments .comments-header .comments-stats .count {
  font-size: 18px;
  font-weight: 700;
}

.blog-comments .comments-header .comments-stats .label {
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.blog-comments .comments-container {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.blog-comments .comment-thread {
  position: relative;
}

.blog-comments .comment-thread:not(:last-child)::after {
  content: "";
  position: absolute;
  left: 25px;
  top: 80px;
  bottom: 0;
  width: 2px;
  background: linear-gradient(to bottom, color-mix(in srgb, var(--accent-color), transparent 40%), color-mix(in srgb, var(--accent-color), transparent 90%));
  z-index: 0;
}

@media (min-width: 768px) {
  .blog-comments .comment-thread:not(:last-child)::after {
    left: 35px;
  }
}

.blog-comments .comment-box {
  position: relative;
  transition: all 0.3s ease;
}

.blog-comments .comment-box.reply {
  margin-left: 50px;
  margin-top: 25px;
}

@media (min-width: 768px) {
  .blog-comments .comment-box.reply {
    margin-left: 70px;
  }
}

.blog-comments .comment-wrapper {
  display: flex;
  gap: 20px;
  position: relative;
}

.blog-comments .avatar-wrapper {
  position: relative;
  flex-shrink: 0;
}

.blog-comments .avatar-wrapper img {
  width: 50px;
  height: 50px;
  border-radius: 15px;
  object-fit: cover;
  border: 3px solid var(--surface-color);
  box-shadow: 0 3px 15px rgba(0, 0, 0, 0.05);
  transition: transform 0.3s ease;
}

@media (min-width: 768px) {
  .blog-comments .avatar-wrapper img {
    width: 70px;
    height: 70px;
  }
}

.blog-comments .avatar-wrapper img:hover {
  transform: scale(1.05);
}

.blog-comments .avatar-wrapper .status-indicator {
  position: absolute;
  bottom: -2px;
  right: -2px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: #4CAF50;
  border: 2px solid var(--surface-color);
  z-index: 1;
}

.blog-comments .comment-content {
  flex: 1;
  background-color: var(--surface-color);
  border-radius: 20px;
  padding: 25px;
  box-shadow: 0 3px 15px rgba(0, 0, 0, 0.03);
  transition: all 0.3s ease;
}

.blog-comments .comment-content:hover {
  transform: translateY(-2px);
  box-shadow: 0 5px 25px rgba(0, 0, 0, 0.05);
}

.blog-comments .comment-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 15px;
}

.blog-comments .comment-header .user-info h4 {
  color: var(--heading-color);
  font-size: 18px;
  font-weight: 600;
  margin: 0 0 5px;
}

.blog-comments .comment-header .user-info .time-badge {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 14px;
  color: color-mix(in srgb, var(--default-color), transparent 40%);
}

.blog-comments .comment-header .user-info .time-badge i {
  font-size: 13px;
}

.blog-comments .comment-header .engagement .likes {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  background-color: color-mix(in srgb, var(--accent-color), transparent 92%);
  border-radius: 20px;
  color: var(--accent-color);
  font-size: 14px;
  font-weight: 500;
}

.blog-comments .comment-header .engagement .likes i {
  font-size: 13px;
}

.blog-comments .comment-body p {
  color: var(--default-color);
  font-size: 15px;
  line-height: 1.6;
  margin-bottom: 20px;
}

.blog-comments .comment-actions {
  display: flex;
  gap: 15px;
}

.blog-comments .comment-actions .action-btn {
  background: none;
  border: none;
  padding: 8px 15px;
  border-radius: 20px;
  color: color-mix(in srgb, var(--default-color), transparent 40%);
  font-size: 14px;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  transition: all 0.3s ease;
}

.blog-comments .comment-actions .action-btn i {
  font-size: 15px;
  transition: all 0.3s ease;
}

.blog-comments .comment-actions .action-btn:hover {
  color: var(--accent-color);
  background-color: color-mix(in srgb, var(--accent-color), transparent 92%);
}

.blog-comments .comment-actions .action-btn:hover.like-btn i {
  transform: scale(1.2);
  color: #ff4b6e;
}

.blog-comments .comment-actions .action-btn:hover.reply-btn i {
  transform: translateX(-3px);
}

.blog-comments .comment-actions .action-btn:hover.share-btn i {
  transform: translateY(-2px);
}

.blog-comments .comment-actions .action-btn.like-btn.active {
  color: #ff4b6e;
}

.blog-comments .replies-container {
  margin-top: 25px;
  display: flex;
  flex-direction: column;
  gap: 25px;
}

@media (max-width: 768px) {
  .blog-comments .comments-header {
    margin-bottom: 30px;
  }

  .blog-comments .comments-header .title {
    font-size: 24px;
  }

  .blog-comments .comments-header .comments-stats {
    padding: 6px 15px;
  }

  .blog-comments .comments-header .comments-stats .count {
    font-size: 20px;
  }

  .blog-comments .comments-header .comments-stats .label {
    font-size: 12px;
  }

  .blog-comments .comment-content {
    padding: 20px;
  }

  .blog-comments .comment-header .user-info h4 {
    font-size: 16px;
  }

  .blog-comments .comment-header .user-info .time-badge {
    font-size: 13px;
  }

  .blog-comments .comment-body p {
    font-size: 14px;
  }

  .blog-comments .comment-actions .action-btn {
    padding: 6px 12px;
    font-size: 13px;
  }
}

/*--------------------------------------------------------------
# Blog Comment Form Section
--------------------------------------------------------------*/
.blog-comment-form {
  max-width: 900px;
  margin: 30px auto 0 auto;
  padding-top: 10px;
}

.blog-comment-form form {
  padding: 2rem;
  background-color: var(--surface-color);
  border-radius: 12px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}

.blog-comment-form .form-header {
  text-align: center;
  margin-bottom: 2rem;
}

.blog-comment-form .form-header h3 {
  color: var(--heading-color);
  font-size: 1.75rem;
  margin-bottom: 0.5rem;
}

.blog-comment-form .form-header p {
  color: color-mix(in srgb, var(--default-color), transparent 30%);
  font-size: 0.9375rem;
}

.blog-comment-form .input-group {
  margin-bottom: 1rem;
  position: relative;
}

.blog-comment-form .input-group label {
  display: block;
  margin-bottom: 0.5rem;
  color: var(--heading-color);
  font-weight: 500;
  font-size: 0.875rem;
}

.blog-comment-form .input-group input,
.blog-comment-form .input-group textarea {
  width: 100%;
  padding: 0.875rem 1rem;
  border: 2px solid color-mix(in srgb, var(--default-color), transparent 85%);
  border-radius: 8px;
  background-color: var(--surface-color);
  color: var(--default-color);
  font-size: 0.9375rem;
  transition: all 0.2s ease;
}

.blog-comment-form .input-group input::placeholder,
.blog-comment-form .input-group textarea::placeholder {
  color: color-mix(in srgb, var(--default-color), transparent 60%);
}

.blog-comment-form .input-group input:hover,
.blog-comment-form .input-group textarea:hover {
  border-color: color-mix(in srgb, var(--default-color), transparent 70%);
}

.blog-comment-form .input-group input:focus,
.blog-comment-form .input-group textarea:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent-color), transparent 90%);
}

.blog-comment-form .input-group input:invalid:not(:placeholder-shown),
.blog-comment-form .input-group textarea:invalid:not(:placeholder-shown) {
  border-color: #dc3545;
}

.blog-comment-form .input-group input:invalid:not(:placeholder-shown)+.error-text,
.blog-comment-form .input-group textarea:invalid:not(:placeholder-shown)+.error-text {
  opacity: 1;
  transform: translateY(0);
}

.blog-comment-form .input-group textarea {
  min-height: 120px;
  resize: vertical;
}

.blog-comment-form .input-group .error-text {
  position: absolute;
  bottom: -20px;
  left: 0;
  color: #dc3545;
  font-size: 0.75rem;
  opacity: 0;
  transform: translateY(-10px);
  transition: all 0.2s ease;
}

.blog-comment-form button[type=submit] {
  background: var(--accent-color);
  color: var(--contrast-color);
  padding: 0.875rem 2.5rem;
  border: none;
  border-radius: 8px;
  font-size: 1rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.3s ease;
}

.blog-comment-form button[type=submit]:hover {
  background: color-mix(in srgb, var(--accent-color), transparent 15%);
  transform: translateY(-2px);
}

.blog-comment-form button[type=submit]:active {
  transform: translateY(0);
}

@media (max-width: 768px) {
  .blog-comment-form {
    padding: 1.5rem;
  }

  .blog-comment-form .form-header h3 {
    font-size: 1.5rem;
  }

  .blog-comment-form button[type=submit] {
    width: 100%;
    padding: 0.875rem 1rem;
  }
}

/*--------------------------------------------------------------
# Starter Section Section
--------------------------------------------------------------*/
.starter-section {
  /* Add your styles here */
}

/*--------------------------------------------------------------
# Error 404 Section
--------------------------------------------------------------*/
.error-404 {
  padding: 80px 0;
  margin: 0 auto;
}

.error-404 .error-icon {
  font-size: 5rem;
  color: color-mix(in srgb, var(--accent-color), transparent 15%);
}

.error-404 .error-code {
  font-size: clamp(6rem, 15vw, 12rem);
  font-weight: 800;
  color: color-mix(in srgb, var(--heading-color), transparent 10%);
  font-family: var(--heading-font);
  line-height: 1;
}

.error-404 .error-title {
  font-size: 2rem;
  color: var(--heading-color);
  font-weight: 600;
}

.error-404 .error-text {
  font-size: 1.1rem;
  color: color-mix(in srgb, var(--default-color), transparent 20%);
  max-width: 600px;
  margin: 0 auto;
}

.error-404 .search-box {
  max-width: 500px;
  margin: 0 auto;
}

.error-404 .search-box .input-group {
  border-radius: 50px;
  overflow: hidden;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
}

.error-404 .search-box .form-control {
  border: 1px solid color-mix(in srgb, var(--default-color), transparent 90%);
  padding: 0.75rem 1.5rem;
  font-size: 1rem;
  color: var(--default-color);
  background-color: var(--surface-color);
  border-radius: 50px;
}

.error-404 .search-box .form-control:focus {
  box-shadow: none;
  border-color: var(--accent-color);
}

.error-404 .search-box .form-control::placeholder {
  color: color-mix(in srgb, var(--default-color), transparent 60%);
}

.error-404 .search-box .search-btn {
  background-color: var(--accent-color);
  color: var(--contrast-color);
  border: none;
  padding: 0.75rem 1.5rem;
  transition: all 0.3s ease;
}

.error-404 .search-box .search-btn:hover {
  background-color: color-mix(in srgb, var(--accent-color), transparent 15%);
}

.error-404 .error-action .btn-primary {
  padding: 0.75rem 2rem;
  font-size: 1.1rem;
  background-color: var(--accent-color);
  border: none;
  color: var(--contrast-color);
  border-radius: 50px;
  transition: all 0.3s ease;
}

.error-404 .error-action .btn-primary:hover {
  background-color: color-mix(in srgb, var(--accent-color), transparent 15%);
  transform: translateY(-2px);
}

@media (max-width: 768px) {
  .error-404 {
    padding: 60px 0;
  }

  .error-404 .error-code {
    font-size: clamp(4rem, 12vw, 8rem);
  }

  .error-404 .error-title {
    font-size: 1.5rem;
  }

  .error-404 .error-text {
    font-size: 1rem;
    padding: 0 20px;
  }

  .error-404 .search-box {
    margin: 0 20px;
  }
}

/*--------------------------------------------------------------
# Widgets
--------------------------------------------------------------*/
.widgets-container {
  margin: 60px 0 30px 0;
}

.widget-title {
  color: var(--heading-color);
  font-size: 20px;
  font-weight: 600;
  padding: 0 0 0 10px;
  margin: 0 0 20px 0;
  border-left: 4px solid var(--accent-color);
}

.widget-item {
  margin-bottom: 30px;
  background-color: color-mix(in srgb, var(--default-color), transparent 98%);
  border: 1px solid color-mix(in srgb, var(--default-color), transparent 90%);
  padding: 30px;
  border-radius: 5px;
}

.widget-item:last-child {
  margin-bottom: 0;
}

.search-widget form {
  background: var(--background-color);
  border: 1px solid color-mix(in srgb, var(--default-color), transparent 75%);
  padding: 3px 10px;
  position: relative;
  border-radius: 50px;
  transition: 0.3s;
}

.search-widget form input[type=text] {
  border: 0;
  padding: 4px 10px;
  border-radius: 4px;
  width: calc(100% - 40px);
  background-color: var(--background-color);
  color: var(--default-color);
}

.search-widget form input[type=text]:focus {
  outline: none;
}

.search-widget form button {
  background: none;
  color: var(--default-color);
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  border: 0;
  font-size: 16px;
  padding: 0 16px;
  transition: 0.3s;
  line-height: 0;
}

.search-widget form button i {
  line-height: 0;
}

.search-widget form button:hover {
  color: var(--accent-color);
}

.search-widget form:is(:focus-within) {
  border-color: var(--accent-color);
}

.recent-posts-widget .post-item {
  display: flex;
  margin-bottom: 15px;
}

.recent-posts-widget .post-item:last-child {
  margin-bottom: 0;
}

.recent-posts-widget .post-item img {
  width: 80px;
  margin-right: 15px;
}

.recent-posts-widget .post-item h4 {
  font-size: 15px;
  font-weight: bold;
  margin-bottom: 5px;
}

.recent-posts-widget .post-item h4 a {
  color: var(--default-color);
  transition: 0.3s;
}

.recent-posts-widget .post-item h4 a:hover {
  color: var(--accent-color);
}

.recent-posts-widget .post-item time {
  display: block;
  font-style: italic;
  font-size: 14px;
  color: color-mix(in srgb, var(--default-color), transparent 50%);
}

.categories-widget ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.categories-widget ul li {
  padding-bottom: 10px;
}

.categories-widget ul li:last-child {
  padding-bottom: 0;
}

.categories-widget ul a {
  color: color-mix(in srgb, var(--default-color), transparent 20%);
  transition: 0.3s;
}

.categories-widget ul a:hover {
  color: var(--accent-color);
}

.categories-widget ul a span {
  padding-left: 5px;
  color: color-mix(in srgb, var(--default-color), transparent 50%);
  font-size: 14px;
}

.tags-widget ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.tags-widget ul li {
  display: inline-block;
}

.tags-widget ul a {
  background-color: color-mix(in srgb, var(--default-color), transparent 94%);
  color: color-mix(in srgb, var(--default-color), transparent 30%);
  border-radius: 50px;
  font-size: 14px;
  padding: 5px 15px;
  margin: 0 6px 8px 0;
  display: inline-block;
  transition: 0.3s;
}

.tags-widget ul a:hover {
  background: var(--accent-color);
  color: var(--contrast-color);
}

.tags-widget ul a span {
  padding-left: 5px;
  color: color-mix(in srgb, var(--default-color), transparent 60%);
  font-size: 14px;
}
@media(max-width:768px){

.challenge-mobile-wrap{
display:flex !important;
flex-direction:column !important;
gap:25px !important;
padding:0 !important;
width:100% !important;
}

.challenge-mobile-title{
font-size:28px !important;
line-height:1.2 !important;
margin-bottom:15px !important;
}

.challenge-mobile-desc{
font-size:13px !important;
line-height:1.8 !important;
max-width:100% !important;
margin-bottom:20px !important;
}

.challenge-mobile-card{
display:flex !important;
align-items:flex-start !important;
padding:15px !important;
width:100% !important;
margin-bottom:14px !important;
}

.challenge-mobile-card h4{
font-size:14px !important;
}

.challenge-mobile-card p{
font-size:12px !important;
line-height:1.6 !important;
}

.challenge-mobile-chart{
width:100% !important;
padding:18px !important;
margin-top:10px !important;
}

.challenge-mobile-bar{
grid-template-columns:65px 1fr 30px !important;
gap:8px !important;
font-size:11px !important;
}

.challenge-mobile-risk{
width:100% !important;
padding:18px !important;
display:flex !important;
align-items:flex-start !important;
gap:12px !important;
}

.challenge-mobile-risk h4{
font-size:14px !important;
}

.challenge-mobile-risk p{
font-size:12px !important;
line-height:1.6 !important;
}

}

@media(max-width:768px){

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

.solution-desc{
font-size:13px !important;
padding:0 10px;
}

.solution-grid{
grid-template-columns:1fr !important;
gap:15px !important;
}

.solution-card{
padding:20px !important;
}

}

@media(max-width:768px){

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

.process-wrap{
grid-template-columns:1fr !important;
gap:25px !important;
}

.process-wrap div[style*="position:absolute"]{
display:none !important;
}

.step-card{
padding:15px !important;
}

.govern-wrap{
grid-template-columns:1fr !important;
gap:25px !important;
}

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

.govern-card{
padding:15px !important;
}

}
@media(max-width:768px){

.trust-title{
font-size:24px !important;
line-height:1.4 !important;
padding:0 10px;
}

.trust-grid{
gap:10px !important;
}

.trust-box{
font-size:12px !important;
padding:10px 14px !important;
}

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

.paperless-desc{
font-size:13px !important;
padding:0 10px;
}

.paperless-buttons{
flex-direction:column !important;
align-items:center !important;
}

.paperless-buttons a{
width:90%;
text-align:center;
}

}

/* ─────────────────────────────────────────
   RESET & BASE
───────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:#f7f4f0;color:#1a202c;overflow-x:hidden}

:root{
  --navy:#37517e;
  --orange:#e8471a;
  --light-bg:#f7f4f0;
  --light-bg2:#f0f0f8;
  --white:#ffffff;
  --muted:#6b7280;
  --card-bg:#37517e;
}

/* ─────────────────────────────────────────
   SHARED KEYFRAMES
───────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeLeft{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeRight{from{opacity:0;transform:translateX(-40px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.7}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes floatYR{0%,100%{transform:translateY(0)}50%{transform:translateY(10px)}}
@keyframes blobDrift{from{transform:translate(0,0) scale(1)}to{transform:translate(30px,20px) scale(1.06)}}
@keyframes scrollX{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes tabReveal{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* scroll-triggered reveal */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-36px);transition:opacity .65s ease,transform .65s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(36px);transition:opacity .65s ease,transform .65s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}

/* ─────────────────────────────────────────
   SECTION LABEL BADGE
───────────────────────────────────────── */
.sec-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff0ed;border:1.5px solid #fbd1c6;
  border-radius:999px;padding:7px 16px;
  font-size:11px;font-weight:700;letter-spacing:.13em;
  color:var(--navy);text-transform:uppercase;
  margin-bottom:20px;
}
.sec-dot{width:8px;height:8px;border-radius:50%;background:var(--orange);animation:pulse 2s infinite}

/* ─────────────────────────────────────────
   ██ FINANCIAL 1 – HERO
───────────────────────────────────────── */
#financial-1{
  min-height:100vh;display:flex;align-items:center;
  padding:70px 80px;position:relative;overflow:hidden;
  background:var(--light-bg);
}
#financial-1::before{
  content:'';position:absolute;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,71,26,.09) 0%,transparent 70%);
  top:-120px;left:-120px;animation:blobDrift 9s ease-in-out infinite alternate;
}
#financial-1::after{
  content:'';position:absolute;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(13,27,62,.06) 0%,transparent 70%);
  bottom:-80px;right:280px;animation:blobDrift 11s ease-in-out infinite alternate-reverse;
}

.f1-inner{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;max-width:1400px;margin:0 auto;gap:60px;position:relative;z-index:1;
}
.f1-left{flex:0 0 52%;max-width:52%}
.f1-right{flex:0 0 44%;max-width:44%;position:relative}

/* hero badge */
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;border:1.5px solid #e5e0d8;
  border-radius:999px;padding:8px 16px;
  font-size:11px;font-weight:700;letter-spacing:.12em;
  color:var(--navy);text-transform:uppercase;margin-bottom:30px;
  animation:fadeUp .6s .1s ease both;
}
.hero-dot{width:8px;height:8px;border-radius:50%;background:var(--orange);animation:pulse 2s infinite}

/* headline */
.hero-h1{
  font-family:'Syne',sans-serif;
  font-size:clamp(48px,5.4vw,74px);font-weight:800;line-height:1.05;
  color:var(--navy);margin-bottom:22px;
}
.hero-h1 .orange{color:var(--orange)}
.hero-h1 .l1{display:block;animation:fadeUp .6s .2s ease both}
.hero-h1 .l2{display:block;animation:fadeUp .6s .35s ease both}
.hero-h1 .l3{display:block;animation:fadeUp .6s .5s ease both}

.hero-body{
  font-size:15px;line-height:1.8;color:#4a5568;
  max-width:480px;margin-bottom:34px;
  animation:fadeUp .6s .65s ease both;
}

.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:52px;animation:fadeUp .6s .8s ease both}

.btn-orange{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--orange);color:#fff;font-size:14px;font-weight:700;
  padding:15px 28px;border-radius:8px;text-decoration:none;border:none;cursor:pointer;
  box-shadow:0 4px 20px rgba(232,71,26,.35);
  transition:background .25s,transform .2s,box-shadow .25s;
}
.btn-orange:hover{background:#cf3a10;transform:translateY(-2px);box-shadow:0 8px 28px rgba(232,71,26,.45)}
.btn-orange .arrow{transition:transform .2s}
.btn-orange:hover .arrow{transform:translateX(4px)}

.btn-outline-navy{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--navy);font-size:14px;font-weight:700;
  padding:15px 28px;border-radius:8px;border:2px solid var(--navy);
  text-decoration:none;cursor:pointer;
  transition:background .25s,color .25s,transform .2s;
}
.btn-outline-navy:hover{background:var(--navy);color:#fff;transform:translateY(-2px)}

/* stats row */
.hero-stats{display:flex;gap:44px;animation:fadeUp .6s .95s ease both}
.hs-val{font-family:'Syne',sans-serif;font-size:28px;font-weight:800;color:var(--navy);display:block}
.hs-lbl{font-size:12px;color:var(--muted);font-weight:500;margin-top:2px;display:block}

/* dashboard card */
.dash-wrap{position:relative;animation:fadeLeft .7s .4s ease both}
.dash-card{
  background:linear-gradient(145deg,#39527c 0%,#334e7c 100%);
  border-radius:20px;padding:32px;
  box-shadow:0 32px 80px rgba(19, 38, 86, 0.35)rgba(255,255,255,.06);
  position:relative;overflow:hidden;
}
.dash-card::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 80% 20%,rgba(255,255,255,.04),transparent 60%);
  pointer-events:none;
}
.dash-lbl{font-size:10px;letter-spacing:.15em;font-weight:600;color:rgba(255,255,255,.4);text-transform:uppercase;margin-bottom:14px}
.dash-amt{font-family:'Syne',sans-serif;font-size:clamp(36px,4vw,50px);font-weight:800;color:#fff;line-height:1;margin-bottom:6px}
.dash-sub{font-size:12px;color:rgba(255,255,255,.45);margin-bottom:26px}
.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.dash-stat{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:18px 18px;transition:background .2s}
.dash-stat:hover{background:rgba(255,255,255,.12)}
.ds-val{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;color:#fff;display:block;margin-bottom:3px}
.ds-lbl{font-size:11px;color:rgba(255,255,255,.4);font-weight:500}

/* floating badges */
.fb{
  position:absolute;background:#fff;border-radius:12px;padding:12px 15px;
  display:flex;align-items:center;gap:10px;
  box-shadow:0 8px 32px rgba(0,0,0,.14);white-space:nowrap;z-index:10;
}
.fb-bio{top:-20px;right:-24px;animation:floatY 6s ease-in-out infinite,fadeLeft .7s 1.1s ease both}
.fb-txn{bottom:-20px;right:-24px;animation:floatYR 5s ease-in-out infinite 1s,fadeLeft .7s 1.3s ease both}
.fb-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px}
.fb-icon.gold{background:#fff3cd}
.fb-icon.green{background:#d1fae5}
.fb-title{font-size:13px;font-weight:700;color:var(--navy)}
.fb-sub{font-size:11px;color:var(--muted)}
.fb-live{width:8px;height:8px;border-radius:50%;background:#22c55e;margin-left:6px;animation:pulse 2s infinite}
.fb-check{width:20px;height:20px;border-radius:50%;background:#22c55e;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:700}

/* ─────────────────────────────────────────
   ██ FINANCIAL 2 – COMPLETE FINTECH INFRA
───────────────────────────────────────── */
#financial-2{
  padding:100px 80px;background:var(--light-bg2);
}
.f2-head{text-align:center;margin-bottom:60px}
.sec-h2{font-family:'Syne',sans-serif;font-size:clamp(36px,4.5vw,60px);font-weight:800;color:var(--navy);line-height:1.1}
.sec-h2 .orange{color:var(--orange)}
.sec-sub{font-size:15px;color:var(--muted);margin-top:14px;max-width:560px;margin-left:auto;margin-right:auto;line-height:1.7}

.cards-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
  max-width:1300px;margin:0 auto;
}
.cards-grid-bottom{
  display:grid;grid-template-columns:repeat(2,1fr);gap:20px;
  max-width:640px;margin:20px auto 0;
}
.srv-card{
  background:#fff;border:1px solid #e8e4e0;border-radius:16px;padding:28px 24px;
  transition:transform .25s,box-shadow .25s;
}
.srv-card:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(13,27,62,.10)}
.srv-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:26px;margin-bottom:18px}
.ic-pink{background:#fce7e2}
.ic-yellow{background:#fef3c7}
.ic-green{background:#d1fae5}
.ic-blue{background:#dbeafe}
.ic-purple{background:#ede9fe}
.ic-teal{background:#ccfbf1}
.srv-title{font-family:'Syne',sans-serif;font-size:17px;font-weight:700;color:var(--navy);margin-bottom:10px}
.srv-desc{font-size:13px;line-height:1.7;color:#4a5568;margin-bottom:18px}
.srv-link{font-size:13px;font-weight:700;color:var(--orange);text-decoration:none}
.srv-link:hover{text-decoration:underline}

/* ─────────────────────────────────────────
   ██ FINANCIAL 3 – BUILT FOR BHARAT'S SCALE
───────────────────────────────────────── */
#financial-3{
  padding:100px 80px;background:#fff;
}
.f3-inner{
  display:flex;align-items:center;gap:64px;
  max-width:1300px;margin:0 auto;
}
.f3-left{flex:0 0 48%;max-width:48%}
.f3-right{flex:0 0 46%;max-width:46%}

/* bc agent app mockup */
.app-wrap{position:relative}
.app-card{
  background:linear-gradient(145deg,#374f7a,#37517e);
  border-radius:20px;padding:28px;
  box-shadow:0 28px 70px #37517e;
}
.app-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.app-greeting{font-size:12px;color:rgba(255,255,255,.5)}
.app-name{font-size:18px;font-weight:700;color:#fff;margin-top:2px}
.app-avatar{width:38px;height:38px;border-radius:8px;background:var(--orange);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff}
.app-collection{background:rgba(255,255,255,.08);border-radius:12px;padding:16px 20px;margin-bottom:16px}
.app-coll-lbl{font-size:11px;color:rgba(255,255,255,.4);margin-bottom:6px}
.app-coll-amt{font-family:'Syne',sans-serif;font-size:36px;font-weight:800;color:#fff}
.app-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px}
.app-action{background:rgba(255,255,255,.08);border-radius:10px;padding:12px 6px;text-align:center;font-size:11px;color:rgba(255,255,255,.7)}
.app-action .aa-icon{font-size:20px;margin-bottom:6px}
.app-txns-lbl{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:10px}
.app-txn{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.app-txn:last-child{border:none}
.txn-left{display:flex;align-items:center;gap:10px}
.txn-icon{width:32px;height:32px;border-radius:8px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:16px}
.txn-title{font-size:13px;font-weight:600;color:#fff}
.txn-time{font-size:11px;color:rgba(255,255,255,.4)}
.txn-amt{font-size:14px;font-weight:700}
.txn-amt.neg{color:#f87171}
.txn-amt.pos{color:#4ade80}
/* uptime floating badge */
.fb-uptime{
  position:absolute;top:30px;right:-30px;background:#fff;
  border-radius:12px;padding:14px 18px;
  box-shadow:0 8px 32px rgba(0,0,0,.14);
  animation:floatY 5s ease-in-out infinite;
}
.fb-uptime-val{font-family:'Syne',sans-serif;font-size:24px;font-weight:800;color:var(--navy)}
.fb-uptime-lbl{font-size:11px;color:var(--muted)}

/* feature list */
.feat-list{display:flex;flex-direction:column;gap:24px}
.feat-item{display:flex;align-items:flex-start;gap:16px}
.feat-icon-wrap{width:44px;height:44px;min-width:44px;border-radius:10px;background:#fff0ed;display:flex;align-items:center;justify-content:center;font-size:20px}
.feat-icon-wrap.blue{background:#dbeafe}
.feat-icon-wrap.green{background:#d1fae5}
.feat-icon-wrap.purple{background:#ede9fe}
.feat-icon-wrap.yellow{background:#fef3c7}
.feat-title{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:4px}
.feat-desc{font-size:13px;line-height:1.7;color:#4a5568}

.btn-orange-lg{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--orange);color:#fff;font-size:15px;font-weight:700;
  padding:16px 32px;border-radius:10px;text-decoration:none;border:none;cursor:pointer;
  box-shadow:0 6px 24px rgba(232,71,26,.35);margin-top:36px;
  transition:background .25s,transform .2s,box-shadow .25s;
}
.btn-orange-lg:hover{background:#cf3a10;transform:translateY(-2px);box-shadow:0 10px 32px rgba(232,71,26,.45)}

/* ─────────────────────────────────────────
   ██ FINANCIAL 4 – STATS BANNER
───────────────────────────────────────── */
#financial-4{
  background:linear-gradient(135deg,#37517e 0%,#37517e 100%);
  padding:70px 80px;
}
.stats-banner{
  display:grid;grid-template-columns:repeat(4,1fr);
  max-width:1200px;margin:0 auto;
}
.sb-item{
  text-align:center;padding:20px;
  border-right:1px solid rgba(255,255,255,.12);
}
.sb-item:last-child{border-right:none}
.sb-val{font-family:'Syne',sans-serif;font-size:clamp(36px,4vw,56px);font-weight:800;color:#fff;display:block}
.sb-val .orange{color:var(--orange)}
.sb-lbl{font-size:13px;color:rgba(255,255,255,.5);margin-top:6px;display:block}

/* ─────────────────────────────────────────
   ██ FINANCIAL 5 – TECHNOLOGY BRIDGES THE GAP
───────────────────────────────────────── */
#financial-5{
  padding:100px 80px;background:#fff;
}
.f5-head{text-align:center;margin-bottom:48px}
.tabs{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-start;margin-bottom:40px;max-width:1200px;margin-left:auto;margin-right:auto}
.tab-btn{
  padding:11px 22px;border-radius:8px;font-size:14px;font-weight:600;
  border:1.5px solid #d1d5db;background:#fff;color:var(--navy);cursor:pointer;
  transition:all .25s;
}
.tab-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.tab-btn:hover:not(.active){border-color:var(--navy);background:#f0f3ff}

.tab-content{display:none;max-width:1200px;margin:0 auto}
.tab-content.active{display:flex;align-items:flex-start;gap:60px;animation:tabReveal .4s ease both}
.tc-left{flex:0 0 42%;max-width:42%}
.tc-right{flex:1;background:#f0f0f8;border-radius:16px;padding:40px;display:flex;align-items:center;justify-content:center;min-height:300px}
.tc-title{font-family:'Syne',sans-serif;font-size:26px;font-weight:800;color:var(--navy);margin-bottom:14px}
.tc-desc{font-size:14px;line-height:1.8;color:#4a5568;margin-bottom:24px}
.tc-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}
.tc-tag{padding:7px 14px;border:1.5px solid #d1d5db;border-radius:6px;font-size:12px;font-weight:500;color:var(--navy);background:#fff}
.tc-icon{font-size:80px;text-align:center}

/* ─────────────────────────────────────────
   ██ FINANCIAL 6 – ENTERPRISE-GRADE TECH STACK
───────────────────────────────────────── */
#financial-6{
  padding:100px 80px;background:var(--light-bg2);
}
.f6-head{text-align:center;margin-bottom:60px}
.tech-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:20px;
  max-width:1300px;margin:0 auto;
}
.tech-grid-bottom{
  display:grid;grid-template-columns:1fr;gap:20px;
  max-width:260px;margin:20px auto 0;
}
.tech-card{
  background:#fff;border:1px solid #e8e4e0;border-radius:16px;padding:28px 20px;
  text-align:center;transition:transform .25s,box-shadow .25s;
}
.tech-card:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(13,27,62,.10)}
.tech-icon{font-size:38px;margin-bottom:14px}
.tech-title{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:10px}
.tech-desc{font-size:12px;line-height:1.7;color:#6b7280}

/* ─────────────────────────────────────────
   ██ FINANCIAL 7 – TRUSTED BY BANKS & FINTECHS
───────────────────────────────────────── */
#financial-7{
  padding:100px 80px;background:#fff;
}
.f7-head{text-align:center;margin-bottom:60px}
.testimonials{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  max-width:1200px;margin:0 auto;
}
.testi-card{
  background:#f7f4f0;border:1px solid #e8e4e0;border-radius:16px;padding:28px 24px;
  transition:transform .25s,box-shadow .25s;
}
.testi-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(13,27,62,.08)}
.stars{color:#f59e0b;font-size:16px;margin-bottom:16px;letter-spacing:2px}
.testi-quote{font-size:14px;line-height:1.8;color:#374151;font-style:italic;margin-bottom:22px}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-avatar{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff}
.av-blue{background:#37517e}
.av-orange{background:var(--orange)}
.av-purple{background:#7c3aed}
.testi-name{font-size:14px;font-weight:700;color:var(--navy)}
.testi-role{font-size:12px;color:var(--muted)}

/* ─────────────────────────────────────────
   ██ FINANCIAL 8 – CONNECTED WITH INDIA'S LEADING BANKS
───────────────────────────────────────── */
#financial-8{
  padding:80px 0;background:#fff;border-top:1px solid #e8e4e0;
}
.f8-head{text-align:center;margin-bottom:40px;padding:0 80px}
.banks-track-wrap{overflow:hidden;position:relative}
.banks-track-wrap::before,
.banks-track-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none;
}
.banks-track-wrap::before{left:0;background:linear-gradient(to right,#fff,transparent)}
.banks-track-wrap::after{right:0;background:linear-gradient(to left,#fff,transparent)}
.banks-track{display:flex;gap:0;width:max-content;animation:scrollX 20s linear infinite}
.bank-chip{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 28px;border:1.5px solid #d1d5db;border-radius:8px;
  font-size:13px;font-weight:600;color:var(--navy);background:#fff;
  white-space:nowrap;margin:0 10px;min-width:160px;text-align:center;
}

/* ─────────────────────────────────────────
   ██ FINANCIAL 9 – CTA / READY TO TRANSFORM
───────────────────────────────────────── */
#financial-9{
  padding:100px 80px;
  background:linear-gradient(135deg,#395483 0%,#37517e 60%,#354b71 100%);
  text-align:center;
}
.f9-h2{
  font-family:'Syne',sans-serif;font-size:clamp(40px,5vw,68px);font-weight:800;
  color:#fff;line-height:1.1;margin-bottom:20px;
}
.f9-sub{font-size:15px;color:rgba(255,255,255,.6);max-width:500px;margin:0 auto 40px;line-height:1.7}
.f9-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn-white{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;color:var(--navy);font-size:15px;font-weight:700;
  padding:16px 32px;border-radius:10px;text-decoration:none;cursor:pointer;border:none;
  transition:transform .2s,box-shadow .2s;
}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.btn-outline-white{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:#fff;font-size:15px;font-weight:700;
  padding:16px 32px;border-radius:10px;border:2px solid rgba(255,255,255,.4);
  text-decoration:none;cursor:pointer;
  transition:background .25s,transform .2s;
}
.btn-outline-white:hover{background:rgba(255,255,255,.1);transform:translateY(-2px)}

/* ─────────────────────────────────────────
   MOBILE RESPONSIVE
───────────────────────────────────────── */
@media(max-width:1024px){
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .tech-grid{grid-template-columns:repeat(3,1fr)}
  .tech-grid-bottom{max-width:100%;grid-template-columns:repeat(2,1fr)}
}

@media(max-width:900px){
  #financial-1,#financial-2,#financial-3,#financial-4,
  #financial-5,#financial-6,#financial-7,#financial-8,
  #financial-9{padding-left:24px;padding-right:24px}
  footer{padding-left:24px;padding-right:24px}

  /* F1 hero */
  #financial-1{padding-top:48px;padding-bottom:64px;min-height:auto}
  .f1-inner{flex-direction:column;gap:48px}
  .f1-left,.f1-right{flex:0 0 100%;max-width:100%}
  .hero-h1{font-size:clamp(40px,9vw,56px)}
  .hero-stats{gap:28px}
  .fb-bio{top:-16px;right:-8px}
  .fb-txn{bottom:-16px;right:-8px}

  /* F2 */
  #financial-2{padding-top:64px;padding-bottom:64px}
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .cards-grid-bottom{max-width:100%}

  /* F3 */
  #financial-3{padding-top:64px;padding-bottom:64px}
  .f3-inner{flex-direction:column;gap:40px}
  .f3-left,.f3-right{flex:0 0 100%;max-width:100%}
  .fb-uptime{right:-10px}

  /* F4 */
  #financial-4{padding-top:50px;padding-bottom:50px}
  .stats-banner{grid-template-columns:repeat(2,1fr)}
  .sb-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.12)}
  .sb-item:nth-child(2n){border-right:none}

  /* F5 */
  #financial-5{padding-top:64px;padding-bottom:64px}
  .tab-content.active{flex-direction:column;gap:32px}
  .tc-left,.tc-right{flex:0 0 100%;max-width:100%}

  /* F6 */
  #financial-6{padding-top:64px;padding-bottom:64px}
  .tech-grid{grid-template-columns:repeat(2,1fr)}
  .tech-grid-bottom{max-width:100%;grid-template-columns:1fr}

  /* F7 */
  #financial-7{padding-top:64px;padding-bottom:64px}
  .testimonials{grid-template-columns:1fr}

  /* F8 */
  .f8-head{padding:0 24px}

  /* F9 */
  #financial-9{padding-top:70px;padding-bottom:70px}
}

/* ─────────────────────────────────────────
       BUSINESS 1 — Hero / Dark Banner Section
    ───────────────────────────────────────── */
    .business-1 {
      background: linear-gradient(135deg, #32486d 0%, #324f80 50%, #3c537b 100%);
      min-height: 340px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      padding: 60px 80px 70px;
      position: relative;
      overflow: hidden;
    }

    /* Subtle radial glow top-right */
    .business-1::before {
      content: '';
      position: absolute;
      top: -80px;
      right: -60px;
      width: 520px;
      height: 520px;
      background: radial-gradient(circle, #37517e 0%, transparent 70%);
      pointer-events: none;
    }

    .business-1__breadcrumb {
      display: flex;
      align-items: center;
      gap: 6px;
      font-size: 13px;
      font-weight: 500;
      color: rgba(255,255,255,0.75);
      margin-bottom: 24px;
      opacity: 0;
      transform: translateY(-12px);
      animation: fadeDown 0.6s ease forwards 0.2s;
    }

    .business-1__breadcrumb a {
      color: rgba(255,255,255,0.9);
      text-decoration: none;
    }

    .business-1__breadcrumb a:hover { text-decoration: underline; }

    .business-1__breadcrumb span { color: rgba(255,255,255,0.5); }

    .business-1__heading {
      font-size: clamp(52px, 6vw, 80px);
      font-weight: 900;
      line-height: 1.0;
      color: var(--white);
      letter-spacing: -1px;
      opacity: 0;
      transform: translateY(20px);
      animation: fadeUp 0.7s ease forwards 0.35s;
    }

    .business-1__sub {
      margin-top: 28px;
      font-size: 15px;
      font-weight: 400;
      color: rgba(255,255,255,0.65);
      max-width: 480px;
      line-height: 1.65;
      opacity: 0;
      transform: translateY(14px);
      animation: fadeUp 0.7s ease forwards 0.55s;
    }

    .business-1__sub strong {
      color: rgba(255,255,255,0.9);
      font-weight: 600;
    }

    /* ─────────────────────────────────────────
       BUSINESS 2 — Core Platform / Cards Section
    ───────────────────────────────────────── */
    .business-2 {
      background: var(--light-bg);
      padding: 80px 80px 100px;
    }

    /* Section tag pill */
    .section-tag {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: var(--tag-bg);
      color: var(--tag-text);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      padding: 8px 18px;
      border-radius: 100px;
      margin-bottom: 28px;
      opacity: 0;
      transform: translateY(14px);
      animation: fadeUp 0.6s ease forwards 0.1s;
    }

    .section-tag::before {
      content: '';
      width: 7px;
      height: 7px;
      border-radius: 50%;
      background: var(--orange);
      display: inline-block;
    }

    /* Section heading */
    .business-2__heading {
      font-size: clamp(36px, 4.5vw, 58px);
      font-weight: 900;
      color: var(--navy);
      line-height: 1.1;
      letter-spacing: -0.5px;
      margin-bottom: 16px;
      opacity: 0;
      transform: translateY(16px);
      animation: fadeUp 0.65s ease forwards 0.2s;
    }

    .business-2__heading .accent { color: var(--orange); }

    .business-2__desc {
      font-size: 15px;
      font-weight: 400;
      color: var(--gray-text);
      max-width: 500px;
      line-height: 1.7;
      margin-bottom: 60px;
      opacity: 0;
      transform: translateY(14px);
      animation: fadeUp 0.65s ease forwards 0.3s;
    }

    /* Cards Grid — 2 columns */
    .cards-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 24px;
    }

    /* Individual Card */
    .card {
      background: white;
      border: 1px solid var(--card-border);
      border-radius: 16px;
      padding: 44px 44px 50px;
      position: relative;
      overflow: hidden;
      transition: box-shadow 0.3s ease, transform 0.3s ease;
      opacity: 0;
      transform: translateY(28px);
    }

    .card:hover {
      box-shadow: 0 20px 60px rgba(13, 27, 62, 0.10);
      transform: translateY(-4px);
    }

    /* Watermark icon bottom-right of each card */
    .card__watermark {
      position: absolute;
      bottom: 24px;
      right: 32px;
      width: 72px;
      height: 72px;
      opacity: 0.07;
    }

    .card__tag {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 1.8px;
      text-transform: uppercase;
      color: var(--orange);
      margin-bottom: 18px;
      display: block;
    }

    .card__title {
      font-size: clamp(20px, 2vw, 26px);
      font-weight: 800;
      color: var(--navy);
      line-height: 1.2;
      margin-bottom: 16px;
    }

    .card__desc {
      font-size: 14px;
      font-weight: 400;
      color: var(--gray-text);
      line-height: 1.7;
      margin-bottom: 28px;
    }

    /* Checklist */
    .card__list {
      list-style: none;
      display: flex;
      flex-direction: column;
      gap: 10px;
    }

    .card__list li {
      font-size: 14px;
      font-weight: 500;
      color: var(--navy);
      display: flex;
      align-items: flex-start;
      gap: 10px;
      line-height: 1.4;
    }

    .card__list li::before {
      content: '✓';
      color: var(--check-color);
      font-weight: 700;
      font-size: 14px;
      flex-shrink: 0;
      margin-top: 1px;
    }

    /* Card animation delays */
    .card:nth-child(1) { animation: fadeUp 0.65s ease forwards 0.4s; }
    .card:nth-child(2) { animation: fadeUp 0.65s ease forwards 0.52s; }
    .card:nth-child(3) { animation: fadeUp 0.65s ease forwards 0.64s; }
    .card:nth-child(4) { animation: fadeUp 0.65s ease forwards 0.76s; }

    /* ─────────────────────────────────────────
       BUSINESS 2 — HOW IT WORKS Section (bottom)
    ───────────────────────────────────────── */
    .how-it-works {
      background: var(--light-bg);
      padding: 80px 80px 100px;
      border-top: 1px solid #dde1ea;
    }

    .how-it-works .section-tag {
      display: block;
      text-align: center;
      width: fit-content;
      margin: 0 auto 28px;
    }

    .how-it-works__heading {
      font-size: clamp(38px, 5vw, 64px);
      font-weight: 900;
      color: var(--navy);
      text-align: center;
      letter-spacing: -1px;
      margin-bottom: 60px;
      opacity: 0;
      transform: translateY(16px);
      animation: fadeUp 0.65s ease forwards 0.2s;
    }

    .how-it-works__heading .accent { color: var(--orange); }

    /* Steps row */
    .steps-row {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 20px;
    }

    .step {
      background: white;
      border: 1px solid var(--card-border);
      border-radius: 14px;
      padding: 36px 30px 40px;
      position: relative;
      transition: box-shadow 0.3s ease, transform 0.3s ease;
      opacity: 0;
      transform: translateY(24px);
    }

    .step:hover {
      box-shadow: 0 16px 48px rgba(13, 27, 62, 0.1);
      transform: translateY(-3px);
    }

    /* Last step — dark filled */
    .step--dark {
      background: white;
      border-color: var(--navy);
    }

    .step--dark .step__num { color: rgba(13, 27, 62, 0.12); }
    .step--dark .step__title { color: var(--navy); }
    .step--dark .step__desc { color: var(--gray-text); }

    .step__num {
      font-size: 52px;
      font-weight: 900;
      color: rgba(13, 27, 62, 0.12);
      line-height: 1;
      margin-bottom: 20px;
      letter-spacing: -2px;
    }

    .step__title {
      font-size: 17px;
      font-weight: 800;
      color: var(--navy);
      margin-bottom: 12px;
      line-height: 1.2;
    }

    .step__desc {
      font-size: 13.5px;
      font-weight: 400;
      color: var(--gray-text);
      line-height: 1.65;
    }

    /* Step animation delays */
    .step:nth-child(1) { animation: fadeUp 0.6s ease forwards 0.3s; }
    .step:nth-child(2) { animation: fadeUp 0.6s ease forwards 0.42s; }
    .step:nth-child(3) { animation: fadeUp 0.6s ease forwards 0.54s; }
    .step:nth-child(4) { animation: fadeUp 0.6s ease forwards 0.66s; }

    /* ─────────────────────────────────────────
       Scroll-triggered animations via IntersectionObserver
    ───────────────────────────────────────── */
    .reveal {
      opacity: 0;
      transform: translateY(24px);
      transition: opacity 0.65s ease, transform 0.65s ease;
    }

    .reveal.visible {
      opacity: 1;
      transform: translateY(0);
    }

    /* ─────────────────────────────────────────
       Keyframes
    ───────────────────────────────────────── */
    @keyframes fadeUp {
      to { opacity: 1; transform: translateY(0); }
    }

    @keyframes fadeDown {
      to { opacity: 1; transform: translateY(0); }
    }

    /* ─────────────────────────────────────────
       MOBILE — Responsive
    ───────────────────────────────────────── */
    @media (max-width: 900px) {
     

      .business-2 { padding: 56px 24px 72px; }
      .cards-grid { grid-template-columns: 1fr; gap: 18px; }
      .card { padding: 32px 28px 40px; }

      .how-it-works { padding: 56px 24px 72px; }
      .steps-row { grid-template-columns: 1fr 1fr; gap: 16px; }
      .how-it-works__heading { font-size: clamp(30px, 7vw, 48px); margin-bottom: 40px; }
    }

    @media (max-width: 560px) {
    
      .business-2 { padding: 44px 20px 60px; }
      .business-2__heading { font-size: 32px; }
      .section-tag { font-size: 11px; }
      .card { padding: 28px 22px 36px; }
      .card__title { font-size: 20px; }

      .how-it-works { padding: 44px 20px 60px; }
      .how-it-works__heading { font-size: 30px; }
      .steps-row { grid-template-columns: 1fr; gap: 14px; }
      .step { padding: 28px 24px 32px; }
      .step__num { font-size: 40px; }
    }

    /* ======================== B2 — SUITE ======================== */
    .b2 { background:#ffffff; padding:80px 72px; }
    .b2-inner { max-width:1280px; margin:0 auto; }
    .b2-desc { font-size:15px; color:#37517e; line-height:1.7; margin-bottom:48px; max-width:460px; }

    .product-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; }

    .product-card {
      background:#fff; border:1.5px solid var(--border); border-radius:14px; padding:32px 30px;
      transition: box-shadow .2s, transform .2s;
    }
    .product-card:hover { box-shadow:0 8px 32px rgba(0,0,0,.07); transform:translateY(-2px); }

    .product-label { font-size:11px; font-weight:700; letter-spacing:1.2px; text-transform:uppercase; color:var(--orange); margin-bottom:12px; }
    .product-title { font-size:clamp(18px,2vw,22px); font-weight:800; color:var(--blue); margin-bottom:12px; line-height:1.2; }
    .product-desc  { font-size:14px; color:var(--text); line-height:1.7; margin-bottom:20px; }

    .feature-list { list-style:none; display:flex; flex-direction:column; gap:8px; }
    .feature-list li { font-size:13.5px; color:var(--text); display:flex; align-items:flex-start; gap:8px; line-height:1.5; }
    .feature-list li::before { content:'✓'; color:var(--orange); font-weight:700; font-size:13px; flex-shrink:0; margin-top:1px; }

    /* ======================== B3 — HOW IT WORKS ======================== */
    .b3 { background:var(--light-bg); padding:80px 72px; }
    .b3-inner { max-width:1280px; margin:0 auto; }
    .b3-header { text-align:center; margin-bottom:56px; }
    .b3-header .section-heading { font-size:clamp(32px,4vw,60px); }

    .steps-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }

    .step-card {
      background:#fff; border:1.5px solid var(--border); border-radius:14px; padding:28px 24px;
      transition: box-shadow .2s;
    }
    .step-card:hover { box-shadow:0 6px 24px rgba(0,0,0,.07); }
    .step-card.active { background:var(--blue); border-color:var(--blue); }

    .step-num { font-size:42px; font-weight:900; color:#d0d5e8; line-height:1; margin-bottom:16px; }
    .step-card.active .step-num { color:rgba(255,255,255,.8); }

    .step-title { font-size:16px; font-weight:800; color:var(--blue); margin-bottom:10px; }
    .step-card.active .step-title { color:#ffffff; }

    .step-desc { font-size:13.5px; color:var(--text); line-height:1.65; }
    .step-card.active .step-desc { color:rgba(255,255,255,.8); }

    /* ======================== B4 — INTEGRATIONS ======================== */
    .b4 { background:var(--light-bg); padding:80px 72px; border-top:1px solid var(--border); }
    .b4-inner { max-width:1280px; margin:0 auto; }
    .b4-header { text-align:center; margin-bottom:56px;color:#37517e; }
    .b4-header .section-heading { font-size:clamp(32px,4vw,60px); }

    .integration-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }

    .integration-card {
      background:#fff; border:1.5px solid var(--border); border-radius:14px;
      padding:36px 24px 28px; text-align:center;
      transition: box-shadow .2s, transform .2s;
    }
    .integration-card:hover { box-shadow:0 8px 28px rgba(0,0,0,.07); transform:translateY(-2px); }
    .integration-card.active { border-color:#c0c8e0; }

    .int-icon  { font-size:36px; margin-bottom:16px; display:block; }
    .int-title { font-size:15px; font-weight:800; color:var(--blue); margin-bottom:10px; }
    .int-desc  { font-size:13px; color:var(--text); line-height:1.65; }

    /* ======================== B5 — CTA ======================== */
    .b5 {
      background: linear-gradient(135deg, #37517e 0%, #37517e 40%, #37517e 70%, #37517e 100%);
      padding:96px 72px; text-align:center; position:relative; overflow:hidden;
    }
    .b5::after {
      content:''; position:absolute; inset:0;
      background-image: radial-gradient(ellipse at 50% 60%, #37517e 0%, transparent 65%);
      pointer-events:none;
    }
    .b5-inner { position:relative; z-index:1; max-width:680px; margin:0 auto; }
    .b5-title { font-size:clamp(28px,4vw,60px); font-weight:900; color:#fff; line-height:1.1; margin-bottom:18px; letter-spacing:-0.5px; }
    .b5-sub   { font-size:16px; color:rgba(255,255,255,.7); margin-bottom:40px; line-height:1.6; }
    .b5-btns  { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; }

    .btn-white {
      display:inline-block; background:#ffffff; color:var(--blue);
      font-family:'Barlow',sans-serif; font-size:14px; font-weight:700;
      padding:13px 28px; border-radius:8px; border:none; cursor:pointer;
      transition: background .2s, transform .15s;
    }
    .btn-white:hover { background:#f0f2f8; transform:translateY(-1px); }

    .btn-outline {
      display:inline-block; background:transparent; color:#fff;
      font-family:'Barlow',sans-serif; font-size:14px; font-weight:700;
      padding:13px 28px; border-radius:8px; border:2px solid rgba(255,255,255,.5); cursor:pointer;
      transition: border-color .2s, transform .15s;
    }
    .btn-outline:hover { border-color:rgba(255,255,255,.9); transform:translateY(-1px); }

    /* ======================== MOBILE ======================== */
    @media (max-width: 960px) {
       .b2, .b3, .b4, .b5 { padding-left:32px; padding-right:32px; }
      .product-grid     { grid-template-columns:1fr; }
      .steps-grid       { grid-template-columns:1fr 1fr; }
      .integration-grid { grid-template-columns:1fr 1fr; }
    }
    @media (max-width: 600px) {
      .b2, .b3, .b4 { padding:48px 18px; }
      .b5  { padding:64px 18px; }
      .product-grid     { grid-template-columns:1fr; gap:14px; }
      .steps-grid       { grid-template-columns:1fr; gap:12px; }
      .integration-grid { grid-template-columns:1fr 1fr; gap:12px; }
      .b3-header .section-heading, .b4-header .section-heading { font-size:26px; }
      .b5-title { font-size:26px; }
      .b5-btns  { flex-direction:column; align-items:center; }
      .btn-white, .btn-outline { width:100%; text-align:center; }
    }










37517e




