.first {
  margin: 0;
  padding: 0;
  padding-top: 00px;
  width: 100%;
  height: 1080px;
  position: relative; 
  display: flex;
  z-index: 1;
  justify-content: center;
  align-items: center;
}

.first::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
  display: block;
  background: none;
}

.first video.bg-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  pointer-events: none;
}

.first > *:not(video.bg-video) {
  position: relative;
  z-index: 1;
}

.heading {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.heading h1 {
    font-family: 'Mongolian Baiti', sans-serif;
    font-size: 100px;
    margin: 0;
    text-align: left;
    text-transform: uppercase;
    font-weight: 500;
}

.heading h2 {
    font-size: 50px;
    margin: 0;
    text-align: left;
    font-weight: 500;
}

.second {
    padding: 100px 200px;
}

.second p {
    font-size: 30px;
    font-weight: 500;
}

.third {
    
    padding: 100px 200px;
    background-color: #fff;
    color: #000;
    font-size: 30px;
    font-weight: 500;
}

.third span {
    font-size: 40px;
    font-weight: 700;
}

.fourth {
    padding: 100px 200px;
    padding-bottom: 50px;
    font-size: 30px;
    font-weight: 500;
}

.five {
    padding: 100px 200px;
}

.five h1 {
    text-transform: uppercase;
    font-size: 60px;
    font-weight: 400;
}

.five p {
    padding-top: 60px;
    font-size: 30px;
    font-weight: 500;
}

.sixth {
    padding: 100px 200px;
    display: flex;
    justify-content: center;
    max-height: 900px;
}

.sixth h2 {
    font-size: 60px;
    font-weight: 700;
}

.sixth p {
    font-size: 30px;
    font-weight: 500;
}

.our-team {
    padding-top: 150px;
    padding-left: 153px;
    padding-right: 80px;
    padding-bottom: 260px;
    background-image: url('../img/bg-ourteam.svg');
    background-size: cover;
    background-repeat: no-repeat; 
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.our-team p {
  padding-top: 20px;
}

.team-memb{
    width: 870px;
    padding-left: 50px;
    padding-top: 50px;
    padding-right: 127px;
    padding-bottom: 60px;
    background-color: #222223;
}

.memb {
    display: flex;
    gap: 20px;
    align-items: center;
    padding-top: 50px;
}

.memb img {
    width: 25%;
    border-radius: 50%;
}

.memb span {
    font-size: 20px;
    color: #aaa;
    font-weight: 500;
}

.memb p {
    font-size: 32px;
}

.see-more {
    display: flex;
    justify-content: flex-end;
    padding-top: 50px;
}

.see-more-btn {
    border: solid 4px #fff;
    padding: 3px 90px;
    font-size: 30px;
    font-weight: 500;
    border-radius: 55px;
}

.seventh {
    padding: 100px 200px;
}

.seventh img {
    width: 20%;
}

.seventh h1 {
    font-size: 60px;
}

#right {
    display: flex;
    flex-direction: row-reverse;
    align-items: center;
    gap: 40px;
}

.right-inf {
    font-size: 25px;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

.right-inf p {
    padding-top: 15px;
    align-items: flex-end;
    text-align: right;
    width: 500px;
    font-weight: 500;
}

.blue span {
    color: #308EFF;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 35px;
}

.yellow span {
    color: #FFC616;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 35px;
}

.red span {
    color: #FF2540;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 35px;
}

.pink span {
    color: #E647FF;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 35px;
}

.red p {
    width: 685px;
}

#left {
    display: flex;
    align-items: center;
    gap: 40px;
}

.left-inf {
    font-size: 25px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.left-inf p {
    padding-top: 15px;
    align-items: flex-start;
    text-align: left;
    width: 700px;
    font-weight: 500;
}

  .pink {
    margin-top: -40px;
  }
  
  .yellow {
    margin-top: -80px;
  }
  
  .red {
    margin-top: -40px;
  }
  
  

.eighth {
    padding: 100px 200px;
}

.eighth h1 {
    font-size: 60px;
}

.eighth p {
    font-size: 30px;
    font-weight: 500;
    padding-top: 50px;
}

.btn-openserv {
    display: flex;
    justify-content: center;
    padding: 120px 0px;
}

.btn-serv {
    border: solid 2px;
    border-radius: 55px;
    padding: 20px 160px;
    font-size: 30px;
    font-weight: 500;
}

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


@media (min-width: 1367px) and (max-width: 1600px) {
  .heading h1 {
    font-size: 90px;
  }
  
  .heading h2 {
    font-size: 45px;
  }
  
  .second {
    padding: 80px 150px;
  }
  
  .second p {
    font-size: 26px;
  }
  
  .third {
    padding: 80px 150px;
    font-size: 26px;
  }
  
  .third span {
    font-size: 36px;
  }
  
  .fourth {
    padding: 80px 150px;
    font-size: 26px;
  }
  
  .five {
    padding: 80px 150px;
  }
  
  .five h1 {
    font-size: 54px;
  }
  
  .five p {
    font-size: 26px;
  }
  
  .sixth {
    padding: 80px 150px;
    max-height: none;
  }
  
  .our-team {
    padding: 100px 80px;
    max-width: 100%;
    background-size: cover;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  
  .our-team p {
    font-size: 25px !important;
  }

  .team-memb {
    width: 100%;
    padding: 50px 80px;
    box-sizing: border-box;
  }

  .team-memb p {
    font-size: 29px !important;
  }

  .memb {
    gap: 15px;
  }
  
  .sixth h2 {
    font-size: 54px;
  }
  
  .sixth p {
    font-size: 18px;
  }
  
  .see-more-btn {
    font-size: 18px;
    padding: 2px 50px;
    white-space: nowrap;
  }
  
  button.learn-more {
    font-size: 18px !important;
    padding: 7px 50px !important;
  }
  
  button.learn-more .button-text {
    font-size: 18px !important;
  }
  
  .seventh {
    padding: 80px 150px;
  }
  
  .seventh h1 {
    font-size: 54px;
  }

  #right {
    margin: 0;
  }

  #left {
    margin: 0;
  }
  
  .right-inf, .left-inf {
    font-size: 20px;
    width: 100%;
  }
  
  .right-inf p {
    width: 100%;
  }
  .left-inf p {
    width: 100%;
  }

  .eighth {
    padding: 80px 150px;
  }
  
  .eighth h1 {
    font-size: 54px;
  }
  
  .eighth p {
    font-size: 26px;
  }
  
  .btn-serv {
    font-size: 26px;
    padding: 18px 140px;
  }
  
  button.btn-serv.learn-more {
    font-size: 26px !important;
    padding: 1px 140px !important;
  }
  
  button.btn-serv.learn-more .button-text {
    font-size: 26px !important;
  }
  
  .blue, .yellow, .red {
    margin-bottom: 0;
  }
  
  .img-eight {
    width: 100%;
    overflow: hidden;
  }
  
  .img-eight img {
    width: 80%;
    max-width: 600px;
    display: block;
    margin: 0 auto;
  }
  .see-more-btn,
  a.see-more-btn {
    font-size: 18px !important;
    padding: 0px 50px !important;
  }
  .btn-serv,
  a.btn-serv {
    font-size: 26px !important;
    padding: 0px 140px !important;
  }
  .see-more-btn .button-text,
  a.see-more-btn .button-text {
    font-size: 25px !important;
  }
  .btn-serv .button-text,
  a.btn-serv .button-text {
    font-size: 26px !important;
  }
}


@media (min-width: 1024px) and (max-width: 1366px) {
  .heading h1 {
    font-size: 80px;
  }
  
  .heading h2 {
    font-size: 40px;
  }
  
  .second {
    padding: 70px 120px;
  }
  
  .second p {
    font-size: 24px;
  }
  
  .third {
    padding: 70px 120px;
    font-size: 24px;
  }
  
  .third span {
    font-size: 32px;
  }
  
  .fourth {
    padding: 70px 120px;
    font-size: 24px;
  }
  
  .five {
    padding: 70px 120px;
  }
  
  .five h1 {
    font-size: 50px;
  }
  
  .five p {
    font-size: 24px;
  }
  
  .sixth {
    padding: 70px 120px;
    max-height: none;
  }
  
  .our-team {
    padding: 80px 60px;
    max-width: 400px;
    background-size: cover;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .our-team p {
    padding-top: 20px;
  }
  
  .team-memb {
    width: 100%;
    padding: 40px 60px;
    box-sizing: border-box;
  }
  
  .memb {
    gap: 10px;
    width: 380px;
  }
  .sixth h2 {
    font-size: 35px;
  }
  
  .sixth p {
    font-size: 18px;
  }

  .memb p {
    font-size: 30px;
  }
  
  .memb span {
    font-size: 17px;
  }
  
  .cards-seven {
    padding-top: 20px;
  }

  .cards-seven span {
    font-size: 27px;
  }

  .cards-seven p {
    font-size: 17px;
  }

  .see-more-btn {
    font-size: 18px;
    padding: 2px 40px;
    white-space: nowrap;
  }
  
  button.learn-more {
    font-size: 18px !important;
    padding: 8px 40px !important;
  }
  
  button.learn-more .button-text {
    font-size: 18px !important;
  }
  
  .seventh {
    padding: 70px 120px;
  }
  
  .seventh h1 {
    font-size: 50px;
  }
  
  #right {
    margin: 0;
    padding-top: 20px;
  }
  #left {
    margin: 0;
    padding-top: 20px;
  }

  .right-inf, .left-inf {
    font-size: 16px;
  }
  
  .eighth {
    padding: 70px 120px;
  }
  
  .eighth h1 {
    font-size: 50px;
  }
  
  .eighth p {
    font-size: 24px;
  }
  
  .btn-serv {
    font-size: 24px;
    padding: 16px 120px;
  }
  
  button.btn-serv.learn-more {
    font-size: 24px !important;
    padding: 3px 120px !important;
  }
  
  button.btn-serv.learn-more .button-text {
    font-size: 24px !important;
  }
  
  .img-eight {
    width: 100%;
    overflow: hidden;
  }
  
  .img-eight img {
    width: 80%;
    max-width: 500px;
    display: block;
    margin: 0 auto;
  }
}


