.prj{
  padding: 72px 0;
}

.prj-head{
  max-width: 820px;
  margin-bottom: 22px;
}

.prj-title{
  margin: 12px 0 10px;
  font-size: clamp(22px, 2.8vw, 34px);
  line-height: 1.15;
}

.prj-sub{
  margin: 0;
  opacity: 0.9;
  line-height: 1.6;
}

/* FEATURED PROJECT CARD */
.prj-featured{
  margin-top: 32px;
}

.featured-card{
  display: block;
  text-decoration: none;
  color: inherit;
  position: relative;
  overflow: hidden;
  border-radius: 20px;
  padding: 28px 32px;
  border: 1px solid rgba(72,170,255,0.18);
  background:
    linear-gradient(135deg, rgba(72,170,255,0.08), rgba(60,255,180,0.04) 60%, rgba(124,92,255,0.06));
  backdrop-filter: blur(12px);
  transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease;
  cursor: pointer;
}

.featured-card::before{
  content:"";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  background:
    radial-gradient(300px 150px at 20% 30%, rgba(72,170,255,0.15), transparent 60%),
    radial-gradient(250px 150px at 80% 70%, rgba(60,255,180,0.10), transparent 55%);
  opacity: 0;
  transition: opacity .3s ease;
  pointer-events: none;
}

.featured-card:hover{
  transform: translateY(-4px);
  border-color: rgba(72,170,255,0.32);
  box-shadow:
    0 16px 48px rgba(0,0,0,0.3),
    0 0 0 1px rgba(72,170,255,0.08);
}

.featured-card:hover::before{
  opacity: 1;
}

.featured-badge{
  display: inline-flex;
  padding: 5px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .3px;
  color: #0a0e19;
  background: linear-gradient(90deg, var(--blue), var(--green));
  margin-bottom: 14px;
}

.featured-content{
  position: relative;
  z-index: 1;
}

.featured-name{
  margin: 0 0 8px;
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 800;
  background: linear-gradient(90deg, #ffffff, rgba(72,170,255,0.95));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.featured-desc{
  margin: 0 0 16px;
  opacity: 0.85;
  line-height: 1.6;
  max-width: 56ch;
}

.featured-link{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  color: var(--blue);
  transition: gap .2s ease;
}

.featured-card:hover .featured-link{
  gap: 14px;
}

@media (max-width: 520px){
  .featured-card{
    padding: 20px 18px;
  }
}

/* BRAND CAROUSEL */
.prj-brands{
  margin-top: 32px;
  position: relative;
  overflow: hidden;
  padding: 10px 0;
}

.prj-brands::before,
.prj-brands::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width: 110px;
  z-index: 3;
  pointer-events:none;
}

.prj-brands::before{
  left:0;
  background: linear-gradient(to right, rgba(10,14,25,1), rgba(10,14,25,0));
}

.prj-brands::after{
  right:0;
  background: linear-gradient(to left, rgba(10,14,25,1), rgba(10,14,25,0));
}

.prj-brands-track{
  display:flex;
  align-items:center;
  gap: 22px;
  width:max-content;
  padding: 18px 6px;
  animation: prjBrandsScroll 24s linear infinite;
  will-change: transform;
}

.prj-brands.paused .prj-brands-track{
  animation-play-state: paused;
}

.brand-card{
  position: relative;
  display:flex;
  align-items:center;
  justify-content:center;

  width: 170px;
  height: 78px;
  border-radius: 16px;

  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 10px 26px rgba(0,0,0,0.22),
    inset 0 1px 0 rgba(255,255,255,0.08);

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  transform: translateZ(0);
  transition: transform .25s ease, border-color .25s ease, background .25s ease, box-shadow .25s ease;
  text-decoration: none;
  cursor: default;
}

.brand-card::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius: inherit;
  background:
    radial-gradient(120px 60px at 30% 30%, rgba(72,170,255,0.18), transparent 65%),
    radial-gradient(140px 70px at 70% 70%, rgba(60,255,180,0.12), transparent 60%);
  opacity: 0;
  transition: opacity .25s ease;
  pointer-events:none;
}

.brand-card img{
  height: 38px;
  width: auto;
  opacity: 0.75;
  filter: grayscale(1);
  transition: opacity .25s ease, filter .25s ease, transform .25s ease;
}

.brand-card:hover{
  transform: translateY(-4px) scale(1.07);
  background: rgba(255,255,255,0.09);
  border-color: rgba(72,170,255,0.22);
  box-shadow:
    0 16px 36px rgba(0,0,0,0.28),
    0 0 0 1px rgba(72,170,255,0.08),
    inset 0 1px 0 rgba(255,255,255,0.10);
}

.brand-card:hover::before{
  opacity: 1;
}

.brand-card:hover img{
  opacity: 1;
  filter: grayscale(0);
  transform: scale(1.05);
}

.prj-brands-track:hover .brand-card:not(:hover){
  transform: scale(0.96);
  opacity: 0.85;
}

@keyframes prjBrandsScroll{
  from{ transform: translateX(0); }
  to{ transform: translateX(-50%); }
}

@media (max-width: 520px){
  .prj-brands-track{
    gap: 14px;
    animation-duration: 20s;
  }

  .brand-card{
    width: 140px;
    height: 68px;
    border-radius: 14px;
  }

  .brand-card img{
    height: 32px;
  }

  .prj-brands::before,
  .prj-brands::after{
    width: 80px;
  }
}

@media (prefers-reduced-motion: reduce){
  .prj-brands-track{
    animation: none;
  }
}
