/* ==========================================================================
   Partner / Mitmachen (/partners) – seitenspezifisch. Aufbau, Karten, Felder,
   Checkbox & Typo aus pages.css; hier nur Info-Spalte + Paketauswahl.
   ========================================================================== */
.ptn-info { display: grid; gap: 1.3rem; align-content: start; }

/* Zweispaltig: die Info-Spalte bleibt beim Scrollen des (längeren) Formulars
   oben stehen. Versatz = Höhe der schwebenden Nav + etwas Luft. */
@media (min-width: 881px) {
    .ptn-info { position: sticky; top: 6.25rem; align-self: start; }
}

/* Kontakt */
.ptn-contact__body { display: grid; gap: .1rem; min-width: 0; }
.ptn-contact__label { color: var(--p-ink-soft); font-size: .9rem; }
.ptn-contact__mail { color: var(--gold); font-weight: 700; font-size: 1.05rem; text-decoration: none; overflow-wrap: anywhere; word-break: break-word; }
.ptn-contact__mail:hover { text-decoration: underline; }

/* Multiplikator */
.ptn-multi { display: grid; gap: 1rem; }
.ptn-multi__title { display: flex; align-items: center; gap: .65rem; }
.ptn-multi__enable { margin-top: .1rem; }

/* Produktbild „Der deutliche Koran" unter dem linken Partner-Bereich. */
.ptn-visual {
    display: block;
    width: 100%;
    height: auto;
    margin-top: .3rem;
    /* Weißen Produkt-Hintergrund auf den hellen Seitengrund einschmelzen
       (kein weißer Kasten) – die Bücher stehen frei auf der Seite. */
    mix-blend-mode: multiply;
}
/* Desktop: Bild in der linken Info-Spalte. Mobil: Bild unter dem Formular.
   Je Breakpoint wird genau eine Platzierung angezeigt. */
.ptn-visual--below { display: none; }
@media (max-width: 880px) {
    .ptn-visual--side { display: none; }
    .ptn-visual--below { display: block; margin-top: 0; }
}

/* ---- Formular: Blöcke ---- */
.ptn-form { display: grid; gap: 2.1rem; }   /* Trennung der Blöcke über Abstand, nicht über Linien */
.ptn-form .psubheading { display: flex; align-items: center; gap: .65rem; }
.ptn-block { display: grid; gap: 1rem; }

/* Paketauswahl (S/M/L/XL) */
.ptn-pkgs { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: .75rem; }
.ptn-pkg__card {
    position: relative;
    display: grid; justify-items: center; gap: .28rem;
    padding: 1.7rem .6rem 1.25rem; text-align: center;
    background: var(--surface-card);
    border-radius: var(--p-radius-sm);
    transition: background var(--transition), box-shadow var(--transition), transform var(--transition);
}
.popt:hover .ptn-pkg__card { transform: translateY(-2px); }
.popt:hover input:not(:checked) + .ptn-pkg__card { background: color-mix(in srgb, var(--secondary) 7%, var(--surface-mix)); }
.popt input:checked + .ptn-pkg__card {
    background: color-mix(in srgb, var(--gold) 9%, var(--surface-mix));
    box-shadow: 0 0 0 1px var(--gold);
}
.popt input:focus-visible + .ptn-pkg__card { box-shadow: 0 0 0 2px var(--gold); }

/* Auswahl-Häkchen oben rechts (statt schlichtem Radio-Punkt) */
.ptn-pkg__radio {
    position: absolute; top: .6rem; right: .6rem;
    display: grid; place-items: center;
    width: 1.3rem; height: 1.3rem;
    border: 1.5px solid var(--p-line-strong); border-radius: 50%; background: var(--surface-card);
    transition: background var(--transition), border-color var(--transition);
}
.popt input:checked + .ptn-pkg__card .ptn-pkg__radio { background: var(--gold); border-color: var(--gold); }
.ptn-pkg__radio::after {
    content: ""; width: .32rem; height: .6rem; margin-top: -2px;
    border: solid #fff; border-width: 0 2px 2px 0; transform: rotate(45deg);
    opacity: 0; transition: opacity var(--transition);
}
.popt input:checked + .ptn-pkg__card .ptn-pkg__radio::after { opacity: 1; }

.ptn-pkg__size { font-family: var(--font-display-medium); font-size: 1.5rem; line-height: 1; color: var(--p-ink); }
.ptn-pkg__qty { font-size: .9rem; font-weight: 600; color: var(--p-ink); }
.ptn-pkg__ship { margin-top: .5rem; font-size: .76rem; color: var(--p-ink-muted); }

/* CTA */
.ptn-form .pcta svg { width: 1.15rem; height: 1.15rem; }

@media (max-width: 620px) {
    .ptn-pkgs { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); }
}
