/* Single agenda event — gescheiden van single.css (die magazine-articles styled). */

.page-agenda-single {
    max-width: var(--container-w-art);
    margin: 0 auto;
    padding: 32px var(--container-pad) 96px;
}

.page-agenda-single .back-link {
    font-family: var(--serif);
    font-style: italic;
    font-size: 14px;
    margin: 0 0 24px;
}

.page-agenda-single .back-link a {
    color: var(--ink-mute);
    text-decoration: none;
    border-bottom: 1px dashed var(--rule);
    padding-bottom: 1px;
}

.page-agenda-single .back-link a:hover {
    color: var(--terracotta);
    border-color: var(--terracotta);
}

.page-agenda-single .back-link-bottom {
    margin: 64px 0 0;
    text-align: center;
}

/* ─── Head ──────────────────────── */
.agenda-head {
    margin: 0 0 32px;
    position: relative;
}

.agenda-head .ribbon {
    display: inline-block;
    background: var(--plum);
    color: var(--paper);
    font-family: var(--serif);
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    padding: 5px 14px;
    transform: rotate(-3deg);
    margin-bottom: 12px;
}

.agenda-head .type-pill {
    display: inline-block;
    font-family: var(--serif);
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    padding: 5px 12px;
    border-radius: 3px;
    color: var(--paper);
    background: var(--ink-soft);
    margin-bottom: 16px;
}

.agenda-head .type-pill.tentoonstelling { background: var(--terracotta); }
.agenda-head .type-pill.lezing,
.agenda-head .type-pill.beurs,
.agenda-head .type-pill.festival,
.agenda-head .type-pill.feest,
.agenda-head .type-pill.jubileum,
.agenda-head .type-pill.atelier,
.agenda-head .type-pill.workshop,
.agenda-head .type-pill.biennale        { background: var(--yellow); color: var(--ink); }
.agenda-head .type-pill.docu,
.agenda-head .type-pill.online,
.agenda-head .type-pill.film            { background: var(--lavender); color: var(--ink); }
.agenda-head .type-pill.wedstrijd       { background: var(--plum-soft); }
.agenda-head .type-pill.anders          { background: var(--lavender); color: var(--ink); }

.agenda-head h1 {
    font-family: var(--display);
    font-weight: 700;
    font-size: var(--font-size-headline);
    line-height: 1.05;
    letter-spacing: -0.015em;
    margin: 0 0 16px;
    text-wrap: balance;
}

.agenda-head h1 em { color: var(--plum); }

/* ─── Hero visual ───────────────── */
.agenda-hero {
    aspect-ratio: 16 / 9;
    border-radius: 8px;
    overflow: hidden;
    margin: 0 0 40px;
    filter: drop-shadow(8px 12px 0 rgba(26, 26, 26, 0.06));
}

.agenda-hero svg,
.agenda-hero img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* ─── Detail-row (aside + body) ── */
.agenda-detail {
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    gap: 48px;
    align-items: start;
}

/* Praktisch-aside */
.agenda-practical {
    background: var(--paper);
    border: 1.5px solid var(--rule);
    border-radius: 10px;
    padding: 24px 28px;
    position: sticky;
    top: 24px;
    box-shadow: 5px 7px 0 rgba(26, 26, 26, 0.06);
}

.agenda-practical h2 {
    font-family: var(--hand);
    font-size: 28px;
    color: var(--plum);
    margin: 0 0 16px;
    transform: rotate(-1deg);
    display: inline-block;
}

.agenda-practical dl {
    margin: 0 0 18px;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 6px 16px;
}

.agenda-practical dt {
    font-family: var(--serif);
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--ink-mute);
    padding-top: 4px;
}

.agenda-practical dd {
    font-family: var(--serif);
    font-size: 15px;
    line-height: 1.4;
    margin: 0 0 8px;
    color: var(--ink);
}

.agenda-practical .good-to-know {
    border-top: 1px dashed var(--rule);
    padding-top: 16px;
    margin-top: 8px;
}

.agenda-practical .good-to-know h3 {
    font-family: var(--hand);
    font-size: 20px;
    color: var(--plum);
    margin: 0 0 8px;
    transform: rotate(-1deg);
    display: inline-block;
}

.agenda-practical .good-to-know p {
    font-family: var(--serif);
    font-size: 14px;
    line-height: 1.5;
    color: var(--ink);
    margin: 0 0 8px;
}

.agenda-practical .good-to-know p:last-child { margin-bottom: 0; }

.agenda-practical .cta-stack {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 8px;
    border-top: 1px dashed var(--rule);
    padding-top: 16px;
}

.agenda-practical .cta-stack .btn {
    justify-content: center;
    text-align: center;
    width: 100%;
}

/* Body */
.agenda-body {
    font-family: var(--serif-body);
    font-size: 17px;
    line-height: 1.7;
    color: var(--ink);
    max-width: 60ch;
}

.agenda-body p {
    margin: 0 0 18px;
}

.agenda-body p:first-child {
    font-size: 19px;
    line-height: 1.6;
}

.agenda-body em { color: var(--plum); }

.agenda-body a {
    color: var(--terracotta);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}

.agenda-body h2,
.agenda-body h3 {
    font-family: var(--display);
    margin: 32px 0 12px;
    line-height: 1.2;
}

.agenda-body h2 { font-size: 28px; }
.agenda-body h3 { font-size: 22px; }

/* ─── Responsive ────────────────── */
@media (max-width: 1024px) {
    .agenda-head h1 { font-size: 48px; }
    .agenda-detail {
        grid-template-columns: minmax(0, 1fr);
        gap: 32px;
    }
    .agenda-practical {
        position: static;
    }
}

@media (max-width: 768px) {
    .page-agenda-single { padding: 20px 20px 64px; }
    .agenda-head h1 { font-size: 36px; }
    .agenda-hero { aspect-ratio: 4 / 3; margin: 0 0 24px; }
    .agenda-body { font-size: 16px; }
}
