/*--------------------------------------------------------------
# General
--------------------------------------------------------------*/
@font-face {
  font-family:'Manrope';
  src:url( '/fonts/Manrope-Regular.ttf') format('truetype');
}

body {
  font-family:'Manrope', sans-serif !important;
  color: #444444;

}

a {
  color: #D4892D;
  text-decoration: none;
  font-weight: 600;
}

a:hover {
  color: #D4892D;
  text-decoration: none;
}

a u{
  text-decoration-color: #D4892D;
}

h1, h2, h3, h4, h5, h6 {
  font-family: "Manrope", sans-serif;
}

.btn-full {
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 11px 28px;
  border-radius: 10px;
  transition: 0.5s;
  margin: 10px 0 0 0;
  color: #fff;
  background: #d4892d;
  box-shadow: 0 1px 8px 0 rgba(0,0,0,.3);
  transition: all 125ms ease-out;
}
.btn-full:hover {
 color: #fff;
 transform: translate3d(0, -1px, 0);
}

.btn-transparant {
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 11px 28px;
  border-radius: 10px;
  transition: 0.5s;
  margin: 10px 0 0 0;
  color: #d4892d;
  box-shadow: 0 1px 8px 0 rgba(0,0,0,.3);
  transition: all 125ms ease-out;
  background-color: white;
}
.btn-transparant:hover {
  transform: translate3d(0, -1px, 0);
}

/*--------------------------------------------------------------
# Preloader
--------------------------------------------------------------*/
#preloader {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 9999;
  overflow: hidden;
  background: #37517e;
}

#preloader:before {
  content: "";
  position: fixed;
  top: calc(50% - 30px);
  left: calc(50% - 30px);
  border: 6px solid #37517e;
  border-top-color: #fff;
  border-bottom-color: #fff;
  border-radius: 50%;
  width: 60px;
  height: 60px;
  -webkit-animation: animate-preloader 1s linear infinite;
  animation: animate-preloader 1s linear infinite;
}

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

@keyframes animate-preloader {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
/*--------------------------------------------------------------
# Back to top button
--------------------------------------------------------------*/
.back-to-top {
  position: fixed;
  visibility: hidden;
  opacity: 0;
  right: 15px;
  bottom: 15px;
  z-index: 996;
  background: #47b2e4;
  width: 40px;
  height: 40px;
  border-radius: 15px;
  transition: all 0.4s;
}
.back-to-top i {
  font-size: 24px;
  color: #fff;
  line-height: 0;
}
.back-to-top:hover {
  background: #6bc1e9;
  color: #fff;
}
.back-to-top.active {
  visibility: visible;
  opacity: 1;
}

/*--------------------------------------------------------------
# Header
--------------------------------------------------------------*/
.content-header {
  padding: 0;
}
#header {
  transition: all 0.5s;
  z-index: 997;
  padding: 15px 0;
  background-color: #152f30;
}
#header.header-scrolled, #header.header-inner-pages {
  background: rgba(21, 47, 48, 0.9);
}
#header .logo {
  font-size: 30px;
  margin: 0;
  padding: 0;
  line-height: 1;
  font-weight: 500;
  letter-spacing: 2px;
  text-transform: uppercase;
  flex-shrink: 0;
}
#header .logo a {
  color: #fff;
}
#header .logo img {
  height: 25px;
  width: auto;
  flex-shrink: 0;
}

/*--------------------------------------------------------------
# Language switcher
--------------------------------------------------------------*/
.language-switcher {
  float: right;
  margin-left: 0px;
}
.language-dropdown{
  margin-top: 0;
  margin-bottom: auto;
}
.language-dropdown .dropdown:hover > ul {
  opacity: 1;
  top: 100%;
  visibility: visible;
  display: block;
}
.navbar-mobile .language-dropdown {
  display: none;
}

.nav-link {
  padding-right: 0px;
}

/*--------------------------------------------------------------
# reCAPTCHA
--------------------------------------------------------------*/
.grecaptcha-badge {
  visibility: hidden;
}

/*--------------------------------------------------------------
# Navigation Menu
--------------------------------------------------------------*/
/**
* Desktop Navigation
*/
.navbar {
  padding: 0;
}
.navbar ul {
  margin: 0;
  padding: 0;
  display: flex;
  list-style: none;
  align-items: center;
}
.navbar li {
  position: relative;
}
.navbar a, .navbar a:focus {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0 10px 30px;
  font-size: 15px;
  font-weight: 500;
  color: #fff;
  white-space: nowrap;
  transition: 0.3s;
}
.navbar a i, .navbar a:focus i {
  font-size: 12px;
  line-height: 0;
  margin-left: 5px;
}
.navbar a:hover, .navbar .active:focus, .navbar li:hover > a {
  color: #D4892D;
}
.navbar .active{
  color: #ffffff;
}
.navbar .getstarted, .navbar .getstarted:focus {
  padding: 8px 20px;
  margin-left: 15px;
  border-radius: 15px;
  color: #fff;
  font-size: 14px;
  border: 2px solid #d4892d;
  margin-top: 0px;
}
.navbar .getstarted:hover, .navbar .getstarted:focus:hover {
  color: #fff;
  background: #d4892d;
}
.navbar .dropdown ul {
  display: block;
  position: absolute;
  left: 14px;
  top: calc(100% + 30px);
  margin: 0;
  margin-top: 2px;
  padding: 10px 0;
  z-index: 99;
  opacity: 0;
  visibility: hidden;
  background: #fff;
  box-shadow: 0px 0px 30px rgba(127, 137, 161, 0.25);
  transition: 0.3s;
  border-radius: 4px;
}
.navbar .dropdown ul li {
  min-width: 200px;
}
.navbar .dropdown ul a {
  padding: 10px 20px;
  font-size: 14px;
  text-transform: none;
  font-weight: 500;
  color: #0c3c53;
}
.navbar .dropdown ul a i {
  font-size: 12px;
}
.navbar .dropdown ul a:hover, .navbar .dropdown ul .active:hover, .navbar .dropdown ul li:hover > a {
  color: #D4892D;
}
.navbar .dropdown:hover > ul {
  opacity: 1;
  top: 100%;
  visibility: visible;
}
.navbar .dropdown .dropdown ul {
  top: 0;
  left: calc(100% - 30px);
  visibility: hidden;
}
.navbar .dropdown .dropdown:hover > ul {
  opacity: 1;
  top: 0;
  left: 100%;
  visibility: visible;
}
/**
* Mega-menu
*/
.navbar .dropdown .dropdown-menu {
  left: -400px;
}
.mega-menu{
  padding: 0px;
  width: max-content;
  max-width: 1000px;
}
.mega-menu p{
  margin-bottom: 5px;
}
.mega-menu .mega-title {
  font-size: 18px;
  margin-top: 0px;
  font-weight: bold;
}
.mega-menu .mega-subtitle {
  font-size: 14px;
  white-space: normal;
}
.mega-menu a {
  white-space: normal;
}
.mega-menu-item:hover {
  background-color: #d4892d1c;
  border-radius: 10px;
}
.mega-menu-img {
  width: -moz-available;
  width: -webkit-fill-available;
  width: fill-available;
}
.navbar .dropdown .dropdown-menu .col-menu-item{
  padding-top: 20px;
  padding-bottom: 20px;
}
.col-menu-stories{
  padding-left: 0px;
  padding-right: 0px;
}
.mega-menu-stories a{
  display: block;
  padding: 0px !important;
}
.mega-menu-stories a:focus{
  display: block;
  padding: 0px !important;
  white-space: normal;
}
.mega-menu-stories-img-box{
  border-radius: 15px;
  position: relative;
}
.mega-menu-stories-img-box:hover {
  -webkit-filter: brightness(85%);
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  -o-transition: all 0.5s ease;
  -ms-transition: all 0.5s ease;
  transition: all 0.5s ease;
}
.mega-menu-stories-img-title{
  position: absolute;
  bottom: 0px;
  padding-left: 16px;
  padding-right: 16px;
  padding-top: 5px;
  padding-bottom: 5px;
  background-color: #0000008f;
  color: white;
  font-size: 14px;
  border-bottom-left-radius: 15px;
  border-bottom-right-radius: 15px;
}
.mega-menu-stories .mega-menu-stories-title a{
  font-size: 14px !important;
  padding-left: 10px !important;
  padding-top: 15px !important;
}
.mega-menu-stories-title img{
  margin-right: 10px;
  margin-left: 10px;
}
.mega-menu-stories .mega-menu-stories-text{
  font-size: 16px;
  padding-left: 20px;
}
.mega-menu-stories-img{
  width: -moz-available;
  width: -webkit-fill-available;
  width: fill-available;
  border-radius: 15px;
  border-radius: 15px;
  max-height: 200px;
  height: 200px;
  object-fit: cover;
}
.ul-intro-text {
  padding-left: 10px;
  padding-right: 10px;
  padding-top: 5px;
  padding-bottom: 5px;
  font-size: 13px;
  color: gray;
}
@media (max-width: 1366px) {
  .navbar .dropdown .dropdown ul {
    left: -90%;
  }
  .navbar .dropdown .dropdown:hover > ul {
    left: -100%;
  }
  .navbar .dropdown .dropdown-menu {
    left: -150px;
  }
}

/**
* Mobile Navigation
*/
.mobile-nav-toggle {
  color: #fff;
  font-size: 28px;
  cursor: pointer;
  display: none;
  line-height: 0;
  transition: 0.5s;
}
.mobile-nav-toggle.bi-x {
  color: #fff;
}

@media (max-width: 991px) {
  .mobile-nav-toggle {
    display: block;
  }
  .btn_login {
    display: inherit;
    color: #37517e !important;
  }
  .navbar ul {
    display: none;
  }
  .mega-menu{
    width: auto;
  }
  .navbar .dropdown .dropdown-menu .col-menu-item{
    padding-top: 0px;
    padding-bottom: 0px;
  }
  .mega-menu-stories-img-box {
    margin-top: 15px;
  }
  .mega-menu .navbar-mobile .dropdown ul a{
    padding: 10px 0px !important;
  }
}
.navbar-mobile {
  position: fixed;
  overflow: hidden;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  background: rgba(21, 47, 48, 0.9);
  transition: 0.3s;
  z-index: 999;
}
.navbar-mobile .mobile-nav-toggle {
  position: absolute;
  top: 15px;
  right: 15px;
}
.navbar-mobile ul {
  display: block;
  position: absolute;
  top: 55px;
  right: 15px;
  bottom: 15px;
  left: 15px;
  padding: 10px 0;
  border-radius: 10px;
  background-color: #fff;
  overflow-y: auto;
  transition: 0.3s;
}
.navbar-mobile a, .navbar-mobile a:focus {
  padding: 10px 20px;
  font-size: 15px;
  color: #37517e;
}
.navbar-mobile a:hover, .navbar-mobile .active, .navbar-mobile li:hover > a {
  color: #D4892D;
}
.navbar-mobile .getstarted, .navbar-mobile .getstarted:focus {
  margin: 15px;
}
.navbar-mobile .dropdown ul {
  position: static;
  display: none;
  margin: 10px 20px;
  padding: 10px 0;
  z-index: 99;
  opacity: 1;
  visibility: visible;
  background: #fff;
  box-shadow: 0px 0px 30px rgba(127, 137, 161, 0.25);
}
.navbar-mobile .dropdown ul li {
  min-width: 200px;
}
.navbar-mobile .dropdown ul a {
  padding: 10px 10px;
}
.navbar-mobile .dropdown ul a i {
  font-size: 12px;
}
.navbar-mobile .dropdown ul a:hover, .navbar-mobile .dropdown ul .active:hover, .navbar-mobile .dropdown ul li:hover > a {
  color: #D4892D;
}
.navbar-mobile .dropdown > .dropdown-active {
  display: block;
}

/*--------------------------------------------------------------
# Hero Section
--------------------------------------------------------------*/
#hero {
  width: 100%;
  /*height: 75vh;*/
  background: white;
}
#hero .container {
  padding-top: 72px;
}
#hero h1 {
  margin: 0 0 10px 0;
  font-size: 40px;
  font-weight: 700;
  line-height: 58px;
  color: #444444;
}
#hero .hero-focus{
  color: #678a3c;
}
#hero h2 {
  color: #444444;
  margin-bottom: 40px;
  font-size: 22px;
}
#hero .subsubline{
  color: #678a3c;
  margin-bottom: 20px;
  font-size: 15px;
  text-transform: uppercase;
}
#hero .btn-get-started {
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 18px 28px 18px 28px;
  border-radius: 15px;
  transition: 0.5s;
  margin: 10px 0 0 0;
  color: #fff;
  background: #d4892d;
}
#hero .btn-get-started:hover {
  background: #ae7228;
}
#hero .hero-img {
  text-align: center;
  display: flex;
  justify-content: center;
}
#hero .img-hero {
  max-width: 90%;
  /*border-radius: 40px;*/
}

#hero .btn-watch-video {
  font-size: 16px;
  display: flex;
  align-items: center;
  transition: 0.5s;
  margin: 10px 0 0 25px;
  color: #fff;
  line-height: 1;
}
#hero .btn-watch-video i {
  line-height: 0;
  color: #fff;
  font-size: 32px;
  transition: 0.3s;
  margin-right: 8px;
}
#hero .btn-watch-video:hover i {
  color: #47b2e4;
}

#hero .hercontactsub{
  font-size: small;
}

#hero .book-a-demo-mobile {
  display: none;
}

@media (max-width: 991px) {
  #hero {
    /*height: 100vh;*/
    text-align: center;
  }
  #hero .animated {
    -webkit-animation: none;
    animation: none;
  }
  #hero .hero-img {
    text-align: center;
    display: flex;
    justify-content: center;
  }
  #hero .hero-img img {
    width: 50%;
  }
  #hero .book-a-demo-mobile {
    display: block;
    background-color: white;
    color: #D4892D;
    border: 2px #D4892D solid;
  }
}
@media (max-width: 768px) {
  #hero h1 {
    font-size: 28px;
    line-height: 36px;
  }
  #hero h2 {
    font-size: 18px;
    line-height: 24px;
    margin-bottom: 30px;
  }
  #hero .hero-img img {
    width: 70%;
  }
}
@media (max-width: 575px) {
  #hero .hero-img img {
    width: 80%;
    margin-bottom: 30px;
  }
  #hero .btn-get-started {
    font-size: 16px;
    padding: 10px 24px 11px 24px;
  }
}

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

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

/*--------------------------------------------------------------
# Sections General
--------------------------------------------------------------*/
section {
  padding: 60px 0;
  padding-bottom: 0px;
  overflow: hidden;
}

.section-bg {
  background-color: #ffffff;
}

.section-title {
  text-align: center;
  padding-bottom: 30px;
}
.section-title h2 {
  font-size: 32px;
  font-weight: bold;
  text-transform: uppercase;
  margin-bottom: 20px;
  padding-bottom: 20px;
  position: relative;
  color: #5b5b5b;
}
/*.section-title h2::before {
  content: "";
  position: absolute;
  display: block;
  width: 120px;
  height: 1px;
  background: #ddd;
  bottom: 1px;
  left: calc(50% - 60px);
}
.section-title h2::after {
  content: "";
  position: absolute;
  display: block;
  width: 40px;
  height: 3px;
  background: #47b2e4;
  bottom: 0;
  left: calc(50% - 20px);
}*/
.section-title p {
  margin-bottom: 0;
}

/*--------------------------------------------------------------
# landing page
--------------------------------------------------------------*/

.landing_hero{
  position: relative;
  height: 60vh;
  color: white;
  background: linear-gradient(rgba(21,47,48, 0.8),rgba(21,47,48, 0.2));
}
#landing_hero_bg_image{
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: -1;
  height: 60vh;
  object-fit: cover;
}
@media (max-width: 768px) {
  .landing_hero {
    height: 95svh;
    align-items: flex-start;
    padding-top: 80px;
    padding-bottom: 40px;
    box-sizing: border-box;
  }
  #landing_hero_bg_image {
    height: 95svh;
  }
  .landing_hero h1 {
    font-size: 26px;
    line-height: 38px;
  }
  .landing_hero h2 {
    font-size: 17px;
  }
}
.landing_hero .btn-get-started {
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 11px 28px;
  border-radius: 15px;
  transition: 0.5s;
  margin: 10px 0 0 0;
  color: #fff;
  background: #d4892d;
}
.landing_hero .btn-get-started:hover {
  background: #ae7228;
}
.landing_hero h1 {
  margin: 0 0 10px 0;
  font-size: 32px;
  font-weight: 700;
  line-height: 56px;
  color: #fff;
}
.landing_hero h2 {
  color: white;
  margin-bottom: 10px;
  font-size: 20px;
}
.hero-cta-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
}
.hero-free-note {
  width: 100%;
  font-size: 13px;
  color: rgba(255,255,255,0.75);
  margin-top: 4px;
}
.solution-sub-note {
  font-size: 12px;
  color: #999;
}
.solution-sub-note a {
  color: #d4892d;
  font-weight: 600;
}
#main .clients {
  margin-top: 40px;
  padding-top: 0px;
  margin-bottom: 10px;
}
#why-us .header_line{
  font-size: 30px;
  font-weight: 600;
  margin-bottom: 50px;
  margin-top: 120px;
}
#why-us .sub_line{
  font-size: 18px;
  font-weight: 100;
  margin-top: 120px;
}
@media (max-width: 768px) {
  #why-us .header_line{
    text-align: center;
  }
  #why-us .sub_line{
    text-align: center;
    margin-top: 50px;
  }
}
#why-us .value_prop_box{
  border: 1px solid #0000002b;
  border-radius: 15px;
  padding:20px;
  min-height: 450px;
  transition: all 125ms ease-out;
}
#why-us .value_prop_box h4{
  font-weight: 600;
}
#why-us .main_box{
  background-color: #fac48359;
  min-height: 480px;
}
#main .why-us .value_prop_box img{
  margin-top: 0px;
  max-width: 100%;
  border: none;
}

