@import url(../css/fonts.css);
/* Works on Firefox */
* {
  scrollbar-width: thin;
  scrollbar-color: #232522 #f3f3f3; }

/* Works on Chrome, Edge, and Safari */
*::-webkit-scrollbar {
  width: 12px; }

*::-webkit-scrollbar-track {
  background: #333; }

*::-webkit-scrollbar-thumb {
  background-color: #f3f3f3;
  border-radius: 25px;
  border: 4px solid #333; }

.container {
  padding-right: calc(var(--bs-gutter-x) * .8) !important;
  padding-left: calc(var(--bs-gutter-x) * .8) !important; }

html {
  padding: 0 !important; }

body {
  font-family: Montserrat, 'Noto Sans TC', sans-serif;
  background-color: #232522;
  color: white;
  font-size: 16px;
  counter-reset: section; }
  @media (min-width: 769px) {
    body {
      font-size: 18px; } }

a {
  text-decoration: none;
  transition: all 0.2s ease-in; }

.font-primary {
  color: #339933; }

.service {
  padding: 4em 0; }
  .service .block-title {
    font-size: 1.8em;
    font-weight: bold;
    text-transform: uppercase;
    margin-bottom: 0.8em; }
  .service .block-subtitle {
    font-size: 1.2em;
    font-weight: bold;
    margin-bottom: 1.5em;
    font-weight: normal; }
  @media (min-width: 520px) {
    .service .block-title {
      font-size: 2.2em; }
    .service .block-subtitle {
      font-size: 1.1em; } }
  @media (min-width: 769px) {
    .service .block-title {
      font-size: 2.6em; }
    .service .block-subtitle {
      font-size: 1.5em; } }
  @media (min-width: 820px) {
    .service .block-title {
      font-size: 2.2em; }
    .service .block-subtitle {
      font-size: 1.5em; } }
  @media (min-width: 1200px) {
    .service .block-title {
      font-size: 2.75em; }
    .service .block-subtitle {
      font-size: 1.67em; } }
  @media (min-width: 2388px) {
    .service {
      padding: 7em 0; }
      .service .block-title {
        font-size: 2.75em; }
      .service .block-subtitle {
        font-size: 1.67em; } }

.mt-4 {
  margin-top: 0.7rem !important; }
  @media (min-width: 821px) {
    .mt-4 {
      margin-top: 1.5rem !important; } }

.mt-5 {
  margin-top: 1.5rem !important; }
  @media (min-width: 992px) {
    .mt-5 {
      margin-top: 3rem !important; } }

.ms-5 {
  margin-left: 0.7rem !important; }
  @media (min-width: 992px) {
    .ms-5 {
      margin-left: 1.5rem !important; } }

.btn {
  font-size: 0.85rem;
  padding: 0.5em 1.2em;
  border-radius: 35px; }
  @media (min-width: 769px) {
    .btn {
      font-size: 0.95rem;
      padding: 0.7em 1.4em; } }
  @media (min-width: 992px) {
    .btn {
      font-size: 1rem;
      padding: 0.7em 1.55em; } }
  @media (min-width: 1200px) {
    .btn {
      font-size: 1.1rem;
      padding: 0.7em 1em; } }

.btn-sm {
  padding: 0.8em 1.5em !important;
  border-radius: 35px; }
  @media (min-width: 769px) {
    .btn-sm {
      font-size: 0.95rem; } }
  @media (min-width: 1200px) {
    .btn-sm {
      font-size: 1rem; } }

.btn-more {
  background-color: transparent;
  border: 1px solid #339933;
  color: white;
  text-align: left;
  position: relative;
  transition: all 0.3s linear;
  display: inline-flex;
  align-items: center; }
  .btn-more img {
    width: auto;
    height: 1.2em; }
  .btn-more:after {
    position: absolute;
    content: "";
    width: calc(100% + 10px);
    height: calc(100% + 10px);
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    border: 1px solid #3b3b3b;
    border-radius: 40px;
    transition: all 0.3s linear; }
  .btn-more:hover, .btn-more:active, .btn-more:focus {
    background-color: #339933;
    border: 1px solid #339933;
    color: white; }
    .btn-more:hover:after, .btn-more:active:after, .btn-more:focus:after {
      position: absolute;
      content: "";
      width: calc(100% + 10px);
      height: calc(100% + 10px);
      left: 50%;
      top: 50%;
      transform: translate(-50%, -50%);
      border: 1px solid #339933;
      border-radius: 40px; }
  @media (min-width: 769px) {
    .btn-more:after {
      width: calc(100% + 12px);
      height: calc(100% + 12px); }
    .btn-more:hover:after, .btn-more:active:after {
      width: calc(100% + 12px);
      height: calc(100% + 12px); }
    .btn-more:focus {
      background-color: #339933 !important;
      border: 1px solid #339933 !important;
      color: white !important; }
      .btn-more:focus:after {
        width: calc(100% + 12px);
        height: calc(100% + 12px); } }

.btn-primary {
  background-color: #339933 !important;
  border: 0;
  color: white;
  border-radius: 7px;
  transition: all 0.3s linear; }
  .btn-primary:hover, .btn-primary:active, .btn-primary:focus {
    background-color: black !important;
    border: 0;
    color: white; }

.btn-outline-primary {
  border: 1px solid #339933;
  border-radius: 40px;
  color: #339933;
  padding: 0.4em 1.2em;
  font-size: 1rem; }
  @media (min-width: 769px) {
    .btn-outline-primary {
      font-size: 0.95rem;
      padding: 0.5em 1.4em; } }
  @media (min-width: 992px) {
    .btn-outline-primary {
      font-size: 0.95rem;
      padding: 0.4em 1.55em; } }
  @media (min-width: 1200px) {
    .btn-outline-primary {
      font-size: 1.1rem;
      padding: 0.5em 1.2em; } }
  .btn-outline-primary:hover, .btn-outline-primary:active {
    background-color: #339933;
    border: 1px solid transparent; }
  .btn-outline-primary:focus {
    background-color: #339933 !important;
    border: 1px solid transparent !important;
    color: white !important; }

.btn-none {
  padding: 0.5em 0;
  color: #999;
  background-color: transparent;
  border: 0;
  border-radius: 0;
  text-transform: uppercase;
  font-size: 0.85em;
  transition: all 0.3s linear; }
  .btn-none:hover {
    color: white; }
  @media (min-width: 769px) {
    .btn-none {
      font-size: 1.1em; } }

.about .main-img .col-12.col-md-6 img {
  border-top-left-radius: 10px;
  border-bottom-left-radius: 0;
  border-top-right-radius: 10px;
  border-bottom-right-radius: 0; }
.about .main-img .col-12.col-md-6:last-child img {
  border-top-left-radius: 0;
  border-bottom-left-radius: 10px;
  border-top-right-radius: 0;
  border-bottom-right-radius: 10px; }
@media (min-width: 769px) {
  .about .main-img .col-12.col-md-6 img {
    border-top-left-radius: 10px;
    border-bottom-left-radius: 10px;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0; }
  .about .main-img .col-12.col-md-6:last-child img {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-top-right-radius: 10px;
    border-bottom-right-radius: 10px; } }
.about p {
  color: #999;
  font-size: 0.85em; }
.about .slogan {
  font-size: 1.6em;
  font-weight: bold;
  font-style: italic;
  color: #339933;
  margin: 2em 0 1em 0;
  text-align: center; }
  @media (min-width: 769px) {
    .about .slogan {
      font-size: 2em; } }
.about .items {
  background-color: #333;
  border-radius: 20px;
  padding: 2em 0;
  text-align: center;
  margin: 4em 0; }
  .about .items img {
    width: 70px;
    height: auto;
    margin-bottom: 1em;
    filter: invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(102%) contrast(102%);
    margin-top: 2em; }
  .about .items .item-title {
    color: #339933;
    font-size: 0.8em;
    margin-bottom: 1em;
    text-transform: uppercase; }
  .about .items .item-con {
    font-size: 0.95em;
    font-style: italic;
    text-transform: uppercase;
    font-weight: bold; }
  @media (min-width: 769px) {
    .about .items {
      padding: 2em 3em; }
      .about .items img {
        width: 60%;
        height: auto;
        margin-top: 0; }
      .about .items .item-title {
        color: #339933;
        font-size: 0.7em;
        margin-bottom: 1em;
        text-transform: uppercase; }
      .about .items .item-con {
        font-size: 0.85em;
        font-style: italic;
        text-transform: uppercase;
        font-weight: bold; } }
  @media (min-width: 1200px) {
    .about .items {
      padding: 2em 3em; }
      .about .items img {
        width: 60%;
        height: auto;
        margin-top: 0; }
      .about .items .item-title {
        color: #339933;
        font-size: 0.8em;
        margin-bottom: 1em;
        text-transform: uppercase; }
      .about .items .item-con {
        font-size: 0.95em;
        font-style: italic;
        text-transform: uppercase;
        font-weight: bold; } }
  .about .items .col-6.col-lg-3:nth-child(4n+1) img, .about .items .col-6.col-lg-3:nth-child(4n+2) img {
    margin-top: 0; }
.about .green .circle-img {
  border-radius: 50%;
  width: 240px;
  height: 240px;
  overflow: hidden;
  border: 2px solid #339933;
  position: relative;
  margin: 0 auto;
  padding: 8px; }
  @media (min-width: 769px) {
    .about .green .circle-img {
      width: 240px;
      height: 240px; } }
  @media (min-width: 992px) {
    .about .green .circle-img {
      width: 320px;
      height: 320px; } }
  @media (min-width: 1200px) {
    .about .green .circle-img {
      width: 350px;
      height: 350px; } }
.about .green h3 {
  font-weight: bold;
  letter-spacing: 0.05em;
  margin-bottom: 1em;
  font-size: 1.6em;
  text-align: center;
  word-wrap: break-word; }
  @media (min-width: 769px) {
    .about .green h3 {
      text-align: left; } }
.about .green p {
  text-align: center; }
  @media (min-width: 769px) {
    .about .green p {
      text-align: left; } }
.about .green .d-block.text-center {
  text-align: center !important; }
  @media (min-width: 769px) {
    .about .green .d-block.text-center {
      text-align: left !important; } }

.gutter-w {
  --bs-gutter-x: 4.5rem; }
  @media (min-width: 769px) {
    .gutter-w {
      --bs-gutter-x: 4rem; } }
  @media (min-width: 992px) {
    .gutter-w {
      --bs-gutter-x: 8rem; } }

.workflow {
  padding-bottom: 3em; }
  .workflow .work1 {
    order: 1; }
  .workflow .work2 {
    order: 2; }
  .workflow .work3 {
    order: 3; }
  .workflow .work4 {
    order: 4; }
  .workflow .work5 {
    order: 5; }
  .workflow .work6 {
    order: 6; }
  .workflow .work7 {
    order: 7; }
  .workflow .work8 {
    order: 8; }
  .workflow .work9 {
    order: 9; }
  .workflow .work10 {
    order: 10; }
  .workflow .work11 {
    order: 11; }
  .workflow .work12 {
    order: 12; }
  .workflow .work13 {
    order: 13; }
  .workflow .work14 {
    order: 14; }
  @media (min-width: 768px) {
    .workflow .work1 {
      order: 1; }
    .workflow .work2 {
      order: 2; }
    .workflow .work3 {
      order: 3; }
    .workflow .work4 {
      order: 6; }
    .workflow .work5 {
      order: 5; }
    .workflow .work6 {
      order: 4; }
    .workflow .work7 {
      order: 7; }
    .workflow .work8 {
      order: 8; }
    .workflow .work9 {
      order: 9; }
    .workflow .work10 {
      order: 12; }
    .workflow .work11 {
      order: 11; }
    .workflow .work12 {
      order: 10; }
    .workflow .work13 {
      order: 13; }
    .workflow .work14 {
      order: 14; } }
  .workflow .worklist {
    position: relative;
    text-align: center; }
    .workflow .worklist .flow-img {
      position: relative;
      width: 100%;
      height: auto;
      border-radius: 50%;
      border: 1px solid white;
      padding: 10px;
      background-color: #232522;
      margin: 0 auto; }
      .workflow .worklist .flow-img:before {
        display: none; }
      .workflow .worklist .flow-img img {
        width: 100%;
        height: auto;
        border-radius: 50%; }
    .workflow .worklist .step {
      position: absolute;
      bottom: 0;
      left: 0;
      color: white;
      font-size: 1.7rem;
      font-weight: bolder;
      font-style: italic;
      display: flex;
      align-items: center;
      justify-content: center;
      width: 70px;
      height: 70px;
      padding: 1em;
      z-index: 0; }
      .workflow .worklist .step:after {
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate(-47%, -50%);
        width: 100%;
        height: 100%;
        content: "";
        background-color: #339933;
        border-radius: 50%;
        z-index: -1; }
      @media (min-width: 520px) {
        .workflow .worklist .step {
          bottom: 0;
          font-size: 1.2rem;
          width: 50px;
          height: 50px;
          padding: 0.3em; } }
      @media (min-width: 769px) {
        .workflow .worklist .step {
          bottom: 0;
          font-size: 1.3rem;
          width: 50px;
          height: 50px; } }
      @media (min-width: 992px) {
        .workflow .worklist .step {
          bottom: 0;
          font-size: 1.45rem;
          width: 50px;
          height: 50px;
          padding: 1em; } }
      @media (min-width: 1200px) {
        .workflow .worklist .step {
          font-size: 2rem;
          width: 50px;
          height: 50px; } }
    .workflow .worklist .step-intro {
      position: relative;
      height: auto; }
      .workflow .worklist .step-intro .step-name {
        margin: 1em 0 0.5em 0;
        font-size: 1.3rem;
        font-weight: bold; }
      .workflow .worklist .step-intro p {
        color: #999;
        font-size: 0.9rem;
        line-height: 1rem; }
      @media (min-width: 520px) {
        .workflow .worklist .step-intro {
          height: 90px; }
          .workflow .worklist .step-intro .step-name {
            font-size: 1.1rem; }
          .workflow .worklist .step-intro p {
            color: #999;
            font-size: 0.8rem; } }
      @media (min-width: 769px) {
        .workflow .worklist .step-intro {
          height: 90px; }
          .workflow .worklist .step-intro .step-name {
            font-size: 0.75rem; }
          .workflow .worklist .step-intro p {
            color: #999;
            font-size: 0.75rem; } }
      @media (min-width: 992px) {
        .workflow .worklist .step-intro {
          height: 100px; }
          .workflow .worklist .step-intro .step-name {
            font-size: 0.9rem; }
          .workflow .worklist .step-intro p {
            color: #999;
            font-size: 0.8rem; } }
      @media (min-width: 1200px) {
        .workflow .worklist .step-intro {
          height: 110px; }
          .workflow .worklist .step-intro .step-name {
            font-size: 1.2rem; }
          .workflow .worklist .step-intro p {
            color: #999;
            font-size: 1rem; } }
      @media (min-width: 1680px) {
        .workflow .worklist .step-intro {
          height: 110px; }
          .workflow .worklist .step-intro .step-name {
            font-size: 1.35rem; }
          .workflow .worklist .step-intro p {
            color: #999;
            font-size: 1.1rem;
            line-height: 1.3rem; } }
    @media (min-width: 768px) {
      .workflow .worklist .flow-img:before {
        position: absolute;
        width: 60%;
        height: 50px;
        left: auto;
        right: -60%;
        top: calc(50% + 25px);
        bottom: auto;
        content: "";
        transform: translateY(-50%);
        border-top: 1px solid #999;
        display: block;
        z-index: -1; }
      .workflow .worklist:nth-child(3) .flow-img:before, .workflow .worklist:nth-child(9) .flow-img:before {
        border-top-right-radius: 20px;
        border-right: 1px solid #999;
        width: 50px;
        right: -50px; }
      .workflow .worklist:nth-child(3) .step-intro, .workflow .worklist:nth-child(9) .step-intro {
        position: relative; }
        .workflow .worklist:nth-child(3) .step-intro:after, .workflow .worklist:nth-child(9) .step-intro:after {
          position: absolute;
          width: 1px;
          height: 250%;
          left: auto;
          right: -49px;
          top: 50%;
          bottom: auto;
          content: "";
          transform: translateY(-50%);
          border-right: 1px solid #999; }
      .workflow .worklist:nth-child(4) .flow-img:before, .workflow .worklist:nth-child(10) .flow-img:before {
        border-bottom-right-radius: 20px;
        border-right: 1px solid #999;
        border-top: 0;
        border-bottom: 1px solid #999;
        left: auto;
        right: -50px;
        top: auto;
        bottom: calc(50% - 25px);
        width: 50px;
        transform: translateY(-50%); }
      .workflow .worklist:nth-child(6) .flow-img:before, .workflow .worklist:nth-child(12) .flow-img:before {
        border-top-left-radius: 20px;
        border-left: 1px solid #999;
        left: -50px;
        right: auto;
        width: 50px; }
      .workflow .worklist:nth-child(6) .flow-img:after, .workflow .worklist:nth-child(12) .flow-img:after {
        position: absolute;
        width: 60%;
        height: 50px;
        left: auto;
        right: -60%;
        top: calc(50% + 25px);
        bottom: auto;
        content: "";
        transform: translateY(-50%);
        border-top: 1px solid #999; }
      .workflow .worklist:nth-child(6) .step-intro, .workflow .worklist:nth-child(12) .step-intro {
        position: relative; }
        .workflow .worklist:nth-child(6) .step-intro:after, .workflow .worklist:nth-child(12) .step-intro:after {
          position: absolute;
          width: 1px;
          height: 260%;
          left: -49px;
          right: auto;
          top: 50%;
          bottom: auto;
          content: "";
          transform: translateY(-50%);
          border-left: 1px solid #999; }
      .workflow .worklist:nth-child(7) .flow-img:before, .workflow .worklist:nth-child(13) .flow-img:before {
        border-bottom-left-radius: 20px;
        border-left: 1px solid #999;
        border-bottom: 1px solid #999;
        border-top: 0;
        left: -50px;
        right: auto;
        top: auto;
        bottom: calc(50% - 25px); }
      .workflow .worklist:nth-child(7) .flow-img:after, .workflow .worklist:nth-child(13) .flow-img:after {
        position: absolute;
        width: 60%;
        height: 50px;
        left: auto;
        right: -60%;
        top: calc(50% + 25px);
        bottom: auto;
        content: "";
        transform: translateY(-50%);
        border-top: 1px solid #999; }
      .workflow .worklist:nth-child(13) .flow-img:before {
        left: -163px;
        width: 180px; }
      .workflow .worklist:nth-child(13) .flow-img:after {
        right: -150px;
        width: 150px; }
      .workflow .worklist:last-child .flow-img:before {
        display: none; } }
    @media (min-width: 992px) {
      .workflow .worklist .flow-img:before {
        position: absolute;
        width: 70%;
        height: 50px;
        left: auto;
        right: -70%;
        top: calc(50% + 25px);
        bottom: auto;
        content: "";
        transform: translateY(-50%);
        border-top: 1px solid #999;
        display: block;
        z-index: -1; }
      .workflow .worklist:nth-child(3) .flow-img:before, .workflow .worklist:nth-child(9) .flow-img:before {
        border-top-right-radius: 25px;
        border-right: 1px solid #999;
        width: 50px;
        right: -50px; }
      .workflow .worklist:nth-child(3) .step-intro, .workflow .worklist:nth-child(9) .step-intro {
        position: relative; }
        .workflow .worklist:nth-child(3) .step-intro:after, .workflow .worklist:nth-child(9) .step-intro:after {
          position: absolute;
          width: 1px;
          height: 285%;
          left: auto;
          right: -49px;
          top: 50%;
          bottom: auto;
          content: "";
          transform: translateY(-50%);
          border-right: 1px solid #999; }
      .workflow .worklist:nth-child(4) .flow-img:before, .workflow .worklist:nth-child(10) .flow-img:before {
        border-bottom-right-radius: 25px;
        border-right: 1px solid #999;
        border-top: 0;
        border-bottom: 1px solid #999;
        left: auto;
        right: -50px;
        top: auto;
        bottom: calc(50% - 25px);
        width: 50px;
        transform: translateY(-50%); }
      .workflow .worklist:nth-child(6) .flow-img:before, .workflow .worklist:nth-child(12) .flow-img:before {
        border-top-left-radius: 25px;
        border-left: 1px solid #999;
        left: -50px;
        right: auto;
        width: 50px; }
      .workflow .worklist:nth-child(6) .flow-img:after, .workflow .worklist:nth-child(12) .flow-img:after {
        position: absolute;
        width: 70%;
        height: 50px;
        left: auto;
        right: -70%;
        top: calc(50% + 25px);
        bottom: auto;
        content: "";
        transform: translateY(-50%);
        border-top: 1px solid #999; }
      .workflow .worklist:nth-child(6) .step-intro, .workflow .worklist:nth-child(12) .step-intro {
        position: relative; }
        .workflow .worklist:nth-child(6) .step-intro:after, .workflow .worklist:nth-child(12) .step-intro:after {
          position: absolute;
          width: 1px;
          height: 285%;
          left: -49px;
          right: auto;
          top: 50%;
          bottom: auto;
          content: "";
          transform: translateY(-50%);
          border-left: 1px solid #999; }
      .workflow .worklist:nth-child(7) .flow-img:before, .workflow .worklist:nth-child(13) .flow-img:before {
        border-bottom-left-radius: 25px;
        border-left: 1px solid #999;
        border-bottom: 1px solid #999;
        border-top: 0;
        left: -50px;
        right: auto;
        top: auto;
        bottom: calc(50% - 25px); }
      .workflow .worklist:nth-child(7) .flow-img:after, .workflow .worklist:nth-child(13) .flow-img:after {
        position: absolute;
        width: 70%;
        height: 50px;
        left: auto;
        right: -70%;
        top: calc(50% + 25px);
        bottom: auto;
        content: "";
        transform: translateY(-50%);
        border-top: 1px solid #999; }
      .workflow .worklist:nth-child(13) .flow-img:before {
        left: -210px;
        width: 210px; }
      .workflow .worklist:nth-child(13) .flow-img:after {
        right: -100%;
        width: 100%; }
      .workflow .worklist:last-child .flow-img:before {
        display: none; } }
    @media (min-width: 1200px) {
      .workflow .worklist .flow-img:before {
        position: absolute;
        width: 60%;
        height: 50px;
        left: auto;
        right: -60%;
        top: calc(50% + 25px);
        bottom: auto;
        content: "";
        transform: translateY(-50%);
        border-top: 1px solid #999;
        display: block;
        z-index: -1; }
      .workflow .worklist:nth-child(3) .flow-img:before, .workflow .worklist:nth-child(9) .flow-img:before {
        border-top-right-radius: 25px;
        border-right: 1px solid #999;
        width: 50px;
        right: -50px; }
      .workflow .worklist:nth-child(3) .step-intro, .workflow .worklist:nth-child(9) .step-intro {
        position: relative; }
        .workflow .worklist:nth-child(3) .step-intro:after, .workflow .worklist:nth-child(9) .step-intro:after {
          position: absolute;
          width: 1px;
          height: 300%;
          left: auto;
          right: -49px;
          top: 50%;
          bottom: auto;
          content: "";
          transform: translateY(-50%);
          border-right: 1px solid #999; }
      .workflow .worklist:nth-child(4) .flow-img:before, .workflow .worklist:nth-child(10) .flow-img:before {
        border-bottom-right-radius: 25px;
        border-right: 1px solid #999;
        border-top: 0;
        border-bottom: 1px solid #999;
        left: auto;
        right: -50px;
        top: auto;
        bottom: calc(50% - 25px);
        width: 50px;
        transform: translateY(-50%); }
      .workflow .worklist:nth-child(6) .flow-img:before, .workflow .worklist:nth-child(12) .flow-img:before {
        border-top-left-radius: 25px;
        border-left: 1px solid #999;
        left: -50px;
        right: auto;
        width: 50px; }
      .workflow .worklist:nth-child(6) .flow-img:after, .workflow .worklist:nth-child(12) .flow-img:after {
        position: absolute;
        width: 60%;
        height: 50px;
        left: auto;
        right: -60%;
        top: calc(50% + 25px);
        bottom: auto;
        content: "";
        transform: translateY(-50%);
        border-top: 1px solid #999; }
      .workflow .worklist:nth-child(6) .step-intro, .workflow .worklist:nth-child(12) .step-intro {
        position: relative; }
        .workflow .worklist:nth-child(6) .step-intro:after, .workflow .worklist:nth-child(12) .step-intro:after {
          position: absolute;
          width: 1px;
          height: 290%;
          left: -49px;
          right: auto;
          top: 50%;
          bottom: auto;
          content: "";
          transform: translateY(-50%);
          border-left: 1px solid #999; }
      .workflow .worklist:nth-child(7) .flow-img:before, .workflow .worklist:nth-child(13) .flow-img:before {
        border-bottom-left-radius: 25px;
        border-left: 1px solid #999;
        border-bottom: 1px solid #999;
        border-top: 0;
        left: -50px;
        right: auto;
        top: auto;
        bottom: calc(50% - 25px); }
      .workflow .worklist:nth-child(7) .flow-img:after, .workflow .worklist:nth-child(13) .flow-img:after {
        position: absolute;
        width: 60%;
        height: 50%;
        left: auto;
        right: -60%;
        top: 75%;
        bottom: auto;
        content: "";
        transform: translateY(-50%);
        border-top: 1px solid #999; }
      .workflow .worklist:nth-child(13) .flow-img:before {
        left: -231px;
        width: 100%; }
      .workflow .worklist:nth-child(13) .flow-img:after {
        right: -60%;
        width: 60%; }
      .workflow .worklist:last-child .flow-img:before {
        display: none; } }
    @media (min-width: 1400px) {
      .workflow .worklist .flow-img:before {
        position: absolute;
        width: 60%;
        height: 50px;
        left: auto;
        right: -60%;
        top: calc(50% + 25px);
        bottom: auto;
        content: "";
        transform: translateY(-50%);
        border-top: 1px solid #999;
        display: block;
        z-index: -1; }
      .workflow .worklist:nth-child(3) .flow-img:before, .workflow .worklist:nth-child(9) .flow-img:before {
        border-top-right-radius: 25px;
        border-right: 1px solid #999;
        width: 50px;
        right: -50px; }
      .workflow .worklist:nth-child(3) .step-intro, .workflow .worklist:nth-child(9) .step-intro {
        position: relative; }
        .workflow .worklist:nth-child(3) .step-intro:after, .workflow .worklist:nth-child(9) .step-intro:after {
          position: absolute;
          width: 1px;
          height: 370%;
          left: auto;
          right: -49px;
          top: 50%;
          bottom: auto;
          content: "";
          transform: translateY(-50%);
          border-right: 1px solid #999; }
      .workflow .worklist:nth-child(4) .flow-img:before, .workflow .worklist:nth-child(10) .flow-img:before {
        border-bottom-right-radius: 25px;
        border-right: 1px solid #999;
        border-top: 0;
        border-bottom: 1px solid #999;
        left: auto;
        right: -50px;
        top: auto;
        bottom: calc(50% - 25px);
        width: 50px;
        transform: translateY(-50%); }
      .workflow .worklist:nth-child(6) .flow-img:before, .workflow .worklist:nth-child(12) .flow-img:before {
        border-top-left-radius: 25px;
        border-left: 1px solid #999;
        left: -50px;
        right: auto;
        width: 50px; }
      .workflow .worklist:nth-child(6) .flow-img:after, .workflow .worklist:nth-child(12) .flow-img:after {
        position: absolute;
        width: 60%;
        height: 50px;
        left: auto;
        right: -60%;
        top: calc(50% + 25px);
        bottom: auto;
        content: "";
        transform: translateY(-50%);
        border-top: 1px solid #999; }
      .workflow .worklist:nth-child(6) .step-intro, .workflow .worklist:nth-child(12) .step-intro {
        position: relative; }
        .workflow .worklist:nth-child(6) .step-intro:after, .workflow .worklist:nth-child(12) .step-intro:after {
          position: absolute;
          width: 1px;
          height: 370%;
          left: -49px;
          right: auto;
          top: 50%;
          bottom: auto;
          content: "";
          transform: translateY(-50%);
          border-left: 1px solid #999; }
      .workflow .worklist:nth-child(7) .flow-img:before, .workflow .worklist:nth-child(13) .flow-img:before {
        border-bottom-left-radius: 25px;
        border-left: 1px solid #999;
        border-bottom: 1px solid #999;
        border-top: 0;
        left: -50px;
        right: auto;
        top: auto;
        bottom: calc(50% - 25px);
        width: 50px; }
      .workflow .worklist:nth-child(7) .flow-img:after, .workflow .worklist:nth-child(13) .flow-img:after {
        position: absolute;
        width: 60%;
        height: 50%;
        left: auto;
        right: -60%;
        top: 75%;
        bottom: auto;
        content: "";
        transform: translateY(-50%);
        border-top: 1px solid #999; }
      .workflow .worklist:nth-child(13) .flow-img:before {
        left: -261px;
        width: 100%; }
      .workflow .worklist:nth-child(13) .flow-img:after {
        left: 100%;
        width: 100%; }
      .workflow .worklist:last-child .flow-img:before {
        display: none; } }

.service {
  background-color: black;
  text-align: center; }
  .service p {
    color: #999; }
  .service .block-subtitle {
    margin-top: 2.5em;
    font-weight: bold;
    text-transform: uppercase; }
  .service .block-subtitle:first-child {
    margin-top: 0; }

.eqp .page-title {
  margin-bottom: 0.5em !important; }
.eqp .eqp-control.show {
  display: block !important; }
.eqp .eqp-control {
  text-align: left;
  border-radius: 0;
  background-color: #24502a;
  padding: 0;
  min-width: 100%;
  display: none;
  border: 0; }
  .eqp .eqp-control a:link, .eqp .eqp-control a:visited {
    color: white;
    padding: 0.8em 1em !important;
    line-height: 1em;
    display: block; }
  .eqp .eqp-control a:hover, .eqp .eqp-control a:active {
    color: white;
    background-color: #232522; }
  .eqp .eqp-control a.active {
    color: white;
    background-color: #339933;
    padding: 0.8em 1em !important; }
  @media (min-width: 768px) {
    .eqp .eqp-control {
      display: block;
      justify-content: inherit;
      background-color: transparent;
      margin: 0; }
      .eqp .eqp-control li {
        display: inline-block;
        position: relative; }
        .eqp .eqp-control li a:link, .eqp .eqp-control li a:visited {
          padding: 0em 1em !important;
          display: inline-block; }
        .eqp .eqp-control li a:hover, .eqp .eqp-control li a:active {
          color: #339933;
          background-color: transparent; }
        .eqp .eqp-control li a.active {
          padding: 0em 1em !important;
          color: #339933;
          background-color: transparent; }
        .eqp .eqp-control li:before {
          content: "";
          width: 1px;
          height: 50%;
          background-color: white;
          position: absolute;
          left: 0;
          top: 50%;
          transform: translateY(-50%); }
        .eqp .eqp-control li:first-child a {
          padding: 0 1em 0 0 !important; }
        .eqp .eqp-control li:first-child:before {
          display: none; }
        .eqp .eqp-control li:last-child a {
          padding: 0 0 0 1em !important; } }
.eqp .btn-none {
  display: initial;
  text-align: center;
  border: 1px solid #3b3b3b;
  padding: 0.5em 1em; }
  @media (min-width: 768px) {
    .eqp .btn-none {
      display: none; } }
.eqp .gx-5 {
  --bs-gutter-x: 4rem; }
.eqp .eqp-list {
  margin-bottom: 3em;
  padding: 0 3rem; }
  .eqp .eqp-list img {
    padding: 0 1em;
    margin-bottom: 1em; }
  .eqp .eqp-list .eqp-brand {
    color: #339933;
    font-size: 1.25rem;
    font-weight: bold; }
  .eqp .eqp-list .eqp-model {
    text-transform: uppercase;
    font-size: 1.25rem;
    font-weight: normal;
    text-align: right; }
  .eqp .eqp-list .eqp-cat {
    background-color: #3b3b3b;
    color: #cdcdcd;
    font-size: 1rem;
    padding: 0.3em 0.8em; }
  @media (min-width: 769px) {
    .eqp .eqp-list {
      padding: 0 3rem; }
      .eqp .eqp-list .eqp-brand {
        font-size: 1.2rem; }
      .eqp .eqp-list .eqp-model {
        font-size: 1.2rem; }
      .eqp .eqp-list .eqp-cat {
        font-size: 1.1rem; } }
  @media (min-width: 992px) {
    .eqp .eqp-list {
      padding: 0 2rem; }
      .eqp .eqp-list .eqp-brand {
        font-size: 1rem; }
      .eqp .eqp-list .eqp-model {
        font-size: 1rem; }
      .eqp .eqp-list .eqp-cat {
        font-size: 0.9rem; } }
  @media (min-width: 1400px) {
    .eqp .eqp-list {
      padding: 0 2rem; }
      .eqp .eqp-list .eqp-brand {
        font-size: 1.2rem; }
      .eqp .eqp-list .eqp-model {
        font-size: 1.2rem; }
      .eqp .eqp-list .eqp-cat {
        font-size: 1.1rem; } }
  @media (min-width: 1680px) {
    .eqp .eqp-list {
      padding: 0 2rem; }
      .eqp .eqp-list .eqp-brand {
        font-size: 1.3rem; }
      .eqp .eqp-list .eqp-model {
        font-size: 1.3rem; }
      .eqp .eqp-list .eqp-cat {
        font-size: 1.2rem; } }
  .eqp .eqp-list dl.spec {
    position: relative;
    padding: 0;
    margin: 1em 0 0 0; }
    .eqp .eqp-list dl.spec .row.justify-content-between.m-0.mb-2:last-child {
      margin-bottom: 0; }
    .eqp .eqp-list dl.spec dt {
      font-weight: normal;
      font-size: 0.9rem;
      margin: 0; }
    .eqp .eqp-list dl.spec dd {
      color: #999;
      font-size: 0.9rem;
      text-align: left;
      margin: 0;
      padding-right: calc(var(--bs-gutter-x) * .5);
      padding-left: calc(var(--bs-gutter-x) * .5); }
      @media (min-width: 769px) {
        .eqp .eqp-list dl.spec dd {
          text-align: right;
          padding-right: 0;
          padding-left: calc(var(--bs-gutter-x) * .5); } }
    @media (min-width: 769px) {
      .eqp .eqp-list dl.spec dt {
        font-size: 0.8rem; }
      .eqp .eqp-list dl.spec dd {
        font-size: 0.8rem; } }
    .eqp .eqp-list dl.spec:before {
      position: absolute;
      left: 0;
      top: 50%;
      width: 3px;
      height: calc(100% - 7px);
      transform: translateY(-50%);
      content: "";
      background-color: #339933; }

.contact {
  margin-bottom: -8px;
  padding-bottom: 0 !important;
  background-image: url("../images/bg-contact.png");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  background-attachment: fixed; }
  .contact .g-map {
    filter: grayscale(100%) invert(85%);
    background-color: black; }
  .contact .form {
    padding: 0; }
    .contact .form p {
      color: #339933; }
    .contact .form form .form-control {
      background-color: black;
      border: 0;
      color: white;
      border-radius: 8px;
      padding: 0.8em 1.2em; }
      .contact .form form .form-control:placeholder {
        color: #999; }
    .contact .form form .chk-num img {
      height: 100%;
      width: auto; }
    .contact .form form .text-end {
      text-align: left !important; }
      @media (min-width: 992px) {
        .contact .form form .text-end {
          text-align: right !important; } }
  .contact .right-side {
    padding: 0;
    margin-bottom: 2.5em; }
    @media (min-width: 992px) {
      .contact .right-side {
        padding-left: 2rem; } }
    .contact .right-side .info-box {
      background-color: #333;
      padding: 1.1rem;
      border-radius: 10px;
      margin: 0 0 1.5em 0;
      font-size: 1rem; }
      .contact .right-side .info-box i {
        color: #339933;
        font-size: 2.5em; }
      .contact .right-side .info-box h4 {
        font-weight: bold;
        font-size: 1.1em; }
      .contact .right-side .info-box p {
        color: #999;
        font-size: 0.9em;
        margin-bottom: 0; }
      .contact .right-side .info-box a {
        color: #999; }
      .contact .right-side .info-box .col-3 {
        text-align: right; }
      @media (min-width: 768px) {
        .contact .right-side .info-box {
          padding: 1.05rem 1.1rem; }
          .contact .right-side .info-box .info-box h4 {
            font-size: 1.2em; }
          .contact .right-side .info-box .info-box p {
            font-size: 0.7em; } }
      @media (min-width: 992px) {
        .contact .right-side .info-box {
          padding: 1.048rem 1.1rem; }
          .contact .right-side .info-box .info-box h4 {
            font-size: 1.2em; }
          .contact .right-side .info-box .info-box p {
            font-size: 0.7em; } }
      @media (min-width: 1200px) {
        .contact .right-side .info-box {
          padding: 0.93rem 1.1rem; }
          .contact .right-side .info-box .info-box h4 {
            font-size: 1.2em; }
          .contact .right-side .info-box .info-box p {
            font-size: 0.7em; } }
      @media (min-width: 1680px) {
        .contact .right-side .info-box {
          padding: 1rem 1.1rem; }
          .contact .right-side .info-box .info-box h4 {
            font-size: 1.2em; }
          .contact .right-side .info-box .info-box p {
            font-size: 0.7em; } }

.form-send .btn {
  width: auto; }
  @media (min-width: 769px) {
    .form-send .btn {
      width: 100%; } }

.bg-black {
  margin-top: -2em;
  padding: 2em 0 1em 0; }
  @media (min-width: 768px) {
    .bg-black {
      padding: 2.5em 0 4em 0; } }
