.hero {
  padding-top: 56px;
  height: 100vh;
  max-height: 800px;
  min-height: 620px;
  display: flex;
  align-items: center;
  color: #fff;
  background: linear-gradient(
    90deg,
    rgba(0, 47, 108, 0.95) 0%,
    rgba(0, 76, 154, 0.9) 60%
  );
  position: relative;
  overflow: hidden;
}

.hero .left {
  padding: 2rem;
}

.hero h1 {
  color: #fff;
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  line-height: 1.1;
  text-shadow: 0 3px 8px rgba(0, 0, 0, 0.3);
}

.hero .lead {
  font-size: 1.05rem;
  color: #e7f2ff;
  margin-bottom: 1rem;
}

.typed {
  color: #fff;
  font-weight: 600;
}

.hero .computer-screen {
  background-image: url(../images/Computer-Screen.png);
  width: 350px;
  height: 300px;
  background-size: cover;
  overflow: hidden;
  padding: 28px 19px;
}

.hero .computer-screen .carousel-item::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  background-color: #71c55455;
}

.hero .computer-screen .carousel-item .carousel-caption {
  width: 100%;
  padding-bottom: 0;
  padding-top: 0;
  top: 20%;
  left: 50%;
  bottom: auto;
  right: 0;
  transform: translate(-50%, 0);
}

.hero .computer-screen .carousel-item .carousel-caption .carousel-caption-text {
  background-color: #ffffffcc;
  padding: 15px;
}

.hero .computer-screen .carousel-item .carousel-caption h6 {
  color: var(--brand-900);
}

.hero .computer-screen .carousel-item .carousel-caption ul li {
  text-align: left;
  font-size: small;
  color: var(--brand-900);
}
