.feature-section-two {
  position: relative;
  padding: 50px 0 0;
  background: #0a192f;
  overflow: hidden;
}

.banner {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.arc {
  width: 50%;
  /* adjust arc width */
  height: 100%;
  position: absolute;
  right: 0;
  top: 0;
  transform: rotate(180deg);
  transform-origin: center;
}

.feature-section-two .auto-container {
  position: relative;
  z-index: 5;
}

@media (max-width: 350px) {
  .arc {
    width: 100% !important;
    height: 65%;
    /* arc height on mobile */
    right: 0;
    top: 49%;
    bottom: 0;
    left: 0;
    transform: rotate(-90deg);
    /* optional, to flip the curve */
    transform-origin: center;
  }
}

@media (min-width: 351px) and (max-width: 767px) {
  .arc {
    width: 100% !important;
    height: 62%;
    /* arc height on mobile */
    right: 0;
    top: 42%;
    bottom: 0;
    left: 0;
    transform: rotate(-90deg);
    /* optional, to flip the curve */
    transform-origin: center;
  }
}

strong {
  font-weight: bold;
  color: #64b5f6;
  text-decoration: underline;
}

/* Ribbon Tail Effect */

/* Must be visible for sticky */
.choose-section,
.choose-section .auto-container,
.choose-section .row {
  overflow: visible !important;
}

/* Sticky left */
@media (min-width: 992px) {
  .sticky-col {
    position: sticky;

    align-self: flex-start;
    /* important */
    z-index: 5;
  }

  /* Make right side taller so sticky has scroll space */
  .right-wrapper {
    position: relative;
  }
}



.page-wrapper {
  overflow: visible;
}

.main-footer .pattern-layer.style-two {
  background-position: left bottom;
  bottom: 0px;
}

.main-footer {
  margin-top: 0px;
}

.cta-box {
  border: solid 1px rgba(0, 0, 0, 0.2);
  padding: 30px 0px;
  background-color: #0a192f;
  margin-top: -100px;
}

@media (min-width: 992px) {
  .sticky-col {
    position: sticky;
    top: 120px;
    align-self: flex-start;
    /* important */
    z-index: 5;
  }

  /* Make right side taller so sticky has scroll space */
  .right-wrapper {
    position: relative;
  }
}

.page-wrapper {
  overflow: visible;
}

.threat {
  padding: 20px 10px;
  background: #f5f5f5;
  border: 1px solid rgba(0, 0, 0, 0.2);
}

.pillar-card {
  position: relative;
 
  border: 1px solid rgba(0, 0, 0, 0.3);
  padding: 20px 20px;
  border-radius: 16px;
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.pillar-number {
  position: absolute;
  top: 20px;
  right: 20px;
  font-size: 50px;
  font-weight: 700;
  color: #0a192f;
  opacity: 0.1;
}

.pillar-icon {
  width: 56px;
  margin-bottom: 20px;
}

.pillar-outcome {
  margin-top: 10px;
  padding-left: 12px;
  border-left: 3px solid #00b9f1;

  opacity: 0.9;
}

.innovation-icon {
  width: 50px;
}

   /* WRAPPER */
        .rings-wrapper {
            display: flex;
            flex-direction: column;
            align-items: center;
        }

        /* ITEM */
        .ring-item {
            text-align: center;

            position: relative;
        }

        /* RING */
        .ring {
            width: 140px;
            height: 140px;
            border: 2px solid rgba(47, 128, 237, 0.5);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            margin: 0 auto 30px;
            position: relative;
        }

        .ring-blue {
            border: 2px solid #3a8bff;
        }

        .ring-violet {
            border: 2px solid #b2d924;
            ;
        }

        .ring-teal {
            border: 2px solid #ff5ca7;
        }


        .ring::after {
            content: "";
            position: absolute;
            inset: 10px;
            border: 1px dashed rgba(0, 0, 0, 0.8);
            border-radius: 50%;
        }

        /* NUMBER */
        .ring-number {
            font-size: 32px;
            font-weight: 600;
            color: #2f80ed;
        }

        /* TITLES */


        /* DESCRIPTION */

        /* OUTCOME */
        .ring-outcome {
            padding-top: 14px;
            border-top: 1px solid rgba(255, 255, 255, 0.08);
        }

        .ring-outcome span {
            display: block;

            text-transform: uppercase;
            color: #2f80ed;
            margin-bottom: 6px;
        }



        /* CONNECTOR */
        .ring-connector {
            width: 2px;
            height: 60px;
            background: linear-gradient(to bottom,
                    rgba(47, 128, 237, 0.4),
                    rgba(47, 128, 237, 0.05));
            margin: 20px 0;
        }

        /* HOVER EFFECT */
        .ring-item:hover .ring {

            transform: scale(1.04);
            transition: 0.3s ease;
        }

        /* MOBILE */
        @media (max-width: 768px) {
            .ring {
                width: 120px;
                height: 120px;
            }

            .ring-item h3 {
                font-size: 22px;
            }
        }

        .zigzag-row {
            display: flex;
            align-items: stretch !important;
            /* force equal height */
        }

        .zig-card {
            height: 100%;
            display: flex;
            flex-direction: column;
            justify-content: center;
            border: solid 1px rgba(0, 0, 0, 0.5);
            padding: 25px 30px;
            border-radius: 10px;
            position: relative;
        }

        /* ICON CIRCLE */
        .zig-icon {
            width: 100px;
            height: 100px;
            border-radius: 50%;
            background: #faf9f6;
            border: 1px solid rgba(0, 0, 0, 0.5);
            position: absolute;
            left: 42%;
            transform: translateY(-50%);
            display: flex;
            align-items: center;
            justify-content: center;

            z-index: 10;
        }

        .zig-icon i {
            font-size: 20px;
            color: #27c0b5;
        }

        /* LEFT SIDE — icon on right edge of the card */

        .left-icon {
            top: 0px;
        }

        .zig-card h4 {
            margin-top: 30px;
            margin-bottom: 10px;
        }

        .zigzag-row .col-md-6 {
            margin-bottom: 70px;
        }
