/* stappen.css — wrapper h2g/stappen + child h2g/stap (Werkwijze-sectie).
   Child-items delen deze CSS met hun wrapper (geen aparte file). */

.h2g-stappen {
    display: block;
    padding: 0 var(--gutter) clamp(64px, 9vw, 100px);
}

/* Sluitende rand onder de laatste stap (elke stap heeft border-top). */
.h2g-stappen__end {
    border-top: 2px solid var(--color-accent);
}

/* ---- Eén stap-rij: 12-koloms grid met asymmetrische spans ---- */
.h2g-stap {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 16px;
    border-top: 2px solid var(--color-accent);
    padding: 40px 0 56px;
}

/* Kolom 1–2: mono-nummer ("Stap 01"). */
.h2g-stap__nr {
    grid-column: 1 / span 2;
    font-family: var(--font-mono);
    font-size: 15px;
    line-height: 1.4;
    color: var(--color-accent);
}

/* Kolom 3–7: titel + tekst. */
.h2g-stap__body {
    grid-column: 3 / span 5;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.h2g-stap__body h2 {
    margin: 0;
    font-family: var(--font-heading);
    font-size: clamp(36px, 4vw, 64px);
    font-weight: 800;
    line-height: 0.95;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    color: var(--color-black);
}

.h2g-stap__tekst {
    margin: 0;
    font-family: var(--font-body);
    font-size: 18px;
    line-height: 1.45;
    max-width: 48ch;
    color: var(--color-text);
}

/* Kolom 9–12: "Wat je krijgt"-lijst + duur. */
.h2g-stap__krijgt {
    grid-column: 9 / span 4;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.h2g-stap__label {
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--color-accent);
}

.h2g-stap__punt {
    display: flex;
    gap: 10px;
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.35;
    color: var(--color-text);
    border-bottom: 1px solid color-mix(in oklch, var(--color-accent) 30%, transparent);
    padding-bottom: 10px;
}

.h2g-stap__punt > span:first-child {
    flex: none;
    line-height: 1.35;
}

.h2g-stap__duur {
    font-family: var(--font-mono);
    font-size: 14px;
    padding-top: 4px;
    color: var(--color-accent);
}

/* ---- Tablet (761–1024px): 2 kolommen i.p.v. de dichte 12-koloms rij ----
   Nummer over de volle breedte, titel+tekst links, "wat je krijgt"-lijst
   rechts. Voorkomt dat de body-kolom (span 5) op ~768px te smal wordt. */
@media (max-width: 1024px) {
    .h2g-stap {
        grid-template-columns: 1fr 1fr;
        column-gap: 32px;
        row-gap: 20px;
    }
    .h2g-stap__nr     { grid-column: 1 / -1; }
    .h2g-stap__body   { grid-column: 1; }
    .h2g-stap__krijgt { grid-column: 2; }
}

/* ---- Mobiel: alles stapelen (padding via var(--gutter)) ---- */
@media (max-width: 760px) {
    .h2g-stap {
        display: flex;
        flex-direction: column;
        gap: 16px;
        padding: 32px 0 40px;
    }
    .h2g-stap__nr,
    .h2g-stap__body,
    .h2g-stap__krijgt {
        grid-column: auto;
    }
}
