.vnjp-cat-intro{
  max-width:1100px;
  margin:0 auto 18px;
  line-height:1.8;
}
.vnjp-cat-hero{
  display:grid;
  grid-template-columns:1.35fr .65fr;
  gap:14px;
  align-items:stretch;
  margin-bottom:14px;
}
.vnjp-cat-hero__text{
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding:16px 18px;
  box-shadow:0 4px 16px rgba(0,0,0,.05);
}
.vnjp-cat-hero__text h2{
  margin:0 0 6px;
  font-size:20px;
  line-height:1.35;
  color:#0f172a;
}
.vnjp-cat-hero__text p{
  margin:0;
  font-size:15.5px;
  color:#334155;
}
.vnjp-cat-hero__note{
  min-width:350px;
}

.vnjp-cat-tags{
  margin-top:10px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.vnjp-tag{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid #e5e7eb;
  background:#f8fafc;
  font-size:13px;
  color:#0f172a;
}
.vnjp-note{
  height:100%;
  background:#f8fafc;          /* nền xám rất nhạt */
  color:#0f172a;               /* chữ xanh đen học thuật */
  border-radius:16px;
  padding:18px 20px;
  border:1px solid #e5e7eb;
  box-shadow:0 6px 18px rgba(15,23,42,.08);
}

.vnjp-note__title{
  font-weight:700;
  font-size:15px;
  margin-bottom:8px;
  color:#0f172a;
}
.vnjp-note__list{ margin:0; padding-left:18px; }
.vnjp-note__list li{ margin:6px 0; font-size:14px; }

.vnjp-cat-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}
.vnjp-card{
  display:block;
  text-decoration:none !important;
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding:14px 14px 12px;
  box-shadow:0 3px 14px rgba(0,0,0,.05);
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.vnjp-card:hover{
  transform:translateY(-2px);
  border-color:#cbd5e1;
  box-shadow:0 10px 26px rgba(0,0,0,.10);
}
.vnjp-card__head{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:6px;
}
.vnjp-card__icon{ font-size:18px; line-height:1; }
.vnjp-card h3{ margin:0; font-size:16px; color:#0f172a; }
.vnjp-card p{ margin:0; color:#475569; font-size:14.8px; }
.vnjp-card__cta{
  display:inline-block;
  margin-top:8px;
  font-weight:600;
  font-size:14px;
  color:#0f172a;
}
@media (max-width:980px){
  .vnjp-cat-hero{ grid-template-columns:1fr; }
  .vnjp-cat-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:600px){
  .vnjp-cat-hero__text{ padding:14px; }
  .vnjp-cat-grid{ grid-template-columns:1fr; }
  .vnjp-cat-hero__text h2{ font-size:18px; }
}
