.catalog-wrap { --brand:#b40000; }
  .catalog-wrap .intro { margin-bottom: 1.25rem; }

  .catalog-wrap .grid{
    display:grid;
    gap:24px;
    grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  }
  .catalog-wrap .card-prod{
    position:relative;
    border:1px solid rgba(0,0,0,.08);
    border-radius:14px;
    background:#fff;
    overflow:hidden;
    transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
    height:100%;
    display:flex;
    flex-direction:column;
  }
  .catalog-wrap .card-prod:hover{
    transform:translateY(-2px);
    box-shadow:0 10px 24px rgba(0,0,0,.08);
    border-color:rgba(0,0,0,.12);
  }

  .catalog-wrap .p-media{ padding:18px 18px 0 18px; }
  .catalog-wrap .img-wrap{
    aspect-ratio:4/3;
    background:linear-gradient(180deg,#fafafa,#f5f5f5);
    border-radius:10px;
    display:grid;
    place-items:center;
    overflow:hidden;
  }
  /* keep images sharp (no stretching) */
  .catalog-wrap .p-media img{
    width:auto; height:auto;
    max-width:100%; max-height:100%;
    object-fit:contain;
  }

  .catalog-wrap .p-body{
    padding:16px 18px 18px 18px;
    display:flex; flex-direction:column;
  }
  .catalog-wrap .p-title{ font-size:1.1rem; margin:0 0 .25rem 0; line-height:1.2; }
  .catalog-wrap .p-kicker{ margin:0 0 .35rem 0; font-weight:600; color:#333; }
  .catalog-wrap .p-desc{
    color:#555; font-size:.95rem; margin:0 0 .9rem 0;
    min-height:3.8em; /* keeps rows tidy; adjust if needed */
  }

  .catalog-wrap .btn-brand{
    align-self:flex-start;
    --bs-btn-bg:var(--brand);
    --bs-btn-border-color:var(--brand);
    --bs-btn-hover-bg:#8b0000;
    --bs-btn-hover-border-color:#8b0000;
    --bs-btn-color:#fff;
    margin-top:auto; /* pins button to bottom */
  }
  .catalog-wrap .btn .chev{ transition:transform .15s ease; }
  .catalog-wrap .btn:hover .chev{ transform:translateX(2px); }
  
  
  /* Card + body are flex columns */
.catalog-wrap .card-prod{
  display:flex;
  flex-direction:column;
  height:100%;
}

.catalog-wrap .p-body{
  display:flex;
  flex-direction:column;
  flex:1 1 auto;   /* take remaining height */
}

/* Text spacing */
.catalog-wrap .p-kicker{
  margin:0 0 .25rem 0;
  color:#333;
  font-weight:600;
  font-size:.96rem;
}

/* Let the text area take space, then pin CTA to bottom */
.catalog-wrap .p-desc{
  margin:0 0 10px 0;        /* no extra gap needed */
  color:#555;
  font-size:.95rem;
  flex:1 1 auto;   /* grows to fill, pushes the button down */
}

/* The CTA sits at the bottom of the card body */
.catalog-wrap .btn-brand{
  margin-top:auto;           /* <- this is the key line */
  align-self:flex-start;
    font-weight: 600;
}
.catalog-wrap .btn-brand:hover {color:#fff;}