/* ── Training detail CTA inline form ── */
.page-cta:has(.training-cta-form) {
    background: linear-gradient(180deg, var(--bg) 0%, var(--bg-elevated) 100%);
}

body[data-training-detail="c-level"] {
    --service-color: var(--purple-soft);
    --service-color-20: var(--purple-soft-20);
    --service-color-15: var(--purple-soft-15);
    --service-color-08: var(--purple-soft-08);
    --service-ink: var(--sa-white);
    --service-fill: var(--purple-soft-fill);
    --service-fill-ink: var(--sa-white);
}

[data-training-detail] .training-day-grid {
    grid-template-columns: 1fr;
}

@media (min-width: 700px) {
    [data-training-detail] .training-day-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (min-width: 1280px) {
    [data-training-detail] .training-day-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

body[data-training-detail="ai-introductie"],
body[data-training-detail="m365-copilot"] {
    --service-color: var(--accent);
    --service-color-20: var(--accent-20);
    --service-color-15: var(--accent-15);
    --service-color-08: var(--accent-08);
    --service-ink: var(--accent-ink);
    --service-fill: var(--accent);
    --service-fill-ink: var(--accent-ink);
}

.training-cta-form {
    max-width: 560px;
    margin: 32px auto 0;
    text-align: left;
}

.training-cta-form .btn {
    width: 100%;
    box-shadow: none;
}

.training-cta-form textarea {
    min-height: 80px;
}

.training-followup-stack {
    max-width: 940px;
    margin: 0 auto;
}

.training-recommendation-note {
    padding: 18px 22px 18px 24px;
    border: 1px solid var(--border-strong);
    border-left: 4px solid var(--service-color, var(--accent));
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.03);
}

.training-followup-copy {
    margin: 0;
    color: var(--fg-muted);
    line-height: 1.6;
    font-size: clamp(1rem, 0.96rem + 0.45vw, 1.22rem);
    text-align: left;
}

.training-next-step-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 18px;
    margin-top: 18px;
    padding: 28px 24px;
    border: 1px solid var(--service-color-20, var(--accent-20));
    border-radius: 24px;
    background:
        linear-gradient(135deg, var(--service-color-15, var(--accent-15)) 0%, var(--service-color-08, var(--accent-08)) 42%, rgba(255, 255, 255, 0.02) 100%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
    color: inherit;
    text-decoration: none;
    transition:
        transform 0.18s ease,
        border-color 0.18s ease,
        box-shadow 0.18s ease;
}

a.training-next-step-card:hover {
    transform: translateY(-2px);
    border-color: var(--service-color, var(--accent));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.03),
        0 18px 40px rgba(0, 0, 0, 0.18);
}

.training-next-step-title {
    margin: 10px 0 0;
    color: var(--fg);
    font-size: clamp(1.35rem, 1.15rem + 1vw, 2rem);
    font-weight: 500;
    line-height: 1.25;
    text-wrap: balance;
}

.training-next-step-arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 999px;
    border: 1px solid var(--service-color-20, var(--accent-20));
    color: var(--service-color, var(--accent));
    background: rgba(255, 255, 255, 0.03);
    font-size: 0.95rem;
    font-weight: 700;
}

a.training-next-step-card:hover .training-next-step-arrow {
    color: var(--service-fill-ink, var(--service-ink, var(--accent-ink)));
    background: var(--service-fill, var(--service-color, var(--accent)));
    border-color: var(--service-fill, var(--service-color, var(--accent)));
}

@media (min-width: 760px) {
    .training-next-step-card {
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
        padding: 30px 32px;
    }
}

/* ── Fixed PDF download FAB ── */
.training-detail-pdf-fab {
    position: fixed;
    bottom: 28px;
    right: 28px;
    z-index: 200;
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 12px 22px 12px 18px;
    background: var(--service-fill, var(--service-color, var(--accent)));
    color: var(--service-fill-ink, var(--service-ink, var(--accent-ink)));
    border-radius: 40px;
    font-weight: 600;
    font-size: 0.87rem;
    text-decoration: none;
    transition: transform 0.18s ease;
    white-space: nowrap;
}

.training-detail-pdf-fab:hover {
    transform: translateY(-2px);
    color: var(--service-fill-ink, var(--service-ink, var(--accent-ink)));
    text-decoration: none;
}

.training-detail-pdf-fab svg {
    width: 17px;
    height: 17px;
    flex-shrink: 0;
    stroke: var(--service-fill-ink, var(--service-ink, var(--accent-ink)));
}

@media (max-width: 480px) {
    .training-detail-pdf-fab {
        bottom: 18px;
        right: 16px;
        padding: 13px 16px;
        gap: 0;
        border-radius: 50%;
        width: 52px;
        height: 52px;
        justify-content: center;
    }

    .training-detail-pdf-fab .fab-label {
        display: none;
    }
}
