/* ============================================================
   controlrooms – Unterseiten / Inhalts-Typografie (Phase D)
   Nutzt die :root-Variablen aus style.css
   ============================================================ */

/* ---- Inner-Page Hero ---- */
.page-hero{position:relative;padding:74px 0 44px;border-bottom:1px solid var(--line);overflow:hidden;
  background:radial-gradient(820px 380px at 82% -25%,rgba(227,6,19,.13),transparent 60%)}
.page-hero::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;-webkit-mask-image:radial-gradient(circle at 70% 0%,#000,transparent 75%);mask-image:radial-gradient(circle at 70% 0%,#000,transparent 75%)}
.page-hero .wrap{position:relative;z-index:2}
.page-hero h1{font-family:var(--display);font-weight:700;letter-spacing:-.025em;line-height:1.04;
  font-size:clamp(30px,4.4vw,54px);max-width:920px;color:var(--ink)}
.page-hero h1 .inf{color:var(--red);font-weight:800;letter-spacing:-.05em}
.page-hero .lead{color:var(--ink-soft);font-size:18px;font-weight:300;max-width:680px;margin-top:18px}

.crumb{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--ink-mute);
  margin-bottom:18px;display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.crumb a{color:var(--ink-mute);transition:color .2s}
.crumb a:hover{color:var(--red-bright)}
.crumb .sep{color:var(--line-strong)}
.crumb span:last-child{color:var(--ink-soft)}

/* ---- Inhalts-Layout ---- */
.page-body{padding:54px 0 8px}
.page-feat{border:1px solid var(--line);border-radius:10px;overflow:hidden;margin-bottom:38px;max-width:980px}
.page-feat img{width:100%;height:auto;display:block}

/* ---- Reiche Typografie aus the_content() ---- */
.cr-entry{color:var(--ink-soft);font-size:16.5px;font-weight:300;line-height:1.78;max-width:820px}
.cr-entry > *:first-child{margin-top:0}
.cr-entry p{margin:0 0 1.15em}
.cr-entry h2{font-family:var(--display);font-weight:700;color:var(--ink);letter-spacing:-.01em;
  font-size:clamp(24px,2.6vw,33px);line-height:1.14;margin:1.7em 0 .55em}
.cr-entry h3{font-family:var(--display);font-weight:600;color:var(--ink);font-size:21px;line-height:1.25;margin:1.5em 0 .45em}
.cr-entry h4{font-family:var(--display);font-weight:600;color:var(--ink);font-size:17.5px;margin:1.3em 0 .35em}
.cr-entry a{color:var(--red-bright);text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(227,6,19,.4);transition:text-decoration-color .2s}
.cr-entry a:hover{text-decoration-color:var(--red-bright)}
.cr-entry strong,.cr-entry b{color:var(--ink);font-weight:600}
.cr-entry em{color:var(--ink)}
.cr-entry ul,.cr-entry ol{margin:0 0 1.2em;padding:0;display:flex;flex-direction:column;gap:.55em}
.cr-entry ul li{list-style:none;position:relative;padding-left:1.5em}
.cr-entry ul li::before{content:"";position:absolute;left:.15em;top:.62em;width:7px;height:7px;border-radius:1px;background:var(--red);transform:rotate(45deg)}
.cr-entry ol{counter-reset:cr;padding-left:.2em}
.cr-entry ol li{list-style:none;position:relative;padding-left:2em;counter-increment:cr}
.cr-entry ol li::before{content:counter(cr);position:absolute;left:0;top:0;font-family:var(--mono);font-size:13px;font-weight:600;color:var(--red)}
.cr-entry li ul,.cr-entry li ol{margin:.55em 0 0}
.cr-entry img,.cr-entry figure img{max-width:100%;height:auto;border-radius:8px;border:1px solid var(--line);display:block}
.cr-entry figure{margin:1.7em 0}
.cr-entry figcaption{font-family:var(--mono);font-size:12px;color:var(--ink-mute);margin-top:9px;text-align:center}
.cr-entry blockquote{border-left:3px solid var(--red);padding:4px 0 4px 24px;margin:1.7em 0;color:var(--ink);font-size:19.5px;font-style:italic;font-weight:300;line-height:1.5}
.cr-entry blockquote p:last-child{margin-bottom:0}
.cr-entry hr{border:none;border-top:1px solid var(--line);margin:2.2em 0}
.cr-entry table{width:100%;border-collapse:collapse;font-size:14.5px;margin:0 0 1.4em;display:block;overflow-x:auto}
.cr-entry th,.cr-entry td{border:1px solid var(--line);padding:11px 15px;text-align:left;vertical-align:top}
.cr-entry th{background:var(--surface-2);font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);font-weight:600}
.cr-entry tr:nth-child(even) td{background:rgba(255,255,255,.02)}
.cr-entry code{font-family:var(--mono);font-size:.9em;background:var(--surface-2);padding:2px 6px;border-radius:4px;color:var(--red-bright)}
.cr-entry pre{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:18px 20px;overflow-x:auto;font-family:var(--mono);font-size:13.5px;margin:0 0 1.4em}
.cr-entry pre code{background:none;padding:0;color:var(--ink-soft)}

