.sdifl {
  --dot-color: #113977;
  text-align: center;
}
.sdifl h2, .sdifl h3 {
  color: #113977;
  font-size: 42px !important;
  line-height: 1.2 !important;
}
.sdifl h3 {
  font-weight: 200 !important;
}
@media screen and (min-width: 1080px) {
  .sdifl h2, .sdifl h3 {
    font-size: 50px !important;
  }
}
.sdifl--headline {
  position: relative;
  margin: 2rem 0 3rem;
}
@media screen and (min-width: 576px) and (max-width: 1079px) {
  .sdifl--headline {
    margin-top: -1rem;
  }
}
@media screen and (min-width: 1130px) {
  .sdifl--headline {
    margin-top: -2rem;
  }
}
.sdifl--headline::before {
  display: block;
  content: "";
  width: 5px;
  height: 250px;
  background: #96C93E;
  margin: 0 auto 3rem;
}
.sdifl--services {
  max-width: 720px;
  min-width: 65%;
  margin: 0 auto -10rem;
  position: relative;
  padding: 2rem 0 18rem;
}
@media screen and (min-width: 1080px) {
  .sdifl--services::before {
    position: absolute;
    top: 0;
    left: 50%;
    z-index: -1;
    transform: translateX(-50%);
    display: block;
    content: "";
    width: 5px;
    height: 125%;
    max-height: 0px;
    background: rgb(150, 201, 62);
    background: linear-gradient(180deg, rgb(150, 201, 62) 0%, rgb(24, 154, 216) 50%, rgb(27, 58, 115) 100%);
    transition: max-height 2s ease-in;
  }
  .sdifl--services.active::before {
    max-height: 2500px;
  }
}
.sdifl--services ul {
  margin: 0;
}
.sdifl--services li {
  list-style-type: none;
  list-style-position: inside;
  padding: 0;
}
.sdifl--services li:nth-child(2n) .sdifl--service {
  flex-flow: column wrap;
}
@media screen and (min-width: 1080px) {
  .sdifl--services li:nth-child(2n) .sdifl--service {
    flex-flow: row-reverse nowrap;
  }
}
.sdifl--services li:nth-child(2n) .sdifl--service-icon--icon-grid .left-outline {
  display: none;
}
@media screen and (min-width: 1080px) {
  .sdifl--services li:nth-child(2n) .sdifl--service-name {
    text-align: right;
  }
  .sdifl--services li:nth-child(2n) .sdifl--service-icon {
    justify-content: flex-start;
  }
  .sdifl--services li:nth-child(2n) .sdifl--service-icon--background {
    grid-column: 2;
    transform: scale(0.9) translateX(3px);
  }
  .sdifl--services li:nth-child(2n) .sdifl--service-icon--icon {
    grid-column: 2;
    transform: translateX(2px);
  }
  .sdifl--services li:nth-child(2n) .sdifl--service-icon--icon-grid {
    grid-template-columns: 35% 65%;
    transform: translateX(-10px);
  }
  .sdifl--services li:nth-child(2n) .sdifl--service-icon--icon-grid .right-outline {
    display: block;
  }
}
.sdifl--services a {
  color: #1B3A73;
  font-size: 30px;
}
.sdifl--services a:hover {
  color: #189AD8 !important;
}
.sdifl--service {
  display: flex;
  justify-content: stretch;
  align-items: center;
  position: relative;
  flex-flow: column wrap;
  margin-bottom: 1rem;
}
.sdifl--service.active .sdifl--service-icon--background {
  opacity: 1;
}
.sdifl--service.active .sdifl--service-name {
  opacity: 1;
}
@media screen and (min-width: 1080px) {
  .sdifl--service {
    flex-flow: row nowrap;
    margin-bottom: -3rem;
  }
  .sdifl--service.active .sdifl--service-icon .left-outline path, .sdifl--service.active .sdifl--service-icon .right-outline path {
    stroke: var(--dot-color) !important;
    stroke-dasharray: 0 1000;
    animation: dash 2s 1s linear 1;
    animation-fill-mode: forwards;
  }
  .sdifl--service.active .sdifl--service-icon .left-outline circle, .sdifl--service.active .sdifl--service-icon .right-outline circle {
    opacity: 1;
    transition: opacity 1s 0.5s ease;
  }
}
@keyframes dash {
  from {
    stroke-dasharray: 0 2000;
  }
  to {
    stroke-dasharray: 2000 0;
  }
}
.sdifl--service-border {
  flex: 0 0 5px;
  align-self: stretch;
}
.sdifl--service-name {
  opacity: 0;
  transition: opacity 1s 0.5s ease-in-out;
}
@media screen and (min-width: 1080px) {
  .sdifl--service-name {
    flex: 0 1 50%;
    text-align: left;
    padding: 0 2rem 0;
  }
}
.sdifl--service-icon {
  position: relative;
  height: 250px;
}
@media screen and (min-width: 1080px) {
  .sdifl--service-icon {
    flex: 0 1 50%;
    display: flex;
    justify-content: flex-end;
    text-align: left;
  }
}
.sdifl--service-icon--icon-grid {
  display: grid;
  grid-template-columns: 250px;
  grid-template-rows: 250px;
  text-align: left;
}
@media screen and (min-width: 1080px) {
  .sdifl--service-icon--icon-grid {
    grid-template-columns: 65% 35%;
    width: 360px;
    transform: translateX(10px);
  }
}
.sdifl--service-icon--icon {
  grid-row: 1;
  grid-column: 1/span 1;
}
@media screen and (min-width: 1080px) {
  .sdifl--service-icon--icon {
    transform: translateX(-2px);
  }
}
.sdifl--service-icon--icon img {
  width: 100%;
  height: 100% !important;
  object-fit: contain;
}
.sdifl--service-icon--background {
  grid-row: 1;
  grid-column: 1/span 1;
  z-index: -1;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 1s 0.5s ease-in-out;
}
@media screen and (min-width: 1080px) {
  .sdifl--service-icon--background {
    transform: scale(0.9) translateX(-1px);
  }
}
.sdifl--service-icon--background img {
  width: 100%;
  height: 100% !important;
  object-fit: contain;
}
.sdifl .left-outline, .sdifl .right-outline {
  display: none;
}
@media screen and (min-width: 1080px) {
  .sdifl .left-outline, .sdifl .right-outline {
    display: block;
    grid-row: 1;
    grid-column: 1/span 2;
  }
}
.sdifl .left-outline svg, .sdifl .right-outline svg {
  width: 100%;
  height: 100%;
}
.sdifl .left-outline path, .sdifl .right-outline path {
  stroke: transparent !important;
  stroke-linecap: initial !important;
}
.sdifl .left-outline circle, .sdifl .right-outline circle {
  fill: var(--dot-color);
  opacity: 0;
  transition: opacity 1s 0.5s ease;
}
.sdifl .right-outline {
  display: none;
}