/* ==========================================================================
   Spenden (/donate) – seitenspezifisch. Gleicher Aufbau wie /order: eine
   zentrierte, einspaltige Karte (ohne Seitenleiste) mit kurzer Einleitung
   (Satz + Häkchen) über dem Beitrags-Auswahlbereich. Karte, Felder & Typo
   stammen aus pages.css; hier nur Panel, Einleitung und die Spenden-Steuerung.
   ========================================================================== */

/* Layout: mobil gestapelt (Karte oben, Banner darunter), Desktop zweispaltig
   (Banner links, Spendenkarte rechts) – beide Spalten gleich hoch. */
.dnt-layout { display: grid; gap: clamp(1rem, 2.5vw, 1.5rem); max-width: 44rem; margin-inline: auto; }
.dnt-panel { width: 100%; }

/* Banner (unter der Karte): Markenfarbe (Gold), Text links, Partner-Bild rechts,
   plus weißes Marken-Motiv (overlay-icon.svg) als dezentes Wasserzeichen. */
.dnt-banner {
    position: relative; isolation: isolate; overflow: hidden;
    display: grid; grid-template-columns: 1fr clamp(8rem, 34%, 14rem);
    align-items: stretch;
    width: 100%;
    border-radius: 18px;
    color: #fff;
    background: var(--gold);   /* Markenfarbe (Primär) */
}
/* SVG-Overlay: Marken-Motiv weiß, sehr dezent, hinter dem Inhalt. */
.dnt-banner::before {
    content: ""; position: absolute; z-index: 0;
    top: 50%; left: clamp(-9rem, -8vw, -3rem);
    height: clamp(30rem, 85vw, 52rem); aspect-ratio: 1;
    transform: translateY(-50%);
    background: url("../images/SVG/overlay-icon.svg") center / contain no-repeat;
    filter: brightness(0) invert(1); opacity: .08;
    pointer-events: none;
}
.dnt-banner__body {
    position: relative; z-index: 1;
    display: grid; gap: .8rem; align-content: center;
    padding: clamp(1.1rem, 3vw, 1.5rem) clamp(1.4rem, 4vw, 2rem);
}
/* Koran-Mockup rechts (transparentes PNG) – frei auf der Goldfläche. */
.dnt-banner__media {
    position: relative; z-index: 1; align-self: stretch; min-height: 100%;
    background: url("../images/koran-mockup.png") center right / contain no-repeat;
}
.dnt-banner__lead { margin: 0; color: #fff; font-size: clamp(.92rem, .88rem + .28vw, 1.05rem); line-height: 1.45; font-weight: 500; }
.dnt-banner__list { list-style: none; margin: 0; padding: 0; display: grid; gap: .55rem; }
.dnt-banner__list li { display: flex; align-items: center; gap: .65rem; color: #fff; font-weight: 600; font-size: .9rem; }
.dnt-banner__check {
    display: grid; place-items: center; flex: none;
    width: 1.65rem; height: 1.65rem; border-radius: 50%;
    background: #fff; color: var(--gold);
}
.dnt-banner__check svg { width: .9rem; height: .9rem; }
/* Schmale Phones: Bild als Streifen unter den Text. */
@media (max-width: 560px) {
    .dnt-banner { grid-template-columns: 1fr; }
    .dnt-banner__media { min-height: 8rem; background-position: center; }
}

.dnt-panel__title { margin-bottom: .9rem; }

/* Beitrags-Auswahlbereich: gleicher vertikaler Rhythmus wie ein Formular. */
.dnt-select { display: grid; gap: 1.1rem; }

/* Betrag-Feld: eigenständige, gold getönte „Spenden"-Eingabe mit Label, großer
   €-Zahl und Gold-Fokusring – hebt sich klar als der Spendenbetrag hervor. */
.dnt-amount {
    display: grid; gap: .35rem; cursor: text;
    padding: .85rem 1.15rem 1rem;
    border: 1.5px solid color-mix(in srgb, var(--gold) 38%, transparent);
    border-radius: 16px;
    background: color-mix(in srgb, var(--gold) 7%, var(--p-paper));
    transition: border-color var(--transition), box-shadow var(--transition), background var(--transition);
}
.dnt-amount:focus-within {
    border-color: var(--gold);
    background: color-mix(in srgb, var(--gold) 10%, var(--p-paper));
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--gold) 16%, transparent);
}
.dnt-amount__label {
    font-size: .72rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
    color: var(--gold);
}
.dnt-amount__field { display: flex; align-items: baseline; gap: .4rem; }
/* €-Zeichen im Body-Font (wie die Zahl) → exakt gleiche Größe und Schriftart. */
.dnt-amount__cur { flex: none; font-family: var(--font-body); font-size: clamp(2.1rem, 6vw, 2.7rem); font-weight: 700; color: var(--gold); line-height: 1.05; }
.dnt-amount__input {
    flex: 1; min-width: 0; border: 0; background: transparent;
    font-family: var(--font-body); font-size: clamp(2.1rem, 6vw, 2.7rem); font-weight: 700;
    color: var(--p-ink); line-height: 1.05; letter-spacing: -.01em;
    -moz-appearance: textfield; appearance: textfield;
}
.dnt-amount__input::placeholder { color: var(--p-ink-muted); opacity: .45; font-weight: 700; }
.dnt-amount__input:focus { outline: none; }
.dnt-amount__input::-webkit-outer-spin-button,
.dnt-amount__input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* Live-Hinweis: wie viele Koranübersetzungen der Betrag ermöglicht. */
.dnt-copies { margin: -.4rem 0 0; min-height: 1.35rem; font-size: .95rem; line-height: 1.4; color: var(--p-ink-muted); }
.dnt-copies.is-active { color: var(--p-ink-soft); }
.dnt-copies strong { color: var(--gold); font-weight: 700; font-variant-numeric: tabular-nums; }