/* WordPress-Ausrichtungen */
.cr-entry .alignright{float:right;margin:.4em 0 1.2em 1.6em;max-width:50%}
.cr-entry .alignleft{float:left;margin:.4em 1.6em 1.2em 0;max-width:50%}
.cr-entry .aligncenter{margin-left:auto;margin-right:auto}
.cr-entry .wp-caption{max-width:100%}
.cr-entry .wp-block-button__link,.cr-entry .wp-block-button a{display:inline-flex;align-items:center;gap:9px;
  background:var(--red);color:#fff;font-weight:600;font-size:14.5px;padding:12px 22px;border-radius:2px;text-decoration:none}
.cr-entry .wp-block-button__link:hover{background:var(--red-bright)}
.cr-entry .wp-block-image{margin:1.7em 0}
@media(max-width:600px){.cr-entry .alignright,.cr-entry .alignleft{float:none;max-width:100%;margin:1.2em 0}}

/* ---- CTA-Band vor dem Footer ---- */
.cta-band{border-top:1px solid var(--line);padding:72px 0;
  background:radial-gradient(720px 320px at 50% -35%,rgba(227,6,19,.16),transparent 60%),var(--bg-2)}
.cta-band .inner{display:flex;justify-content:space-between;align-items:center;gap:34px;flex-wrap:wrap}
.cta-band h2{font-family:var(--display);font-weight:700;font-size:clamp(24px,3vw,38px);letter-spacing:-.02em;line-height:1.1;color:var(--ink)}
.cta-band h2 .inf{color:var(--red);font-weight:800;letter-spacing:-.05em}
.cta-band p{color:var(--ink-soft);font-weight:300;margin-top:11px;max-width:540px;font-size:16px}
@media(max-width:760px){.cta-band .inner{flex-direction:column;align-items:flex-start;gap:22px}}

/* ---- Beitrags-Meta (single) ---- */
.post-meta{font-family:var(--mono);font-size:12.5px;letter-spacing:.04em;color:var(--ink-mute);
  display:flex;gap:14px;align-items:center;margin-top:16px}
.post-meta .cat{color:var(--red-bright)}

/* ---- Suche / Archiv-Pagination ---- */
.cr-pagination{display:flex;gap:8px;flex-wrap:wrap;margin-top:40px}
.cr-pagination .page-numbers{font-family:var(--mono);font-size:14px;color:var(--ink-soft);
  border:1px solid var(--line-strong);border-radius:3px;padding:9px 14px;transition:.2s;display:inline-block}
.cr-pagination .page-numbers:hover{border-color:var(--red);color:var(--red-bright)}
.cr-pagination .page-numbers.current{background:var(--red);border-color:var(--red);color:#fff}
.cr-pagination .dots{border:none}

/* ---- Suchformular ---- */
.cr-search{display:flex;gap:10px;max-width:520px;margin-top:8px}
.cr-search input[type=search]{flex:1;background:var(--bg-2);border:1px solid var(--line-strong);border-radius:5px;
  padding:12px 15px;color:var(--ink);font-family:var(--sans);font-size:15px}
.cr-search input[type=search]:focus{border-color:var(--red);outline:none}

/* ---- 404 ---- */
.err404{text-align:center;padding:110px 0}
.err404 .big{font-family:var(--display);font-weight:800;font-size:clamp(86px,15vw,168px);color:var(--red);line-height:.85;letter-spacing:-.04em}
.err404 h1{font-family:var(--display);font-weight:700;font-size:clamp(24px,3vw,34px);margin:18px 0 12px;color:var(--ink)}
.err404 p{color:var(--ink-soft);font-weight:300;max-width:440px;margin:0 auto 28px}

/* ============================================================
   WPForms -> controlrooms Dark-Design (Kontaktformular)
   ============================================================ */
.cform .wpforms-container{margin:0;background:none}
.cform .wpforms-form .wpforms-field{padding:0 0 14px}
.cform .wpforms-field-label{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute);font-weight:400;margin:0 0 6px;display:block}
.cform .wpforms-required-label{color:var(--red)}
.cform .wpforms-form input[type=text],
.cform .wpforms-form input[type=email],
.cform .wpforms-form input[type=tel],
.cform .wpforms-form input[type=url],
.cform .wpforms-form input[type=number],
.cform .wpforms-form input[type=password],
.cform .wpforms-form textarea,
.cform .wpforms-form select{width:100%!important;background:var(--bg-2)!important;border:1px solid var(--line-strong)!important;border-radius:5px!important;padding:12px 14px!important;color:var(--ink)!important;font-family:var(--sans)!important;font-size:14.5px!important;line-height:1.4!important;transition:border-color .2s!important;box-shadow:none!important;max-width:none!important;margin:0!important}
.cform .wpforms-form input::placeholder,.cform .wpforms-form textarea::placeholder{color:var(--ink-mute);opacity:1}
.cform .wpforms-form input:focus,.cform .wpforms-form textarea:focus,.cform .wpforms-form select:focus{border-color:var(--red)!important;outline:none!important;box-shadow:none!important}
.cform .wpforms-form textarea{resize:vertical!important;min-height:110px!important}
.cform .wpforms-field-description{font-size:12px;color:var(--ink-mute);margin-top:6px}
/* Zwei-Spalten-Reihe (WPForms Spalten / Layout) */
.cform .wpforms-field-row,.cform .wpforms-layout-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:620px){.cform .wpforms-field-row,.cform .wpforms-layout-row{grid-template-columns:1fr}}
/* DSGVO / Checkbox */
.cform .wpforms-form .wpforms-field-checkbox ul,
.cform .wpforms-form .wpforms-field-gdpr-checkbox ul{margin:0;padding:0;list-style:none}
.cform .wpforms-form .wpforms-field-checkbox li,
.cform .wpforms-form .wpforms-field-gdpr-checkbox li{display:flex;gap:10px;align-items:flex-start;margin:0}
.cform .wpforms-form input[type=checkbox]{width:16px;height:16px;flex:none;margin-top:3px;accent-color:var(--red)}
.cform .wpforms-form .wpforms-field-label-inline{font-size:12.5px;color:var(--ink-mute);line-height:1.45;font-weight:300}
.cform .wpforms-form .wpforms-field-label-inline a{color:var(--ink-soft);text-decoration:underline}
/* Submit-Button = unser .btn-primary */
.cform .wpforms-submit-container{padding:0;margin-top:4px}
.cform button.wpforms-submit{width:100%!important;justify-content:center;background:var(--red)!important;color:#fff!important;font-family:var(--sans)!important;font-weight:600!important;font-size:14.5px!important;padding:13px 22px!important;border:1px solid transparent!important;border-radius:2px!important;cursor:pointer;transition:.22s ease!important;display:inline-flex!important;align-items:center;gap:9px;text-transform:none!important}
.cform button.wpforms-submit:hover{background:var(--red-bright)!important;transform:translateY(-2px);box-shadow:0 10px 30px -8px rgba(227,6,19,.6)}
/* Name-Feld First/Last (falls Format "Erweitert" bleibt) */
.cform .wpforms-form .wpforms-field-name .wpforms-field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cform .wpforms-form .wpforms-field-name .wpforms-field-sublabel{font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--ink-mute);margin-top:4px}

