.card { border: 1px solid #e2e8f0; border-radius: 0.5rem; background: #FDFDFD; box-shadow: 0 1px 2px rgba(0,0,0,.05), 0 1px 1px rgba(0,0,0,.04); }
.card__header, .card__footer { padding: 0.75rem 1rem; border-bottom: 1px solid #e2e8f0; }
.card__footer { border-bottom: 0; border-top: 1px solid #e2e8f0; display: flex; gap: 0.5rem; justify-content: flex-end; }
.card__body { 
    padding: 1rem;
    padding-top: 0;
    padding-bottom: 2rem;
    display:flex;
    flex-direction:column;
    gap:1.25rem;
    flex:1 1 auto;
}
.card__title { margin: 0; font-size: var(--fs-300); }

.card__body > .btn-full{
  margin-top:auto;          /* push CTA to bottom */
  align-self:stretch;       /* keep full width */
}

/* Divider between first paragraph and subtitle with 24px spacing above/below the line */
.card--training .card__body > p:first-of-type + .card__subtitle{
    border-top:1px solid #e2e8f0;
    margin-top: .25rem;   /* space above the divider */
    padding-top: 1.5rem;  /* space below the divider (before the h4 text) */
}

.card--training .card__body > p:first-of-type {
    margin-bottom: 0;
}

/* Training card variant with 1.5px border and icon list */
.card--training { 
    border-width: 1.5px;
    max-width: 600px;
    min-height: 904px;
    display: flex;
    flex-direction: column;
    height: 100%;

    @media (min-width: 720px) {
        min-height: 850px;
    }

    @media (min-width: 901px) {
        min-height: 966px;
    }

    @media (min-width: 990px) {
        min-height: 909px;
    }

}
.card__subtitle { 
margin: 0.75rem 0 0.5rem; 
font-family: 'Roboto', sans-serif;
font-size: 1rem;
line-height: 1.250;
font-weight: bold !important;
color: #2B3841; 
}
.icon-list { list-style: none; padding: 0; display: grid; gap: .75rem; }
.icon-list__item { 
display: grid; grid-template-columns: 1.25rem 1fr; gap: .5rem; align-items: start;
font-family: 'Roboto', sans-serif;
font-size: 1rem;
line-height: 1.250;
font-weight: 400;
}
.icon-list__icon { margin-top: .1rem; }
.icon { width: 1rem; height: 1rem; display: inline-block; }
.btn-full { width: 100%; justify-content: center; }

/* Consistent media ratio for card images */
.card__img { 
    flex:0 0 auto; 
    display: block; 
    width: 100%; 
    height: auto; 
    object-fit:cover; 
    padding:2rem; 
    aspect-ratio:16/9; 
    border-radius: 40px; }



.training-cards {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    align-items: stretch;
    gap: 1rem;
    margin-block: 1.5rem;
    margin-bottom: 4.25rem;
    transform: unset;
    padding: 0 1.25rem;

    @media (min-width: 768px) {
        transform: translateY(-64px);
        margin-bottom: 1.25rem;
    }

    @media (min-width: 1280px) {
        padding: unset;
    }
}
.training-cards > * {
flex: 1 1 calc(50% - 1rem);
max-width: calc(50% - 1rem);
}
@media (max-width: 900px) {
.training-cards { gap: 4rem; justify-content: center; }
.training-cards > * { flex-basis: 100%; max-width: 100%; }
}


/* Polish CSS */
:root{--ease:cubic-bezier(.22,.61,.36,1)}

.card{transition:transform .35s var(--ease),box-shadow .35s var(--ease);will-change:transform}
.card:hover{transform:translateY(-6px);box-shadow:0 10px 20px rgba(0,0,0,.12),0 4px 8px rgba(0,0,0,.08)}
/* .card:focus-within{outline:2.5px solid #0067E7;outline-offset:3px} */

.card:focus:not(:focus-visible) {
    outline: none !important;
}

.card__img{transition:transform .6s var(--ease)}
.card:hover .card__img{transform:scale(1.02)}

.card--training{position:relative;overflow:hidden}
.card--training:hover::after{transform:scaleY(1);opacity:1}

.icon-list__item{transition:transform .25s var(--ease)}
.card:hover .icon-list__item{transform:translateX(2px)}
.icon{transition:filter .3s var(--ease),transform .3s var(--ease)}
.card:hover .icon{filter:brightness(1.08) saturate(1.2);transform:translateY(-1px)}

/* .btn-full{transition:transform .25s var(--ease)} */
.card:hover .btn-full{transform:translateY(2px)}

@media (prefers-reduced-motion:reduce){
.card,.card__img,.card--training::after,.icon,.icon-list__item,.btn-full{transition:none}
}