/**
 * Train & Validate - Flex Part Styles
 *
 * Structure per Figma:
 *   Card (704px in 2-col, padding 40px → 624px inner)
 *   └── card-inner (row, gap 20px)
 *       ├── icon (96×96)
 *       └── card-body (column, gap 20px)
 *           ├── title
 *           └── description
 */

.train-validate {
    padding: 80px 0;
}

/* Section Title - Centered H1 Heading */
.train-validate__section-title {
    color: var(--color-purple-dark, #1D004B);
    text-align: center;
    font: var(--font-h1);
    letter-spacing: var(--font-h1-spacing);
    margin-bottom: 40px;
}

/* Intro text */
.train-validate__intro {
    text-align: center;
    margin-bottom: 40px;
    font: var(--font-body-lg);
    color: var(--color-text);
}

.train-validate__intro h2 {
    color: var(--color-purple-dark, #1D004B);
    text-align: center;
    font: var(--font-h1);
    font-size: 56px;
    letter-spacing: var(--font-h1-spacing);
    margin: 0;
}

.train-validate__intro p {
    font: var(--font-body-lg);
    color: var(--color-text);
    margin: 0;
}

/* Grid: 2 cards side by side, 32px gap
   Math: card = calc(50% - 16px) where 16 = 32/2 */
.train-validate__grid {
    display: flex;
    flex-wrap: wrap;
    gap: 32px;
}

/* Card: padding 40px, inner content = width - 80px */
.train-validate__card {
    flex: 1 0 calc(50% - 16px);
    padding: 40px;
    border-radius: 8px;
    background: var(--color-white, #FFF);
    box-shadow: 0 4px 15px 3px rgba(39, 43, 43, 0.08);
    align-self: stretch;
}

/* Inner row: icon + body side by side
   Figma: 96px icon + 20px gap + remaining = body */
.train-validate__card-inner {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 20px;
}

/* Icon: fixed 96×96 */
.train-validate__icon {
    display: flex;
    width: 96px;
    height: 96px;
    min-width: 96px;
    justify-content: center;
    align-items: center;
    flex-shrink: 0;
}

.train-validate__icon img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

/* Body column: title + description stacked
   Takes remaining space next to icon */
.train-validate__card-body {
    display: flex;
    flex-direction: column;
    gap: 20px;
    flex: 1;
}

/* Title - H2 */
.train-validate__title {
    color: var(--color-purple-dark, #1D004B);
    font: var(--font-h2);
    letter-spacing: var(--font-h2-spacing);
    margin: 0;
}

/* Description - Body Large */
.train-validate__desc {
    color: var(--color-text, #000);
    font: var(--font-body-lg);
}

.train-validate__desc p {
    margin: 0;
}

.train-validate__desc p + p {
    margin-top: 16px;
}

/* CTA */
.train-validate__cta {
    text-align: center;
    margin-top: 40px;
}

/* Responsive */
@media (max-width: 1024px) {
    .train-validate__card {
        flex: 1 0 100%;
        padding: 30px 20px;
    }
}

@media (max-width: 768px) {
    .train-validate {
        padding: 60px 0;
    }

    .train-validate__section-title {
        font: var(--font-h2);
        letter-spacing: var(--font-h2-spacing);
        margin-bottom: 30px;
    }

    .train-validate__intro h2 {
        font: var(--font-h2);
        letter-spacing: var(--font-h2-spacing);
    }

    .train-validate__icon {
        width: 96px;
        height: 96px;
        min-width: 96px;
    }

    /* Card title - 26px/600 per Figma mobile */
    .train-validate__title {
        font-family: "Funnel Sans", sans-serif;
        font-size: 26px;
        font-weight: 600;
        line-height: 120%;
    }

    /* CTA button - full width on mobile */
    .train-validate__cta .btn {
        width: 100%;
        font-size: 22px;
    }
}