/* ── Before / After ── */
.before-after {
  padding-top: 80px;
  padding-bottom: 80px;
  background: #fff;
}
.ba-tabs {
  display: inline-flex;
  background: #f5f5f5;
  border-radius: 10px;
  padding: 4px;
  gap: 0;
}
.ba-tab-btn {
  background: none;
  border: none;
  padding: 10px 24px;
  font-family: inherit;
  font-size: 0.9rem;
  font-weight: 700;
  color: #999;
  border-radius: 7px;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.ba-tab-btn.active {
  background: #fff;
  color: #222;
  box-shadow: 0 1px 4px rgba(0,0,0,.10);
}
.ba-card {
  border-radius: 14px;
  padding: 28px 24px;
  text-align: left;
  height: 100%;
}
.ba-card.ba-before {
  background: #fafafa;
  border: 1.5px solid #e0e0e0;
}
.ba-card.ba-after {
  background: #f0f7f2;
  border: 1.5px solid #b2d8be;
}
.ba-card-title {
  font-size: 0.9rem;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.ba-card.ba-before .ba-card-title { color: #aaa; }
.ba-card.ba-after  .ba-card-title { color: #2e7d47; }
.ba-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.ba-list li {
  padding: 6px 0;
  font-size: 1rem;
  color: #555;
  line-height: 1.45;
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.ba-photo {
  border-radius: 12px;
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: block;
  box-shadow: 0 4px 16px rgba(0,0,0,.10);
}
.ba-card.ba-before .ba-list li::before {
  content: '✗';
  color: #ccc;
  font-weight: 700;
  flex-shrink: 0;
}
.ba-card.ba-after .ba-list li::before {
  content: '✓';
  color: #2e7d47;
  font-weight: 700;
  flex-shrink: 0;
}

/* ── Getting started steps ── */
.getting-started {
  padding-top: 60px;
  padding-bottom: 40px;
}
.getting-started-bg {
  background-color: #f0f4f7;
}
.step-card {
  background: #fff;
  border: 1.5px solid #eee;
  border-radius: 16px;
  padding: 32px 24px;
  transition: border-color .2s, box-shadow .2s;
}
.step-card:hover {
  border-color: #D4892D;
  box-shadow: 0 4px 20px rgba(212,137,45,.12);
}
.step-number {
  width: 36px;
  height: 36px;
  background: #fff4e6;
  color: #D4892D;
  border-radius: 50%;
  font-size: 0.85rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
}
.step-title {
  font-size: 1.1rem;
  font-weight: 800;
  color: #222;
  margin-bottom: 10px;
}
.step-desc {
  font-size: 1rem;
  color: #777;
  line-height: 1.6;
}
.step-arrow {
  font-size: 1.4rem;
  font-weight: 700;
  color: #D4892D;
}

/* ── Modular solutions section ── */
.solution-intro-block {
  padding-top: 70px;
  padding-bottom: 70px;
}
.solution-intro-block .col-lg-6 p {
  font-size: 18px;
}
.solution-modular-title {
  font-size: 1.6rem;
  font-weight: 700;
  color: #333;
}
#main .solutions-subtitle {
  color: #777;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}
#why-us .solution-core-card {
  border-color: #b2d8be;
  background-color: #f0f7f2;
  text-align: center;
  align-items: center;
}
#why-us .solution-addon-card {
  border-style: dashed;
  border-color: #d0d0d0;
  text-align: center;
  align-items: center;
}
.solution-badge {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 20px;
  margin-bottom: 12px;
}
.solution-badge-core {
  background: #d0edda;
  color: #2e7d47;
}
.solution-badge-addon {
  background: #fff4e6;
  color: #D4892D;
}
.solution-plus-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.solution-plus-circle {
  width: 48px;
  height: 48px;
  background: #fff4e6;
  border: 2px solid #f0d4a0;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  font-weight: 800;
  color: #D4892D;
}
.solution-optional-text {
  font-size: 0.7rem;
  font-weight: 700;
  color: #D4892D;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}
.solution-insight {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: #f0f7f2;
  border: 1.5px solid #b2d8be;
  border-radius: 12px;
  padding: 16px 20px;
  text-align: left;
  font-size: 0.9rem;
  color: #3a6644;
  line-height: 1.5;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 30px;
}
.solution-insight strong {
  font-weight: 800;
}
.solution-bullets {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  width: 75%;
  text-align: left;
}
.solution-bullets li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 8px;
  font-size: 1rem;
  color: #555;
  line-height: 1.4;
}
.solution-core-card .solution-bullets li::before {
  content: '✓';
  color: #2e7d47;
  font-weight: 700;
  flex-shrink: 0;
}
.solution-addon-card .solution-bullets li::before {
  content: '✓';
  color: #D4892D;
  font-weight: 700;
  flex-shrink: 0;
}

#main .segments {
  margin-top: 70px;
  margin-bottom: 100px;
}
#main .segments h3{
  font-weight: 500;
}
#main .segments h5{
  margin-top: 20px;
  font-weight: 600;
  font-size: 18px;
}
#main .segments h5:hover{
  color:#d4892d;
}
#main .segments img{
  width: 100%;
  border-radius: 5px;
}
#main .segments img:hover{
  transform: scale(1.02);
}
#main .segments a{
  color:inherit;
  font-weight: inherit;
}
#main .segments .link_demo_garden {
  color: #D4892D;
  text-decoration: none;
  font-weight: 600;
}
#main .segments .link_demo_garden:hover {
  color: #D4892D;
  text-decoration: none;
}

/*--------------------------------------------------------------
# ArbNet banner
--------------------------------------------------------------*/
.arbnet-banner .arbnet-logo {
  margin-left: 50px;
  margin-right: 50px;
}
@media (max-width: 1024px) {
 	.arbnet-banner .arbnet-logo {
 		 text-align: left;
     margin-bottom: 30px;
 	}
  .arbnet-banner .content {
    margin-left: 10px;
    margin-right: 10px;
  }
}

/*--------------------------------------------------------------
# Stories
--------------------------------------------------------------*/
.stories-bg{
}

.main_stories_wrapper{
  margin-top: 0px;
  margin-bottom: 10px;
}
.main_stories_wrapper .story_title{
  color: #D4892D;
  font-size: 1.1rem;
}
.main_stories_wrapper .hashtags a{
  font-size: 15px;
  color: #D4892D;
}
.main_stories_wrapper .publishdate{
  font-size: 12px;
  color: grey;
}

/*--------------------------------------------------------------
# Media kit
--------------------------------------------------------------*/
.media_kit_section{
  margin-top: 80px;
  margin-bottom: 80px;
}

/*--------------------------------------------------------------
# Services
--------------------------------------------------------------*/
#services {
  padding-top: 80px;
  padding-bottom: 160px;
}
.card {
	 border: none;
	 transition: all 500ms cubic-bezier(0.19, 1, 0.22, 1);
	 overflow: hidden;
	 border-radius: 0px;
	 box-shadow: 0 0 12px 0 rgba(0, 0, 0, 0.2);
}
 @media (max-width: 768px) {
	 .card {
		 min-height: 350px;
	}
}
 @media (max-width: 420px) {
	 .card {
		 min-height: 300px;
	}
}
.ecosystem1{
  background-image:url('../images/website_2/ecodomains/private_domains.jpg');
}
.ecosystem2{
  background-image:url('../images/website_2/ecodomains/public_domains.jpg');
}
.ecosystem3{
  background-image:url('../images/website_2/ecodomains/education.jpg');
}
.ecosystem4{
  background-image:url('../images/website_2/ecodomains/fruit_and_veg.jpg');
}
.ecosystem5{
  background-image:url('../images/website_2/ecodomains/business.jpg');
}
.ecosystem6{
  background-image:url('../images/website_2/ecodomains/professionals.jpg');
}
.card.card-has-bg {
	 transition: all 500ms cubic-bezier(0.19, 1, 0.22, 1);
	 background-size: 145%;
	 background-repeat: no-repeat;
	 background-position: center center;
}
 .card.card-has-bg:before {
	 content: '';
	 position: absolute;
	 top: 0;
	 right: 0;
	 bottom: 0;
	 left: 0;
	 background: inherit;
	 -webkit-filter: grayscale(1);
	 -moz-filter: grayscale(100%);
	 -ms-filter: grayscale(100%);
	 -o-filter: grayscale(100%);
	 filter: grayscale(100%);
}
 .card.card-has-bg:hover {
	 transform: scale(0.98);
	 box-shadow: 0 0 5px -2px rgba(0, 0, 0, 0.3);
	 background-size: 160%;
	 transition: all 500ms cubic-bezier(0.19, 1, 0.22, 1);
}
 .card.card-has-bg:hover .card-img-overlay {
	 transition: all 800ms cubic-bezier(0.19, 1, 0.22, 1);
	 background: #234f6d;
	 background: linear-gradient(0deg, rgba(21, 47, 48, 0.5) 0%, rgba(0, 0, 0, 1) 100%);
}
 .card .card-footer {
	 background: none;
	 border-top: none;
}
 .card .card-footer .media img {
	 border: solid 3px rgba(255, 255, 255, 0.3);
}
 .card .card-meta {
	 color: #26bd75;
}
 .card .card-body {
	 transition: all 500ms cubic-bezier(0.19, 1, 0.22, 1);
   padding: 0px;
   padding-top: 20px;
}
 .card:hover {
	 cursor: pointer;
	 transition: all 800ms cubic-bezier(0.19, 1, 0.22, 1);
}
 .card:hover .card-body {
	 margin-top: 10px;
	 transition: all 800ms cubic-bezier(0.19, 1, 0.22, 1);
}
.card:hover .card-title {
  background-color: #d4892d7a;
}
 .card .card-img-overlay {
	 transition: all 800ms cubic-bezier(0.19, 1, 0.22, 1);
	 background: #234f6d;
	 background: linear-gradient(0deg, rgba(21,47,48, 0.3785889355742297) 0%, rgba(21,47,48, 1) 100%);
   padding: 0px;
}
.card .card-title {
  background-color: #d4892d3b;
  padding-top: 10px;
  padding-bottom: 1px;
  padding-left: 20px;
  padding-right: 100px;
  width: fit-content;
}
.card .media-body a {
  background-color: white;
  margin-right: 5px;
  padding-left: 8px;
  padding-right: 8px;
  padding-top: 3px;
  padding-bottom: 3px;
  color: #3f3f3f;
  border-radius: 5px;
  margin-bottom: 5px;
  display: inline-block;
}
.card .media-body a:hover {
  background-color: white;
  padding-left: 8px;
  padding-right: 8px;
  padding-top: 3px;
  padding-bottom: 3px;
  color: white;
  background-color: #d4892d;
  display: inline-block;
}

/*--------------------------------------------------------------
# slogan
--------------------------------------------------------------*/
#slogan{
  display: block;
  margin-bottom: 50px;
  font-size: 35px;
  font-weight: 100;
}

/*--------------------------------------------------------------
# Clients
--------------------------------------------------------------*/
.clients {
  padding: 30px 0;
  text-align: center;
  margin-top: 80px;
}
.clients img {
  max-width: 75%;
  max-height: 150px;
  transition: all 0.4s ease-in-out;
  display: inline-block;
  padding: 15px 0;
  filter: grayscale(100);
  padding-top: 10px !important;
}
.clients img:hover {
  filter: none;
  transform: scale(1.1);
}
@media (max-width: 768px) {
  .clients img {
    max-width: 80%;
  }
}
.clientslogan {
    position: relative;
    margin-right: 0.5rem;
    z-index: 0;
}
.clientslogan:after {
    content: "";
    position: absolute;
    bottom: -12px;
    left: -0.4rem;
    height: 15px;
    width: 103%;
    background-image: url("../images/website_2/misc/underline.svg");;
    background-size: contain;
    background-repeat: no-repeat;
    z-index: -1;
}
.clients .references .subslogan {
  color: #678A3C;
  font-weight: 600;
  margin-bottom: 5px;
  font-size: 15px;
  padding-left: 35px;
  padding-right: 35px;
}
.clients .references .subslogan2 {
  font-size: 13px;
  padding-left: 10px;
  padding-right: 10px;
}

/*--------------------------------------------------------------
# About Us
--------------------------------------------------------------*/
.about .content h3 {
  font-weight: 600;
  font-size: 26px;
}
.about .content ul {
  list-style: none;
  padding: 0;
}
.about .content ul li {
  padding-left: 28px;
  position: relative;
}
.about .content ul li + li {
  margin-top: 10px;
}
.about .content ul i {
  position: absolute;
  left: 0;
  top: 2px;
  font-size: 20px;
  color: #47b2e4;
  line-height: 1;
}
.about .content p:last-child {
  margin-bottom: 0;
}
.about .content .btn-learn-more {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 12px 32px;
  border-radius: 4px;
  transition: 0.3s;
  line-height: 1;
  color: #47b2e4;
  -webkit-animation-delay: 0.8s;
  animation-delay: 0.8s;
  margin-top: 6px;
  border: 2px solid #47b2e4;
}
.about .content .btn-learn-more:hover {
  background: #47b2e4;
  color: #fff;
  text-decoration: none;
}

/*--------------------------------------------------------------
# Why Us
--------------------------------------------------------------*/
.why-us {
  padding: 0px 0px;
}
.why-us .block{
  margin: 120px 0px;
}
.why-us .content {
  padding: 0px 20px 0 20px;
}
.why-us .content h2{
  text-transform: uppercase;
}
.why-us .content h3 {
  font-weight: 400;
  font-size: 18px;
  color: #678a3c;
}
.why-us .content h4 {
  font-size: 25px;
  font-weight: 700;
  margin-top: 5px;
}
.why-us .content p {
  font-size: 15px;
  color: #848484;
}
.why-us .img {
  border-radius: 10px;
  max-width: 80%
}
.why-us .icon {
  height: 100px;
}
#why-us .btn-labels {
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 11px 28px;
  border-radius: 10px;
  transition: 0.5s;
  margin: 10px 0 0 0;
  color: #fff;
  background: #d4892d;
  box-shadow: 0 1px 8px 0 rgba(0,0,0,.3)
}
#why-us .btn-labels:hover {
  background: #ae7228;
}
.why-us .accordion-list {
  padding: 0 100px 60px 100px;
}
.why-us .accordion-list ul {
  padding: 0;
  list-style: none;
}
.why-us .accordion-list li + li {
  margin-top: 15px;
}
.why-us .accordion-list li {
  padding: 20px;
  background: #fff;
  border-radius: 4px;
}
.why-us .accordion-list a {
  display: block;
  position: relative;
  font-family: "Poppins", sans-serif;
  font-size: 16px;
  line-height: 24px;
  font-weight: 500;
  padding-right: 30px;
  outline: none;
  cursor: pointer;
}
.why-us .accordion-list span {
  color: #47b2e4;
  font-weight: 600;
  font-size: 18px;
  padding-right: 10px;
}
.why-us .accordion-list i {
  font-size: 24px;
  position: absolute;
  right: 0;
  top: 0;
}
.why-us .accordion-list p {
  margin-bottom: 0;
  padding: 10px 0 0 0;
}
.why-us .accordion-list .icon-show {
  display: none;
}
.why-us .accordion-list a.collapsed {
  color: #343a40;
}
.why-us .accordion-list a.collapsed:hover {
  color: #47b2e4;
}
.why-us .accordion-list a.collapsed .icon-show {
  display: inline-block;
}
.why-us .accordion-list a.collapsed .icon-close {
  display: none;
}
@media (max-width: 1024px) {
  .why-us .content, .why-us .accordion-list {
    padding-left: 0;
    padding-right: 0;
  }
}
@media (max-width: 992px) {
  .why-us .img {
    min-height: 300px;
  }
  .why-us .content {
    padding-top: 30px;
    text-align: center !Important;
  }
  .why-us .accordion-list {
    padding-bottom: 30px;
  }
}
@media (max-width: 575px) {
  .why-us .img {
    min-height: 150px;
  }
}

/*--------------------------------------------------------------
# Skills
--------------------------------------------------------------*/
.skills .content h3 {
  font-weight: 700;
  font-size: 32px;
  color: #37517e;
  font-family: "Poppins", sans-serif;
}
.skills .content ul {
  list-style: none;
  padding: 0;
}
.skills .content ul li {
  padding-bottom: 10px;
}
.skills .content ul i {
  font-size: 20px;
  padding-right: 4px;
  color: #47b2e4;
}
.skills .content p:last-child {
  margin-bottom: 0;
}
.skills .progress {
  height: 60px;
  display: block;
  background: none;
  border-radius: 0;
}
.skills .progress .skill {
  padding: 0;
  margin: 0 0 6px 0;
  text-transform: uppercase;
  display: block;
  font-weight: 600;
  font-family: "Poppins", sans-serif;
  color: #37517e;
}
.skills .progress .skill .val {
  float: right;
  font-style: normal;
}
.skills .progress-bar-wrap {
  background: #e8edf5;
  height: 10px;
}
.skills .progress-bar {
  width: 1px;
  height: 10px;
  transition: 0.9s;
  background-color: #4668a2;
}

/*--------------------------------------------------------------
# Cta
--------------------------------------------------------------*/
.cta {
  /*background: linear-gradient(rgb(147 112 52 / 52%), rgba(90, 63, 40, 0.9)), url(../images/website_2/cta.jpeg) fixed center center;*/
  background-size: cover;
  padding-bottom: 100px;
}
.cta h3 {
  /*color: #fff;*/
  font-size: 28px;
  font-weight: 700;
}
.cta p {
  /*color: #fff;*/
}
.cta-btn {
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 12px 40px;
  border-radius: 15px;
  transition: 0.5s;
  margin: 0px;
  border: 2px solid #D4892D;
  color: #fff;
  background: #d4892d;
  width: auto;
}
.cta-btn:hover {
  background: #ae7228;
}
@media (max-width: 1024px) {
  .cta {
    background-attachment: scroll;
  }
}
@media (min-width: 769px) {
  .cta .cta-btn-container {
    display: flex;
    align-items: center;
    justify-content: flex-end;
  }
}