@media (min-width: 768px) and (max-width: 1023px) {
  .first {
    height: 600px;
  }
  
  .heading {
    padding-left: 40px;
  }
  
  .heading h1 {
    font-size: 60px;
  }
  
  .heading h2 {
    font-size: 30px;
  }
  
  .second {
    padding: 60px 40px;
  }
  
  .second p {
    font-size: 20px;
  }
  
  .third {
    padding: 60px 40px;
    font-size: 20px;
  }
  
  .third span {
    font-size: 28px;
  }
  
  .fourth {
    padding: 60px 40px;
    font-size: 20px;
  }
  
  .five {
    padding: 60px 40px;
  }
  
  .five h1 {
    font-size: 40px;
  }
  
  .five p {
    font-size: 20px;
    padding-top: 40px;
  }
  
  .sixth {
    padding: 60px 40px;
    flex-direction: column;
    max-height: none;
  }
  
  .sixth h2 {
    font-size: 40px;
  }
  
  .sixth p {
    font-size: 20px;
  }
  
  .our-team {
    padding: 80px 40px;
    width: 100%;
    box-sizing: border-box;
  }
  
  .team-memb {
    width: 100%;
    padding: 40px;
    box-sizing: border-box;
  }
  
  .memb {
    gap: 40px;
    padding-top: 30px;
  }
  
  .memb img {
    width: 15%;
  }
  
  .memb p {
    font-size: 35px;
  }
  
  .memb span {
    font-size: 23px;
  }
  
  .see-more-btn {
    font-size: 20px;
    padding: 2px 60px;
  }
  
  button.learn-more {
    font-size: 20px !important;
    padding: 6px 60px !important;
  }
  
  button.learn-more .button-text {
    font-size: 20px !important;
  }
  
  .seventh {
    padding: 60px 40px;
  }
  
  .seventh h1 {
    font-size: 40px;
    padding-bottom: 30px;
  }
  
  .seventh img {
    width: 15%;
  }
  
  .blue span {
    font-size: 20px;
  }
  .yellow span {
    font-size: 20px;
  }
  .red span {
    font-size: 20px;
  }
  .pink span {
    font-size: 20px;
  }

  .right-inf, .left-inf {
    font-size: 18px;
  }
  
  .right-inf p {
    width: 300px;
  }
  
  .left-inf p {
    width: 400px;
  }

  #right.red {
    padding-top: 20px;
  }

  #right {
    
    margin: 0;
  }

  #left {
    margin: 0;
  }

  
  
  .eighth {
    padding: 60px 40px;
  }
  
  .eighth h1 {
    font-size: 40px;
  }
  
  .eighth p {
    font-size: 20px;
    padding-top: 60px;
  }
  
  .btn-openserv {
    padding: 80px 0px;
  }
  
  .btn-serv {
    font-size: 20px;
    padding: 15px 100px;
  }
  
  button.btn-serv.learn-more {
    font-size: 20px !important;
    padding: 7px 100px !important;
  }
  
  button.btn-serv.learn-more .button-text {
    font-size: 20px !important;
  }
  
  .img-eight {
    width: 100%;
    overflow: hidden;
  }
  
  .img-eight img {
    width: 80%;
    max-width: 400px;
    display: block;
    margin: 0 auto;
  }
  .see-more-btn,
  a.see-more-btn {
    font-size: 20px !important;
    padding: 0px 60px !important;
  }
  .btn-serv,
  a.btn-serv {
    font-size: 20px !important;
    padding: 0px 100px !important;
  }
  .see-more-btn .button-text,
  a.see-more-btn .button-text {
    font-size: 20px !important;
  }
  .btn-serv .button-text,
  a.btn-serv .button-text {
    font-size: 20px !important;
  }
}


