/* ════════════════════════════════════════════════════════════════
   subpages.css — Unterseiten für Jochen Ott (baut auf main.css auf)
   ════════════════════════════════════════════════════════════════ */

.back-link{display:inline-flex;align-items:center;gap:8px;font-size:.875rem;font-weight:700;letter-spacing:.02em;opacity:.9;margin-bottom:22px}
/* solid header for subpages (readable over light heroes) */
.site-header--solid{background:#fff;box-shadow:0 2px 18px rgba(0,0,0,.08)}
/* Wortmarke „Jochen Ott" auf den (hellen) Unterseiten-Headern komplett rot */
.site-header--solid .wordmark{color:var(--red)}
.site-header--solid .wordmark span{color:var(--red);opacity:1}
.site-header--solid .nav a{color:var(--ink)}
.site-header--solid .nav-toggle span{background:var(--ink)}
.site-header--solid .btn--cta{background:var(--red);color:#fff;border-color:var(--red)}
.back-link i{font-style:normal;transition:transform .15s}
.back-link:hover i{transform:translateX(-3px)}

/* ---- Page hero ---- */
.page-hero{position:relative;overflow:hidden}
.page-hero--red{background:var(--red);color:#fff}
.page-hero--paper{background:var(--grey);box-shadow:inset 0 -1px 0 rgba(21,18,15,.12)}
.page-hero__inner{max-width:var(--wrap);margin:0 auto;padding:clamp(124px,17vh,184px) var(--pad) clamp(54px,8vh,88px);position:relative;z-index:2}
.page-hero--split .page-hero__inner{display:grid;grid-template-columns:1.32fr .8fr;gap:clamp(32px,5vw,72px);align-items:start}
.page-hero__title{font-family:var(--display);font-weight:800;font-size:clamp(2.2rem,5.4vw,4.4rem);line-height:1.03;letter-spacing:-.02em;overflow-wrap:break-word;hyphens:auto}
.page-hero__lead{font-size:clamp(1.125rem,1.5vw,1.4375rem);line-height:1.55;max-width:48ch;margin-top:26px}
/* NRW-Marker links neben dem Page-Hero-Titel */
.page-hero .flag-heading{margin-bottom:clamp(18px,2.2vh,26px)}
/* Bio hero quote — groß, anspruchsvoll, in der warmen Zitatstimme */
.hero-quote{margin:0}
.hero-quote .quote-mark{font-family:var(--serif);font-weight:600;font-style:normal;color:var(--red)}
.page-hero--red .hero-quote .quote-mark{color:#fff}
.hero-quote blockquote{font-family:var(--serif);font-weight:600;font-size:clamp(2rem,4.2vw,3.875rem);line-height:1.18;letter-spacing:-.004em;color:var(--ink)}
.page-hero--red .hero-quote blockquote{color:#fff}
/* Betonung im Zitat ohne Unterstreichung (Underlines bleiben Links vorbehalten) */
.hero-quote blockquote em{font-style:italic;font-weight:600;color:var(--red-dark)}
.page-hero--red .hero-quote blockquote em{color:#fff}
.page-hero--red .page-hero__lead{color:#fff}
.page-hero__media{position:relative;border-radius:0;overflow:hidden;aspect-ratio:4/5;background:var(--red-deep)}
.page-hero__media img{width:100%;height:100%;object-fit:cover}
/* dezentes, stilisiertes NRW-Umriss-Signet — füllt den Leerraum rechts im
   roten Programm-Hero, liegt hinter dem Text (z-index unter .page-hero__inner) */
.page-hero__outline{position:absolute;z-index:1;top:50%;right:clamp(8px,3vw,52px);transform:translateY(-50%);width:min(46vw,500px);height:auto;pointer-events:none}
.page-hero__outline path{fill:rgba(255,255,255,.06);stroke:rgba(255,255,255,.42);stroke-width:.6;stroke-linejoin:round}
/* Variante für helle Heroes (Kontakt): leise rote Landesbindung statt toter Graufläche */
.page-hero__outline--paper path{fill:rgba(227,6,19,.04);stroke:rgba(227,6,19,.18)}
@media (max-width:760px){.page-hero__outline{width:min(76vw,360px);right:-12vw}.page-hero__outline path{stroke:rgba(255,255,255,.26);fill:rgba(255,255,255,.04)}}

/* ---- Generic content block ---- */
.block{padding:clamp(58px,9vh,116px) var(--pad)}
.block--paper{background:var(--grey)}
.block--white{background:#fff}
.block--red{background:var(--red);color:#fff}
.block__inner{max-width:var(--wrap);margin:0 auto}
/* justify-content:start: eine gemeinsame linke Lese-Achse mit Intro/Sonderblöcken
   (vorher sprang die Textkante von Sektion zu Sektion) */
.block__grid{display:grid;grid-template-columns:minmax(220px,300px) minmax(0,640px);justify-content:start;gap:clamp(30px,5vw,84px);align-items:start}
/* Block-Überschriften in Rot (Gestalter-Wunsch) — .block__label.subheading schlägt .subheading */
.block__label{font-family:var(--display);font-weight:800;font-size:clamp(1.4rem,2.2vw,1.95rem);line-height:1.1;letter-spacing:-.01em;color:var(--red-dark)}
.block__label.subheading{color:var(--red-dark)}
.block--red .block__label{color:#fff}
.prose>p{font-size:clamp(1.0625rem,1.25vw,1.25rem);line-height:1.72;color:var(--prose-ink);margin-bottom:1.15em;max-width:64ch;text-wrap:pretty}
.block--red .prose>p{color:#fff}
.prose>p:last-child{margin-bottom:0}
.prose .intro{display:block;font-weight:700;font-size:1.3em;line-height:1.35;letter-spacing:-.01em;color:var(--ink);margin-bottom:.5em}
.block--red .prose .intro{color:#fff}
.prose strong{font-weight:800;color:var(--red-dark)}
/* Hervorhebung über Gewicht/Farbe statt Unterstreichung (nur Links unterstrichen) */
.block--red .prose strong{color:#fff;font-weight:800}
/* echte Kursive für ruhige, „gesprochene" Betonung — bewusst nicht rot, damit
   sie sich klar vom roten Fettdruck (strong) absetzt (Red-Restraint Rule) */
.prose em{font-style:italic;color:inherit}
.subheading{font-family:var(--display);font-weight:800;font-size:clamp(1.5rem,3vw,2.35rem);line-height:1.08;letter-spacing:-.015em;margin:0 0 20px;color:var(--ink)}
/* Unterkapitel-Ebene (z. B. „Schule fürs Leben" unter dem Bildungs-Block):
   eine klare Stufe kleiner, damit die Lesehierarchie nicht kippt */
.subheading--minor{font-size:clamp(1.25rem,1.9vw,1.6rem)}
.block--red .subheading{color:#fff}
.subheading+.prose{margin-top:0}
/* .declaration innerhalb .prose muss die generische .prose>p-Regel (Größe/Farbe) schlagen */
.prose .declaration{font-size:clamp(1.4rem,2.4vw,2rem);line-height:1.14;letter-spacing:-.012em;margin:0;max-width:none}
.prose .declaration--ink{color:var(--ink)}
.stack{display:flex;flex-direction:column;gap:clamp(46px,7vh,86px)}

/* ---- Aussage-/Zitatblock mit dezentem Seitenfoto: Text links, Bild rechts ---- */
.text-figure{display:grid;grid-template-columns:minmax(0,1fr) minmax(240px,400px);gap:clamp(30px,4.5vw,68px);align-items:center}
.text-figure__media{border-radius:0;overflow:hidden;aspect-ratio:4/5;box-shadow:0 16px 38px rgba(0,0,0,.2)}
.text-figure__media img{width:100%;height:100%;object-fit:cover;display:block}
@media (max-width:900px){
  .text-figure{grid-template-columns:1fr;gap:26px}
  .text-figure__media{aspect-ratio:16/11;max-height:440px}
}

/* ---- Big pull quote ---- */
.pull-quote{margin:0;max-width:none}
.pull-quote .quote-mark{font-family:var(--serif);font-weight:600;font-style:normal;color:var(--red)}
.block--red .pull-quote .quote-mark{color:#fff;opacity:.85}
.pull-quote blockquote{font-family:var(--serif);font-weight:600;font-size:clamp(1.4375rem,2.7vw,2.375rem);line-height:1.3;letter-spacing:-.004em;color:var(--ink);max-width:46ch}
.block--red .pull-quote blockquote{color:#fff}
.pull-quote .pull-quote__lead{display:block;font-weight:600;font-size:1.92em;line-height:1.08;letter-spacing:-.012em;margin-bottom:.5em;color:#fff}
.pull-quote .pull-quote__line{display:block;font-size:.62em;font-weight:600;line-height:1.5;letter-spacing:0;color:#fff;max-width:44ch;margin-bottom:.86em}
.pull-quote .pull-quote__line:last-child{margin-bottom:0}
.pull-quote em{font-style:italic;font-weight:600;color:#fff}

/* ---- Program field module (NRW gerecht machen) ---- */
.policy-field{padding:clamp(60px,10vh,128px) var(--pad);position:relative;overflow:hidden;scroll-margin-top:80px}
.policy-field--red{background:var(--red);color:#fff}
.policy-field--paper{background:var(--grey)}
.policy-field--white{background:#fff}
/* Layout nach Gestalter-Entwurf „Frame 27": Headline + Zitat + Text links,
   Bild rechts (alternierend), „Das bedeutet"-Karten in voller Breite darunter.
   display:contents löst die Wrapper auf, sodass die Inhalte direkt im Grid liegen. */
/* grid-template-rows: Restraum aus überschüssiger Bildhöhe landet UNTER dem Fließtext
   (Zeile 3 = 1fr), nicht als zufällige Lücken zwischen Headline/Zitat/Text */
.policy-field__inner{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:1.05fr .95fr;grid-template-rows:auto auto 1fr auto;column-gap:clamp(34px,5vw,72px);align-items:start;grid-template-areas:"name media" "quote media" "prose media" "konkret konkret"}
.policy-field--reversed .policy-field__inner{grid-template-columns:.95fr 1.05fr;grid-template-areas:"media name" "media quote" "media prose" "konkret konkret"}
.policy-field__head,.policy-field__body{display:contents}
.policy-field__head .flag-heading{grid-area:name;margin-bottom:clamp(14px,1.8vw,22px)}
.policy-field__body .prose{grid-area:prose}
.policy-field__media{grid-area:media;align-self:stretch;height:100%;min-height:clamp(240px,30vw,430px);overflow:hidden;box-shadow:0 14px 34px rgba(0,0,0,.18)}
.policy-field__media img{width:100%;height:100%;object-fit:cover;display:block}
.policy-field--red .prose>p{color:#fff}
.policy-field--red .prose .intro{color:#fff}
.policy-field--red .prose strong{color:#fff;font-weight:800}
/* Feld-Headline in Rot (auf roten Feldern weiß); NRW-Marker links daneben */
.policy-field__title{font-family:var(--display);font-weight:800;font-size:clamp(1.8rem,3.8vw,3rem);line-height:1.04;letter-spacing:-.015em;margin-bottom:0;color:var(--red)}
.policy-field--red .policy-field__title{color:#fff}
.policy-field--red .flag-marker{box-shadow:0 0 0 2px rgba(255,255,255,.9)}
.policy-field--red .flag-marker i+i{box-shadow:inset 0 1px 0 rgba(255,255,255,.9)}
.policy-field__quote{grid-area:quote;font-family:var(--serif);font-style:italic;font-weight:600;font-size:clamp(1.5rem,2.8vw,2.25rem);line-height:1.24;letter-spacing:-.002em;color:var(--ink);margin-bottom:clamp(20px,2.6vw,32px)}
.policy-field--red .policy-field__quote{color:#fff}
.policy-field__quote .quote-mark{font-style:normal;font-weight:600;color:var(--red);margin:0 .12em}
.policy-field--red .policy-field__quote .quote-mark{color:#fff}
.policy-field__body .prose>p{max-width:60ch}
.specifics{grid-area:konkret;margin-top:clamp(36px,5vw,60px)}
.specifics-eyebrow{font-family:var(--sans);font-weight:700;font-size:.8125rem;letter-spacing:.16em;text-transform:uppercase;color:var(--red-dark);display:flex;align-items:center;gap:.55em;margin-bottom:18px}
.policy-field--red .specifics-eyebrow{color:#fff}
.specifics-eyebrow::before{content:'»';font-weight:800;font-size:1.6em;line-height:0;color:var(--red);flex:0 0 auto}
.policy-field--red .specifics-eyebrow::before{color:#fff}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
/* Programmseite: 6-Spalten-Raster, damit 2er-Reihen die Breite füllen (.card--half)
   statt ein leeres Drittel oder Waisenkarten stehen zu lassen */
.specifics .card-grid{grid-template-columns:repeat(6,1fr)}
.specifics .card{grid-column:span 2}
.specifics .card--half{grid-column:span 3}
.card{background:#fff;border:1px solid var(--line);border-radius:11px;padding:20px 22px}
.policy-field--paper .card,.policy-field--white .card{background:#fff}
.policy-field--red .card{background:transparent;border-color:rgba(255,255,255,.55)}
/* Kartentitel ÜBER Prose-Niveau: die Maßnahmen sind das Beweis-Material der Seite */
.card h3{font-family:var(--sans);font-weight:800;font-size:1.1875rem;line-height:1.2;margin-bottom:8px;display:flex;gap:11px;align-items:flex-start;color:var(--ink)}
.policy-field--red .card h3{color:#fff}
/* Karten-Marker in Tinte: das rote » bleibt Zitaten, Eyebrows und Trennern vorbehalten
   (Chevron-Dosierung über Farbe, Motiv bleibt) */
.card h3 .marker{flex:0 0 auto;color:var(--ink);font-weight:800;font-size:1.15em;line-height:1.1}
.card h3 .marker::before{content:'»'}
.policy-field--red .card h3 .marker{color:#fff}
.card p{font-size:1rem;line-height:1.55;color:var(--muted)}
.policy-field--red .card p{color:#fff}
.card--wide,.specifics .card--wide{grid-column:1/-1}
.card--wide p{max-width:75ch}

/* ---- Anker-Chips im Programm-Hero: Sprungbrett zu den sechs Feldern ---- */
.field-anchors{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px;position:relative;z-index:2}
.field-anchors a{display:inline-flex;align-items:center;font-weight:700;font-size:.875rem;line-height:1;color:#fff;border:1.5px solid rgba(255,255,255,.55);border-radius:999px;padding:11px 17px;white-space:nowrap;transition:background .15s,border-color .15s}
.field-anchors a:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.85)}
@media (max-width:760px){
  .field-anchors{flex-wrap:nowrap;overflow-x:auto;padding-bottom:8px;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-right:calc(-1*var(--pad));padding-right:var(--pad)}
  .field-anchors::-webkit-scrollbar{display:none}
}

/* ---- Störer im Unterstützen-Hero: füllt die leere Rotfläche rechts und zahlt
   direkt aufs Seitenziel ein (Sprung zum Spendenformular) ---- */
.page-hero__badge{position:absolute;z-index:2;right:clamp(28px,8vw,150px);top:50%;transform:translateY(-50%) rotate(5deg)}
a.page-hero__badge:hover{transform:translateY(-50%) rotate(5deg) translateY(-2px)}
@media (max-width:900px){.page-hero__badge{display:none}}

/* ---- Forms ---- */
.form{display:grid;gap:18px;max-width:680px}
.form[hidden]{display:none}   /* author display:grid would otherwise beat [hidden] */
.form .form__row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-field{display:flex;flex-direction:column;gap:8px}
.form-field label{font-size:.875rem;font-weight:700;color:var(--ink)}
.form-field input,.form-field textarea,.form-field select{font-family:var(--sans);font-size:1rem;padding:14px 16px;border:1.5px solid rgba(21,18,15,.2);border-radius:7px;background:#fff;color:var(--ink);transition:border-color .15s,box-shadow .15s}
.form-field textarea{min-height:150px;resize:vertical}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(227,6,19,.12)}
.checkbox-field{display:flex;gap:11px;align-items:flex-start;font-size:.875rem;color:var(--muted);line-height:1.5}
.checkbox-field input{width:20px;height:20px;flex:0 0 auto;margin-top:1px;accent-color:var(--red)}

/* ---- Validation, busy + confirmation states ---- */
.required-mark{color:var(--red-dark);font-weight:800}
.form__note{font-size:.8125rem;color:var(--subtle);line-height:1.5;margin:2px 0 0}
/* inline error — Red Dark keeps small text AA-legible (Red-Restraint Rule) */
.form-error{font-size:.8125rem;font-weight:600;color:var(--red-dark);line-height:1.4;margin:0}
.form-error[hidden]{display:none}
.form-field.is-invalid input,.form-field.is-invalid textarea{border-color:var(--red-dark)}
.form-field.is-invalid input:focus,.form-field.is-invalid textarea:focus{box-shadow:0 0 0 3px rgba(124,0,9,.16)}
.checkbox-field.is-invalid{color:var(--red-dark)}
.checkbox-field.is-invalid input{outline:2px solid var(--red-dark);outline-offset:2px}
/* button while submitting / locked against double-submit */
.btn[aria-busy="true"],.btn:disabled{opacity:.6;cursor:not-allowed}
.btn[aria-busy="true"]:hover,.btn:disabled:hover{transform:none;box-shadow:none;background:var(--red);border-color:var(--red)}
/* honest confirmation panel shown in place of the form */
.form__success{background:#fff;border:1px solid var(--line);border-radius:14px;padding:clamp(24px,3vw,38px);display:flex;gap:18px;align-items:flex-start}
.form__success[hidden]{display:none}
.form__success .form__success-icon{flex:0 0 auto;width:46px;height:46px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center}
.form__success h3{font-family:var(--display);font-weight:700;font-size:clamp(1.4375rem,2.6vw,1.9375rem);line-height:1.04;color:var(--ink);margin:0 0 6px}
.form__success p{font-size:.96875rem;color:var(--muted);line-height:1.6;max-width:52ch;margin:0}
.form__success:focus{outline:none}

/* ---- Overflow guards: grid children must be allowed to shrink ---- */
.block__grid>*,.policy-field__inner>*,.page-hero--split .page-hero__inner>*,.text-figure>*{min-width:0}
.policy-field__title,.policy-field__quote{overflow-wrap:break-word}
.bank-details dd{overflow-wrap:anywhere}
.card{min-width:0}
.card h3,.card p{overflow-wrap:break-word;hyphens:auto}
/* Inline multi-column layouts (set per-page via style=) carry no responsive
   rule of their own — collapse them on small screens. !important is required
   to beat the inline grid-template-columns. */
@media (max-width:820px){.grid-2up{grid-template-columns:1fr!important}}
@media (max-width:760px){.grid-3up{grid-template-columns:1fr!important}}

/* ---- Donation amounts ---- */
.amount-options{display:flex;flex-wrap:wrap;gap:12px;margin:6px 0 4px}
.amount-option{font-family:var(--display);font-weight:700;font-size:1.5rem;white-space:nowrap;padding:12px 28px;border:1.5px solid rgba(21,18,15,.2);border-radius:999px;background:#fff;cursor:pointer;transition:border-color .15s,color .15s,background .15s}
.amount-option:hover{border-color:var(--red);color:var(--red)}
.amount-option[aria-pressed="true"]{background:var(--red);color:#fff;border-color:var(--red)}
/* custom-amount field, revealed when "Anderer Betrag" is chosen */
.amount-custom{margin-top:14px}
.amount-custom[hidden]{display:none}
.currency-input{position:relative;display:flex;align-items:center}
.currency-input input{flex:1;font-family:var(--sans);font-size:1rem;padding:14px 38px 14px 16px;border:1.5px solid rgba(21,18,15,.2);border-radius:7px;background:#fff;color:var(--ink);transition:border-color .15s,box-shadow .15s;min-width:0}
.currency-input input:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(227,6,19,.12)}
.currency-input .currency-input__symbol{position:absolute;right:16px;font-weight:700;color:var(--subtle);pointer-events:none}

/* ---- Bank / info card ---- */
.info-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:clamp(26px,3vw,40px)}
.bank-details{display:grid;grid-template-columns:auto 1fr;gap:10px 22px;font-size:1rem;margin-top:14px}
.bank-details dt{font-weight:700;color:var(--subtle)}
.bank-details dd{font-variant-numeric:tabular-nums;color:var(--ink)}
.tax-note{font-size:.875rem;line-height:1.65;color:var(--subtle);max-width:74ch}
.tax-note h3{font-family:var(--display);font-weight:700;font-size:1.25rem;color:var(--ink);margin-bottom:10px}

/* press box — in der Markenpalette (weiße Karte) statt als einzige Schwarzfläche der
   Site; die Presse-Nische stiehlt dem Formular-CTA nicht mehr die Aufmerksamkeit */
.press-box{background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:14px;padding:clamp(26px,3vw,40px)}
.press-box h3{font-family:var(--display);font-weight:700;font-size:1.5rem;margin-bottom:14px;color:var(--red-dark)}
.press-box a{color:var(--red-dark);border-bottom:1px solid rgba(124,0,9,.35)}
.press-box .press-box__rows{display:grid;gap:6px;font-size:1rem;line-height:1.6;color:var(--muted)}

/* ---- Legal / utility pages (Impressum, Datenschutz) ---- */
.legal{max-width:66ch}
.legal>section+section{margin-top:clamp(32px,4.5vh,52px)}
.legal h2{font-family:var(--display);font-weight:700;font-size:clamp(1.375rem,2.4vw,1.875rem);line-height:1.06;color:var(--ink);margin-bottom:14px}
.legal address{font-style:normal;font-size:1rem;line-height:1.72;color:var(--prose-ink)}
.legal address strong{font-weight:800;color:var(--ink)}
.legal p{font-size:1rem;line-height:1.72;color:var(--prose-ink);margin-bottom:1em;max-width:66ch}
.legal p:last-child{margin-bottom:0}
.legal a{color:var(--red-dark);text-decoration:underline;text-underline-offset:2px;overflow-wrap:anywhere}
.legal ul{margin:0 0 1em;padding-left:1.2em}
.legal li{font-size:1rem;line-height:1.7;color:var(--prose-ink);margin-bottom:.35em}
.legal dt{font-weight:700;color:var(--ink);margin-top:.6em}
.legal dd{color:var(--prose-ink);line-height:1.6}

@media (max-width:900px){
  .page-hero--split .page-hero__inner{grid-template-columns:1fr;gap:34px}
  .page-hero__media{aspect-ratio:16/11;max-height:440px}
  .block__grid{grid-template-columns:1fr;gap:22px}
  .block__label{position:static}
  .policy-field__inner,.policy-field--reversed .policy-field__inner{grid-template-columns:1fr;grid-template-rows:none;grid-template-areas:"name" "quote" "media" "prose" "konkret"}
  .policy-field__media{min-height:0;aspect-ratio:16/10}
  .form .form__row{grid-template-columns:1fr}
}
@media (max-width:760px){
  .card-grid,.specifics .card-grid{grid-template-columns:1fr 1fr}
  .specifics .card,.specifics .card--half{grid-column:auto}
  .specifics .card--wide{grid-column:1/-1}
}
@media (max-width:600px){
  .card-grid,.specifics .card-grid{grid-template-columns:1fr}
  /* Beweis-Karten mobil: dunkler Rot-Wash als Chunk-Bildung auf Vollrot-Sektionen */
  .policy-field--red .card{background:rgba(0,0,0,.12);border-color:rgba(255,255,255,.4)}
}
@media (max-width:560px){
  /* Bankdaten gestapelt: nie wieder „SPD-Landesverban d" oder dreizeilige IBAN */
  .bank-details{grid-template-columns:1fr;gap:2px 0}
  .bank-details dt{margin-top:12px}
  .bank-details dt:first-child{margin-top:0}
}