/* ============================================================
   Unterseiten: Zwei-Spalten-Layout + Sidebar (Phase D)
   ============================================================ */
.page-body .page-layout{display:grid;grid-template-columns:minmax(0,1fr) 318px;gap:46px;align-items:start}
.page-main{min-width:0}
.page-main .cr-entry{max-width:none}
.page-side{position:sticky;top:92px;display:flex;flex-direction:column;gap:18px}
@media(max-width:980px){.page-body .page-layout{grid-template-columns:1fr;gap:40px}.page-side{position:static}}

/* Sidebar-Cards */
.side-card{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:22px 22px 24px}
.side-card .side-h{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--line)}
/* Kontakt-Card */
.side-contact .person{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.side-contact .person .av{flex:none;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;font-size:14px;color:#fff;background:radial-gradient(circle at 30% 30%,#ff2230,#a8030d);margin-top:2px}
.side-contact .person > div{min-width:0}
.side-contact .person .pn{font-family:var(--display);font-weight:600;font-size:15px;color:var(--ink)}
.side-contact .person .pr{font-family:var(--mono);font-size:10.5px;letter-spacing:.03em;color:var(--ink-mute);margin-top:2px}
.side-contact .person .pphone{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;letter-spacing:-.01em;color:var(--ink-soft);margin-top:8px;overflow-wrap:anywhere}
.side-contact .person .pphone svg{flex:none;width:13px;height:13px;fill:currentColor;color:var(--red-bright)}
.side-contact .person .pphone svg[fill="none"]{fill:none!important}
.side-contact .person .pphone:hover{color:var(--red-bright)}
/* Mail-Icons (stroke-basiert) duerfen nicht gefuellt werden */
.cr-share a svg[fill="none"],.side-card svg[fill="none"]{fill:none!important}
.side-contact-rows{display:flex;flex-direction:column;gap:11px;margin:18px 0 18px;padding-top:16px;border-top:1px solid var(--line)}
.side-contact-rows a{display:flex;align-items:center;gap:11px;color:var(--ink-soft);font-size:13.5px;font-weight:300;word-break:break-word}
.side-contact-rows a:hover{color:var(--red-bright)}
.side-contact-rows .ci{flex:none;width:32px;height:32px;border:1px solid var(--line-strong);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--red-bright)}
.side-contact-rows .ci svg{width:15px;height:15px;fill:currentColor}
.side-contact-rows a:nth-child(2) .ci svg{fill:none}
.side-btn{width:100%;justify-content:center}
/* Neueste Beitraege */
.side-posts a{display:flex;gap:12px;padding:12px 0;border-top:1px solid var(--line);align-items:center}
.side-posts a:first-of-type{border-top:0;padding-top:0}
.side-posts a:last-of-type{padding-bottom:0}
.side-posts .pt{flex:none;width:58px;height:44px;border-radius:5px;overflow:hidden;background:var(--bg-2);display:block}
.side-posts .pt img{width:100%;height:100%;object-fit:cover;display:block}
.side-posts .px{display:flex;flex-direction:column;gap:3px;min-width:0}
.side-posts .ptitle{font-size:13px;color:var(--ink);line-height:1.3;font-weight:500;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.side-posts a:hover .ptitle{color:var(--red-bright)}
.side-posts .pmeta{font-family:var(--mono);font-size:10px;letter-spacing:.03em;color:var(--ink-mute)}
/* Partner */
.side-partner .pbadge{height:50px;width:auto;display:block;margin-bottom:16px}
.side-partner-row{display:flex;align-items:center;flex-wrap:wrap;gap:13px 18px;padding:15px 0 3px;border-top:1px solid var(--line);margin-bottom:14px}
.side-partner-row img{height:19px;width:auto;opacity:.85;transition:opacity .2s}
.side-partner-row img:hover{opacity:1}
.side-partner-row .wm{font-family:var(--display);font-weight:700;font-size:15px;color:var(--ink-soft);letter-spacing:.01em}
.side-partner p{font-size:12.5px;color:var(--ink-soft);font-weight:300;line-height:1.5}

/* Share-Leiste unter dem Titel */
.cr-share{display:flex;align-items:center;gap:11px;margin-top:24px}
.cr-share-lbl{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}
.cr-share a{width:36px;height:36px;border:1px solid var(--line-strong);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);transition:color .2s,background .2s,border-color .2s,transform .2s}
.cr-share a svg{width:16px;height:16px;fill:currentColor}
.cr-share a:hover{color:#fff;background:var(--red);border-color:var(--red);transform:translateY(-2px)}
/* Alte schwebende Share-Panels / MH-Social ausblenden (hohe Spezifitaet schlaegt Inline-!important) */
html body #cr-social-fixed-panel,html body .wp-socializer,html body .mh-social-top,html body .mh-social-bottom{display:none!important}

/* Alte helle Content-Box "Verwandte Artikel" -> dunkel */
.cr-entry .cr-related-articles{background:radial-gradient(560px 200px at 0% 0%,rgba(227,6,19,.08),transparent 60%),var(--surface-2)!important;border:1px solid rgba(227,6,19,.22)!important;border-left:3px solid var(--red)!important;border-radius:10px!important;box-shadow:0 12px 34px -18px rgba(227,6,19,.4)!important;color:var(--ink-soft)!important;padding:22px 24px!important;margin:34px 0!important}
.cr-entry .cr-related-articles strong{color:var(--ink)!important;font-family:var(--display)!important}
.cr-entry .cr-related-articles a{color:var(--red-bright)!important}
/* "Verwandte Themen" (.cr-related-topics) genauso dezent hervorheben */
.cr-entry .cr-related-topics{background:radial-gradient(560px 200px at 0% 0%,rgba(227,6,19,.08),transparent 60%),var(--surface-2)!important;border:1px solid rgba(227,6,19,.22)!important;border-left:3px solid var(--red)!important;border-radius:10px!important;box-shadow:0 12px 34px -18px rgba(227,6,19,.4)!important;color:var(--ink-soft)!important;padding:22px 24px!important;margin:34px 0!important}
.cr-entry .cr-related-topics strong{color:var(--red)!important;font-family:var(--mono)!important;font-size:11px!important;letter-spacing:.16em!important;text-transform:uppercase!important}
.cr-entry .cr-related-topics a{color:var(--red-bright)!important;font-weight:400!important}
.cr-entry .cr-related-topics li{margin:6px 0!important}

/* ============================================================
   FAQ aus dem Content (.cr-faq-highlight) -> dunkle Akkordeon-Card
   Hoehere Spezifitaet (.cr-entry ...) schlaegt die Inline-Styles
   ============================================================ */
.cr-entry .cr-faq-highlight{background:radial-gradient(700px 240px at 0% 0%,rgba(227,6,19,.07),transparent 58%),var(--surface-2)!important;border:1px solid rgba(227,6,19,.20)!important;border-left:3px solid var(--red)!important;border-radius:10px!important;box-shadow:0 12px 38px -18px rgba(227,6,19,.38)!important;padding:28px 30px!important;margin:36px 0!important;color:var(--ink-soft)!important}
.cr-entry .cr-faq-highlight .cr-faq-eyebrow{font-family:var(--mono)!important;font-size:11px!important;font-weight:600!important;letter-spacing:.2em!important;text-transform:uppercase!important;color:var(--red)!important;margin:0 0 10px!important}
.cr-entry .cr-faq-highlight h2{font-family:var(--display)!important;color:var(--ink)!important;font-size:26px!important;line-height:1.2!important;font-weight:700!important;margin:0 0 8px!important}
.cr-entry .cr-faq-highlight .cr-faq-item{border-top:1px solid var(--line)!important;padding:0!important;margin:0!important}
.cr-entry .cr-faq-highlight .cr-faq-item:first-of-type{border-top:0!important}
.cr-entry .cr-faq-highlight .cr-faq-item h3{color:var(--ink)!important;font-family:var(--display)!important;font-weight:600!important;font-size:17.5px!important;line-height:1.35!important;margin:0!important;padding:18px 38px 18px 0!important;position:relative;cursor:pointer;transition:color .2s;user-select:none}
.cr-entry .cr-faq-highlight .cr-faq-item h3:hover{color:var(--red-bright)!important}
.cr-entry .cr-faq-highlight .cr-faq-item h3::after{content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-family:var(--mono);font-size:22px;font-weight:400;color:var(--red);transition:transform .25s}
.cr-entry .cr-faq-highlight .cr-faq-item.cr-open h3::after{content:"";width:14px;height:2px;background:var(--red);right:0}
.cr-entry .cr-faq-highlight .cr-faq-item p{color:var(--ink-soft)!important;font-weight:300!important;line-height:1.7!important;max-height:0;overflow:hidden;opacity:0;margin:0!important;padding:0!important;transition:max-height .4s ease,opacity .3s ease,padding .4s ease}
.cr-entry .cr-faq-highlight .cr-faq-item.cr-open p{max-height:600px;opacity:1;padding:0 0 20px!important}

/* FAQ-Variante B: direkte h3 + p Paare (ohne .cr-faq-item) */
.cr-entry .cr-faq-highlight > h3{color:var(--ink)!important;font-family:var(--display)!important;font-weight:600!important;font-size:17.5px!important;line-height:1.35!important;margin:0!important;padding:18px 38px 18px 0!important;border-top:1px solid var(--line)!important;position:relative;cursor:pointer;transition:color .2s;user-select:none}
.cr-entry .cr-faq-highlight > h2 + h3{border-top:0!important}
.cr-entry .cr-faq-highlight > h3:hover{color:var(--red-bright)!important}
.cr-entry .cr-faq-highlight > h3::after{content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-family:var(--mono);font-size:22px;font-weight:400;color:var(--red);transition:transform .25s}
.cr-entry .cr-faq-highlight > h3.cr-open::after{content:"";width:14px;height:2px;background:var(--red);right:0}
.cr-entry .cr-faq-highlight > h3 + p{color:var(--ink-soft)!important;font-weight:300!important;line-height:1.7!important;max-height:0;overflow:hidden;opacity:0;margin:0!important;padding:0!important;transition:max-height .4s ease,opacity .3s ease,padding .4s ease}
.cr-entry .cr-faq-highlight > h3.cr-open + p{max-height:600px;opacity:1;padding:0 0 18px!important}

/* ============================================================
   Site-weiter Scroll-Reveal fuer Unterseiten-Inhalte
   Nur aktiv mit .cr-js (kein Flackern; ohne JS bleibt alles sichtbar)
   ============================================================ */
.cr-js .page-hero .crumb,
.cr-js .page-hero h1,
.cr-js .page-hero .lead,
.cr-js .page-hero .post-meta,
.cr-js .page-side > .side-card,
.cr-js .cta-band .inner,
.cr-js .cr-entry > *{
  opacity:0;transform:translateY(42px);
  transition:opacity .85s cubic-bezier(.16,1,.3,1),transform .85s cubic-bezier(.16,1,.3,1);
  will-change:opacity,transform;
}
.cr-js .page-hero .crumb.in,
.cr-js .page-hero h1.in,
.cr-js .page-hero .lead.in,
.cr-js .page-hero .post-meta.in,
.cr-js .page-side > .side-card.in,
.cr-js .cta-band .inner.in,
.cr-js .cr-entry > *.in{opacity:1;transform:none}

@media (prefers-reduced-motion: reduce){
  .cr-js .page-hero .crumb,.cr-js .page-hero h1,.cr-js .page-hero .lead,.cr-js .page-hero .post-meta,
  .cr-js .page-side > .side-card,.cr-js .cta-band .inner,.cr-js .cr-entry > *{
    opacity:1!important;transform:none!important;transition:none!important;
  }
}
/* Bestätigung / Fehler */
.cform .wpforms-confirmation-container-full{background:rgba(39,196,107,.12);border:1px solid rgba(39,196,107,.4);color:#7be0a4;border-radius:6px;padding:14px 16px;font-size:13.5px;margin:0}
.cform .wpforms-confirmation-container-full p{margin:0;color:#7be0a4}
.cform label.wpforms-error,.cform .wpforms-error{color:var(--red-bright);font-size:12px;font-weight:400}
.cform .wpforms-form input.wpforms-error,.cform .wpforms-form textarea.wpforms-error{border-color:var(--red)}

/* ============================================================
   Dedizierte Kontaktseite (page-kontakt.php)
   ============================================================ */
.contact-page{padding:56px 0 72px}
.contact-page .cr-kontakt-intro{margin:0 0 6px}
.contact-page .cr-kontakt-intro p{margin:0 0 12px}
.cdetail small{color:var(--ink-mute);font-weight:400}
/* Ansprechpartner */
.kont-persons{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:26px 0 22px}
.kperson{display:flex;gap:12px;align-items:flex-start;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:16px 16px}
.kperson .av{flex:0 0 auto;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:13px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--red),#b00510);letter-spacing:.02em}
.kperson .kp-name{font-weight:600;color:var(--ink);font-size:15px;line-height:1.2}
.kperson .kp-role{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);margin:2px 0 8px}
.kperson .kp-body a{display:block;color:var(--ink-soft);font-size:12.5px;line-height:1.7;overflow-wrap:anywhere;text-decoration:none}
.kperson .kp-body a:hover{color:var(--red-bright)}
/* Social-Reihe */
.csocial{display:flex;gap:12px;margin-top:6px}
.csocial a{width:42px;height:42px;border:1px solid var(--line-strong);border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:var(--ink-soft);transition:color .25s,background .25s,border-color .25s,transform .25s}
.csocial a svg{width:18px;height:18px;fill:currentColor}
.csocial a:hover{color:#fff;background:var(--red);border-color:var(--red);transform:translateY(-3px)}
/* Karte */
.cmap{margin-top:34px;border:1px solid var(--line);border-radius:14px;overflow:hidden;line-height:0;
  box-shadow:0 24px 60px -30px rgba(0,0,0,.7)}
.cmap iframe{display:block;width:100%;filter:grayscale(.25) contrast(1.05)}
@media(max-width:760px){ .kont-persons{grid-template-columns:1fr} }

/* Autoren-Byline (single.php) */
.post-author{display:flex;align-items:center;gap:12px;margin-top:20px;flex-wrap:wrap}
.post-author .pa-av{flex:0 0 auto;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:12px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--red),#b00510);letter-spacing:.02em}
.post-author .pa-meta{font-size:14px;color:var(--ink-mute);line-height:1.5}
.post-author .pa-meta a[rel="author"]{color:var(--ink);text-decoration:none}
.post-author .pa-meta a[rel="author"]:hover{color:var(--red-bright)}
.post-author .pa-connect{display:inline-flex;align-items:center;gap:5px;margin-left:10px;color:var(--red-bright);text-decoration:none;font-weight:500;white-space:nowrap}
.post-author .pa-connect svg{width:15px;height:15px;fill:currentColor}
.post-author .pa-connect:hover{text-decoration:underline}
