.portfolio-hero{
  position:relative;
  min-height:78vh;
  padding:clamp(96px,8vw,100px) 0;
  background:linear-gradient(to right,#001351,#003f7c);
  color:#fff;
  overflow:hidden
}

.portfolio-hero__canvas{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  pointer-events:none
}

.portfolio-shell{
  position:relative;
  z-index:1;
  width:min(1180px,calc(100% - 48px));
  margin:0 auto;
  display:grid;
  gap:clamp(28px,4vw,44px)
}

.portfolio-intro{
  max-width:900px;
  margin:0 auto;
  padding:clamp(28px,3vw,36px);
  border-radius:20px;
  background:rgba(0,0,0,.28);
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 30px 90px rgba(0,0,0,.35);
  backdrop-filter:blur(10px);
  text-align:center;
  display:grid;
  gap:14px;
  justify-items:center
}

.portfolio-title{
  font-size:clamp(44px,5vw,64px);
  line-height:1.05;
  font-weight:900;
  letter-spacing:-.03em;
  margin:0
}

.portfolio-lede{
  max-width:60ch;
  line-height:1.7;
  font-weight:600;
  color:rgba(255,255,255,.85);
  margin:0
}

.portfolio-content{
  width:min(1040px,100%);
  margin:0 auto;
  background:#fff;
  color:#0b1f3a;
  border-radius:22px;
  padding:clamp(28px,4vw,40px);
  box-shadow:0 26px 70px rgba(0,0,0,.25)
}

.portfolio-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:22px
}

.portfolio-card{
  display:grid;
  gap:14px;
  border-radius:18px;
  overflow:hidden;
  background:#fff;
  border:1px solid rgba(11,31,58,.10);
  box-shadow:0 14px 36px rgba(0,0,0,.18)
}

.portfolio-card__media{
  position:relative;
  aspect-ratio:16/10;
  overflow:hidden
}

.portfolio-card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 320ms ease
}

.portfolio-card:hover .portfolio-card__media img{
  transform:scale(1.03)
}

.portfolio-card__body{
  padding:16px;
  display:grid;
  gap:10px
}

.portfolio-card__title{
  margin:0;
  font-size:18px;
  font-weight:900;
  letter-spacing:-.01em
}

.portfolio-card__desc{
  margin:0;
  line-height:1.6;
  color:rgba(11,31,58,.78)
}



@media(max-width:900px){
  .portfolio-grid{
    grid-template-columns:1fr
  }
}