@media (max-width: 767px) {
  .first {
    height: 400px;
    padding-top: 0;
  }
  
  .heading {
    padding-left: 20px;
  }
  
  .heading h1 {
    font-size: 40px;
  }
  
  .heading h2 {
    font-size: 20px;
  }
  
  .second {
    padding: 40px 20px;
  }
  
  .second p {
    font-size: 16px;
  }
  
  .third {
    padding: 40px 20px;
    font-size: 16px;
  }
  
  .third span {
    font-size: 20px;
  }
  
  .fourth {
    padding: 40px 20px;
    font-size: 16px;
  }
  
  .five {
    padding: 40px 20px;
  }
  
  .five h1 {
    font-size: 32px;
  }
  
  .five p {
    font-size: 16px;
    padding-top: 30px;
  }
  
  .sixth {
    padding: 40px 20px;
    flex-direction: column;
    max-height: none;
  }
  
  .sixth h2 {
    font-size: 32px;
  }
  
  .sixth p {
    font-size: 16px;
  }
  
  .our-team {
    padding: 40px 20px;
    width: 100%;
    box-sizing: border-box;
  }
  
  .team-memb {
    width: 100%;
    padding: 30px 20px;
    box-sizing: border-box;
  }
  
  .memb {
    gap: 20px;
    padding-top: 20px;
  }
  
  .memb img {
    width: 60px;
    height: 60px;
  }
  
  .memb p {
    font-size: 16px;
  }
  
  .memb span {
    font-size: 12px;
  }
  
  .see-more-btn {
    font-size: 16px;
    padding: 2px 40px;
  }
  
  button.learn-more {
    font-size: 16px !important;
    padding: 2px 40px !important;
  }
  
  button.learn-more .button-text {
    font-size: 16px !important;
  }
  
  .seventh {
    padding: 40px 20px;
  }
  
  .seventh h1 {
    font-size: 32px;
  }
  
  .seventh img {
    width: 22%;
  }
  
  .cards-seven {
    padding-top: 40px;
  }
  
  .cards-seven > div {
    margin-bottom: 20px;
  }
  
  .cards-seven > div:last-child {
    margin-bottom: 0;
  }
  
  #right, #left {
    gap: 20px;
  }
  
  .right-inf, .left-inf {
    font-size: 11px;
  }

  .right-inf span {
    text-align: right;
    font-size: 14px;
  }
  .left-inf span {
    text-align: left;
    font-size: 13px;
  }
  
  .right-inf p {
    width: 100%;
    font-size: 13px;
  }
  
  .left-inf p {
    width: 100%;
    font-size: 13px;
  }


  
  .pink, .yellow, .red {
    margin-top: 0;
  }
  
  .eighth {
    padding: 40px 20px 0px 20px;
  }
  
  .eighth h1 {
    font-size: 32px;
  }
  
  .eighth p {
    font-size: 16px;
    padding-top: 40px;
  }
  
  .btn-openserv {
    padding: 60px 0px 60px 0px;
  }
  
  .btn-serv {
    font-size: 16px;
    padding: 12px 60px;
  }
  
  button.btn-serv.learn-more {
    font-size: 16px !important;
    padding: 12px 60px !important;
  }
  
  button.btn-serv.learn-more .button-text {
    font-size: 16px !important;
  }
  
  .img-eight {
    width: 100%;
    overflow: hidden;
  }
  
  .img-eight img {
    width: 80%;
    max-width: 300px;
    display: block;
    margin: 0 auto;
  }
  .see-more-btn,
  a.see-more-btn {
    font-size: 16px !important;
    padding: 0px 40px !important;
  }
  .btn-serv,
  a.btn-serv {
    font-size: 16px !important;
    padding: 0px 60px !important;
  }
  .see-more-btn .button-text,
  a.see-more-btn .button-text {
    font-size: 16px !important;
  }
  .btn-serv .button-text,
  a.btn-serv .button-text {
    font-size: 16px !important;
  }
}


