@layer components {
  .ka-vt {
    container-type: inline-size;
    container-name: ka-vt;
    background: var(--bg-surface);
  }

  .ka-vt__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-xl);
  }

  .ka-vt__card {
    display: flex;
    flex-direction: column;
    gap: var(--space-m);
    padding: var(--space-xl);
    background: var(--bg-body);
    border: 1px solid var(--border-primary);
    border-radius: var(--radius-l);
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
  }

  .ka-vt__card:hover {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--primary-10);
  }

  .ka-vt__card-content {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
  }

  .ka-vt__card-title {
    font-size: var(--text-l);
    font-weight: var(--weight-semibold);
    color: var(--text-title);
    line-height: 1.3;
  }

  .ka-vt__card-text {
    font-size: var(--text-s);
    color: var(--text-body);
    line-height: 1.7;
  }

  @container ka-vt (max-width: 968px) {
    .ka-vt__grid {
      grid-template-columns: repeat(2, 1fr);
    }
  }

  @container ka-vt (max-width: 640px) {
    .ka-vt__grid {
      grid-template-columns: 1fr;
      gap: var(--space-l);
    }
  }

  @container ka-vt (max-width: 480px) {
    .ka-vt__card {
      padding: var(--space-l);
    }
  }
}
