/* Stellenangebote — stellenangebote.css */

.page-intro__title em {
    color: var(--accent);
    font-style: normal;
}

.stellen-hero {
    padding-block: var(--gap-l) clamp(2rem, 6vw, 4rem);
}

.stellen-hero__media {
    aspect-ratio: 16 / 8;
    overflow: hidden;
}

.stellen-block {
    padding-block: clamp(2.5rem, 8vw, 5rem);
}

.stellen-block + .stellen-block {
    border-top: 1px solid var(--border);
}

.stellen-block__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--gap-l);
}

.stellen-block__head h2 {
    font-size: var(--fs-l);
    line-height: 1.05;
    letter-spacing: -0.02em;
    max-width: 14ch;
}

.stellen-block__body p {
    color: var(--fg-muted);
    line-height: 1.75;
    margin-bottom: var(--gap-m);
    font-size: 1.0625rem;
    max-width: 60ch;
}

.stellen-block__body p:last-child {
    margin-bottom: 0;
}

.stellen-list {
    display: grid;
    grid-template-columns: 1fr;
    border-top: 1px solid var(--border);
    margin-block: var(--gap-s) var(--gap-m);
}

.stellen-list li {
    padding: 0.9rem 0 0.9rem 2rem;
    border-bottom: 1px solid var(--border);
    position: relative;
    color: var(--fg);
    line-height: 1.55;
}

.stellen-list li::before {
    content: "→";
    position: absolute;
    left: 0;
    top: 0.9rem;
    color: var(--accent);
    font-weight: 600;
}

.stellen-cta {
    padding-block: clamp(3rem, 8vw, 5.5rem);
    background: var(--bg-deep);
    border-top: 1px solid var(--border);
}

.stellen-cta__inner {
    display: flex;
    flex-direction: column;
    gap: var(--gap-m);
    align-items: flex-start;
    max-width: 60ch;
}

.stellen-cta__inner h2 {
    font-size: var(--fs-l);
    line-height: 1;
}

.stellen-cta__inner p {
    color: var(--fg-muted);
    line-height: 1.7;
    font-size: 1.0625rem;
}

.stellen-cta__inner a {
    color: var(--accent);
    text-decoration: underline;
    text-decoration-color: rgba(168, 99, 28, 0.4);
}

@media (min-width: 768px) {
    .stellen-block__grid {
        grid-template-columns: 1fr 1.5fr;
        gap: var(--gap-xl);
        align-items: start;
    }
}
