.ag-shared-customized-title {
  --customized-title-flow-duration: 3.6s;
  --shared-title-section-gap: var(--section-gap, clamp(56px, 7vw, 110px));
}

.ag-shared-customized-title.framework-banner {
  position: relative;
  z-index: 2;
  width: min(calc(100% - 130px), 1360px);
  margin: calc(var(--shared-title-section-gap) - 40px) auto calc(var(--shared-title-section-gap) * 0.6);
  padding: clamp(22px, 3.4vw, 40px) clamp(20px, 4.2vw, 66px);
  border-radius: 14px;
}

.ag-shared-customized-title .framework-banner__title {
  text-align: center;
  text-transform: uppercase;
  font-size: 55px;
  line-height: 1.05;
  font-weight: 800;
  letter-spacing: 0.03em;
  background: linear-gradient(90deg, #E8383B 0%, #5983BC 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
  width: fit-content;
  margin: 0 auto;
}

.ag-shared-customized-title .framework-banner__title.reverse {
  background-image: linear-gradient(90deg, #5983BC 0%, #E8383B 100%);
}

.ag-shared-customized-title .framework-banner__title.plain__text {
  background: none;
  color: #FFFFFF;
  font-weight: 700;
  -webkit-text-fill-color: #FFFFFF;
  -webkit-background-clip: border-box;
  background-clip: border-box;
  margin-bottom: 16px;
}

.ag-shared-customized-title .framework-banner__divider {
  width: 85%;
  height: 1px;
  margin: clamp(14px, 1.8vw, 26px) auto clamp(14px, 2vw, 28px);
  background: rgba(255, 255, 255, 0.9);
}

.ag-shared-customized-title .customized-title__divider {
  width: 100%;
  margin: clamp(4px, 1.8vw, 8px) auto clamp(4px, 2vw, 8px);
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.ag-shared-customized-title .customized-title__divider.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.ag-shared-customized-title .plain__text,
.ag-shared-customized-title .customized-title-reveal {
  visibility: hidden;
}

.ag-shared-customized-title .customized-title-visible {
  visibility: visible !important;
}

.ag-shared-customized-title .customized-title-type-slot {
  position: relative;
  display: inline-block;
  min-width: 0;
  white-space: nowrap;
  --customized-title-cursor-fill: #FFFFFF;
}

.ag-shared-customized-title .customized-title-type-line {
  position: relative;
  display: block;
  width: fit-content;
  margin: 0 auto;
}

.ag-shared-customized-title .customized-title-type-line + .customized-title-type-line {
  margin-top: 0.02em;
}

.ag-shared-customized-title .customized-title-reveal .customized-title-type-slot,
.ag-shared-customized-title .customized-title-reveal .customized-title-type-line {
  background-image: var(--customized-title-static-gradient);
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: 100% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

.ag-shared-customized-title .customized-title-reveal--framework .customized-title-type-slot {
  --customized-title-cursor-fill: linear-gradient(90deg, #E8383B 0%, #5983BC 100%);
}

.ag-shared-customized-title .customized-title-reveal--work .customized-title-type-slot {
  --customized-title-cursor-fill: linear-gradient(90deg, #5983BC 0%, #E8383B 100%);
}

.ag-shared-customized-title .plain__text .customized-title-type-slot,
.ag-shared-customized-title .plain__text .customized-title-type-line {
  background: none;
  color: #FFFFFF;
  -webkit-text-fill-color: #FFFFFF;
  -webkit-background-clip: border-box;
  background-clip: border-box;
}

.ag-shared-customized-title .customized-title-reveal {
  --customized-title-static-gradient: linear-gradient(90deg, #E8383B 0%, #5983BC 100%);
  --customized-title-flow-gradient: linear-gradient(90deg, #E8383B 0%, #5983BC 25%, #E8383B 50%, #5983BC 75%, #E8383B 100%);
  background-image:
    linear-gradient(90deg, #FFFFFF 0%, #FFFFFF 100%),
    var(--customized-title-static-gradient);
  background-repeat: no-repeat;
  background-position: 0 0, 0 0;
  background-size: 100% 100%, 100% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

.ag-shared-customized-title .customized-title-reveal.reverse,
.ag-shared-customized-title .customized-title-reveal--work {
  --customized-title-static-gradient: linear-gradient(90deg, #5983BC 0%, #E8383B 100%);
  --customized-title-flow-gradient: linear-gradient(90deg, #5983BC 0%, #E8383B 25%, #5983BC 50%, #E8383B 75%, #5983BC 100%);
}

.ag-shared-customized-title .customized-title-reveal.is-flowing .customized-title-type-line {
  background-image: var(--customized-title-flow-gradient);
  background-repeat: repeat;
  background-position: 0 0;
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  will-change: background-position;
  animation: ag-shared-customized-title-gradient-flow var(--customized-title-flow-duration) linear infinite;
}

.ag-shared-customized-title .customized-title-cursor::before {
  content: "_";
  position: absolute;
  left: calc(100% + 0.04em);
  bottom: -0.02em;
  color: transparent;
  background: var(--customized-title-cursor-fill);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  pointer-events: none;
  animation: ag-shared-customized-title-caret 0.9s steps(1, end) infinite;
}

@keyframes ag-shared-customized-title-caret {
  0%,
  49% {
    opacity: 1;
  }

  50%,
  100% {
    opacity: 0;
  }
}

@keyframes ag-shared-customized-title-gradient-flow {
  0% {
    background-position: 0 0;
  }

  100% {
    background-position: 100% 0;
  }
}

@media (max-width: 900px) {
  .ag-shared-customized-title.framework-banner {
    z-index: 4;
    width: calc(100% - 40px);
    margin: 10px auto 28px;
    padding: 18px 14px 20px;
    border-radius: 12px;
  }

  .ag-shared-customized-title .framework-banner__title {
    font-size: clamp(25px, 8.6vw, 36px);
    letter-spacing: 0.025em;
  }

  .ag-shared-customized-title .customized-title-reveal--framework {
    line-height: 0.96;
  }

  .ag-shared-customized-title .customized-title__divider {
    width: calc(100% - 24px);
  }
}