/*--------------------------------------------------------------
# Portfolio
--------------------------------------------------------------*/
.portfolio #portfolio-flters {
  list-style: none;
  margin-bottom: 20px;
}
.portfolio #portfolio-flters li {
  cursor: pointer;
  display: inline-block;
  margin: 10px 5px;
  font-size: 15px;
  font-weight: 500;
  line-height: 1;
  color: #444444;
  transition: all 0.3s;
  padding: 8px 20px;
  border-radius: 15px;
  font-family: "Poppins", sans-serif;
}
.portfolio #portfolio-flters li:hover, .portfolio #portfolio-flters li.filter-active {
  background: #47b2e4;
  color: #fff;
}
.portfolio .portfolio-item {
  margin-bottom: 30px;
}
.portfolio .portfolio-item .portfolio-img {
  overflow: hidden;
}
.portfolio .portfolio-item .portfolio-img img {
  transition: all 0.6s;
}
.portfolio .portfolio-item .portfolio-info {
  opacity: 0;
  position: absolute;
  left: 15px;
  bottom: 0;
  z-index: 3;
  right: 15px;
  transition: all 0.3s;
  background: rgba(29, 81, 9, 0.8);
  padding: 10px 15px;
}
.portfolio .portfolio-item .portfolio-info h4 {
  font-size: 18px;
  color: #fff;
  font-weight: 600;
  color: #fff;
  margin-bottom: 0px;
}
.portfolio .portfolio-item .portfolio-info p {
  color: #f9fcfe;
  font-size: 14px;
  margin-bottom: 0;
}
.portfolio .portfolio-item .portfolio-info .preview-link, .portfolio .portfolio-item .portfolio-info .details-link {
  position: absolute;
  right: 40px;
  font-size: 24px;
  top: calc(50% - 18px);
  color: #fff;
  transition: 0.3s;
}
.portfolio .portfolio-item .portfolio-info .preview-link:hover, .portfolio .portfolio-item .portfolio-info .details-link:hover {
  color: #47b2e4;
}
.portfolio .portfolio-item .portfolio-info .details-link {
  right: 10px;
}
.portfolio .portfolio-item:hover .portfolio-img img {
  transform: scale(1.15);
}
.portfolio .portfolio-item:hover .portfolio-info {
  opacity: 1;
}
.portfolio .portfolio-wrap {
  transition: 0.3s;
  position: relative;
  overflow: hidden;
  z-index: 1;
  background: rgba(255, 255, 255, 0.6);
}

.portfolio .portfolio-wrap::before {
  content: "";
  background: rgba(255, 255, 255, 0.6);
  position: absolute;
  left: 30px;
  right: 30px;
  top: 30px;
  bottom: 30px;
  transition: all ease-in-out 0.3s;
  z-index: 2;
  opacity: 0;
}

.portfolio .portfolio-wrap .portfolio-info {
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  text-align: center;
  z-index: 3;
  transition: all ease-in-out 0.3s;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.portfolio .portfolio-wrap .portfolio-info::before {
  display: block;
  content: "";
  width: 48px;
  height: 48px;
  position: absolute;
  top: 35px;
  left: 35px;
  border-top: 3px solid #bdc6ca;
  border-left: 3px solid #bdc6ca;
  transition: all 0.5s ease 0s;
  z-index: 9994;
}

.portfolio .portfolio-wrap .portfolio-info::after {
  display: block;
  content: "";
  width: 48px;
  height: 48px;
  position: absolute;
  bottom: 35px;
  right: 35px;
  border-bottom: 3px solid #bdc6ca;
  border-right: 3px solid #bdc6ca;
  transition: all 0.5s ease 0s;
  z-index: 9994;
}

.portfolio .portfolio-wrap .portfolio-info h4 {
  font-size: 20px;
  color: #d6d7d7;
  font-weight: 600;
}

.portfolio .portfolio-wrap .portfolio-info p {
  color: #d6d7d7;
  font-size: 14px;
  text-transform: uppercase;
  padding: 0;
  margin: 0;
}

.portfolio .portfolio-wrap .portfolio-links a:hover {
  color: #8dd0f0;
}

.portfolio .portfolio-wrap:hover::before {
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  opacity: 1;
}

.portfolio .portfolio-wrap:hover .portfolio-info {
  opacity: 1;
}

.portfolio .portfolio-wrap:hover .portfolio-info::before {
  top: 15px;
  left: 15px;
}

.portfolio .portfolio-wrap:hover .portfolio-info::after {
  bottom: 15px;
  right: 15px;
}

/*--------------------------------------------------------------
# Portfolio Details
--------------------------------------------------------------*/
.portfolio-details {
  padding-top: 40px;
}
.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: #fff;
  opacity: 1;
  border: 1px solid #47b2e4;
}
.portfolio-details .portfolio-details-slider .swiper-pagination .swiper-pagination-bullet-active {
  background-color: #47b2e4;
}
.portfolio-details .portfolio-info {
  padding: 30px;
  box-shadow: 0px 0 30px rgba(55, 81, 126, 0.08);
}
.portfolio-details .portfolio-info h3 {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #eee;
}
.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;
}

/*--------------------------------------------------------------
# Team
--------------------------------------------------------------*/
.about_content{
  padding-top: 100px;
}
.team_hero{
  height: 60vh;
  color: white;
  background: linear-gradient(rgba(21,47,48, 0.9),rgba(21,47,48, 0.5));
}
#team_hero_bg_image{
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: -1;
  height: 60vh;
  object-fit: cover;
}
.team_hero .btn-get-started {
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 11px 28px;
  border-radius: 15px;
  transition: 0.5s;
  color: #fff;
  background: #d4892d;
}
.team_hero .btn-get-started:hover {
  background: #ae7228;
}
.team_hero h1 {
  margin: 0 0 10px 0;
  font-size: 32px;
  font-weight: 700;
  line-height: 56px;
  color: #fff;
}
.team_hero h2 {
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 50px;
  font-size: 20px;
}
.team{
  padding-bottom:100px;
}
.team .intro{
  margin-bottom: 100px;
}
.team-content{
    padding-top:0px;
}
.team .member {
  margin-top: 50px;
  position: relative;
  box-shadow: 0px 2px 15px rgba(0, 0, 0, 0.1);
  border-radius: 5px;
  background: #fff;
  transition: 0.5s;
}
.team .member .row {
  width: -webkit-fill-available;
}
.team .member .pic {
  overflow: hidden;
  width: 180px;
  border-radius: 50%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 25px;
}
.team .member .pic img {
  transition: ease-in-out 0.3s;
}
.team .member:hover {
  transform: translateY(-10px);
}
.team .member .member-info {
  padding-left: 20px;
  padding-top: 20px;
  padding-bottom: 20px;
}
.team .member .member-info-name {
  margin-bottom: 5px;
}
@media (max-width: 992px) {
  .team .member .member-info {
    padding-left: 0px;
  }
}
.team .member h4 {
  font-weight: 700;
  margin-bottom: 5px;
  font-size: 18px;
  color: #5b5b5b;
  display: contents;
}
.team .member span {
  display: block;
  font-size: 15px;
  padding-bottom: 10px;
  padding-top: 5px;
  position: relative;
  font-weight: 500;
}
.team .member span::after {
  content: "";
  position: absolute;
  display: block;
  width: 50px;
  height: 1px;
  background: #cbd6e9;
  bottom: 0;
  left: 0;
}
.team .member p {
  margin: 10px 0 0 0;
  font-size: 14px;
}
.team .member .member-info-name span::after {
  display: none;
}
.team .member .member-badges {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  gap: 6px;
  margin-top: 8px;
  padding-bottom: 12px;
  margin-bottom: 8px;
  border-bottom: 1px solid #cbd6e9;
}
.team .member span.member-badge {
  display: inline-block;
  background: #e6f4e6;
  color: #3a7a3a;
  border: 1px solid #a8d5a8;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  padding: 3px 10px;
  white-space: nowrap;
  letter-spacing: 0.02em;
  position: static;
  padding-bottom: 3px;
}
.team .member span.member-badge::after {
  display: none;
}
.team .member .social {
  margin-top: 12px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.team .member .social a {
  font-size: 18px;
  display: inline-block;
  background: #f8eace;
  color: #DBA366;
  line-height: 1;
  padding: 8px 0;
  margin-right: 4px;
  border-radius: 50%;
  text-align: center;
  width: 36px;
  height: 36px;
  transition: 0.3s;
}
.team .member .social a:hover {
  background: #D4892D;
  color: #fff;
  text-decoration: none;
}
.team .member .social a + a {
  margin-left: 8px;
}
@media (max-width: 768px) {
  .team .member .member-info {
    text-align: center;
  }
  .team .member .social {
    justify-content: center;
  }
  .team .member .member-badges {
    justify-content: center;
  }
  .team .member span{
    padding-bottom: 0;
  }
  .team .member .member-badges {
    border-bottom: 1px solid #cbd6e9;
  }
}
.team .slogan{
  margin-top: 100px;
}
.team .slogan h3{
  padding-top: 50px;
  padding-bottom: 50px;
  padding-right: 10px;
  padding-left: 10px;
}
.team .mission{
  margin-top: 100px;
}
.team .picture_gallery{
  margin-top: 100px;
  margin-bottom: 0px;
}
.team .picture_gallery .gallery {
   line-height:0;
   -webkit-column-count:4;
   -webkit-column-gap:1px;
   -moz-column-count:4;
   -moz-column-gap:1px;
   column-count:4;
   column-gap:1px;
}
@media (max-width: 1000px) {
   .team .picture_gallery .gallery {
    -moz-column-count:    3;
    -webkit-column-count: 3;
    column-count:         3;
   }
}
@media (max-width: 800px) {
  .team .picture_gallery .gallery {
     line-height:0;
     -webkit-column-count:2;
     -moz-column-count:2;
     column-count:2;
  }
}
@media (max-width: 400px) {
  .team .picture_gallery .gallery {
     line-height:0;
     -webkit-column-count:1;
     -moz-column-count:1;
     column-count:1;
  }
}
.team .picture_gallery .gallery img {
   width: 100% !important;
   height: auto !important;
   margin-bottom:1px;
   filter: grayscale(100%);
}
.team .picture_gallery .gallery img:hover {
   filter:none;
}

/*--------------------------------------------------------------
# Advisery board
--------------------------------------------------------------*/

#adviseryboard .row {
  background: white;
}

.adviseryboard .member .linkedin {
  font-size: 18px;
  display: inline-block;
  background: #f8eace;
  color: #DBA366;
  line-height: 1;
  padding: 8px 0;
  margin-right: 4px;
  border-radius: 50%;
  text-align: center;
  width: 36px;
  height: 36px;
  transition: 0.3s;
}
.adviseryboard .member .linkedin:hover {
  background: #D4892D;
  color: #fff;
  text-decoration: none;
}
.adviseryboard .member {
  padding: 50px;
}
@media (max-width: 767px) {
  .adviseryboard .member {
    padding: 25px;
  }
}

/*--------------------------------------------------------------
# Pricing
--------------------------------------------------------------*/
.pricing .row {
  padding-top: 0px;
}
.pricing .box {
  padding: 60px 40px;
  box-shadow: 0 3px 20px -2px rgba(20, 45, 100, 0.1);
  background: #fff;
  height: 100%;
  border-top: 4px solid #fff;
  border-radius: 5px;
}
.pricing h3 {
  font-weight: 600;
  margin-bottom: 15px;
  font-size: 20px;
  color: #5b5a5a;
}
.pricing h4 {
  font-size: 48px;
  color: #37517e;
  font-weight: 400;
  font-family: "Manrope", sans-serif;
  margin-bottom: 25px;
}
.pricing h4 sup {
  font-size: 28px;
}
.pricing h4 span {
  color: #47b2e4;
  font-size: 18px;
  display: block;
}
.pricing ul {
  padding: 20px 0;
  list-style: none;
  color: #999;
  text-align: left;
  line-height: 20px;
}

.pricing ul i {
  color: #28a745;
  font-size: 24px;
  position: absolute;
  left: 0;
  top: 6px;
}
.pricing ul .na {
  color: #ccc;
}
.pricing ul .na i {
  color: #ccc;
}
.pricing ul .na span {
  text-decoration: line-through;
}
.pricing .buy-btn {
  display: inline-block;
  padding: 12px 35px;
  border-radius: 15px;
  color: #47b2e4;
  transition: none;
  font-size: 16px;
  font-weight: 500;
  font-family: "Manrope", sans-serif;
  transition: 0.3s;
  border: 1px solid #47b2e4;
}
.pricing .buy-btn:hover {
  background: #47b2e4;
  color: #fff;
}
.pricing .featured {
  border-top-color: #47b2e4;
}
.pricing .featured .buy-btn {
  background: #47b2e4;
  color: #fff;
}
.pricing .featured .buy-btn:hover {
  background: #23a3df;
}
@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;
  }
}
#pricing_labels{
  padding-left: 0px;
  padding-right: 0px;
}
#pricing_labels .frame {
  background: #fff;
  padding: 30px 0;
  border: 1px solid #a4a2a2;
  min-height: 30px;
  border-radius: 15px;
  text-align: center;
}
#pricing_labels .inner-lign {
border-right: 1px solid #dbdbdb;
}
#pricing_labels .frame h5{
  font-size: 16px;
  font-weight: 600;
}
#pricing_labels .frame .label-img{
  min-height: 180px;
}
#pricing_labels .frame img{
  padding: 20px;
  max-width: 100%;
  max-height: 300px;
}
#pricing_labels .frame .small_tag{
  max-height: 180px;
}
#pricing_labels .frame .signs{
  max-height: 180px;
}
#pricing_labels .frame .icon{
    max-width: 20px;
    padding: 0px;
    margin-right: 5px;
}
#pricing_labels .amount{
    display: inline-block;
    font-size: 30px;
    color: #5a5a5a;
    position: relative;
    font-weight: 800;
}
#pricing_labels .currency{
    font-size: 14px;
}
#pricing_labels .tag-size{
    font-size: 14px;
}
#pricing_labels .popular{

  position:relative
}
@media (max-width: 1200px) {
  #pricing_labels .frame .label-2,.label-4{
    margin-top: 60px;
  }
}
@media (max-width: 767px) {
  #pricing_labels .frame .label-2,.label-3,.label-4{
    margin-top: 60px;
  }
  #pricing_labels .inner-lign {
    border-right: 0px;
  }
}
/* ── Labels pricing (dgs theme overrides) ── */
#pricing_labels .dgs-card {
  height: 100%;
}
@media (max-width: 767px) {
  #pricing_labels .col-xl-3 {
    margin-bottom: 16px;
  }
  #pricing_labels .col-xl-3:last-child {
    margin-bottom: 0;
  }
}
#pricing_labels .dgs-card-head,
.dgs-attachment-row .dgs-card-head {
  border-bottom: none;
  min-height: unset;
  padding-bottom: 12px;
  text-align: left;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.dgs-labels-price-block {
  margin-top: auto;
}
.dgs-vol-price-table {
  width: 100%;
  border-collapse: collapse;
}
.dgs-vol-price-table thead th {
  font-size: 0.72rem;
  color: #bbb;
  font-weight: 500;
  padding: 0 0 5px 0;
  border-bottom: 1px solid #f0f0f0;
  vertical-align: baseline;
}
.dgs-vol-price-table td {
  padding: 4px 0;
  border-bottom: 1px solid #f8f8f8;
  vertical-align: baseline;
}
.dgs-vol-price-table tbody tr:last-child td {
  border-bottom: none;
}
.dgs-vol-qty {
  font-size: 0.78rem;
  color: #aaa;
  font-weight: 500;
  width: 45%;
}
.dgs-vol-price {
  font-size: 0.9rem;
  font-weight: 800;
  color: #333;
  text-align: right;
}
.dgs-label-img-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 130px;
  margin-bottom: 16px;
}
.dgs-label-img-wrap img {
  max-height: 120px;
  max-width: 100%;
  object-fit: contain;
  cursor: zoom-in;
  transition: transform 0.15s ease;
}
.dgs-label-img-wrap img:hover {
  transform: scale(1.06);
}
.label-zoom-dialog {
  max-width: 560px;
}
.label-zoom-content {
  background: #fff;
  border: none;
  border-radius: 16px;
  padding: 32px;
  position: relative;
  text-align: center;
}
.label-zoom-content img {
  max-width: 100%;
  max-height: 70vh;
  object-fit: contain;
  border-radius: 8px;
}
.label-zoom-close {
  position: absolute;
  top: 12px;
  right: 16px;
  background: none;
  border: none;
  font-size: 1.6rem;
  line-height: 1;
  color: #aaa;
  cursor: pointer;
  padding: 0;
}
.label-zoom-close:hover {
  color: #333;
}
.dgs-labels-card-footer {
  padding: 14px 22px 20px;
  border-top: 1px solid #f0f0f0;
  margin-top: 16px;
}
.dgs-labels-examples-link {
  font-size: 0.8rem;
  font-weight: 700;
  color: #D4892D;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  font-family: "Manrope", sans-serif;
}
.dgs-labels-examples-link:hover { text-decoration: underline; }
.labels-gallery-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.6);
  z-index: 1050;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.labels-gallery-overlay.open { display: flex; }
