.registration-page { display: grid; gap: 1.25rem; }
.registration-page__header { display: flex; justify-content: space-between; gap: 1rem; align-items: flex-start; }
.registration-page__header h2, .registration-event-head h2, .registration-form-section h3 { margin-top: 0; }
.registration-back-link { display: inline-block; margin-bottom: .5rem; }
.registration-stats { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1rem; }
.registration-stat { display: grid; gap: .25rem; }
.registration-stat strong { font-size: 1.7rem; }
.registration-section-heading, .registration-participant__head, .registration-actions { display: flex; justify-content: space-between; align-items: center; gap: 1rem; }
.registration-table-actions { white-space: nowrap; }
.registration-settings-form, .registration-public-form { display: grid; gap: 1.25rem; }
.registration-form-section { display: grid; gap: 1rem; }
.registration-grid { display: grid; gap: 1rem; }
.registration-grid--two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.registration-grid--three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.registration-form-section label:not(.checkbox-item) { display: grid; gap: .35rem; font-weight: 500; }
.registration-check { grid-template-columns: auto 1fr !important; align-items: start; }
.registration-check input { margin-top: .2rem; }
.registration-hint { color: var(--color-text-muted, #666); font-size: .92rem; margin: 0; }
.registration-field-error { color: #a51818; font-weight: 600; }
.registration-notice--success { border-left: 4px solid #267b35; }
.registration-notice--error { border-left: 4px solid #a51818; }
.registration-public-page { max-width: 980px; margin: 0 auto; }
.registration-kicker { margin: 0 0 .35rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; font-size: .82rem; }
.registration-event-meta { display: flex; flex-wrap: wrap; gap: .65rem 1.25rem; }
.registration-participant { border: 1px solid #d8d8d8; border-radius: .35rem; padding: 1rem; margin: 0 0 1rem; display: grid; gap: 1rem; }
.registration-participant legend { font-weight: 600; padding: 0; }
.registration-remove-participant { border: 0; background: transparent; color: #a51818; text-decoration: underline; cursor: pointer; }
.registration-confirmation { text-align: center; padding: 2rem; }
.registration-confirmation-text { margin: 1rem auto; max-width: 680px; }
.registration-reference code { font-size: 1rem; }
@media (max-width: 800px) {
    .registration-stats, .registration-grid--three { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 600px) {
    .registration-page__header, .registration-section-heading, .registration-actions { align-items: stretch; flex-direction: column; }
    .registration-stats, .registration-grid--two, .registration-grid--three { grid-template-columns: 1fr; }
    .registration-actions .button { width: 100%; text-align: center; }
}
.registration-event-panel { padding-top: 1rem; }
.registration-record { margin-top: 1rem; }
.registration-record__head { display: flex; gap: 1rem; align-items: center; justify-content: space-between; flex-wrap: wrap; }
.registration-record .compact-list li { display: flex; gap: 1rem; justify-content: space-between; align-items: center; flex-wrap: wrap; }

/* Kompakte Einbindung in die Termin-Einzelansicht */
.registration-event-details {
    padding: 0;
    overflow: hidden;
}

.registration-event-details > summary {
    padding: 0.7rem 0.8rem;
    cursor: pointer;
    list-style-position: inside;
}

.registration-event-details[open] > summary {
    border-bottom: 1px solid var(--color-border);
}

.registration-event-panel--compact {
    display: grid;
    gap: 0.7rem;
    padding: 0.75rem;
}

.registration-event-panel--compact > p,
.registration-event-panel--compact > h3 {
    margin: 0;
}

.registration-event-panel--compact form {
    display: grid;
    gap: 0.7rem;
}

.registration-event-panel--compact .form-grid,
.registration-event-panel--compact .form-checkbox-grid {
    gap: 0.65rem;
}

.registration-event-panel--compact .form-row {
    margin: 0;
}

.registration-event-panel--compact textarea {
    min-height: 4.5rem;
}

.registration-masterdata-option {
    align-self: end;
    padding: 0.55rem 0.65rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-surface-soft);
}

.registration-masterdata-option .checkbox-row {
    margin: 0;
}

.registration-event-panel--compact .actions {
    margin-top: 0;
}

/* Öffentliches Formular kompakter, ohne Lesbarkeit zu opfern */
.registration-public-form {
    gap: 0.75rem;
}

.registration-public-form .registration-form-section {
    gap: 0.7rem;
    padding: 0.8rem;
}

.registration-public-form .registration-form-section > h3,
.registration-public-form .registration-section-heading h3,
.registration-public-form .registration-section-heading p {
    margin: 0;
}

.registration-public-form .registration-grid {
    gap: 0.65rem 0.8rem;
}

.registration-public-form .registration-participant {
    gap: 0.65rem;
    padding: 0.75rem;
    margin-bottom: 0.65rem;
}

.registration-public-form textarea {
    min-height: 4rem;
}

.registration-public-form .registration-actions {
    justify-content: flex-end;
}

@media (max-width: 600px) {
    .registration-event-details > summary,
    .registration-event-panel--compact,
    .registration-public-form .registration-form-section {
        padding: 0.65rem;
    }
}

.registration-mail-status {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: .85rem 1rem;
}
.registration-mail-status h3 { margin: 0 0 .2rem; }
.registration-mail-status p { margin: 0; }
.registration-mail-status__counts {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem .9rem;
    margin-top: .45rem;
    font-size: .9rem;
}
.registration-mail-status__counts span { white-space: nowrap; }
@media (max-width: 760px) {
    .registration-mail-status { align-items: stretch; flex-direction: column; }
}

.registration-event-admin-header {
    align-items: flex-start;
}

.registration-event-admin-actions {
    flex-wrap: wrap;
    justify-content: flex-end;
}

.registration-summary-box {
    display: grid;
    gap: 0.75rem;
}

.registration-summary-box > summary {
    cursor: pointer;
    font-weight: 600;
}

.registration-summary-form {
    display: grid;
    gap: 0.8rem;
    margin-top: 0.75rem;
}

.registration-summary-form label {
    display: grid;
    gap: 0.3rem;
}

.registration-summary-form textarea {
    min-height: 12rem;
}

.registration-event-list-card {
    display: grid;
    gap: 1rem;
}

.registration-event-table {
    width: 100%;
}

.registration-event-table th,
.registration-event-table td {
    vertical-align: top;
}

.registration-event-table td {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

.registration-event-participants {
    display: grid;
    gap: 0.28rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.registration-event-participants li {
    line-height: 1.35;
}

.registration-event-remarks span:not(.muted) {
    display: -webkit-box;
    max-width: 22rem;
    overflow: hidden;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    line-height: 1.35;
}

.registration-event-row-actions {
    white-space: nowrap;
}

.registration-event-row-actions .inline-form {
    display: inline;
}

.link-button {
    border: 0;
    background: transparent;
    color: var(--color-primary-dark);
    cursor: pointer;
    font: inherit;
    padding: 0;
    text-decoration: none;
}

.link-button:hover {
    text-decoration: underline;
}

.link-button--danger {
    color: var(--color-danger);
}

@media (max-width: 820px) {
    .registration-event-table-wrap {
        overflow: visible;
    }

    .registration-event-table,
    .registration-event-table thead,
    .registration-event-table tbody,
    .registration-event-table tr,
    .registration-event-table th,
    .registration-event-table td {
        display: block;
    }

    .registration-event-table thead {
        position: absolute;
        width: 1px;
        height: 1px;
        overflow: hidden;
        clip: rect(0 0 0 0);
    }

    .registration-event-table tr {
        margin-bottom: 0.8rem;
        padding: 0.75rem;
        border: 1px solid var(--color-border);
        border-radius: var(--radius);
        background: #fff;
    }

    .registration-event-table td {
        display: grid;
        grid-template-columns: 8rem minmax(0, 1fr);
        gap: 0.75rem;
        padding: 0.35rem 0;
        border: 0;
    }

    .registration-event-table td::before {
        content: attr(data-label);
        color: var(--color-muted);
        font-weight: 600;
    }

    .registration-event-row-actions {
        white-space: normal;
    }
}


.registration-shared-blocks { display: grid; gap: .5rem; margin-top: .75rem; }
.registration-shared-blocks > p { margin: 0; }
.registration-shared-block { display: grid; grid-template-columns: minmax(8rem, auto) auto 1fr; gap: .25rem .75rem; align-items: baseline; padding: .45rem .6rem; border: 1px solid var(--color-border); border-radius: var(--radius); background: #f8fafc; }
.registration-shared-block small { color: var(--color-muted); }
@media (max-width: 720px) { .registration-shared-block { grid-template-columns: 1fr; gap: .15rem; } }

.registration-event-block-label {
    display: block;
    margin-top: 0.2rem;
    color: var(--color-primary-dark);
    font-size: 0.78rem;
    font-weight: 600;
}

/* Ausbau Anmeldemodul */
.registration-account-benefits {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border-left: 4px solid var(--color-primary, #9e1b32);
}
.registration-account-benefits p { margin: .3rem 0 0; color: var(--color-muted); }
.registration-account-benefits__actions { display: flex; flex-wrap: wrap; gap: .5rem; flex: 0 0 auto; }
.registration-optional { color: var(--color-muted); font-size: .82rem; font-weight: normal; }
.registration-club-picker { position: relative; }
.registration-club-results {
    position: absolute;
    z-index: 30;
    width: min(100%, 42rem);
    max-height: 18rem;
    overflow: auto;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: #fff;
    box-shadow: 0 .5rem 1.5rem rgba(15, 23, 42, .13);
}
.registration-club-result { display: block; width: 100%; padding: .65rem .8rem; border: 0; border-bottom: 1px solid var(--color-border); background: #fff; text-align: left; cursor: pointer; }
.registration-club-result:hover, .registration-club-result:focus { background: var(--color-surface-soft); }
.registration-participant-fee { display: flex; justify-content: flex-end; gap: .35rem; color: var(--color-muted); font-size: .92rem; }
.registration-cost-summary { display: flex; justify-content: space-between; align-items: center; padding: .85rem 1rem; border-top: 2px solid var(--color-border); font-size: 1.05rem; }
.registration-cost-summary strong { font-size: 1.25rem; }
.registration-document-notice { border-left: 4px solid #a76b00; }
.registration-actions--center { justify-content: center; flex-wrap: wrap; }
.registration-actions--left { justify-content: flex-start; flex-wrap: wrap; }
.registration-success-icon { width: 3rem; height: 3rem; display: grid; place-items: center; margin: 0 auto .75rem; border-radius: 50%; background: #e9f6ec; color: #267b35; font-size: 1.7rem; font-weight: 700; }
.registration-status { display: inline-flex; align-items: center; width: fit-content; padding: .22rem .55rem; border-radius: 999px; background: #eef2f6; font-size: .82rem; }
.registration-status--confirmed { background: #e9f6ec; color: #225c2b; }
.registration-status--waiting { background: #fff3d6; color: #7a5100; }
.registration-status--cancelled_by_user, .registration-status--cancelled_by_admin, .registration-status--rejected { background: #fbe9e9; color: #8f1c1c; }
.registration-management-participants { display: grid; gap: .5rem; }
.registration-management-person { display: grid; grid-template-columns: minmax(12rem, 1fr) minmax(10rem, 2fr) auto; gap: .75rem; align-items: center; padding: .65rem .75rem; border: 1px solid var(--color-border); border-radius: var(--radius); }
.registration-management-person span { color: var(--color-muted); }
.registration-document-list { display: grid; gap: .65rem; }
.registration-document-row { display: grid; grid-template-columns: minmax(12rem, 1fr) auto minmax(16rem, auto); gap: .75rem; align-items: center; padding: .75rem; border: 1px solid var(--color-border); border-radius: var(--radius); }
.registration-document-row > div:first-child { display: grid; gap: .15rem; }
.registration-document-row span, .registration-document-row small { color: var(--color-muted); }
.registration-document-status { white-space: nowrap; font-size: .85rem; }
.registration-document-status--accepted { color: #267b35; }
.registration-document-status--rejected, .registration-document-status--missing { color: #a51818; }
.registration-document-status--uploaded { color: #7a5100; }
.registration-document-upload { display: flex; align-items: center; justify-content: flex-end; gap: .5rem; }
.registration-document-upload input[type=file] { max-width: 15rem; }
.registration-cancel-box { padding: 0; overflow: hidden; }
.registration-cancel-box > summary { padding: .8rem 1rem; cursor: pointer; color: var(--color-danger); }
.registration-cancel-form { display: grid; gap: .75rem; padding: 0 1rem 1rem; }
.registration-cancel-form label { display: grid; gap: .3rem; }
.registration-account-list { display: grid; gap: .75rem; }
.registration-account-item { display: grid; grid-template-columns: minmax(0, 1fr) auto auto; gap: 1rem; align-items: center; }
.registration-account-item h3, .registration-account-item p { margin: 0; }
.registration-account-item p { margin-top: .25rem; color: var(--color-muted); }
@media (max-width: 760px) {
    .registration-account-benefits, .registration-account-item { align-items: stretch; grid-template-columns: 1fr; flex-direction: column; }
    .registration-account-benefits__actions .button { flex: 1 1 auto; text-align: center; }
    .registration-management-person, .registration-document-row { grid-template-columns: 1fr; }
    .registration-document-upload { justify-content: stretch; flex-direction: column; align-items: stretch; }
    .registration-document-upload input[type=file] { max-width: none; }
}

/* Verwaltung, Dashboard und Einbindung in Termine */
.event-registration-callout {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin: 1rem 0;
    padding: 1rem;
    border: 1px solid var(--color-border);
    border-left: 4px solid var(--color-primary, #9e1b32);
    border-radius: var(--radius);
    background: var(--color-surface-soft, #f8fafc);
}
.event-registration-callout__content { display: grid; gap: .22rem; }
.event-registration-callout__content h3,
.event-registration-callout__content p { margin: 0; }
.event-registration-callout__eyebrow { color: var(--color-primary-dark); font-size: .78rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.event-registration-callout__actions { display: flex; flex-wrap: wrap; gap: .5rem; flex: 0 0 auto; }

.registration-attention-summary { display: grid; gap: .7rem; }
.registration-attention-summary h3,
.registration-attention-summary p { margin: 0; }
.registration-attention-chips { display: flex; flex-wrap: wrap; gap: .4rem; }
.registration-attention-chips span { padding: .28rem .58rem; border-radius: 999px; background: var(--color-surface-soft, #eef2f6); font-size: .84rem; }

.registration-settings-subsection,
.registration-admin-section { display: grid; gap: .75rem; padding: 1rem 0; border-top: 1px solid var(--color-border); }
.registration-settings-subsection:first-of-type,
.registration-admin-section:first-of-type { border-top: 0; }
.registration-settings-subsection > h3,
.registration-admin-section > h3 { margin: 0; }
.registration-notification-config { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: .8rem; }
.registration-master-list,
.registration-sport-list,
.registration-document-config-list,
.registration-admin-participant-list,
.registration-admin-document-list,
.registration-activity-list { display: grid; gap: .6rem; }
.registration-master-list > div,
.registration-document-config-row,
.registration-admin-participant,
.registration-admin-document,
.registration-activity-list > li { padding: .7rem .8rem; border: 1px solid var(--color-border); border-radius: var(--radius); background: #fff; }
.registration-master-list > div { display: grid; gap: .18rem; }
.registration-master-list span { color: var(--color-muted); font-size: .9rem; }
.registration-inline-details { border: 1px solid var(--color-border); border-radius: var(--radius); background: #fff; }
.registration-inline-details > summary { padding: .65rem .8rem; cursor: pointer; }
.registration-inline-details[open] > summary { border-bottom: 1px solid var(--color-border); }
.registration-chip-list { display: flex; flex-wrap: wrap; gap: .35rem; padding: .7rem .8rem; }
.registration-chip-list span { padding: .22rem .5rem; border-radius: 999px; background: var(--color-surface-soft, #eef2f6); font-size: .82rem; }
.registration-reminder-manual-card { display: flex; justify-content: space-between; align-items: center; gap: 1rem; }
.registration-reminder-manual-card h3,
.registration-reminder-manual-card p { margin: 0; }
.registration-reminder-manual-card p { margin-top: .25rem; }

.registration-admin-detail { display: grid; gap: 1rem; }
.registration-admin-participant__head,
.registration-admin-document { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.registration-admin-participant__head h4,
.registration-admin-participant__head p,
.registration-admin-document h4,
.registration-admin-document p { margin: 0; }
.registration-admin-participant--review { border-left: 4px solid #a76b00; }
.registration-identity-review { display: grid; gap: .55rem; margin-top: .65rem; padding-top: .65rem; border-top: 1px solid var(--color-border); }
.registration-document-review-form { display: grid; grid-template-columns: minmax(9rem, auto) minmax(12rem, 1fr) auto; gap: .5rem; align-items: end; width: min(100%, 42rem); }
.registration-admin-document__actions { display: flex; flex-wrap: wrap; align-items: center; justify-content: flex-end; gap: .5rem; }
.registration-activity-list { margin: 0; padding: 0; list-style: none; }
.registration-activity-list small { color: var(--color-muted); }

.dashboard-card--registration > summary { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.dashboard-registration-section { display: grid; gap: .55rem; padding-top: .8rem; border-top: 1px solid var(--color-border); }
.dashboard-registration-section:first-child { border-top: 0; padding-top: 0; }
.dashboard-registration-section h4 { margin: 0; }
.dashboard-registration-section .dashboard-list { margin: 0; }

@media (max-width: 820px) {
    .event-registration-callout,
    .registration-reminder-manual-card { align-items: stretch; flex-direction: column; }
    .event-registration-callout__actions .button { flex: 1 1 auto; text-align: center; }
    .registration-notification-config { grid-template-columns: 1fr; }
    .registration-document-review-form { grid-template-columns: 1fr; width: 100%; }
    .registration-admin-document__actions { justify-content: flex-start; width: 100%; }
}

/* Bearbeitbare Anmeldungs-Stammdaten */
.registration-notification-config--checkboxes {
    align-items: stretch;
}

.registration-choice-group {
    min-width: 0;
    margin: 0;
    padding: .7rem .8rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: #fff;
}

.registration-choice-group legend,
.registration-choice-group > label {
    padding: 0 .2rem;
    font-weight: 500;
}

.registration-checkbox-list {
    display: grid;
    gap: .35rem;
    max-height: 13rem;
    overflow: auto;
    padding-right: .2rem;
}

.registration-checkbox-list .checkbox-row {
    align-items: start;
    margin: 0;
}

.registration-number-with-suffix {
    display: grid;
    grid-template-columns: minmax(5.5rem, 8rem) auto;
    gap: .55rem;
    align-items: center;
}

.registration-master-editor-list,
.registration-sport-editor-list,
.registration-graduation-editor-list {
    display: grid;
    gap: .6rem;
}

.registration-master-editor-row {
    display: grid;
    grid-template-columns: minmax(12rem, .8fr) minmax(16rem, 1.4fr) auto;
    gap: .65rem;
    align-items: end;
    padding: .7rem .8rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: #fff;
}

.registration-master-editor-row--sport {
    grid-template-columns: minmax(16rem, 1fr) auto;
    padding: 0;
    border: 0;
}

.registration-master-editor-row__wide {
    min-width: 0;
}

.registration-sport-editor__body {
    display: grid;
    gap: .7rem;
    padding: .75rem .8rem;
}

.registration-graduation-editor-head,
.registration-graduation-editor-row {
    display: grid;
    grid-template-columns: minmax(10rem, .8fr) minmax(12rem, 1fr) auto;
    gap: .5rem;
    align-items: center;
}

.registration-graduation-editor-head {
    color: var(--color-muted);
    font-size: .82rem;
}

.registration-master-editor-row > .button,
.registration-graduation-editor-row > .button {
    white-space: nowrap;
}

@media (max-width: 820px) {
    .registration-master-editor-row,
    .registration-master-editor-row--sport,
    .registration-graduation-editor-row {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .registration-graduation-editor-head {
        display: none;
    }

    .registration-number-with-suffix {
        grid-template-columns: 1fr;
        gap: .2rem;
    }
}

.registration-payment-account-list {
    display: grid;
    gap: .6rem;
}

.registration-payment-account__body {
    display: grid;
    gap: .7rem;
    padding: .75rem .8rem;
}

.registration-master-editor-row--document {
    grid-template-columns: minmax(11rem, .7fr) minmax(14rem, 1fr) minmax(16rem, 1.2fr) auto;
}

@media (max-width: 1100px) {
    .registration-master-editor-row--document {
        grid-template-columns: 1fr 1fr;
        align-items: stretch;
    }
}

@media (max-width: 820px) {
    .registration-master-editor-row--document {
        grid-template-columns: 1fr;
    }
}

.event-registration-callout--prominent {
    border-left: .32rem solid var(--color-primary);
}

.event-registration-callout__primary {
    font-size: 1.05rem;
    padding: .72rem 1.2rem;
}

.registration-document-template-field {
    min-width: 15rem;
}
