#khp-1.khproducts { display:grid; gap:16px; grid-template-columns: repeat(3, minmax(0,1fr)); }
  @media (max-width: 900px) { #khp-1.khproducts { grid-template-columns: repeat(2, 1fr); } }
  @media (max-width: 520px) { #khp-1.khproducts { grid-template-columns: 1fr; } }

  /* karta */
  #khp-1 .kh-card { background:#fff; border:1px solid #eee; border-radius:12px; overflow:hidden; display:flex; flex-direction:column; transition:box-shadow .2s ease, transform .12s ease; }
  #khp-1 .kh-card:hover { box-shadow:0 8px 24px rgba(0,0,0,.08); transform: translateY(-1px); }
  #khp-1 .kh-img { position:relative; aspect-ratio: 4 / 3; background:#fafafa; }
  #khp-1 .kh-img img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
  #khp-1 .kh-body { padding:12px; display:flex; flex-direction:column; gap:8px; }
  #khp-1 .kh-name { font-size:14px; line-height:1.35; font-weight:600; color:#333; text-decoration:none; }
  #khp-1 .kh-name:hover { text-decoration:underline; }
  #khp-1 .kh-meta { display:flex; align-items:center; justify-content:space-between; gap:8px; flex-wrap:wrap; }
  #khp-1 .kh-price { font-weight:700; font-size:15px; color:#111; }
  #khp-1 .kh-avail { font-size:12px; color:#3a7f2f; }