.labels-gallery-box {
  background: #fff;
  border-radius: 16px;
  padding: 28px;
  max-width: 1000px;
  width: 100%;
  position: relative;
}
.labels-gallery-title {
  margin-bottom: 24px;
}
.labels-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.labels-gallery-grid img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 8px;
  cursor: zoom-in;
  transition: transform 0.15s ease;
}
.labels-gallery-grid img:hover { transform: scale(1.04); }
.labels-gallery-close {
  position: absolute;
  top: 12px;
  right: 16px;
  background: none;
  border: none;
  font-size: 1.6rem;
  line-height: 1;
  color: #aaa;
  cursor: pointer;
  padding: 0;
}
.labels-gallery-close:hover { color: #333; }
.dgs-moq-note {
  font-size: 0.72rem;
  color: #bbb;
  margin-top: 4px;
}
.dgs-attachment-row .dgs-label-img-wrap {
  height: 260px;
}
.dgs-attachment-row .dgs-label-img-wrap img {
  max-height: 240px;
}
.dgs-attachment-row .dgs-price-amount .currency {
  font-size: 14px;
}
.dgs-attachment-desc {
  font-size: 0.78rem;
  color: #888;
  margin-top: 12px;
  line-height: 1.5;
}
.labels-cta-area {
  text-align: center;
  margin-top: 28px;
}
.labels-cta-area .dgs-btn-cta {
  display: inline-block;
  width: auto;
  padding: 12px 32px;
}
.labels-below-grid {
  font-size: 0.83rem;
  color: #aaa;
}
.labels-below-grid a {
  color: #D4892D;
  font-weight: 700;
}

.badge-popular-pill{
  position:absolute;
  top:-25px;
  left:67%;
  transform:translateX(-50%);
  padding:4px 10px;
  border-radius:999px;
  background:linear-gradient(90deg,#ecffeb,#a5ffa0);
  color:#073047;
  font-weight:600;
  font-size:10px;
  box-shadow:0 6px 16px rgba(255,184,107,0.12);
  display:inline-flex;
  align-items:center;
  gap:8px;
  z-index:2;
}

/*----------
# Pricing modal
----------*/
.pricing .modal p {
  font-size: 15px;
}
.pricing .modal .modal-content{
  color: #444444
}
.pricing .modal .modal-body .img{
  width: 50%;
  border: 1px solid #d5d2d2;
  border-radius: 10px;
}
.modal-header {
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 4px;
}
.modal-header .btn-close {
  position: absolute;
  top: 14px;
  right: 16px;
}
.signup-modal-badge {
  display: inline-block;
  background: #fff4e6;
  color: #D4892D;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 20px;
}
.signup-modal-subtitle {
  font-size: 0.8rem;
  color: #999;
  font-weight: 500;
}
.signup-modal-bullets {
  list-style: none;
  padding: 14px 16px;
  margin: 0 0 14px;
  background: #fafafa;
  border: 1.5px solid #eee;
  border-radius: 10px;
}
.signup-modal-bullets li {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  font-size: 0.88rem;
  color: #444;
  padding: 4px 0;
  padding-left: 10px;
  line-height: 1.4;
}
.signup-modal-bullets li::before {
  content: '✓';
  color: #D4892D;
  font-weight: 800;
  flex-shrink: 0;
}
.signup-modal-redirect {
  font-size: 0.78rem;
  color: #888;
  line-height: 1.5;
  margin-bottom: 16px;
  padding: 10px 14px;
  background: #f5f5f5;
  border-radius: 8px;
}

/*--------------------------------------------------------------
# Frequently Asked Questions
--------------------------------------------------------------*/
.faq .faq-list {
  padding: 0 100px;
}
.faq .faq-list ul {
  padding: 0;
  list-style: none;
}
.faq .faq-list li + li {
  margin-top: 15px;
}
.faq .faq-list li {
  padding: 20px;
  background: #fff;
  border-radius: 4px;
  position: relative;
}
.faq .faq-list a {
  display: block;
  position: relative;
  font-family: "Poppins", sans-serif;
  font-size: 16px;
  line-height: 24px;
  font-weight: 500;
  padding: 0 30px;
  outline: none;
  cursor: pointer;
}
.faq .faq-list .icon-help {
  font-size: 24px;
  position: absolute;
  right: 0;
  left: 20px;
  color: #47b2e4;
}
.faq .faq-list .icon-show, .faq .faq-list .icon-close {
  font-size: 24px;
  position: absolute;
  right: 0;
  top: 0;
}
.faq .faq-list p {
  margin-bottom: 0;
  padding: 10px 0 0 0;
}
.faq .faq-list .icon-show {
  display: none;
}
.faq .faq-list a.collapsed {
  color: #37517e;
  transition: 0.3s;
}
.faq .faq-list a.collapsed:hover {
  color: #47b2e4;
}
.faq .faq-list a.collapsed .icon-show {
  display: inline-block;
}
.faq .faq-list a.collapsed .icon-close {
  display: none;
}
.faq .accordion-button:focus{
  border-color: #D4892D !important;
  box-shadow: none;
}
.faq .accordion-button:not(.collapsed) {
  color: #D4892D !important;
  background-color:#d4892d29;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}
.faq .accordion-body {
  background-color:#d4892d08;
}
@media (max-width: 1200px) {
  .faq .faq-list {
    padding: 0;
  }
}
/*--------------------------------------------------------------
# Contact
--------------------------------------------------------------*/
.contact_hero{
  height: 50vh;
  color: white;
  background: linear-gradient(rgba(21,47,48, 0.9),rgba(21,47,48, 0.5));
}
#contact_hero_bg_image{
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: -1;
  height: 50vh;
  object-fit: cover;
}
.contact_hero h1 {
  margin: 0 0 10px 0;
  font-size: 32px;
  font-weight: 700;
  line-height: 56px;
  color: #fff;
}
.contact_hero h2 {
  color: white;
  margin-bottom: 50px;
  font-size: 20px;
}
.contact_box{
  margin-top: 80px;
}
.contact .info {
  /*border-top: 3px solid #47b2e4;
  border-bottom: 3px solid #47b2e4;*/
  padding: 30px;
  /*background: #fff;*/
  width: 100%;
  /*box-shadow: 0 0 24px 0 rgba(0, 0, 0, 0.1);*/
}
.contact .info i {
  font-size: 20px;
  color: #D4892D;
  float: left;
  width: 44px;
  height: 44px;
  background: #fde0a4;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 15px;
  transition: all 0.3s ease-in-out;
}
.contact .info h4 {
  padding: 0 0 0 60px;
  font-size: 22px;
  font-weight: 600;
  margin-bottom: 5px;
  color: #37517e;
}
.contact .info p {
  padding: 0 0 10px 60px;
  margin-bottom: 20px;
  font-size: 14px;
  color: #6182ba;
}
.contact .info .email p {
  padding-top: 5px;
}
.contact .info .social-links {
  padding-left: 60px;
}
.contact .info .social-links a {
  font-size: 18px;
  display: inline-block;
  background: #333;
  color: #fff;
  line-height: 1;
  padding: 8px 0;
  border-radius: 50%;
  text-align: center;
  width: 36px;
  height: 36px;
  transition: 0.3s;
  margin-right: 10px;
}
.contact .info .social-links a:hover {
  background: #D4892D;
  color: #fff;
}
.contact .info .email:hover i, .contact .info .address:hover i, .contact .info .phone:hover i {
  background: #D4892D;
  color: #fff;
}
.php-email-form {
  width: 100%;
  padding: 20px;
  background: #fff;
  box-shadow: 0 0 24px 0 rgba(0, 0, 0, 0.12);
}
.php-email-form .form-group {
  padding-bottom: 8px;
}
.php-email-form .validate {
  display: none;
  color: red;
  margin: 0 0 15px 0;
  font-weight: 400;
  font-size: 13px;
}
.php-email-form .error-message {
  display: none;
  color: #fff;
  background: #ed3c0d;
  text-align: left;
  padding: 15px;
  font-weight: 600;
}
.php-email-form .error-message br + br {
  margin-top: 25px;
}
.php-email-form .sent-message {
  display: none;
  color: #fff;
  background: #288B22;
  text-align: center;
  padding: 15px;
  font-weight: 600;
}
.php-email-form .loading {
  display: none;
  background: #fff;
  text-align: center;
  padding: 15px;
}
.php-email-form .loading:before {
  content: "";
  display: inline-block;
  border-radius: 50%;
  width: 24px;
  height: 24px;
  margin: 0 10px -6px 0;
  border: 3px solid #18d26e;
  border-top-color: #eee;
  -webkit-animation: animate-loading 1s linear infinite;
  animation: animate-loading 1s linear infinite;
}
.php-email-form .form-group {
  margin-bottom: 0px;
}
.php-email-form label {
  padding-bottom: 8px;
}
.php-email-form input, .php-email-form textarea, .php-email-form select{
  border-radius: 0;
  box-shadow: none;
  font-size: 16px;
  border-radius: 12px;
}
.php-email-form input:focus, .php-email-form textarea:focus, .php-email-form select:focus {
  border-color: #47b2e4;
}
.php-email-form select {
  color: #6C757D;
}
.php-email-form input, .php-email-form select{
  height: 50px;
}
.php-email-form textarea {
  padding: 10px 12px;
}
.php-email-form button[type=submit] {
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 11px 28px;
  border-radius: 10px;
  transition: 0.5s;
  margin: 10px 0 0 0;
  color: #fff;
  background: #d4892d;
  box-shadow: 0 1px 8px 0 rgba(0,0,0,.3);
  transition: all 125ms ease-out;
  border: initial;
}
.php-email-form button[type=submit]:hover {
  color: #fff;
  transform: translate3d(0, -1px, 0);
}
.php-email-form .fa-asterisk {
    color: #e58282;
    font-size: 8px;
    position: absolute;
    right: 10px;
    margin-top: 8px;
    z-index: 1;
}
.php-email-form .footnote {
    color: #6c757d;
    font-size: 11px;
    margin-top: 2px;
    margin-left: 10px;
}
.php-email-form .use_cases_title{
  display: flex;
  margin-top: 25px;
}
.php-email-form .use_case_label {
  display: flex
}
.php-email-form .trial-text {
  font-size: 14px;
  margin-top: 20px;
}
.php-email-form .use_case_checkbox {
  width:20px;
  height:20px;
  margin-right: 10px;
  float: left;
}
.php-email-form .fg_use_cases {
    padding-bottom: 0px;
}
.php-email-form .checkbox-asterisk{
  margin-top: auto;
  margin-bottom: 15px;
  position: inherit;
  margin-left: 2px;
}

@-webkit-keyframes animate-loading {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes animate-loading {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@media (max-width: 575px) {
  .contact .php-email-form {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.contact .office-box {
  width: 100%;
  background: #fff;
  box-shadow: 0 0 24px 0 rgba(0, 0, 0, 0.12);
}
.contact .office-box .office-box-detail {
  width: 100%;
  padding: 30px;
  min-height: 280px;
}

/*--------------------------------------------------------------
# Breadcrumbs
--------------------------------------------------------------*/
.breadcrumbs {
  padding: 15px 0 0 0;
  min-height: 40px;
  margin-top: 20px;
  position: absolute;
  z-index: 1;
}
@media (max-width: 992px) {
  .breadcrumbs {
    margin-top: 10px;
  }
}
.breadcrumbs a{
  color: #D4892D;
}
.breadcrumbs h2 {
  font-size: 28px;
  font-weight: 600;
  color: #37517e;
}
.breadcrumbs ol {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 0 0 10px 0;
  margin: 0;
  font-size: 14px;
  color: white;
}
.breadcrumbs ol li + li {
  padding-left: 4px;
}
.breadcrumbs ol li + li::before {
  display: inline-block;
  padding-right: 10px;
  color: #D4892D;
}

/*--------------------------------------------------------------
# Ecosystems
--------------------------------------------------------------*/
.ecosystem_content{
  background: white;
}
.ecosystem_hero{
  height: 60vh;
  color: white;
  background: linear-gradient(rgba(21, 47, 48, 0.8), rgba(21, 47, 48, 0.2));
}
.ecosystem_hero a{
  font-size: 14px;
}
#ecosystem_hero_bg_image{
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: -1;
  height: 60vh;
  object-fit: cover;
}
.ecosystem .btn-get-started {
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 11px 28px;
  border-radius: 15px;
  transition: 0.5s;
  color: #fff;
  background: #d4892d;
}
.ecosystem_hero .btn-get-started:hover {
  background: #ae7228;
}
.ecosystem_hero h1 {
  margin: 0 0 10px 0;
  font-size: 32px;
  font-weight: 700;
  line-height: 56px;
  color: #fff;
}
.ecosystem_hero h2 {
  color: white;
  margin-bottom: 10px;
  font-size: 20px;
}
.ecosystem_section_1{
  padding-top: 100px;
  padding-bottom: 50px;
}
.extension_icon{
  height: 35px;
  width: 35px;
}
.extension_box{
  position: relative;
  box-shadow: 0px 2px 15px rgb(0 0 0 / 10%);
  padding: 30px;
  border-radius: 5px;
  background: #fff;
  transition: 0.5s;
}
.extension_box h5{
  margin-top: 0.5rem;
}
.ecosystem_content a{
  color: #D4892D;
}
.ecosystem_section_2{
  padding-top: 50px;
  padding-bottom: 120px;
}
.ecosystem_section_3{
  height: 50vh;
  color: white;
  background: linear-gradient(rgba(21,47,48, 0.6),rgba(21,47,48, 0.6));
}
#ecosystem_section_3_bg_image{
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: -1;
  height: 50vh;
  object-fit: cover;
}
.ecosystem_stories_wrapper{
  margin-top: 100px;
  margin-bottom: 100px;
}
.ecosystem_stories_wrapper .story_title{
  color: #D4892D;
  font-size: 1.1rem;
}
.ecosystem_stories_wrapper .hashtags a{
  font-size: 15px;
  color: #D4892D;
}
.ecosystem_stories_wrapper .publishdate{
  font-size: 12px;
  color: grey;
}
.ecosystem .check {
  margin-right: 10px;
}
.ecosystem .why-us .block{
  padding-top: 0px;
  margin-top: 80px;
}
.ecosystem .clients {
  margin-top: 0px;
}
@media (max-width: 992px) {
  .ecosystem_hero h1 {
    margin: 0 0 10px 0;
    font-size: 28px;
    font-weight: 700;
    line-height: 40px;
  }
  .ecosystem_hero h2 {
    margin-bottom: 20px;
    font-size: 16px;
  }
}
.ecosystem .why-us .value_prop_box {
  min-height: 200px !important;
  align-items: inherit;
}
#school .why-us .value_prop_box {
  min-height: 240px !important;
}
#community .why-us .value_prop_box {
  min-height: 220px !important;
}
.ecosystem .why-us .value_prop_box h5{
  font-size: 18px;
}
.ecosystem .why-us .pillars{
  margin-top: 140px;
}
#agroecology .why-us .pillars{
  margin-top: 60px;
}
.ecosystem .arbnet-banner{
  margin-bottom: 80px;
}
.ecosytem_testimonial{
  margin-bottom: 100px;
}
.ecosytem_testimonial img{
  max-height: 180px;
  border-radius: 10px;
}
.ecosytem_testimonial .quotation-symbol{
  max-height: 50px;
  position: absolute;
  z-index: -99;
}

/*--------------------------------------------------------------
# Pricing
--------------------------------------------------------------*/
.pricing .breadcrumbs ol{
  color: black;
}
.pricing .pricing_section{
  margin-top: 100px;
}
.pricing .col-md-6 {
  margin-top: 20px;
}
.pricing .clients{
  margin-top: 0px;
  padding: 0px;
  margin-bottom: 0px;
  margin-top: 0px;
}
.pricing .ecosytem_testimonial{
  margin-top: 100px;
  margin-bottom: 50px;
}
.clients .references .slogan{
  padding-left: 10px;
  padding-right: 10px;
  margin-bottom: 80px;
}
.currency-selector{
  display: flex;
  align-items: baseline;
  justify-content: center;
}
.currency-selector label{
  margin-right: 10px;
}
#currency-selector{
  width: auto;
}
.pricingTable{
    text-align: center;
    background: #fff;
    padding: 30px 0;
    border: 1px solid #a4a2a2;
    min-height: 300px;
    border-radius: 15px;
    padding-right: 0px;
}
.pricingTable .pricing-header{
    min-height: 285px;
    position: relative;
    display: flex;
    flex-direction: column;
}
.pricingTable .subtitle{
    font-size: 16px;
    font-weight: 300;
    color: #2e282a;
    margin: 10px 15px 10px 15px;
    min-height: 45px;
}
.pricingTable .trial-button-subtitle{
    font-size: 12px;
    font-weight: 300;
    color: #2e282a;
    min-height: 43px;
    margin-top: auto;
    padding-left: 5px;
    padding-right: 5px;
    width: 100%;
}
.pricingTable .trial-button-subtitle-bottom{
    font-size: 12px;
    font-weight: 300;
    color: #2e282a;
    min-height: 43px;
    position: relative;
    bottom: 0;
    left:0;
}
.pricingTable .price-value{
    padding: 30px 0;
    padding-bottom: 20px;
    margin-bottom: 10px;
    position: relative;
}
.pricingTable.plan_1 .price-value{
    padding-top: 45px;
    padding-bottom: 33px;
    min-height: 150px;
    border-top: 1px solid #dad8d8;
    border-bottom: 1px solid #dad8d8;
}
.pricingTable.plan_2 .price-value{
    min-height: 150px;
    border-top: 1px solid #dad8d8;
    border-bottom: 1px solid #dad8d8;
}
.pricingTable.plan_3 .price-value{
    min-height: 150px;
    border-top: 1px solid #dad8d8;
    border-bottom: 1px solid #dad8d8;
    color:#5a5a5a;
}
.pricingTable.plan_4 .price-value{
    min-height: 150px;
    border-top: 1px solid #dad8d8;
    border-bottom: 1px solid #dad8d8;
}
.pricingTable .pricing_icon{
  width: 20%;
  margin-bottom: 20px;
}
.pricingTable .price-value:before{
    content: "";
    border-top: 15px solid #fff;
    border-left: 15px solid transparent;
    border-right: 15px solid transparent;
    position: absolute;
    top: 0;
    left: 46%;
}
.pricingTable .month{
    display: block;
    font-size: 15px;
    color: #5a5a5a;
    text-transform: uppercase;
}
.pricingTable .yearly{
    display: block;
    font-size: 14px;
    color: #5a5a5a;
    text-transform: none;
    margin-top: 5px;
}
.pricingTable .amount{
    display: inline-block;
    font-size: 30px;
    color: #5a5a5a;
    position: relative;
    font-weight: 800;
}
.plan_3 .amount{
    margin-top: 5px;;
}
.pricingTable .currency{
    font-size: 14px;
}
.pricingTable .value{
    font-size: 20px;
    position: absolute;
    top: 21px;
    right: -27px;
}
.pricingTable .pricing-content{
    padding: 0;
    margin: 0 0 30px 0;
    list-style: none;
    min-height: 300px;
}
.pricingTable .pricing-content li{
    font-size: 14px;
    color: #868686;
    line-height: 20px;
}
.pricingTable .pricing-content li .list-icon img{
    margin-right: 5px;
    height: 13px;
}
.pricingTable .pricing-content li .list-icon-gem img{
    margin-right: 4px;
    height: 15px;
}
.pricingTable .pricing-content .list-item{
    flex-direction: row;
    padding-right: 5px;
}
.pricingTable .pricing-content li .list-icon,.list-icon-gem{
   order: 1;
}
.pricingTable .pricing-content li .list-text{
  order: 2;
  line-height: 20px;
}
.pricingTable .pricing-content li .list-footnote{
  font-size: 13px;
  margin-top: 5px;
  color: #678A3C;
}
.pricingTable .pricing-content li .list-footnote a{
  color: #678A3C;
}
.pricingTable .pricing-content .hero-items{
  margin-bottom: 10px;
}
.pricingTable .pricing-content .base-items{
  min-height: 220px;
}
.pricingTable .pricing-content .feature-items{
  min-height: 350px;
}
.pricingTable .pricing-content .service-items{
  min-height: 100px;
}
.pricingTable .pricing-content li a{
  display: contents;
}
.pricingTable .pricing-content .seperator{
  border-top: 1px solid #cecece;
  height: 0px;
  margin-left: 20px;
  margin-right: 20px;
}
.pricingTable .pricing-content .tooltip-button{
  order: 3;
  border-radius: 15px;
  background-color: white;
  border: 1px #e1e1e1 solid;
  margin-left: 5px;
  color: #e1e1e1;
  height: 18px;
  font-size: 11px;
  width: 18px;
  padding: 0px;
  font-weight: 600;
  line-height: 0px;
}
.pricingTable .pricingTable-contact{
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 11px 28px;
  border-radius: 10px;
  transition: 0.5s;
  margin: 10px 0 0 0;
  color: #fff;
  background: #d4892d;
  box-shadow: 0 1px 8px 0 rgba(0,0,0,.3);
  transition: all 125ms ease-out;
}
.pricingTable .pricingTable-contact:hover{
  color: #fff;
  transform: translate3d(0, -1px, 0);
}
.pricingTable .pricingTable-contact-clean{
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 10px 28px;
  border-radius: 15px;
  transition: 0.5s;
  color: #5b5a5a;
}
.pricingTable .pricingTable-contact-clean:hover{
  font-weight: 600;
}
.pricingTable .pricing-header .pricingTable-contact{
  margin-bottom: 10px;
}