@media (max-width: 480px) {
  .heading h1 {
    font-size: 40px;
  }
  
  .heading h2 {
    font-size: 22px;
  }
  
  .second p {
    font-size: 14px;
  }
  
  .third {
    font-size: 14px;
  }
  
  .third span {
    font-size: 18px;
  }
  
  .fourth {
    font-size: 14px;
  }
  
  .five h1 {
    font-size: 28px;
  }
  
  .five p {
    font-size: 14px;
  }
  
  .sixth h2 {
    font-size: 28px;
  }
  
  .sixth p {
    font-size: 14px;
  }
  
  .memb p {
    font-size: 20px;
  }
  
  .memb span {
    font-size: 13px;
  }
  
  .see-more-btn {
    font-size: 14px;
    padding: 2px 30px;
  }
  
  button.learn-more {
    font-size: 14px !important;
    padding: 12px 30px !important;
  }
  
  button.learn-more .button-text {
    font-size: 14px !important;
  }
  
  .blue span {
    font-size: 13px;
    font-weight: 600;
  }
  .yellow span {
    font-size: 13px;
    font-weight: 600;
  }
  .red span {
    font-size: 13px;
    font-weight: 600;
  }
  .pink span {
    font-size: 13px;
    font-weight: 600;
  }

  .seventh h1 {
    font-size: 28px;
  }
  
  .right-inf, .left-inf {
    font-size: 14px;
  }
  
  .eighth h1 {
    font-size: 28px;
  }
  
  .eighth p {
    font-size: 14px;
  }
  
  .btn-serv {
    font-size: 14px;
    padding: 10px 50px;
  }
  
  button.btn-serv.learn-more {
    font-size: 14px !important;
    padding: 10px 50px !important;
  }
  
  button.btn-serv.learn-more .button-text {
    font-size: 16px !important;
  }
}


