.kbv-team{
  --kbv-accent:#69B43A;
  --kbv-cols-desktop:5;
  --kbv-cols-tablet:3;
  --kbv-cols-mobile:2;
  --kbv-gap-desktop:22px;
  --kbv-gap-mobile:18px;
  padding:24px 0 48px;
}

.kbv-team *{box-sizing:border-box;}

.kbv-team-head{
  max-width:1100px;
  margin:0 auto 18px;
  padding:0 16px;
  text-align:center;
}

.kbv-team-title{
  margin:0;
  font-size:40px;
  line-height:1.1;
  font-weight:750;
  color:#0f172a;
}

.kbv-team-accent{
  width:86px;
  height:4px;
  border-radius:999px;
  background:var(--kbv-accent);
  margin:12px auto 0;
}

.kbv-team-desc{
  max-width:860px;
  margin:14px auto 0;
  background:#f8fafc;
  border:1px solid #e2e8f0;
  border-radius:16px;
  padding:14px 16px;
  color:#334155;
  font-size:15px;
  line-height:1.6;
  text-align:left;
}

.kbv-team-desc p{margin:0;}
.kbv-team-desc p + p{margin-top:10px;}

.kbv-grid{
  max-width:1200px;
  margin:0 auto;
  padding:0 16px;
  display:grid;
  grid-template-columns:repeat(var(--kbv-cols-desktop), minmax(0, 1fr));
  gap:var(--kbv-gap-desktop);
}

@media (max-width:1024px){
  .kbv-team-title{font-size:34px;}
  .kbv-grid{
    grid-template-columns:repeat(var(--kbv-cols-tablet), minmax(0, 1fr));
    gap:var(--kbv-gap-mobile);
  }
}

@media (max-width:640px){
  .kbv-team-title{font-size:30px;}
  .kbv-grid{
    grid-template-columns:repeat(var(--kbv-cols-mobile), minmax(0, 1fr));
    gap:var(--kbv-gap-mobile);
    padding:0 14px;
  }
  .kbv-team-desc{padding:12px 14px;}
}

.kbv-card{
  position:relative;
  padding-bottom:86px;
}

.kbv-media{
  position:relative;
  overflow:hidden;
  border-radius:26px;
  aspect-ratio:4 / 5;
  background:linear-gradient(135deg,
      hsl(var(--kbv-h1, 130) 75% 46%),
      hsl(var(--kbv-h2, 210) 75% 42%)
  );
  box-shadow:0 26px 58px rgba(2,6,23,.16);
  transform:translateZ(0);
  transition:transform .25s ease, box-shadow .25s ease;
}

.kbv-media::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:var(--kbv-img);
  background-size:cover;
  background-position:center;
  opacity:0;
  transform:scale(1);
  filter:none;
  transition:opacity .25s ease, transform .35s ease, filter .35s ease;
}

.kbv-media.has-image::before{opacity:1;}

.kbv-media::after{
  content:"";
  position:absolute;
  inset:0;
  background-image:var(--kbv-hover-img);
  background-size:cover;
  background-position:center;
  opacity:0;
  transform:scale(1);
  filter:none;
  transition:opacity .25s ease, transform .35s ease, filter .35s ease;
}

.kbv-dot{
  position:absolute;
  top:14px;
  left:14px;
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--kbv-accent);
  box-shadow:0 0 0 6px rgba(255,255,255,.18);
  z-index:6;
}

.kbv-placeholder{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:#fff;
  z-index:5;
  padding:18px 14px;
}

.kbv-initials{
  font-size:66px;
  line-height:1;
  font-weight:850;
  letter-spacing:.02em;
}

.kbv-pl-name{
  margin-top:10px;
  font-weight:750;
  letter-spacing:.08em;
  text-transform:uppercase;
  opacity:.92;
}

.kbv-pl-first{font-size:13px;}
.kbv-pl-last{font-size:13px;margin-top:4px;}

.kbv-info{
  position:absolute;
  left:16px;
  right:16px;
  bottom:10px;
  background:#fff;
  border-radius:18px;
  padding:14px 14px 12px;
  text-align:center;
  box-shadow:0 20px 55px rgba(2,6,23,.20);
  z-index:10;
}

.kbv-name{
  font-size:18px;
  font-weight:750;
  color:var(--kbv-accent);
  line-height:1.15;
}

.kbv-role{
  margin-top:6px;
  font-size:13px;
  color:#64748b;
  line-height:1.35;
}

.kbv-card:hover .kbv-media{
  transform:translateY(-4px);
  box-shadow:0 30px 70px rgba(2,6,23,.22);
}

.kbv-card:hover .kbv-media::before{
  transform:scale(1.04);
  filter:saturate(1.05) contrast(1.05);
}

.kbv-card.has-hover:hover .kbv-media::before{opacity:0;}
.kbv-card.has-hover:hover .kbv-media::after{
  opacity:1;
  transform:scale(1.04);
  filter:saturate(1.05) contrast(1.05);
}

@media (max-width:640px){
  .kbv-card{padding-bottom:92px;}
  .kbv-info{left:12px;right:12px;bottom:8px;padding:12px 12px 10px;}
  .kbv-name{font-size:16px;}
  .kbv-role{font-size:12px;}
  .kbv-initials{font-size:58px;}
}