.featureTable{
  margin-top: 100px;
  margin-bottom: 40px;
}
.featureTable th{
  font-weight: 300;
}
.featureTable a{
  color: #D4892D;
}
.featureTable .plan_1,.plan_2,.plan_3,.plan_4{
  text-align: center;
  color: white;
}
.featureTable .plan_1{
  background-color: #8ec274;
}
.featureTable .plan_2{
  background-color: #a69250;
}
.featureTable .plan_3{
  background-color: #6282b0;
}
.featureTable .plan_4{
  background-color: #af6573;
}
.featureTable .description{
  width: 28%;
  font-weight: bold;
}
.featureTable .plan{
  width: 18%;
}
.featureTable td{
  text-align: center;
}
.featureTable tr{
  border-bottom: 1px solid #dbdbdb;
}
.featureTable .ecosystem{
  text-transform: uppercase;
  font-weight: 600;
}
.featureTable .featureTable-contact{
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 11px 28px;
  border-radius: 15px;
  transition: 0.5s;
  margin: 10px 0 0 0;
  color: #fff;
  background: #d4892d;
}
.featureTable .featureTable-contact:hover{
  background: #ae7228;
}
.featureTable .tooltip-button{
  border-radius: 50px;
  width: 18px;
  border: 1px solid grey;
  margin-left: 5px;
  font-size: 9px;
}
.featureTable .feature_subline{
  font-size: 13px;
  margin-top: 5px;
}
@media only screen and (max-width: 990px){
    .pricingTable{
      margin-bottom: 30px;
    }
}
@media only screen and (max-width: 767px){
    .featureTable{
      display: none;
    }
}
.pricing_faq{
    margin-bottom: 100px;
}
.pricing_faq .accordion-button{
  color: white;
  background: rgba(21, 47, 48, 0.9);
}
.pricing_faq .accordion-button:focus{
  box-shadow: 0 0 0 0.15rem #d4892d;
}
.pricing_faq .accordion-button::after{
  background-image: url("../images/website_2/pricing/arrow_down.svg");
}

/*--------------------------------------------------------------
# Landing page references
--------------------------------------------------------------*/
#landing-references {
  border: 1px solid #0000002b;
  border-radius: 10px;
}
#landing-references .col-lg-3{
  border-right: 1px solid #0000002b;
  position: relative;
}
#landing-references .box-4{
  border-right: 0px;
}
#landing-references .client-logo{
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 80px;
}
#landing-references .client-logo img{
  max-height: 80px;         /* prevent oversized logos */
  width: auto;
  object-fit: contain;
  max-width: 85%;
  padding: 0px;
  padding-top: 0px !important;
}
#landing-references .box-title{
  position: absolute;
  top: -2em;
  left: 50%;
  transform: translateX(-50%); /* centers horizontally */
  background: #fff;
  font-weight: 600;
  padding-left: 5px;
  padding-right: 5px;
  font-size: 14px;
}
@media only screen and (max-width: 576px){
  #landing-references .box-2,
  #landing-references .box-4{
    border-right: 0px;
  }
  #landing-references .box-1,.box-2{
    margin-bottom: 30px;
  }
  #landing-references .box-3,.box-4{
    padding-top: 30px;
    border-top: 1px solid #0000002b;
  }
  #landing-references .box-3 .box-title,
  #landing-references .box-4 .box-title{
    top: -1em;
  }
  #landing-references .client-logo{
    margin-top: 0px;
    margin-bottom: 0px;
  }
  #landing-references .client-logo img{
    width: 60%
  }
}


/*--------------------------------------------------------------
# Jobs
--------------------------------------------------------------*/
.jobs_hero{
  height: 60vh;
  color: white;
  background: linear-gradient(rgba(21,47,48, 0.9),rgba(21,47,48, 0.5));
}
#jobs_hero_bg_image{
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: -1;
  height: 60vh;
  object-fit: cover;
}
.jobs_hero h1 {
  margin: 0 0 10px 0;
  font-size: 32px;
  line-height: 56px;
  font-weight: 700;
  color: #fff;
}
.jobs_hero h2 {
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 50px;
  font-size: 24px;
}
.jobs_wrapper h2 {
  font-size: 30px;
}
.jobs_wrapper h3 {
  font-size: 20px;
}
.jobs_wrapper h4 {
  font-size: 20px;
}
.jobs_hero .btn-get-started {
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 11px 28px;
  border-radius: 15px;
  transition: 0.5s;
  margin: 10px 0 0 0;
  color: #fff;
  background: #d4892d;
}
.jobs_hero .btn-get-started:hover {
  background: #ae7228;
}
.jobs_wrapper {
  margin-top: 80px;
  margin-bottom: 80px;
}
.job_line h4{
  color: black;
}
.job_line p{
  color: black;
}
.jobs_cta{
  height: 50vh;
  color: white;
  background: linear-gradient(rgba(21,47,48, 0.6),rgba(21,47,48, 0.6));
}
.jobs_cta h3{
  font-size: 32px;
}
.jobs_cta h4{
  font-size: 20px;
}
#jobs_cta_bg_image{
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: -1;
  height: 50vh;
  object-fit: cover;
}
.job_hero{
  height: 60vh;
  color: white;
  background: linear-gradient(rgba(21,47,48, 0.9),rgba(21,47,48, 0.5));
}
#job_hero_bg_image{
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: -1;
  height: 60vh;
  object-fit: cover;
}
.job_hero h1 {
  margin: 0 0 10px 0;
  font-size: 40px;
  line-height: 56px;
  font-weight: 700;
  color: #fff;
}
.job_hero h2 {
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 50px;
  font-size: 20px;
}
.job_content{
  margin-top: 80px;
  margin-bottom: 80px;
}
.job_content .description{
  font-size: 18px;
}
.job_content .description h1{
  font-size: 25px;
}
/*--------------------------------------------------------------
# Stories
--------------------------------------------------------------*/
#stories .stories_wrapper{
  margin-top: 150px;
  margin-bottom: 100px;
}
#story .content{
  margin-top: 100px;
  margin-bottom: 50px;
}
.stories_wrapper .publishdate{
  font-size: 12px;
  color: grey;
}
.stories_wrapper .story_title{
  color: #D4892D;
}
.stories_wrapper .hashtags a{
  font-size: 15px;
  color: #D4892D;
}
.stories_hero{
  height: 400px;
  color: white;
  background: linear-gradient(rgba(21,47,48, 0.9),rgba(21,47,48, 0.5));
}
#stories_hero_bg_image{
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: -1;
  height: 400px;
  object-fit: cover;
}
.stories_hero h1 {
  margin: 0 0 10px 0;
  font-size: 32px;
  line-height: 56px;
  font-weight: 700;
  color: #fff;
}
.stories_hero h2 {
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 50px;
  font-size: 24px;
}
.stories_hero .btn-get-started {
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 11px 28px;
  border-radius: 15px;
  transition: 0.5s;
  margin: 10px 0 0 0;
  color: #fff;
  background: #d4892d;
}
.stories_hero .btn-get-started:hover {
  background: #ae7228;
}
.story-card-wrapper {
  padding: 10px;
}
.story-card {
  position: relative;
  box-shadow: 0px 2px 15px rgb(0 0 0 / 10%);
  border-radius: 5px;
  background: #ffffffa6;
  transition: 0.5s;
}
.story-card-wrapper .hero_image{
  height: 12rem;
  width: 100%;
  object-fit: cover;
  margin-bottom: 10px;
  border-top-left-radius:5px;
  border-top-right-radius:5px;
}
.story-card-wrapper .hero_image:hover{
  transform: scale(1.02);
}
.story-card-content{
  padding: 15px;
}
.story_quote{
  margin-bottom: 50px;
}
.stories .content_image{
  width: -moz-available;
  width: -webkit-fill-available;
  width: fill-available;
  margin-left: 80px;
  margin-right: 80px;
}
@media (max-width: 992px) {
  .stories .content_image{
    margin-top: 30px;
    margin-left: 0px;
    margin-right: 0px;
  }
}
.stories .content_image_caption {
  width: -webkit-fill-available;
  margin-left: 20px;
  margin-right: 20px;
  margin-top: 10px;
  text-align: center;
  font-style: italic;
}
.stories .content_2{
  margin-top: 100px;
}
.stories .content_3{
  margin-top: 100px;
}
.story_tags{
  margin-top: 30px;
}
.story_tags a{
  color: #D4892D;
}
.stories .youtube-video{
  aspect-ratio: 16 / 9;
  width: 100%;
  padding-left: 50px;
}
@media (max-width: 992px) {
  .stories_hero h1 {
    font-size: 24px;
    line-height: inherit;
    font-weight: 700;
    color: #fff;
  }
  .stories_hero h2 {
    font-size: 18px;
  }
  .stories .youtube-video{
    padding-left: 0px;
  }
}


/*--------------------------------------------------------------
# Digital Garden Experience
--------------------------------------------------------------*/
.experience_hero{
  position: relative;
  height: 60vh;
  color: white;
  background: linear-gradient(rgba(21,47,48, 0.8),rgba(21,47,48, 0.2));
}
.experience_hero h1 {
  margin: 0 0 10px 0;
  font-size: 32px;
  font-weight: 700;
  line-height: 56px;
  color: #fff;
}
.experience_hero h2 {
  color: #fff;
  margin-bottom: 20px;
  font-size: 20px;
}
.experience_hero .accordion{
  width: 60%;
}
@media only screen and (max-width: 767px){
  .experience_hero .accordion{
    width: 100%;
  }
  .experience_hero {
    height: 95svh;
    align-items: flex-start;
    padding-top: 60px;
    padding-bottom: 40px;
    box-sizing: border-box;
  }
  .experience_hero h1 {
    font-size: 26px;
    line-height: 38px;
  }
  .experience_hero h2 {
    font-size: 17px;
    margin-bottom: 15px;
  }
}
.experience_hero .accordion-item {
  color: black;
  font-size: 12px;
}
.experience_hero .accordion-item h2 {
  margin-bottom: 0px;
}
.experience_hero .accordion-button {
  font-size: 12px;
  padding-top: 8px;
  padding-bottom: 8px;
}
.experience_hero .accordion-body {
  padding-top: 10px;
  padding-bottom: 10px;
}
.experience_hero .accordion-button:focus{
  border-color: green;
  box-shadow: none;
}
.experience_hero .accordion-button:not(.collapsed){
  color: black;
  font-weight: 600;
  background-color: white;
}
#garden_experience .why-us{
  margin-top: 0px;
}
#garden_experience .header_line{
  font-size: 30px;
  font-weight: 600;
  margin-bottom: 50px;
  margin-top: 30px;
}
#garden_experience .sub_line{
  font-size: 18px;
  font-weight: 100;
  margin-top: 30px;
}
#garden_experience .clients{
  margin-top: 0px;
  padding-top: 0px;
}
#garden_experience .faq{
  padding-top: 60px;
  margin-bottom: 50px
}
#garden_experience .slogan{
  padding-top: 0px;
}
#garden_experience .why-us .img{
  border: 1px solid #0000002b;
}

/*--------------------------------------------------------------
# Labels
--------------------------------------------------------------*/
.labels_hero{
  height: 60vh;
  color: white;
  background: linear-gradient(rgba(21,47,48, 0.9),rgba(21,47,48, 0.5));
}
#labels_hero_bg_image{
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  object-fit: cover;
}
.labels_hero .btn-get-started {
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 11px 28px;
  border-radius: 15px;
  transition: 0.5s;
  margin: 10px 0 0 0;
  color: #fff;
  background: #d4892d;
}
.labels_hero .btn-get-started:hover {
  background: #ae7228;
}
.labels_hero h1 {
  margin: 0 0 10px 0;
  font-size: 32px;
  font-weight: 700;
  line-height: 56px;
  color: #fff;
}
.labels_hero h2 {
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 50px;
  font-size: 24px;
}
.labels_title{
  margin-top:80px;
  margin-bottom: 80px;
}
.labels_overview{
  margin-bottom: 80px;
}
.label_box{
  position: relative;
  box-shadow: 0px 2px 15px rgb(0 0 0 / 10%);
  border-radius: 5px;
  background: #fff;
  transition: 0.5s;
  min-height: 700px;
}
.label_box_2{
  min-height: 500px;
}
.label_box_content{
  padding: 10px;
}
#labels .plantsoon_dashboard {
  margin-top: 60px;
  margin-bottom: 100px;
}
#labels .btn-get-quote {
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 18px 28px 18px 28px;
  border-radius: 15px;
  transition: 0.5s;
  margin: 10px 0 0 0;
  color: #fff;
  background: #d4892d;
}
#labels .btn-get-quote:hover {
  background: #ae7228;
}
#labels .slogan {
  margin-top: 20px;
  margin-bottom: 80px;
}
#labels .clients {
  margin-top: 0px;;
}
#labels .cta {
  margin-top: 0px;
  margin-bottom: 0px;
}
#labels .why-us{
  margin-top: 50px;
  margin-bottom: 0px;
}
#labels .why-us .value_prop_box{
  border: 1px solid #0000002b;
  border-radius: 15px;
  padding: 20px;
  min-height: 300px;
  transition: all 125ms ease-out;
}
#labels .how-it-works {
  padding-top: 0px;
}
#labels .how-it-works a{
  margin-top: 0px !important;
}
#labels .main_box{
  background-color: #fac48359;
}
#labels .why-us .img {
    border: 1px solid #0000002b;
}
#labels .why-us .value_prop_box img{
  margin-top: 20px;
  max-width: 100%;
  border: none;
}
#labels .why-us .header_line{
  margin-top: 0px;
  margin-bottom: 20px;
}
#labels .why-us .sub_line{
  margin-top: 0px;
  margin-bottom: 40px;
}
#labels .ecosytem_testimonial{
  margin-top: 100px;
  margin-bottom: 50px;
}

/*--------------------------------------------------------------
# Mission
--------------------------------------------------------------*/
.mission{
  padding-bottom: 0;
}
.mission_hero{
  height: 60vh;
  color: white;
  background: linear-gradient(rgba(21,47,48, 0.9),rgba(21,47,48, 0.5));
}
#mission_hero_bg_image{
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: -1;
  height: 60vh;
  object-fit: cover;
}
.mission_hero h1 {
  margin: 0 0 10px 0;
  font-size: 48px;
  font-weight: 700;
  line-height: 56px;
  color: #fff;
}
.mission_hero h2 {
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 50px;
  font-size: 24px;
}
.mission .statement {
  margin-top: 100px;
  margin-bottom: 100px;
}
.mission_box{
  position: relative;
  box-shadow: 0px 2px 15px rgb(0 0 0 / 10%);
  border-radius: 5px;
  background: #fff;
  transition: 0.5s;
  padding-top: 50px;
  padding-bottom: 50px;
  padding-right: 20px;
  padding-left: 20px;
  min-height: 300px;
}
.mission .core_values_title{
  margin-top: 150px;
  margin-bottom: 150px;
}
.mission_icon{
  width: 30px;
  height: 30px;
}
#mission .cta {
  background: linear-gradient(rgba(147, 112, 52, 0.9), rgba(90, 63, 40, 0.9)), url("../images/website_2/mission/cta.jpg") fixed center center;
  background-repeat: no-repeat;
  background-size: cover;
  margin-top: 100px;
  padding-top: 100px;
  color: #fff;
}