@media (min-width: 1920px) and (max-width: 2559px) {
  .blue, .yellow, .red {
    margin-bottom: 0;
  }
}


@media (min-width: 2560px) {
  .team-memb {
    width: 100%;
    padding: 60px 100px;
    box-sizing: border-box;
  }
  
  .memb {
    gap: 60px;
    padding-top: 40px;
    max-width: 100%;
  }
  
  .memb img {
    width: 25%;
    max-width: 120px;
  }
  
  .memb p {
    font-size: 38px;
  }
  
  .memb span {
    font-size: 25px;
  }
  
  .our-team {
    padding: 120px 100px;
    max-width: 1000px;
    background-size: cover;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  
  .sixth {
    max-height: none;
  }
  
  .blue, .yellow, .red {
    margin-bottom: 0;
  }

  .cards-seven span {
    font-size: 40px;
  }

  .cards-seven p {
    font-size: 28px;
    width: 100%;
  }

}


button {
  position: relative;
  display: inline-block;
  cursor: pointer;
  outline: none;
  border: 0;
  vertical-align: middle;
  text-decoration: none;
  background: transparent;
  padding: 0;
  font-size: inherit;
  font-family: inherit;
}

button.learn-more {
  width: auto;
  height: auto;
  min-width: 12rem;
  padding: 0px 80px;
  border-radius: 55px;
  background-color: transparent;
  display: inline-block;
  border: solid 4px #fff;
  color: #fff;
  font-size: 30px;
  font-weight: 500;
}

button.learn-more .circle {
  transition: all 0.45s cubic-bezier(0.65, 0, 0.076, 1);
  position: absolute;
  display: block;
  margin: 0;
  width: 3rem;
  height: 3rem;
  background: #fff;
  border-radius: 1.625rem;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}

button.learn-more .circle .icon {
  transition: all 0.45s cubic-bezier(0.65, 0, 0.076, 1);
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  background: #000;
}

button.learn-more .circle .icon.arrow {
  transition: all 0.45s cubic-bezier(0.65, 0, 0.076, 1);
  left: 0.625rem;
  width: 1.125rem;
  height: 0.125rem;
  background: none;
}

button.learn-more .circle .icon.arrow::before {
  position: absolute;
  content: "";
  top: -0.29rem;
  right: 0.0625rem;
  width: 0.625rem;
  height: 0.625rem;
  border-top: 0.125rem solid #000;
  border-right: 0.125rem solid #000;
  transform: rotate(45deg);
}

button.learn-more .button-text {
  transition: all 0.45s cubic-bezier(0.65, 0, 0.076, 1);
  position: relative;
  color: #fff;
  font-weight: 500;
  line-height: 1.6;
  text-align: center;
  text-transform: none;
  font-size: 28px;
  z-index: 1;
}

button:hover .circle {
  width: 100%;
}

button:hover .circle .icon.arrow {
  background: #000;
  transform: translate(1rem, 0);
}

button:hover .button-text {
  color: #000;
}


button.btn-serv.learn-more {
  width: auto;
  height: auto;
  min-width: 12rem;
  padding: 0px 160px;
  border-radius: 55px;
  background-color: transparent;
  display: inline-block;
  border: solid 2px;
  color: inherit;
  font-size: 30px;
  font-weight: 500;
}

button.btn-serv.learn-more .circle {
  transition: all 0.45s cubic-bezier(0.65, 0, 0.076, 1);
  position: absolute;
  display: block;
  margin: 0;
  width: 3rem;
  height: 3rem;
  background: #fff;
  border-radius: 1.625rem;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}

button.btn-serv.learn-more .circle .icon {
  transition: all 0.45s cubic-bezier(0.65, 0, 0.076, 1);
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  background: #000;
}

button.btn-serv.learn-more .circle .icon.arrow {
  transition: all 0.45s cubic-bezier(0.65, 0, 0.076, 1);
  left: 0.625rem;
  width: 1.125rem;
  height: 0.125rem;
  background: none;
}

button.btn-serv.learn-more .circle .icon.arrow::before {
  position: absolute;
  content: "";
  top: -0.29rem;
  right: 0.0625rem;
  width: 0.625rem;
  height: 0.625rem;
  border-top: 0.125rem solid #000;
  border-right: 0.125rem solid #000;
  transform: rotate(45deg);
}

button.btn-serv.learn-more .button-text {
  transition: all 0.45s cubic-bezier(0.65, 0, 0.076, 1);
  position: relative;
  padding: 0.75rem 0;
  margin: 0 0 0 1.85rem;
  color: inherit;
  font-weight: 500;
  line-height: 1.6;
  text-align: center;
  text-transform: none;
  font-size: 30px;
  z-index: 1;
}

button.btn-serv.learn-more:hover .circle {
  width: 100%;
}

button.btn-serv.learn-more:hover .circle .icon.arrow {
  background: #000;
  transform: translate(1rem, 0);
}

button.btn-serv.learn-more:hover .button-text {
  color: #000;
}

a.see-more-btn,
a.btn-serv {
  position: relative;
  display: inline-block;
  cursor: pointer;
  outline: none;
  vertical-align: middle;
  text-decoration: none;
  background: transparent;
  border-radius: 55px;
  color: #fff;
  font-size: 30px;
  font-weight: 500;
  letter-spacing: 1px;
  padding: 0px 90px;
  transition: color 0.45s cubic-bezier(0.65, 0, 0.076, 1);
  overflow: hidden;
  border: 4px solid #fff;
}

a.btn-serv {
  border: 2px solid;
  padding: 0px 160px;
}

a.see-more-btn .circle,
a.btn-serv .circle {
  transition: all 0.45s cubic-bezier(0.65, 0, 0.076, 1);
  position: absolute;
  display: block;
  margin: 0;
  width: 3rem;
  height: 3rem;
  background: #fff;
  border-radius: 1.625rem;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 0;
}

a.see-more-btn .circle .icon,
a.btn-serv .circle .icon {
  transition: all 0.45s cubic-bezier(0.65, 0, 0.076, 1);
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  background: #000;
}

a.see-more-btn .circle .icon.arrow,
a.btn-serv .circle .icon.arrow {
  transition: all 0.45s cubic-bezier(0.65, 0, 0.076, 1);
  left: 0.625rem;
  width: 1.125rem;
  height: 0.125rem;
  background: none;
}

a.see-more-btn .circle .icon.arrow::before,
a.btn-serv .circle .icon.arrow::before {
  position: absolute;
  content: "";
  top: -0.29rem;
  right: 0.0625rem;
  width: 0.625rem;
  height: 0.625rem;
  border-top: 0.125rem solid #000;
  border-right: 0.125rem solid #000;
  transform: rotate(45deg);
}

a.see-more-btn .button-text,
a.btn-serv .button-text {
  transition: all 0.45s cubic-bezier(0.65, 0, 0.076, 1);
  position: relative;
  padding: 0.75rem 0;
  margin: 0 0 0 1.85rem;
  color: #fff;
  font-weight: 500;
  line-height: 1.6;
  text-align: center;
  text-transform: none;
  font-size: 28px;
  z-index: 1;
}

a.see-more-btn:hover .circle,
a.btn-serv:hover .circle {
  width: 100%;
}

a.see-more-btn:hover .circle .icon.arrow,
a.btn-serv:hover .circle .icon.arrow {
  background: #000;
  transform: translate(1rem, 0);
}

a.see-more-btn:hover .button-text,
a.btn-serv:hover .button-text {
  color: #000;
}


.fade-in {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1), transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
  will-change: opacity, transform;
}
.fade-in.visible {
  opacity: 1;
  transform: translateY(0);
}