/* ============================================
   Projects page - hero section
   ============================================ */

.projects-hero {
  background: #02050a;
  overflow: hidden;
  position: relative;
}

.projects-hero .page-header-content {
  padding: 0;
}

.projects-hero-shapes {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.projects-shape {
  position: absolute;
}

.projects-shape-1 {
  top: 0;
  right: 0;
  opacity: 0.45;
}

.projects-shape-2 {
  bottom: -20px;
  left: -10px;
  opacity: 0.38;
}

.projects-shape-3 {
  top: 0;
  left: 0;
  opacity: 0.16;
}

.projects-hero-inner {
  display: flex;
  align-items: center;
  gap: 70px;
  min-height: 100vh;
  min-height: 100svh;
  padding: 140px 0 80px;
  position: relative;
  z-index: 1;
}

.projects-hero-text {
  flex: 1;
  min-width: 0;
}

.projects-hero-text .title {
  color: #fff;
  font-size: clamp(34px, 4.8vw, 68px);
  font-weight: 700;
  line-height: 1.08;
  margin-bottom: 20px;
}

.projects-hero-text .sub-title {
  font-size: 14px;
  font-weight: 400;
}

.projects-hero-text .sub-title a {
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
}

.projects-hero-text .sub-title a.inner-page {
  color: rgba(255, 255, 255, 0.88);
}

.projects-hero-text .sub-title a:not(.inner-page)::after {
  content: ">";
  margin: 0 8px;
  color: rgba(255, 255, 255, 0.28);
}

.projects-hero-visual {
  flex: 1.05;
  min-width: 0;
  min-height: 470px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.projects-orb {
  width: min(430px, 80vw);
  aspect-ratio: 1.08;
  border-radius: 28px;
  position: relative;
  display: grid;
  place-items: center;
  background:
    linear-gradient(135deg, rgba(63, 90, 243, 0.16), rgba(255, 194, 38, 0.08)),
    radial-gradient(circle at 22% 18%, rgba(63, 90, 243, 0.34), transparent 34%),
    radial-gradient(circle at 84% 78%, rgba(255, 194, 38, 0.18), transparent 34%),
    rgba(13, 17, 23, 0.58);
  box-shadow:
    0 35px 90px rgba(0, 0, 0, 0.45),
    inset 0 0 0 1px rgba(255, 255, 255, 0.09);
  animation: projectsOrbFloat 8s ease-in-out infinite;
  overflow: hidden;
}

.projects-orb::before,
.projects-orb::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.projects-orb::before {
  inset: 26px;
  border-radius: 22px;
  border: 1px solid rgba(63, 90, 243, 0.24);
  background:
    linear-gradient(rgba(255, 255, 255, 0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.06) 1px, transparent 1px);
  background-size: 58px 58px;
  opacity: 0.58;
}

.projects-orb::after {
  width: 38%;
  height: 56%;
  right: 34px;
  bottom: 30px;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), transparent 38%),
    rgba(2, 5, 10, 0.34);
  box-shadow: -70px -44px 0 -18px rgba(63, 90, 243, 0.2);
}

.projects-orb-core {
  width: 52%;
  min-height: 150px;
  border-radius: 20px;
  display: grid;
  place-content: center;
  text-align: center;
  background: rgba(13, 17, 23, 0.72);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 20px 55px rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(12px);
  position: relative;
  z-index: 1;
}

.projects-orb-core span {
  color: rgba(255, 255, 255, 0.55);
  font-size: 13px;
  letter-spacing: 0;
}

.projects-orb-core strong {
  color: #fff;
  font-size: clamp(18px, 2.2vw, 25px);
  line-height: 1.1;
}

.project-badge {
  position: absolute;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-height: 46px;
  padding: 10px 15px;
  color: rgba(255, 255, 255, 0.86);
  background: rgba(13, 17, 23, 0.82);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 8px;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(12px);
  font-size: 14px;
  font-weight: 600;
  white-space: nowrap;
}

.project-badge i {
  color: var(--rr-color-theme-primary);
  font-size: 15px;
}

.project-badge-1 {
  top: 12%;
  left: 3%;
  animation: projectFloatA 6s ease-in-out infinite;
}

.project-badge-2 {
  top: 18%;
  right: -2%;
  animation: projectFloatB 7s ease-in-out 0.5s infinite;
}

.project-badge-3 {
  left: -3%;
  bottom: 24%;
  animation: projectFloatB 7.5s ease-in-out 0.2s infinite;
}

.project-badge-4 {
  right: 5%;
  bottom: 16%;
  animation: projectFloatA 6.5s ease-in-out 0.8s infinite;
}

.project-badge-5 {
  left: 50%;
  bottom: 3%;
  transform: translateX(-50%);
  animation: projectFloatCenter 8s ease-in-out 0.4s infinite;
}

@keyframes projectsOrbFloat {
  0%, 100% { transform: translateY(0) scale(1); }
  50% { transform: translateY(-18px) scale(1.02); }
}

@keyframes projectFloatA {
  0%, 100% { transform: translateY(0) rotate(-2deg); }
  50% { transform: translateY(-13px) rotate(0deg); }
}

@keyframes projectFloatB {
  0%, 100% { transform: translateY(0) rotate(2deg); }
  50% { transform: translateY(-15px) rotate(0deg); }
}

@keyframes projectFloatCenter {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50% { transform: translateX(-50%) translateY(-12px); }
}

@media (max-width: 992px) {
  .projects-hero-inner {
    flex-direction: column;
    gap: 42px;
    min-height: auto;
    padding: 125px 0 65px;
  }

  .projects-hero-text {
    text-align: center;
  }

  .projects-hero-visual {
    width: 100%;
    min-height: 420px;
  }

  .project-badge-2 {
    right: 3%;
  }

  .project-badge-3 {
    left: 4%;
  }
}

@media (max-width: 600px) {
  .projects-hero-inner {
    padding: 115px 0 54px;
    gap: 30px;
  }

  .projects-hero-visual {
    min-height: 330px;
  }

  .projects-orb {
    width: min(280px, 76vw);
  }

  .project-badge {
    min-height: 38px;
    padding: 8px 10px;
    font-size: 12px;
  }

  .project-badge i {
    font-size: 13px;
  }

  .project-badge-1 {
    top: 8%;
    left: 0;
  }

  .project-badge-2 {
    top: 18%;
    right: 0;
  }

  .project-badge-3 {
    left: 0;
    bottom: 25%;
  }

  .project-badge-4 {
    right: 0;
    bottom: 18%;
  }

  .project-badge-5 {
    bottom: 0;
  }
}