/*--------------------------------------------------------------
# Partners
--------------------------------------------------------------*/
.partners_hero{
  height: 60vh;
  color: white;
  background: linear-gradient(rgba(21,47,48, 0.9),rgba(21,47,48, 0.5));
}
#partners_hero_bg_image{
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: -1;
  height: 60vh;
  object-fit: cover;
}
.partners_hero h1 {
  margin: 0 0 10px 0;
  font-size: 32px;
  font-weight: 700;
  line-height: 56px;
  color: #fff;
}
.partners_hero h2 {
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 50px;
  font-size: 24px;
}
.partners_content .section_partners{
  margin-top: 120px;
  margin-bottom: 50px;
}
.partners_content .section_project_partners{
  margin-top: 150px;
  margin-bottom: 120px;
}
.partners_content .section_partners img{
  max-height: 120px;
}
.partners_content .section_project_partners img{
  max-height: 120px;
}

/*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/
#footer {
  font-size: 14px;
  background: #152F30;
}
#footer .treehatch_logo {
  width: 90px;
}
#footer .footer-newsletter {
  padding: 50px 0;
  background: #f3f5fa;
  text-align: center;
  font-size: 15px;
  color: #444444;
}
#footer .footer-newsletter h4 {
  font-size: 24px;
  margin: 0 0 20px 0;
  padding: 0;
  line-height: 1;
  font-weight: 600;
  color: #37517e;
}
#footer .footer-newsletter form {
  margin-top: 30px;
  background: #fff;
  padding: 6px 10px;
  position: relative;
  border-radius: 15px;
  box-shadow: 0px 2px 15px rgba(0, 0, 0, 0.06);
  text-align: left;
}
#footer .footer-newsletter form input[type=email] {
  border: 0;
  padding: 4px 8px;
  width: calc(100% - 100px);
}
#footer .footer-newsletter form input[type=submit] {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  border: 0;
  background: none;
  font-size: 16px;
  padding: 0 20px;
  background: #47b2e4;
  color: #fff;
  transition: 0.3s;
  border-radius: 15px;
  box-shadow: 0px 2px 15px rgba(0, 0, 0, 0.1);
}
#footer .footer-newsletter form input[type=submit]:hover {
  background: #209dd8;
}
#footer .footer-top {
  padding: 60px 0 30px 0;
  background: white;
  border-top: 1px solid #dad7d7;
}
#footer .footer-top .footer-contact {
  margin-bottom: 30px;
  color: #5e5e5e;
}
#footer .footer-top .footer-contact h3 {
  font-size: 28px;
  margin: 0 0 10px 0;
  padding: 2px 0 2px 0;
  line-height: 1;
  text-transform: uppercase;
  font-weight: 600;
  color: #37517e;
}
#footer .footer-top .footer-contact p {
  font-size: 14px;
  line-height: 24px;
  margin-bottom: 0;
  color: #5e5e5e;
}
#footer .footer-top h4 {
  font-size: 16px;
  font-weight: bold;
  color: #525458;
  position: relative;
  padding-bottom: 12px;
}
#footer .footer-top .footer-links {
  margin-bottom: 30px;
}
#footer .footer-top .footer-links ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
#footer .footer-top .footer-links ul i {
  padding-right: 2px;
  color: #47b2e4;
  font-size: 18px;
  line-height: 1;
}
#footer .footer-top .footer-links ul li {
  padding: 10px 0;
  display: flex;
}
#footer .footer-top .footer-links ul li:first-child {
  padding-top: 0;
}
#footer .footer-top .footer-links ul a {
  color: #777777;
  transition: 0.3s;
  display: inline-block;
  line-height: 1;
  font-weight: 100;
}
#footer .footer-top .footer-links ul a:hover {
  text-decoration: none;
  color: #D4892D;
}
#footer .footer-bottom .social-links a {
  font-size: 18px;
  display: inline-block;
  background: #f8eace;
  color: #DBA366;
  line-height: 1;
  padding: 9px 0;
  margin-right: 4px;
  border-radius: 50%;
  text-align: center;
  width: 36px;
  height: 36px;
  transition: 0.3s;
}
#footer .footer-bottom .social-links a:hover {
  background: #D4892D;
  color: #fff;
  text-decoration: none;
}
#footer .footer-bottom {
  padding-top: 30px;
  padding-bottom: 30px;
  color: #fff;
}
#footer .copyright {
  font-size: 14px;
  text-align: center;
}
#footer .credits {
  float: right;
  font-size: 13px;
}
#footer .credits a {
  transition: 0.3s;
}
#footer .APGA {
  margin-top: 25px;
  color: #525458;
  font-weight: 600;
}
#footer .APGA-logo {
  width: 200px;
}

@media (max-width: 768px) {

  #footer .footer-bottom {
    padding-top: 20px;
    padding-bottom: 20px;
  }
  #footer .copyright, #footer .credits {
    text-align: center;
    float: none;
  }
  #footer .credits {
    padding-top: 4px;
  }
  #footer .footer-links {
    text-align: center;
  }
  #footer .footer-top .footer-links ul li {
    justify-content: center;
  }
}


/*--------------------------------------------------------------
# Mailerlite
--------------------------------------------------------------*/
#mlb2-28229230.ml-form-embedContainer .ml-form-embedWrapper .ml-form-embedBody .ml-form-embedContent h4, #mlb2-28229230.ml-form-embedContainer .ml-form-embedWrapper .ml-form-successBody .ml-form-successContent h4{
  font-family:'Manrope', sans-serif !important;
  font-weight: bold !important;
}
#mlb2-28229230.ml-form-embedContainer .ml-form-embedWrapper .ml-form-embedBody .ml-form-fieldRow input {
  font-family:'Manrope', sans-serif !important;
}
#mlb2-28229230.ml-form-embedContainer .ml-form-embedWrapper .ml-form-embedBody .ml-form-embedPermissions .ml-form-embedPermissionsContent.privacy-policy p {
  font-family:'Manrope', sans-serif !important;
}
#mlb2-28229230.ml-form-embedContainer .ml-form-embedWrapper .ml-form-embedBody, #mlb2-28229230.ml-form-embedContainer .ml-form-embedWrapper .ml-form-successBody {
  padding: 0px !important;
  padding-left: 20px !important;
  padding-right: 20px !important;
}
#mlb2-28229230.ml-form-embedContainer .ml-form-embedWrapper .ml-form-embedBody .ml-form-embedSubmit button {
  max-width: 50% !important;
  font-family: "Manrope", sans-serif !important;
}
#mlb2-28229230.ml-form-embedContainer .ml-form-align-center {
  text-align: left !important;
}
#mlb2-28229230.ml-form-embedContainer .ml-form-embedWrapper .ml-form-embedBody .ml-form-embedSubmit:hover {
 color: #fff !important;
 transform: translate3d(0, -1px, 0) !important;
}

/*--------------------------------------------------------------
# Referral
--------------------------------------------------------------*/
.referral .breadcrumbs ol{
  color: black;
}
.referral .referral_section{
  margin-top: 100px;
}
.referral .headline{
  color:#D4892D;
  font-weight: 700;
  font-size:34px;
}
.referral .terms{
  font-size:12px;
  font-weight: 600;
}
.referral .subheadline{
  font-weight: 900;
  font-size:24px;
}
.referral .left-section {
  background-color: #fff5f8;
  padding: 50px;
}
@media only screen and (max-width: 767px){
    .referral .left-section{
      padding: 25px;
    }
}
.referral .how_it_works_title_1 {
  color:#D4892D;
  text-transform: uppercase;
  font-weight: 800;
}
.referral .how_it_works_title_2 {
  font-weight: 800;
  font-size: 25px;
}
.referral .how_it_works_subtitle {
  margin-bottom: 10px;
  font-size: 18px;
  font-weight: 700;
}
.referral .how_it_works_icon {
  max-height: 80px;
  margin-bottom: 20px;
}
.referral .referral_hero{
  max-width: -webkit-fill-available;
  height: -webkit-fill-available;
}
.referral_terms_section {
  margin-top: 100px;
  margin-bottom: 100px;
}
.referral_terms_section .title{
  font-weight: 700;
  font-size: 35px;
}
.referral_terms_section .paragraph_title
{
  font-weight: 700;
  font-size: 25px;
}

/*--------------------------------------------------------------
# Partnerships
--------------------------------------------------------------*/
.partnerships_hero{
  height: 60vh;
  color: white;
  background: linear-gradient(rgba(21,47,48, 0.9),rgba(21,47,48, 0.5));
}
#partnerships_hero_bg_image{
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: -1;
  height: 60vh;
  object-fit: cover;
}
.partnerships_hero h1 {
  margin: 0 0 10px 0;
  font-size: 32px;
  font-weight: 700;
  line-height: 56px;
  color: #fff;
}
.partnerships_hero h2 {
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 50px;
  font-size: 24px;
}
#partnerships .content {
  margin-top: 100px;
  margin-bottom: 100px;
}
.partnerships_box{
  position: relative;
  box-shadow: 0px 2px 15px rgb(0 0 0 / 10%);
  border-radius: 5px;
  background: #fff;
  transition: 0.5s;
  padding-top: 50px;
  padding-bottom: 50px;
  padding-right: 20px;
  padding-left: 20px;
}
#partnerships .cta-btn {
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 11px 28px;
  border-radius: 15px;
  transition: 0.5s;
  margin: 10px 0 0 0;
  color: #fff;
  background: #d4892d;
}
#partnerships .cta-btn:hover {
  background: #ae7228;
}
@media (max-width: 992px) {
  .partnerships_hero h1 {
    margin: 0 0 10px 0;
    font-size: 28px;
    font-weight: 700;
    line-height: 40px;
    color: #fff;
  }
  .partnerships_hero h2 {
    color: rgba(255, 255, 255, 0.6);
    margin-bottom: 50px;
    font-size: 16px;
  }
}

/*--------------------------------------------------------------
# ArbNet
--------------------------------------------------------------*/
#arbnet .breadcrumbs ol{
  color: black;
}
#arbnet .hero_section{
  margin-top: 120px;
}
#arbnet .hero_section .img{
  width: 90%;
}
#arbnet h1 {
  font-size: 30px;
}
#arbnet .link {
  text-decoration: underline;
}
#arbnet h2 {
  font-size: 20px;
  margin-top: 10px;
  margin-bottom: 15px;
}
#arbnet .arbnet-logo{
  margin-top: 20px;
  margin-bottom: 20px;
  max-width: 250px;
}
#arbnet .main{
  margin-top: 0px;
}
#arbnet .pricingTable ul li{
  padding-top: 8px;
  padding-bottom: 8px;
  padding-left: 20px;
}
#arbnet .pricingTable{
  padding-bottom: 0px;
}
#arbnet .pricingTable .pricing-content .base-items {
  min-height:0;
}
#arbnet .pricingTable .pricing-content .feature-items {
  min-height:0;
}
#arbnet .pricingTable .pricing-content .service-items {
  min-height:0;
}
/*----------
# DGS Pricing Cards (dgs-*)
----------*/
.dgs-pricing-row {
  padding-top: 24px;
}
.dgs-card {
  background: #fff;
  border: 1.5px solid #e6e6e6;
  border-radius: 16px;
  overflow: visible;
  position: relative;
  display: flex;
  flex-direction: column;
}
.dgs-card-popular {
  border-color: #D4892D;
  box-shadow: 0 8px 32px rgba(212,137,45,.15);
}
.dgs-popular-badge {
  position: absolute;
  top: 0; right: 20px;
  background: #D4892D;
  color: #fff;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 0 0 8px 8px;
}
.dgs-card-head {
  padding: 28px 22px 20px;
  border-bottom: 1px solid #f0f0f0;
  min-height: 290px;
}
.dgs-plan-name {
  font-size: 1.05rem;
  font-weight: 800;
  color: #1a1a1a;
  margin-bottom: 4px;
}
.dgs-plan-tagline {
  font-size: 0.78rem;
  color: #888;
  line-height: 1.45;
  margin-bottom: 18px;
  min-height: 36px;
}
.dgs-price-row {
  display: flex;
  align-items: baseline;
  gap: 5px;
  margin-bottom: 2px;
}
.dgs-price-amount {
  font-size: 1.8rem;
  font-weight: 800;
  color: #1a1a1a;
  line-height: 1;
}
.dgs-price-period {
  font-size: 0.78rem;
  color: #aaa;
  font-weight: 500;
}
.dgs-price-note {
  font-size: 0.72rem;
  color: #bbb;
  margin-bottom: 16px;
}
.dgs-btn-cta {
  display: block;
  width: 100%;
  padding: 10px 16px;
  border-radius: 10px;
  font-family: "Manrope", sans-serif;
  font-size: 0.88rem;
  font-weight: 700;
  text-align: center;
  cursor: pointer;
  border: none;
  text-decoration: none !important;
  transition: transform .1s, opacity .1s;
}
.dgs-btn-cta:hover { transform: translateY(-1px); }
.dgs-btn-primary  { background: #D4892D; color: #fff !important; }
.dgs-btn-secondary { background: #fff4e6; color: #D4892D !important; border: 1.5px solid #f0d4a0; }
.dgs-btn-ghost    { background: #f5f5f5; color: #555 !important; border: 1.5px solid #e0e0e0; }
.dgs-record-block {
  margin: 18px 22px 0;
  background: #f8f9fa;
  border: 1.5px solid #ebebeb;
  border-radius: 10px;
  padding: 12px 14px;
}
.dgs-record-block-popular {
  border-color: #f0d4a0;
}
.dgs-record-row {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 0.9rem;
  font-weight: 600;
  color: #333;
  padding: 3px 0;
}
.dgs-record-row > span:not(.dgs-dot) { flex: 1; }
.dgs-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.dgs-dot-green { background: #4a7c59; }
.dgs-dot-blue  { background: #3a7abf; }
.dgs-dot-red   { background: #b84040; }
.dgs-features {
  padding: 14px 22px 20px;
  flex: 1;
}
.dgs-features-label {
  font-size: 0.9rem;
  font-weight: 700;
  color: #555;
  background: #f5f5f5;
  border-radius: 6px;
  padding: 4px 8px;
  margin-bottom: 10px;
  display: block;
}
.dgs-sep {
  border-top: 1px solid #b2b2b2;
  margin: 10px 0;
}
.dgs-feature-list {
  list-style: none;
  padding: 0 0 0 8px; margin: 0;
  color: inherit;
  line-height: inherit;
  text-align: left;
}
.dgs-feature-list li,
#pricing_digital_green_space .dgs-feature-list li {
  display: flex;
  align-items: flex-start;
  gap: 7px;
  font-size: 0.9rem;
  color: #555;
  padding: 5px 0;
  position: static;
  line-height: 1.45;
}
.dgs-feature-list li::before {
  content: '✓';
  color: #D4892D;
  font-weight: 800;
  font-size: 0.82rem;
  flex-shrink: 0;
  margin-top: 1px;
}
.dgs-feature-list li span { flex: 1; }
.dgs-tip {
  border-radius: 50%;
  background: #eee;
  border: none;
  width: 15px; height: 15px;
  font-size: 0.6rem;
  font-weight: 800;
  color: #999;
  text-align: center;
  line-height: 15px;
  padding: 0;
  cursor: default;
  flex-shrink: 0;
  margin-top: 2px;
}
.dgs-card-footnote {
  padding: 0 22px 18px;
  font-size: 0.75rem;
}
.dgs-card-footnote a {
  color: #4a7c59;
  font-weight: 700;
  text-decoration: underline;
}

#arbnet .explanation {
  padding-right: 60px;
}
#arbnet .explanation .cta-btn{
  margin-top: 20px;
}
#arbnet .clients{
  margin-top: 50px;
  margin-bottom: 50px;
}
#arbnet .owl-carousel .owl-item img {
  padding-bottom: 20px;
}
#arbnet .owl-carousel .owl-item {
  align-self: end;
}
#arbnet .owl-carousel .owl-item .ArbNet-name{
  font-size: 13px;
  color: black;
}
#arbnet .owl-carousel .owl-item .ArbNet-level{
  font-size: 12px;
  background-color: #79a12eab;
  color: white;
  font-weight: bold;
  margin-right: 3px;
}
#arbnet .owl-carousel .owl-item .ArbNet-accr{
  font-size: 12px;
  background-color: #076223ba;
  color: white;
  font-weight: bold;
  margin-right: 3px;
}
#arbnet .img{
  border-radius: 20px
}
#arbnet .modal .modal-body {
  text-align: center;
}
#arbnet .modal .modal-body .img{
  width: 50%;
  border: 1px solid #d5d2d2;
  border-radius: 10px;
}
#arbnet .ecosytem_testimonial{
  margin-top: 100px;
  margin-bottom: 50px;
}