/* Beitragsoptionen: minimal – alle vier in EINER Reihe (Desktop), nur Menge + Preis. */
.dnt-options { display: grid; grid-template-columns: repeat(4, 1fr); gap: .55rem; }
.dnt-option {
    appearance: none; cursor: pointer; width: 100%; text-align: center;
    display: flex; flex-direction: column; align-items: center; gap: .25rem;
    padding: .8rem .5rem;
    border: 1px solid var(--p-line); border-radius: 12px;
    background: var(--p-paper);
    transition: border-color var(--transition), background var(--transition);
}
.dnt-option:hover { border-color: var(--p-line-strong); background: color-mix(in srgb, var(--secondary) 4%, var(--p-paper)); }
.dnt-option:focus-visible { outline: var(--focus-ring); outline-offset: 2px; }
.dnt-option__qty { font-size: .9rem; font-weight: 600; color: var(--p-ink); white-space: nowrap; }
/* Preis im Body-Font, damit das €-Zeichen exakt Schriftart und -größe der Zahl hat. */
.dnt-option__price { font-family: var(--font-body); font-weight: 700; font-size: 1.05rem; color: var(--p-ink); font-variant-numeric: tabular-nums; white-space: nowrap; }

/* Ausgewählt: Navy-Kontur + dezente Tönung. */
.dnt-option.is-active {
    border-color: var(--secondary);
    background: color-mix(in srgb, var(--secondary) 6%, var(--p-paper));
}

/* CTA: vollbreiter, dunkler Navy-Button mit Pfeil. */
.dnt-cta {
    appearance: none; cursor: pointer; width: 100%;
    display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
    min-height: 54px; padding: .9rem 1.4rem;
    border: 0; border-radius: var(--radius-button);
    background: var(--secondary); color: #fff;
    font-family: var(--font-body); font-size: 1.02rem; font-weight: 700;
    transition: background var(--transition), transform var(--transition);
}
.dnt-cta svg { width: 1.2rem; height: 1.2rem; }
.dnt-cta:hover { background: color-mix(in srgb, var(--secondary) 88%, #000); transform: translateY(-1px); }
.dnt-cta:active { transform: translateY(0); }
.dnt-cta:focus-visible { outline: var(--focus-ring); outline-offset: 2px; }

/* ---- Schmale Phones: vier in einer Reihe wird zu kompaktem 2×2-Raster. */
@media (max-width: 640px) {
    .dnt-options { grid-template-columns: 1fr 1fr; gap: .6rem; }
    .dnt-option { padding: .9rem .6rem; gap: .3rem; }
    .dnt-option__price { font-size: 1.12rem; }
}