@media (max-width: 992px) {
  #arbnet .arbnet_section{
    margin-top: 80px;
  }
  #arbnet .hero-img{
    margin-top: 80px;
  }
  #arbnet .hero_section .img{
    margin-top: 50px;
    width: 100%;
  }
  #arbnet .explanation {
    padding-right: 12px;
  }
}
/*--------------------------------------------------------------
# Testimonials
--------------------------------------------------------------*/
.testimonials{
  margin-top: 80px;
}
.testimonials .slider-container {
  position: relative;
  overflow: hidden;
}
.testimonials .slider-track {
  display: flex;
  transition: transform 0.5s ease;
}
.testimonials .testimonial {
  flex: 0 0 calc((100% - 40px) / 3); /* 3 testimonials visible */
  box-sizing: border-box;
  padding: 15px;
  margin-right: 20px;
}
.testimonials .testimonial:last-child {
  margin-right: 0; /* no extra gap on the last item */
}
.testimonials .testimonial-card {
  background: #fff;
  border-radius: 12px;
  padding: 20px;
  box-shadow: 0 4px 8px rgba(0,0,0,0.1);
  height: 100%;
  transition: transform 0.3s ease;
}
.testimonials .testimonial-card .customer{
  font-size: 14px;
}
.testimonials .testimonial-card:hover {
  transform: translateY(-5px);
}
.testimonials .testimonial-card img {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  object-fit: cover;
  margin-bottom: 15px;
}
.testimonials .testimonial-card h5 {
  font-weight: 600;
  margin-bottom: 10px;
}
.testimonials .testimonial-card p {
  font-size: 0.95rem;
  color: #555;
}
.testimonials .slider-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: #d4892d6b;
  border: none;
  color: #fff;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  cursor: pointer;
  z-index: 10;
}
.testimonials .slider-btn:hover {
  background: rgba(0,0,0,0.7);
}
.testimonials .slider-btn.prev {
  left: 10px;
}
.testimonials .slider-btn.next {
  right: 10px;
}
@media (max-width: 768px) {
  .testimonials .testimonial {
    flex: 0 0 100%; /* 1 per row */
    margin-right: 0;
  }
  .testimonials .testimonial-card p {
    margin-top: 20px;
  }
}

/*--------------------------------------------------------------
# Legal
--------------------------------------------------------------*/
.legal_hero{
  height: 60vh;
  color: white;
  background: linear-gradient(rgba(21,47,48, 0.9),rgba(21,47,48, 0.5));
}
.legal_hero_bg_image{
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: -1;
  height: 60vh;
  object-fit: cover;
}
.legal_hero h1 {
  margin: 0 0 10px 0;
  font-size: 48px;
  font-weight: 700;
  line-height: 56px;
  color: #fff;
}
.legal_hero h2 {
  margin: 0 0 10px 0;
  font-size: 20px;
  font-weight: 500;
  line-height: 56px;
  color: #fff;
}
.legal_body{
    margin-bottom: 50px;
    margin-top: 70px;
}
.legal_body h2{
  margin-top: 40px;
  font-size: 24px;
}
.legal_body h3{
  margin-top: 30px;
  font-size: 20px;
}
.legal_body h4{
  margin-top: 25px;
  font-size: 18px;
}
.legal_body h5{
  margin-top: 25px;
  font-size: 16px;
}
.legal_body .legal-box{
  height: 190px;
  padding: 50px;
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}
.legal_body .legal-box img{
  height: 10px;
  margin-left: 3px;
}
.legal_body table thead tr {
  border-bottom: 1px dashed #ccc;
}
.legal_body table tbody tr {
  border-bottom: 1px solid #ccc;
}
.legal_body table tbody tr td{
  padding-top: 10px;
  padding-bottom: 10px;
}
.legal_body .subprocessors th:nth-child(1), .legal_body .subprocessors td:nth-child(1) {
  width: 20%;
}
.legal_body .subprocessors th:nth-child(2), .legal_body .subprocessors td:nth-child(2) {
  width: 50%;
}
.legal_body .subprocessors th:nth-child(3), .legal_body .subprocessors td:nth-child(3) {
  width: 30%;
}
.legal_body .service-concepts th:nth-child(1), .legal_body .service-concepts td:nth-child(1) {
  width: 20%;
}
.legal_body .service-concepts th:nth-child(2), .legal_body .service-concepts td:nth-child(2) {
  width: 80%;
}


/*--------------------------------------------------------------
# Privacy policy
--------------------------------------------------------------*/
.privacy_policy_hero{
  height: 60vh;
  color: white;
  background: linear-gradient(rgba(21,47,48, 0.9),rgba(21,47,48, 0.5));
}
#privacy_policy_hero_bg_image{
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: -1;
  height: 60vh;
  object-fit: cover;
}
.privacy_policy_hero h1 {
  margin: 0 0 10px 0;
  font-size: 48px;
  font-weight: 700;
  line-height: 56px;
  color: #fff;
}

/*--------------------------------------------------------------
# Cookie consent
--------------------------------------------------------------*/
.cookie-consent-wrapper {
  background-color: #d4892d;
  display: block;
  text-align: center;
  width: 100%;
  padding: 15px;
  opacity: 0.95;
}

.cookie-consent__btn {
  margin-top: 10px;
  display: block;
}

.cookie-consent__agree {
  font-family: "Manrope", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 11px 28px;
  border-radius: 15px;
  transition: 0.5s;
  margin: 10px 0 0 0;
  color: #fff;
  background: #d4892d;
  border-color: #fff;
}

.cookie-consent__readmore {
  font-family: "Manrope", sans-serif;
  font-weight: 300;
  font-size: 14px;
  letter-spacing: 1px;
  margin: 10px 0 0 0;
  padding-top: 3px;
  padding-bottom: 3px;
  position: inherit;
  margin-left: 10px;
  color: #fff;
}

.cookie-consent__message {
  margin-right: 15px;
  font-size: 14px;
  color: white;
  padding: 20px;
}

@media (max-width: 900px){
  .cookie-consent__message {
    display: block;
  }

  .cookie-consent__readmore {
      margin-top: 0px;
      margin-left: 15px;
  }
}

@media (max-width: 376px) {
  .cookie-consent-wrapper {
    padding: 15px 25px;
  }

  .cookie-consent__readmore {
      margin-top: 15px;
      margin-left: 0px;
  }
}

/*--------------------------------------------------------------
# Select2 searchable dropdown
--------------------------------------------------------------*/
.select2-selection {
  height: 50px !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  border: 1px solid #ced4da !important;
  border-radius: 12px !important;
  transition: border-color .15s ease-in-out,box-shadow .15s ease-in-out !important;
}

.select2-container--default .select2-selection--single{
  display: flex !important;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
  color: grey !important;
  align-content: center !important;
  padding-left: 10px;
}

/*--------------------------------------------------------------
# Mobile logo marquee
--------------------------------------------------------------*/
#landing-references-marquee {
  overflow: hidden;
  border: 1px solid #0000002b;
  border-radius: 10px;
  padding: 10px 0;
}
#landing-references-marquee .marquee-row {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  position: relative;
  padding: 6px 0;
  cursor: grab;
}
#landing-references-marquee .marquee-row::-webkit-scrollbar {
  display: none;
}
#landing-references-marquee .marquee-row::before,
#landing-references-marquee .marquee-row::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 32px;
  z-index: 2;
  pointer-events: none;
}
#landing-references-marquee .marquee-row::before {
  left: 0;
  background: linear-gradient(to right, #fff, transparent);
}
#landing-references-marquee .marquee-row::after {
  right: 0;
  background: linear-gradient(to left, #fff, transparent);
}
#landing-references-marquee .marquee-track {
  display: flex;
  gap: 24px;
  width: max-content;
  align-items: center;
}
#landing-references-marquee .marquee-track img {
  height: 72px;
  width: auto;
  max-width: 150px;
  object-fit: contain;
  filter: grayscale(1);
  opacity: 0.55;
  flex-shrink: 0;
}

/* ── Product Demo Section ── */
.product-demo {
  padding: 30px 0 80px;
  background: #f4f2ed;
}
.demo-tab-list { display: flex; flex-direction: column; gap: 8px; }
.demo-tab-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 10px;
  cursor: pointer;
  border: 2px solid transparent;
  transition: background 0.2s, border-color 0.2s;
}
.demo-tab-item:hover { background: rgba(212,137,45,0.06); }
.demo-tab-item.active { background: white; border-color: #d4892d; }
.demo-tab-num {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #e0ddd7;
  color: #888;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 13px;
  flex-shrink: 0;
  transition: background 0.2s, color 0.2s;
}
.demo-tab-item.active .demo-tab-num { background: #d4892d; color: white; }
.demo-tab-body { flex: 1; }
.demo-tab-title { font-weight: 700; font-size: 14px; color: #333; }
.demo-tab-desc { font-size: 13px; color: #888; margin-top: 3px; line-height: 1.5; }
.demo-tab-progress { height: 2px; background: #e0ddd7; border-radius: 1px; overflow: hidden; }
.demo-tab-progress-bar { height: 100%; width: 0; background: #d4892d; border-radius: 1px; }
.demo-tab-item.active .demo-tab-progress-bar { animation: tabProgressFill 7s linear forwards; }
.demo-tab-item.active .demo-tab-progress-bar.paused { animation-play-state: paused; }
@keyframes tabProgressFill { from { width: 0; } to { width: 100%; } }
.demo-tab-progress-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
}
.demo-tab-progress-row .demo-tab-progress {
  flex: 1;
  margin-top: 0;
}
.demo-pause-btn {
  display: none;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  color: #bbb;
  transition: color 0.2s;
}
.demo-pause-btn:hover { color: #d4892d; }
.demo-tab-item.active .demo-pause-btn { display: flex; }
/* Pause icon (two bars) — shown while playing */
.demo-pause-btn::before {
  content: '';
  display: block;
  width: 9px;
  height: 10px;
  background:
    linear-gradient(currentColor, currentColor) 0 0 / 3px 100% no-repeat,
    linear-gradient(currentColor, currentColor) 6px 0 / 3px 100% no-repeat;
}
/* Play icon (triangle) — shown while paused */
.demo-tab-list.paused .demo-tab-item.active .demo-pause-btn::before {
  width: 0;
  height: 0;
  background: none;
  border-style: solid;
  border-width: 5px 0 5px 9px;
  border-color: transparent transparent transparent currentColor;
}
.demo-visual-wrap {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 340px;
}
.demo-visual { display: none; width: 100%; justify-content: center; animation: demoSceneFadeIn 0.45s ease both; }
.demo-visual.active { display: flex; }
@keyframes demoSceneFadeIn {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Scene 0: Browser */
.browser-frame {
  width: 100%;
  max-width: 480px;
  border-radius: 12px;
  overflow: visible;
  box-shadow: 0 8px 40px rgba(0,0,0,0.12);
  background: white;
  display: flex;
  flex-direction: column;
}
.browser-bar { background: #ebebeb; padding: 9px 14px; display: flex; align-items: center; gap: 10px; border-radius: 12px 12px 0 0; }
.browser-dots { display: flex; gap: 5px; }
.browser-dots span { width: 10px; height: 10px; border-radius: 50%; }
.browser-dots span:nth-child(1) { background: #ff5f57; }
.browser-dots span:nth-child(2) { background: #febc2e; }
.browser-dots span:nth-child(3) { background: #28c840; }
.browser-url { flex: 1; background: white; border-radius: 5px; padding: 3px 10px; font-size: 11px; color: #888; text-align: center; }
.browser-body { display: flex; min-height: 260px; position: relative; }
.browser-sidebar { width: 54px; background: white; border-right: 1px solid #eee; display: flex; flex-direction: column; align-items: center; padding: 14px 0; gap: 12px; border-bottom-left-radius: 12px; }
.sidebar-logo { width: 36px; height: auto; object-fit: contain; margin-bottom: 6px; }
.sidebar-item { width: 24px; height: 4px; border-radius: 2px; background: #e0e0e0; }
.sidebar-item.active-item { background: #d4892d; height: 5px; width: 26px; }
.browser-main { flex: 1; padding: 14px; }
.browser-header-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.browser-page-title { font-weight: 700; font-size: 13px; color: #152f30; }
.browser-add-btn { background: #d4892d; color: white; font-size: 10px; padding: 4px 9px; border-radius: 5px; font-weight: 600; }
.plant-row {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 7px 9px;
  border-radius: 7px;
  margin-bottom: 5px;
  background: #f8f7f4;
  opacity: 0;
  animation: plantRowSlideIn 0.4s ease both;
}
.pr-1 { animation-delay: 0.2s; }
.pr-2 { animation-delay: 0.55s; }
.pr-3 { animation-delay: 0.9s; }
.pr-4 { animation-delay: 1.25s; }
@keyframes plantRowSlideIn {
  from { opacity: 0; transform: translateX(16px); }
  to   { opacity: 1; transform: translateX(0); }
}
.pr-photo { width: 32px; height: 32px; border-radius: 6px; object-fit: cover; flex-shrink: 0; }
.pr-info { flex: 1; min-width: 0; }
.pr-name { font-size: 12px; font-weight: 600; color: #333; }
.pr-sub { font-size: 10px; color: #aaa; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pr-badge { font-size: 10px; padding: 2px 7px; border-radius: 8px; background: #e8f4ea; color: #2a7a38; font-weight: 600; }

/* Browser split: list + map */
.browser-content-split { display: flex; gap: 0; flex: 1; }
.browser-list { flex: 1; min-width: 0; }
.browser-map-panel {
  position: absolute;
  right: 0; top: 10px; bottom: 10px;
  width: 155px;
  z-index: 10;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  background: white;
  box-shadow: 0 8px 32px rgba(0,0,0,0.18), 0 2px 8px rgba(0,0,0,0.10);
  overflow: hidden;
  transform: translateX(calc(50% + 160px));
  animation: mapPanelSlideIn 0.5s 0.6s cubic-bezier(0.34,1.1,0.64,1) both;
}
@keyframes mapPanelSlideIn {
  from { transform: translateX(calc(50% + 160px)); }
  to   { transform: translateX(50%); }
}
.bmp-map {
  flex: 1;
  position: relative;
  background: #c9dfa8;
  overflow: hidden;
  min-height: 140px;
}
.bmp-map-svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.bmp-pin {
  position: absolute;
  transform: translate(-50%, -50%);
  opacity: 0;
  animation: pinDrop 0.4s cubic-bezier(0.34,1.56,0.64,1) both;
}
.bmp-p1 { left: 38%; top: 28%; animation-delay: 3.0s; }
.bmp-p2 { left: 68%; top: 42%; animation-delay: 3.35s; }
.bmp-p3 { left: 52%; top: 68%; animation-delay: 3.7s; }
.bmp-p4 { left: 28%; top: 55%; animation-delay: 4.05s; }
@keyframes pinDrop {
  from { opacity: 0; transform: translate(-50%, -160%); }
  to   { opacity: 1; transform: translate(-50%, -50%); }
}
.bmp-dot {
  width: 12px;
  height: 12px;
  background: #d4892d;
  border-radius: 50%;
  border: 2px solid white;
  box-shadow: 0 2px 6px rgba(0,0,0,0.3);
}
.bmp-coords {
  padding: 5px 8px;
  font-size: 9px;
  color: #999;
  background: white;
  border-top: 1px solid #eee;
  font-family: monospace;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Virtual garden scene — map + bottom sheet */
.vg-screen { position: relative !important; height: 370px !important; overflow: hidden !important; }

/* Map */
.vg-map {
  position: absolute;
  inset: 0;
  background: linear-gradient(145deg, #d4edda 0%, #b8dfc4 55%, #9ecfb0 100%);
}
.vg-map-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.35) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.35) 1px, transparent 1px);
  background-size: 22px 22px;
}
.vg-map-label {
  position: absolute;
  top: 10px; left: 10px;
  font-size: 9px;
  font-weight: 700;
  color: #152f30;
  background: rgba(255,255,255,0.85);
  padding: 3px 8px;
  border-radius: 8px;
}

/* Pins */
.vg-map-pin {
  position: absolute;
  transform: translate(-50%, -50%);
  opacity: 0;
  animation: pinDrop 0.4s cubic-bezier(0.34,1.56,0.64,1) both;
}
.vgp-1 { left: 38%; top: 38%; animation-delay: 0.3s; }
.vgp-2 { left: 68%; top: 28%; animation-delay: 0.6s; }
.vgp-3 { left: 58%; top: 62%; animation-delay: 0.9s; }
.vgp-4 { left: 25%; top: 60%; animation-delay: 1.2s; }
.vg-pin-dot {
  width: 14px;
  height: 14px;
  background: #d4892d;
  border-radius: 50%;
  border: 2.5px solid white;
  box-shadow: 0 2px 6px rgba(0,0,0,0.3);
}

/* Tap ring — same position as pin 1 */
.vg-tap-ring {
  position: absolute;
  left: 38%; top: 38%;
  width: 30px;
  height: 30px;
  border: 2.5px solid #d4892d;
  border-radius: 50%;
  transform: translate(-50%, -50%) scale(0);
  opacity: 0;
  animation: tapRing 0.7s 1.7s ease-out both;
}
@keyframes tapRing {
  0%   { transform: translate(-50%, -50%) scale(0.4); opacity: 1; }
  100% { transform: translate(-50%, -50%) scale(2.2); opacity: 0; }
}

/* Bottom sheet */
.vg-sheet {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: white;
  border-radius: 16px 16px 0 0;
  padding: 8px 14px 16px;
  box-shadow: 0 -4px 24px rgba(0,0,0,0.14);
  transform: translateY(100%);
  animation: sheetSlideUp 0.45s 2.1s cubic-bezier(0.34,1.1,0.64,1) both;
}
@keyframes sheetSlideUp {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}
.vg-sheet-handle { width: 32px; height: 3px; background: #e0e0e0; border-radius: 2px; margin: 0 auto 10px; }
.vg-sheet-img {
  width: 100%; height: 72px; object-fit: cover; border-radius: 8px; display: block; margin-bottom: 8px;
  opacity: 0;
  animation: phoneContentIn 0.35s 2.4s ease both;
}
.vg-sheet-name {
  font-size: 14px; font-weight: 700; color: #152f30;
  opacity: 0; animation: phoneContentIn 0.3s 2.55s ease both;
}
.vg-sheet-sub {
  font-size: 11px; color: #888; font-style: italic; margin-bottom: 6px;
  opacity: 0; animation: phoneContentIn 0.3s 2.65s ease both;
}
.vg-sheet-story {
  font-size: 10px; color: #555; line-height: 1.5; margin-bottom: 10px;
  opacity: 0; animation: phoneContentIn 0.3s 2.75s ease both;
}
.vg-sheet-btn {
  display: block; text-align: center;
  background: #d4892d; color: white;
  font-size: 11px; font-weight: 600;
  padding: 7px 14px; border-radius: 8px;
  opacity: 0; animation: phoneContentIn 0.3s 2.9s ease both;
}

/* Scene 1: Label */
.label-scene-wrap { display: flex; align-items: center; gap: 32px; position: relative; }
.label-photo-label-wrap {
  position: relative;
  display: inline-block;
  flex-shrink: 0;
}
.label-plant-wrap {
  width: 320px;
  height: 250px;
  border-radius: 12px;
  overflow: hidden;
  background: #f4f2ed;
}
.label-plant-photo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  opacity: 1;
}
.label-plant-emoji { font-size: 80px; display: block; animation: plantSway 3s ease-in-out infinite; }
@keyframes stakeAppear {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.label-stake-card {
  background: white;
  border: 1px solid #ddd;
  border-radius: 4px;
  padding: 4px 5px 3px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  width: 42px;
}
.label-stake-brand {
  font-size: 6px;
  font-weight: 700;
  color: #152f30;
  letter-spacing: 0.3px;
  text-transform: lowercase;
}
.label-stake-qr {
  width: 28px;
  height: 28px;
  display: block;
  border-radius: 2px;
}
.label-stake-rod {
  width: 2px;
  height: 28px;
  background: #888;
  border-radius: 0 0 1px 1px;
}
@keyframes plantSway {
  0%, 100% { transform: rotate(-3deg); }
  50%       { transform: rotate(3deg); }
}
.smart-label-mockup {
  background: #111;
  border: 1px solid white;
  border-radius: 6px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.35);
  padding: 10px;
  width: 90px;
  text-align: center;
  position: absolute;
  bottom: -20px;
  right: -27px;
  animation: labelAppear 0.5s ease both;
  z-index: 2;
}
@keyframes labelAppear {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
.slm-brand { font-size: 5px; color: rgba(255,255,255,0.4); letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 3px; }
.slm-name { font-size: 7px; font-weight: 700; color: white; margin-bottom: 1px; }
.slm-family { font-size: 6px; color: rgba(255,255,255,0.6); font-style: italic; margin-bottom: 6px; }
.slm-qr { width: 45px; height: 45px; margin: 0 auto 6px; position: relative; }
.slm-qr svg { width: 100%; height: 100%; }
.slm-scan-line {
  position: absolute;
  left: 4px; right: 4px;
  height: 2px;
  background: rgba(212,137,45,0.8);
  border-radius: 1px;
  box-shadow: 0 0 6px rgba(212,137,45,0.5);
  opacity: 0;
  animation: qrScan 1.8s 2s ease-in-out infinite;
}
@keyframes qrScan {
  0%   { top: 5%; opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { top: 90%; opacity: 0; }
}
.slm-tactile { width: 30px; height: 3px; background: rgba(255,255,255,0.2); border-radius: 2px; margin: 0 auto; }
.slm-stake-rod {
  width: 9px;
  height: 40px;
  background: #111;
  border-radius: 0 0 3px 3px;
  margin: 0 auto;
}
.label-phone-mini {
  width: 108px;
  height: 189px;
  background: #152f30;
  border-radius: 12px;
  padding: 3px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.2);
  margin-left: -90px;
  margin-bottom: -259px;
  position: relative;
  z-index: 10;
  animation: phoneMiniAppear 0.7s 2s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
  transform-origin: center bottom;
}
@keyframes phoneMiniAppear {
  from { opacity: 0; transform: scale(2.2) translateY(-10px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}
.lpm-screen { background: white; border-radius: 8px; height: 100%; overflow: hidden; position: relative; }
.lpm-scan-overlay {
  position: absolute;
  inset: 0;
  background: white;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  animation: lpmScanFadeOut 0.4s 3.8s ease both;
}
@keyframes lpmScanFadeOut {
  from { opacity: 1; }
  to   { opacity: 0; pointer-events: none; }
}
.lpm-scan-corner {
  position: absolute;
  width: 10px;
  height: 10px;
  border-color: #152f30;
  border-style: solid;
  border-width: 0;
}
.lpm-scan-corner.tl { top: 6px;  left: 6px;  border-top-width: 2px; border-left-width: 2px; }
.lpm-scan-corner.tr { top: 6px;  right: 6px; border-top-width: 2px; border-right-width: 2px; }
.lpm-scan-corner.bl { bottom: 6px; left: 6px;  border-bottom-width: 2px; border-left-width: 2px; }
.lpm-scan-corner.br { bottom: 6px; right: 6px; border-bottom-width: 2px; border-right-width: 2px; }
.lpm-scan-beam {
  position: absolute;
  left: 8px; right: 8px;
  height: 1.5px;
  background: rgba(212,137,45,0.85);
  box-shadow: 0 0 4px rgba(212,137,45,0.6);
  top: 10%;
  animation: lpmBeam 1.2s 2s ease-in-out infinite;
}
@keyframes lpmBeam {
  0%   { top: 10%; opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { top: 88%; opacity: 0; }
}
.lpm-content {
  padding: 6px;
  opacity: 0;
  animation: lpmContentIn 0.4s 4s ease both;
}
@keyframes lpmContentIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.lpm-img { height: 60px; background: url('/images/website_2/main/visual/Rosa Mister Lincoln.jpg') center/cover no-repeat; border-radius: 4px; margin-bottom: 5px; }
.lpm-title { font-size: 7px; font-weight: 700; color: #152f30; margin-bottom: 4px; }
.lpm-line { height: 4px; background: #eee; border-radius: 2px; margin-bottom: 3px; }
.lpm-line.short { width: 60%; }

/* Scene 2: Visitor phone */
.phone-frame {
  width: 220px;
  background: #2a2a2a;
  border-radius: 40px;
  padding: 4px;
  box-shadow: 0 16px 60px rgba(0,0,0,0.25), 0 0 0 1px rgba(255,255,255,0.08), inset 0 0 0 1px rgba(255,255,255,0.04);
}
.phone-notch { width: 44px; height: 14px; background: #2a2a2a; border-radius: 0 0 10px 10px; margin: 0 auto; position: relative; z-index: 2; }
.phone-screen { background: white; border-radius: 35px; overflow: hidden; margin-top: -8px; }
.phone-hero-img {
  height: 180px;
  overflow: hidden;
  animation: phoneImgIn 0.5s ease both;
}
.phone-hero-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
@keyframes phoneImgIn { from { opacity: 0; } to { opacity: 1; } }
.phone-story { margin-top: 8px; opacity: 0; animation: phoneContentIn 0.4s 0.65s ease both; }
.phone-story-label { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: #d4892d; margin-bottom: 4px; }
.phone-story-text { font-size: 10px; color: #555; line-height: 1.5; }
.phone-content-area { padding: 12px; }
.phone-plant-title { font-size: 15px; font-weight: 700; color: #152f30; opacity: 0; animation: phoneContentIn 0.4s 0.2s ease both; }
.phone-plant-subtitle { font-size: 11px; color: #888; font-style: italic; margin-bottom: 8px; opacity: 0; animation: phoneContentIn 0.4s 0.35s ease both; }
.phone-divider { height: 1px; background: #f0f0f0; margin-bottom: 8px; opacity: 0; animation: phoneContentIn 0.4s 0.45s ease both; }
.phone-fact { display: flex; align-items: center; gap: 6px; margin-bottom: 5px; opacity: 0; animation: phoneContentIn 0.4s ease both; }
.pf-a { animation-delay: 0.5s; }
.pf-b { animation-delay: 0.65s; }
.pf-c { animation-delay: 0.8s; }
.pf-icon { font-size: 11px; }
.pf-text { font-size: 11px; color: #555; }
.phone-desc-block { margin-top: 8px; opacity: 0; animation: phoneContentIn 0.4s 0.95s ease both; }
.phone-line { height: 5px; background: #f0f0f0; border-radius: 3px; margin-bottom: 4px; }
.phone-line.full { width: 100%; }
.phone-line.half { width: 55%; }
.phone-no-app-badge {
  display: inline-block;
  margin-top: 10px;
  background: #e8f4ea;
  color: #2a7a38;
  font-size: 10px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 10px;
  opacity: 0;
  animation: phoneContentIn 0.4s 1.15s ease both;
}
@keyframes phoneContentIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Scene badges */
.scene-badge-wrap { display: flex; width: 100%; justify-content: center; }
.scene-content-wrap { position: relative; display: flex; width: 480px; max-width: 100%; }
.scene-badge {
  position: absolute;
  bottom: 14px;
  background: #fff4e6;
  color: #D4892D;
  border: 1.5px solid #f0d4a0;
  font-size: 14px;
  font-weight: 600;
  padding: 10px 12px;
  border-radius: 10px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.12);
  white-space: normal;
  opacity: 0;
  z-index: 10;
}
.scene-badge-left { left: -14px; animation: sceneBadgeLeft 0.5s 4s cubic-bezier(0.34,1.56,0.64,1) forwards; }
.scene-badge-top  { right: -14px; top: -14px; bottom: auto; animation: sceneBadgeTop 0.5s 4.2s cubic-bezier(0.34,1.56,0.64,1) forwards; }
.scene-badge-story { right: -100px; width: 155px; }
@media (max-width: 575px) { .scene-badge-story { right: -14px; width: auto; } }
@keyframes sceneBadgeLeft { from { opacity: 0; transform: translateX(-24px); } to { opacity: 1; transform: translateX(0); } }
@keyframes sceneBadgeTop  { from { opacity: 0; transform: translateY(-16px); } to { opacity: 1; transform: translateY(0); } }

/* Scene 2: photo swipe */
.phone-hero-crossfade { position: relative; overflow: hidden; }
.phone-hero-crossfade .phone-hero-photo { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ph-img-1 { transform: translateX(0); animation: ph1SwipeOut 0.55s 2.5s cubic-bezier(0.4,0,0.2,1) forwards; }
.ph-img-2 { transform: translateX(100%); animation: ph2SwipeIn 0.55s 2.5s cubic-bezier(0.4,0,0.2,1) forwards; }
@keyframes ph1SwipeOut { to { transform: translateX(-100%); } }
@keyframes ph2SwipeIn  { to { transform: translateX(0); } }

/* Scene 2: scroll reveal */
.phone-content-clip { overflow: hidden; height: 220px; }
.phone-scroll-track { animation: phoneScrollAnim 2s 3.5s ease forwards; }
@keyframes phoneScrollAnim {
  from { transform: translateY(0); }
  to   { transform: translateY(-140px); }
}

/* Scene 2: origin map */
.phone-origin-map {
  margin-top: 10px;
  opacity: 0;
  animation: phoneContentIn 0.4s 5s ease forwards;
}
.phone-origin-map-label {
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #d4892d;
  margin-bottom: 5px;
}
.phone-origin-map-body {
  border-radius: 8px;
  overflow: hidden;
  height: 100px;
}
.phone-origin-map-body svg { display: block; width: 100%; height: 100%; }

/* Scene 2: no-app overlay (outside phone, bottom-left) */
.phone-scene-wrap { position: relative; display: inline-flex; }
.phone-no-app-overlay {
  position: absolute;
  bottom: 14px;
  left: -14px;
  background: #fff4e6;
  color: #D4892D;
  border: 1.5px solid #f0d4a0;
  font-size: 14px;
  font-weight: 600;
  padding: 5px 12px;
  border-radius: 10px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.12);
  white-space: normal;
  opacity: 0;
  animation: noAppFlyIn 0.5s 6s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
  z-index: 10;
}
@keyframes noAppFlyIn {
  from { opacity: 0; transform: translateX(-24px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* Scene 4: Experience map */
.exp-body {
  position: relative;
  display: flex;
  height: 280px;
  overflow: hidden;
}
.exp-map {
  position: absolute;
  inset: 0;
  background: #e8e0d8;
}
.exp-map-svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.exp-map-label {
  position: absolute;
  top: 10px; left: 10px;
  font-size: 9px;
  font-weight: 700;
  color: #152f30;
  background: rgba(255,255,255,0.85);
  padding: 3px 8px;
  border-radius: 8px;
  z-index: 2;
}
.exp-pin {
  position: absolute;
  transform: translate(-50%, -50%);
  opacity: 0;
  animation: pinDrop 0.4s cubic-bezier(0.34,1.56,0.64,1) both;
  z-index: 3;
}
/* Mix: cluster near pond + spread around garden */
.ep-1  { left: 47%; top: 30%; animation-delay: 0.15s; } /* near pond */
.ep-2  { left: 53%; top: 28%; animation-delay: 0.25s; } /* near pond */
.ep-3  { left: 44%; top: 38%; animation-delay: 0.35s; } /* near pond */
.ep-4  { left: 56%; top: 36%; animation-delay: 0.45s; } /* near pond */
.ep-5  { left: 50%; top: 44%; animation-delay: 0.55s; } /* near pond */
.ep-6  { left: 60%; top: 42%; animation-delay: 0.65s; } /* near pond */
.ep-7  { left: 41%; top: 46%; animation-delay: 0.75s; } /* near pond */
.ep-8  { left: 57%; top: 50%; animation-delay: 0.85s; } /* near pond */
/* Spread across the garden */
.ep-9  { left: 18%; top: 22%; animation-delay: 0.95s; }
.ep-10 { left: 76%; top: 22%; animation-delay: 1.05s; }
.ep-11 { left: 18%; top: 74%; animation-delay: 1.15s; }
.ep-12 { left: 76%; top: 74%; animation-delay: 1.25s; }
.ep-13 { left: 10%; top: 48%; animation-delay: 1.35s; }
.ep-14 { left: 87%; top: 48%; animation-delay: 1.45s; }
.ep-15 { left: 50%; top: 14%; animation-delay: 1.55s; }
.ep-16 { left: 30%; top: 20%; animation-delay: 1.62s; }
.ep-17 { left: 68%; top: 18%; animation-delay: 1.69s; }
.ep-18 { left: 24%; top: 58%; animation-delay: 1.76s; }
.ep-19 { left: 72%; top: 60%; animation-delay: 1.83s; }
.ep-20 { left: 38%; top: 78%; animation-delay: 1.90s; }
.ep-21 { left: 62%; top: 80%; animation-delay: 1.97s; }
.ep-22 { left: 12%; top: 33%; animation-delay: 2.04s; }
.ep-23 { left: 84%; top: 35%; animation-delay: 2.11s; }
.ep-24 { left: 50%; top: 85%; animation-delay: 2.18s; }
.ep-25 { left: 35%; top: 64%; animation-delay: 2.25s; }
.exp-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 2px solid white;
  box-shadow: 0 2px 6px rgba(0,0,0,0.3);
}
.ep-green { background: #2a7a38; }
.ep-red   { background: #c0392b; }
.ep-black { background: #2c2c2c; }
.ep-dot-clicked {
  width: 16px;
  height: 16px;
  box-shadow: 0 0 0 3px rgba(42,122,56,0.35), 0 2px 8px rgba(0,0,0,0.35);
}
.ep-tap-ring {
  position: absolute;
  left: 56%; top: 36%;
  width: 30px;
  height: 30px;
  border: 2.5px solid #2a7a38;
  border-radius: 50%;
  transform: translate(-50%, -50%) scale(0.4);
  opacity: 0;
  z-index: 4;
  animation: tapRing 0.7s 1.8s ease-out both;
}

/* Detail panel */
.exp-detail {
  position: absolute;
  right: 0; top: 10px; bottom: 10px;
  width: 185px;
  background: white;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 10px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.18), 0 2px 8px rgba(0,0,0,0.10);
  overflow: hidden;
  z-index: 5;
  transform: translateX(calc(100% + 20px));
  animation: detailSlideIn 0.45s 2.3s cubic-bezier(0.34,1.1,0.64,1) both;
}
@keyframes detailSlideIn {
  from { transform: translateX(calc(100% + 20px)); }
  to   { transform: translateX(0); }
}
.exp-detail-close {
  position: absolute;
  top: 7px; right: 8px;
  font-size: 11px;
  color: #aaa;
  cursor: pointer;
  z-index: 1;
}
.exp-detail-img {
  width: 100%;
  height: 130px;
  object-fit: cover;
  object-position: top;
  display: block;
  opacity: 0;
  animation: phoneContentIn 0.4s 2.6s ease both;
}
.exp-detail-name {
  font-size: 13px;
  font-weight: 700;
  color: #152f30;
  padding: 8px 10px 2px;
  opacity: 0;
  animation: phoneContentIn 0.35s 2.55s ease both;
}
.exp-detail-sub {
  font-size: 10px;
  color: #888;
  padding: 0 10px 6px;
  opacity: 0;
  animation: phoneContentIn 0.35s 2.65s ease both;
}
.exp-detail-divider {
  height: 1px;
  background: #f0f0f0;
  margin: 0 10px 8px;
  opacity: 0;
  animation: phoneContentIn 0.35s 2.72s ease both;
}
.exp-detail-story {
  font-size: 10px;
  color: #555;
  line-height: 1.55;
  padding: 0 10px 8px;
  opacity: 0;
  animation: phoneContentIn 0.35s 2.8s ease both;
}
.exp-detail-gps {
  font-size: 9px;
  color: #aaa;
  font-family: monospace;
  padding: 0 10px 12px;
  opacity: 0;
  animation: phoneContentIn 0.35s 2.95s ease both;
}

@media (max-width: 991px) {
  .label-scene-wrap { flex-direction: column; gap: 0; align-items: center; }
  .label-plant-emoji { font-size: 48px; }
  .label-plant-wrap { width: 100%; max-width: 360px; }
  .smart-label-mockup { bottom: -20px; right: 12px; }
  .label-phone-mini {
    margin-left: 60px;
    margin-top: -80px;
    margin-bottom: 0;
    position: relative;
    z-index: 10;
  }
  .demo-tab-list { flex-direction: row; overflow-x: auto; gap: 6px; padding-bottom: 8px; }
  .demo-tab-item { min-width: 200px; }
  .demo-tab-progress-row { margin-top: 8px; }
}
