/* =========================================================
   PATTERNS.CSS — Ergänzungen für Live-Site-Funktionen
   (Newsletter, Tag-Cloud, Footer-Magazin, Suche, YT-Embed,
    Pagination, Checkliste, Related-Posts)
   ========================================================= */

/* Footer-Bereich (newsletter, tag-cloud, footer-magazin) muss
   die feste Sidebar (100px) freihalten — sonst Überlappung. */
body > footer,
.wp-site-blocks > footer,
footer.footer-magazin,
footer .newsletter-box,
footer .tag-cloud {
  padding-left: max(100px, env(safe-area-inset-left));
  padding-right: var(--gutter, 32px);
  box-sizing: border-box;
}
footer .newsletter-box,
footer .tag-cloud { margin-left: 0; margin-right: 0; }

/* ---------- Newsletter-Box ---------- */
.newsletter-box {
  margin: 64px 0;
  padding: 48px 56px;
  background: var(--bg-alt);
  border: 1px solid var(--line);
  border-radius: 4px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
.newsletter-box .nl-text h3 {
  font-family: var(--fs-italic);
  font-style: italic;
  font-weight: 600;
  font-size: 36px;
  line-height: 1.15;
  margin: 12px 0 16px;
  color: var(--ink);
}
.newsletter-box .nl-text p {
  font-family: var(--fs-serif);
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink-soft);
  margin: 0;
}
.newsletter-box .nl-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.newsletter-box .nl-form input {
  padding: 14px 16px;
  background: var(--bg);
  border: 1px solid var(--line);
  font-family: var(--fs-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  color: var(--ink);
  border-radius: 3px;
}
.newsletter-box .nl-form input:focus {
  outline: none;
  border-color: var(--navy);
}
.newsletter-box .nl-form button {
  padding: 14px 18px;
  background: var(--navy);
  color: white;
  border: 0;
  font-family: var(--fs-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 3px;
  transition: background .2s;
}
.newsletter-box .nl-form button:hover { background: var(--navy-deep); }
.newsletter-box .nl-meta {
  font-family: var(--fs-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--muted);
  margin: 6px 0 0;
  line-height: 1.5;
}
.newsletter-box .nl-meta a { color: var(--navy); }
@media (max-width: 720px) {
  .newsletter-box { grid-template-columns: 1fr; padding: 32px; gap: 28px; }
  .newsletter-box .nl-text h3 { font-size: 28px; }
}

/* ---------- Tag-Cloud (Schlagwörter) ---------- */
.tag-cloud {
  margin: 56px 0;
  padding: 32px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.tag-cloud .tags {
  margin-top: 18px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.tag-cloud .tag {
  display: inline-block;
  padding: 6px 12px;
  background: var(--bg-alt);
  border: 1px solid var(--line);
  font-family: var(--fs-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
  text-decoration: none;
  border-radius: 3px;
  transition: background .15s, color .15s, border-color .15s;
  cursor: pointer;
}
.tag-cloud .tag:hover {
  background: var(--navy-soft);
  border-color: var(--navy);
  color: var(--navy);
}

/* ---------- Footer-Magazin (4 Spalten) ---------- */
.footer-magazin {
  margin-top: 80px;
  padding: 56px 0 48px;
  border-top: 1px solid var(--line);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 48px;
}
.footer-magazin .ft-col {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.footer-magazin .ft-col .eyebrow { margin-bottom: 8px; }
.footer-magazin .ft-col a {
  font-family: var(--fs-serif);
  font-size: 15px;
  color: var(--ink-soft);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  width: fit-content;
}
.footer-magazin .ft-col a:hover {
  border-bottom-color: var(--navy);
  color: var(--navy);
}
.footer-magazin .ft-meta p {
  font-family: var(--fs-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--muted);
  line-height: 1.6;
  margin: 8px 0 0;
}
.footer-magazin .ft-meta a { font-family: var(--fs-mono); font-size: 11px; }
@media (max-width: 720px) {
  .footer-magazin { grid-template-columns: 1fr 1fr; gap: 32px; }
}

/* ---------- Suche (Topbar-Trigger + Overlay) ---------- */
.topbar .search-trigger {
  font-size: 16px;
  margin-left: 8px;
  color: var(--ink);
  text-decoration: none;
  padding: 4px 8px;
  border: 1px solid transparent;
  border-radius: 3px;
}
.topbar .search-trigger:hover {
  color: var(--navy);
  border-color: var(--line);
}
.search-overlay {
  position: fixed;
  inset: 0;
  background: rgba(239, 238, 234, 0.96);
  backdrop-filter: blur(8px);
  z-index: 100;
  display: none;
  align-items: flex-start;
  justify-content: center;
  padding-top: 18vh;
}
.search-overlay.open { display: flex; }
.search-overlay .search-box {
  width: 92%;
  max-width: 720px;
}
.search-overlay input {
  width: 100%;
  padding: 18px 20px;
  background: white;
  border: 1px solid var(--line);
  font-family: var(--fs-italic);
  font-style: italic;
  font-size: 28px;
  color: var(--ink);
  border-radius: 4px;
}
.search-overlay input:focus { outline: none; border-color: var(--navy); }
.search-overlay .hint {
  font-family: var(--fs-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 14px;
  text-align: center;
}

/* ---------- YouTube-Embed (Borlabs-Slot) ---------- */
.yt-embed { margin: 48px auto; max-width: 1100px; padding: 0 32px; }
.yt-placeholder {
  background: var(--ink);
  color: var(--bg);
  padding: 56px 48px;
  border-radius: 4px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.yt-placeholder::before {
  content: "▷";
  position: absolute;
  top: 24px;
  right: 32px;
  font-size: 48px;
  color: rgba(255,255,255,.12);
}
.yt-placeholder .eyebrow {
  color: rgba(255,255,255,.7);
  display: block;
  margin-bottom: 16px;
}
.yt-placeholder h4 {
  font-family: var(--fs-italic);
  font-style: italic;
  font-weight: 600;
  font-size: 26px;
  margin: 0 0 12px;
  color: var(--bg);
}
.yt-placeholder p {
  font-family: var(--fs-serif);
  font-size: 15px;
  line-height: 1.55;
  color: rgba(255,255,255,.75);
  max-width: 540px;
  margin: 0 auto 24px;
}
.yt-placeholder button {
  background: var(--navy);
  color: white;
  border: 0;
  padding: 14px 28px;
  font-family: var(--fs-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 3px;
  transition: background .2s;
}
.yt-placeholder button:hover { background: var(--navy-deep); }
.yt-placeholder .yt-meta {
  display: block;
  margin-top: 16px;
  font-family: var(--fs-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  color: rgba(255,255,255,.5);
}
.yt-placeholder .yt-meta a { color: rgba(255,255,255,.85); text-decoration: underline; }

/* ---------- Pagination (Custom + WP-Core) ---------- */
.pagination,
.wp-block-query-pagination,
nav.wp-block-query-pagination {
  display: flex !important;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 4px;
  margin-top: 48px;
  padding-top: 32px;
  border-top: 1px solid var(--line);
}
.pagination a,
.pagination span,
.wp-block-query-pagination a,
.wp-block-query-pagination span,
.wp-block-query-pagination .page-numbers,
.wp-block-query-pagination-numbers .page-numbers,
.wp-block-query-pagination-previous,
.wp-block-query-pagination-next {
  font-family: var(--fs-mono) !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  font-style: normal !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: var(--ink-soft) !important;
  text-decoration: none !important;
  padding: 10px 14px !important;
  margin: 0 !important;
  border: 1px solid transparent !important;
  border-radius: 3px !important;
  line-height: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 38px !important;
  box-sizing: border-box !important;
  cursor: pointer;
  background: transparent !important;
}
.pagination a:hover,
.wp-block-query-pagination a:hover,
.wp-block-query-pagination .page-numbers:hover {
  border-color: var(--line) !important;
  color: var(--navy) !important;
}
.pagination .pg-num.active,
.wp-block-query-pagination .page-numbers.current,
.wp-block-query-pagination-numbers .page-numbers.current {
  color: var(--navy) !important;
  border-color: var(--navy) !important;
  font-weight: 600 !important;
}
.pagination .pg-arrow,
.wp-block-query-pagination-previous,
.wp-block-query-pagination-next { padding: 10px 18px !important; }
.wp-block-query-pagination-numbers { display: inline-flex; gap: 4px; align-items: center; }

/* ---------- Archiv-Filter Chips ---------- */
.archiv-filter {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin: 24px 0 0;
  padding-bottom: 12px;
}
.archiv-filter .chip {
  padding: 7px 14px;
  background: transparent;
  border: 1px solid var(--line);
  font-family: var(--fs-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
  text-decoration: none;
  border-radius: 3px;
  cursor: pointer;
}
.archiv-filter .chip:hover { border-color: var(--navy); color: var(--navy); }
.archiv-filter .chip.active { background: var(--navy); border-color: var(--navy); color: white; }
.archiv-filter .filter-divider { color: var(--muted); padding: 0 6px; font-family: var(--fs-mono); }

/* ---------- Checkliste (Sicherheit) ---------- */
.checklist {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
}
@media (max-width: 1100px) {
  .checklist { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px) {
  .checklist { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .checklist { grid-template-columns: 1fr; }
}
.checklist .check-item {
  padding: 28px 24px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--bg);
}
.checklist .num {
  font-family: var(--fs-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--navy);
  margin-bottom: 12px;
}
.checklist .lbl {
  display: block;
  font-family: var(--fs-italic);
  font-style: italic;
  font-weight: 600;
  font-size: 22px;
  color: var(--ink);
  margin-bottom: 8px;
  line-height: 1.2;
}
.checklist .desc {
  font-family: var(--fs-serif);
  font-size: 14px;
  line-height: 1.55;
  color: var(--muted);
}

/* ---------- Related Posts ---------- */
.related {
  max-width: 1100px;
  margin: 64px auto;
  padding: 48px 32px 0;
  border-top: 1px solid var(--line);
}
.related .eyebrow {
  display: block;
  margin-bottom: 24px;
}

/* ---------- Single-Post: Sidebar-Offset für Sections außerhalb .container ---------- */
@media (min-width: 720px) {
  main.page > .yt-embed,
  main.page > .related,
  main.page > .comments,
  main.page > .footer-magazin {
    margin-left: 132px;
    margin-right: 32px;
  }
  main.page > .footer-magazin {
    max-width: calc(100% - 164px);
    padding-left: 0;
    padding-right: 0;
  }
}

/* ---------- Comments (Single-Post) ---------- */
.comments {
  max-width: 1100px;
  margin: 0 auto 80px;
  padding: 48px 0;
  border-top: 1px solid var(--line);
}
.comments h3 {
  font-family: var(--fs-italic);
  font-style: italic;
  font-weight: 600;
  font-size: 28px;
  margin: 0 0 32px;
  color: var(--ink);
}
/* WP wraps Kommentar-Liste in <ol class="wp-block-comment-template"> — Defaults killen */
.wp-block-comment-template,
.comment-list,
.comments ol,
.comments ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.wp-block-comment-template > li,
.comment-list > li {
  list-style: none;
  padding: 24px 0;
  margin: 0;
  border-bottom: 1px solid var(--line-soft);
}
/* Custom Wrapper: Avatar links, Content rechts */
.comment-wrap {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 20px;
  align-items: start;
}
.comment-content {
  min-width: 0;
  width: 100%;
}
.comment-head {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 6px;
}
.comment-wrap .avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--navy-soft);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--fs-mono);
  font-size: 12px;
  color: var(--navy);
  font-weight: 600;
  letter-spacing: 0.05em;
}
.comment-wrap .avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.comment-wrap .name {
  font-family: var(--fs-italic);
  font-style: italic;
  font-weight: 600;
  font-size: 17px;
  color: var(--ink);
  display: inline-block;
}
.comment-wrap .date {
  font-family: var(--fs-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  display: inline-block;
}
.comment-wrap .body {
  color: var(--ink-soft);
  font-size: 15.5px;
  line-height: 1.65;
  margin-top: 4px;
  font-family: var(--fs-serif);
}
.comment-wrap .body p { margin: 0 0 0.8em; }
.comment-wrap .comment-reply {
  display: inline-block;
  margin-top: 10px;
  font-family: var(--fs-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--navy);
}
.comment-wrap .comment-reply:hover { color: var(--navy-deep); }
/* Verschachtelte Antworten */
.wp-block-comment-template .wp-block-comment-template,
.comment-list .children { margin: 16px 0 0; padding: 16px 0 0 36px; border-left: 1px solid var(--line-soft); }
.comment-form { margin-top: 32px; }
.comment-form textarea {
  width: 100%;
  min-height: 110px;
  padding: 16px;
  background: var(--bg);
  border: 1px solid var(--line);
  font-family: var(--fs-serif);
  font-size: 15px;
  color: var(--ink);
  resize: vertical;
  border-radius: 4px;
  box-sizing: border-box;
}
.comment-form textarea:focus { outline: none; border-color: var(--navy); }
.comment-form .row {
  display: flex;
  gap: 16px;
  margin-top: 14px;
  align-items: center;
  flex-wrap: wrap;
}
.comment-form input[type=text],
.comment-form input[type=email],
.comment-form input[type=url],
.comment-form input[type=tel],
.comment-form input[type=password],
.comment-form input:not([type]) {
  flex: 1;
  min-width: 180px;
  padding: 12px 14px;
  background: var(--bg);
  border: 1px solid var(--line);
  font-family: var(--fs-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink);
  border-radius: 3px;
}
.comment-form input:focus { outline: none; border-color: var(--navy); }
/* Cross-Browser: WP-Core-Form bekommt sonst weißes UA-Default für E-Mail/URL */
.comment-form input { background: var(--bg) !important; }
.comment-form button,
.comment-form input[type=submit],
.comment-form .submit,
.comment-form #submit,
.wp-block-post-comments-form input[type=submit],
.wp-block-post-comments-form .submit,
form.comment-form input[type=submit],
p.form-submit input[type=submit],
p.form-submit .submit {
  background: var(--navy) !important;
  color: #ffffff !important;
  border: 0 !important;
  padding: 13px 28px !important;
  font-family: var(--fs-mono) !important;
  font-size: 11px !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  border-radius: 3px !important;
  transition: background .2s !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  display: inline-block !important;
  width: auto;
  text-shadow: none !important;
  box-shadow: none !important;
}
.comment-form button:hover,
.comment-form input[type=submit]:hover,
p.form-submit input[type=submit]:hover { background: var(--navy-deep) !important; }
p.form-submit { margin-top: 18px; }

/* ---------- Cookie Banner (Single) ---------- */
.cookie {
  position: fixed;
  bottom: 24px;
  left: 132px;
  right: 32px;
  background: var(--ink);
  color: var(--bg);
  padding: 18px 22px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  gap: 24px;
  z-index: 30;
  box-shadow: 0 12px 40px rgba(0,0,0,.18);
  font-family: var(--fs-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.cookie .msg { flex: 1; line-height: 1.5; max-width: 720px; text-transform: none; letter-spacing: 0.04em; font-size: 12px; font-family: var(--fs-serif); }
.cookie .msg strong { color: var(--bg); font-weight: 600; }
.cookie .actions { display: flex; gap: 10px; }
.cookie button {
  background: transparent;
  color: var(--bg);
  border: 1px solid rgba(255,255,255,.3);
  padding: 10px 16px;
  font-family: var(--fs-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .2s, color .2s;
  border-radius: 3px;
}
.cookie button.primary { background: var(--navy); border-color: var(--navy); }
.cookie button.primary:hover { background: var(--navy-deep); border-color: var(--navy-deep); }
.cookie button:hover { background: rgba(255,255,255,.08); }
.cookie.hide { display: none; }
@media (max-width: 720px) {
  .cookie { left: 16px; right: 16px; flex-direction: column; align-items: flex-start; }
}

/* ---------- Native core/tag-cloud → Brand-Pills ---------- */
.tag-cloud .wp-block-tag-cloud {
  margin-top: 18px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.tag-cloud .wp-block-tag-cloud a,
.tag-cloud .tag-cloud-link {
  display: inline-block !important;
  padding: 6px 12px !important;
  background: var(--bg-alt);
  border: 1px solid var(--line);
  font-family: var(--fs-mono) !important;
  font-size: 11px !important;
  letter-spacing: 0.08em;
  color: var(--ink-soft) !important;
  text-decoration: none;
  border-radius: 3px;
  transition: background .15s, color .15s, border-color .15s;
}
.tag-cloud .wp-block-tag-cloud a:hover,
.tag-cloud .tag-cloud-link:hover {
  background: var(--navy-soft);
  border-color: var(--navy);
  color: var(--navy) !important;
}

/* Theme-Breadcrumb (Yoast oder Fallback) */
.ra-breadcrumb {
  font-family: var(--fs-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 24px;
}
.ra-breadcrumb a {
  color: var(--navy);
  text-decoration: none;
  border-bottom: 1px solid transparent;
}
.ra-breadcrumb a:hover { border-bottom-color: var(--navy); }

/* ---------- Native Block → Brand-Mapping (Single-Post Body) ---------- */
/* Damit Redakteure native Gutenberg-Blöcke nutzen können und trotzdem
   das Magazin-Layout aus styles.css greift. */

.wp-block-pullquote.is-style-ra-navy {
  text-align: center;
  margin: 80px auto;
  max-width: 1000px;
  padding: 0 32px;
  border: 0;
  background: transparent;
}
.wp-block-pullquote.is-style-ra-navy blockquote { border: 0; padding: 0; }
.wp-block-pullquote.is-style-ra-navy p {
  font-family: var(--fs-display);
  font-weight: 700;
  font-size: clamp(28px, 3vw, 44px);
  line-height: 1.2;
  color: var(--navy);
  letter-spacing: -0.01em;
  quotes: "\201C" "\201D";
  margin: 0;
}
.wp-block-pullquote.is-style-ra-navy p::before { content: open-quote; }
.wp-block-pullquote.is-style-ra-navy p::after  { content: close-quote; }
.wp-block-pullquote.is-style-ra-navy cite {
  display: block;
  margin-top: 24px;
  font-family: var(--fs-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--muted);
  font-style: normal;
}

p.is-style-ra-lede,
.is-style-ra-lede > p {
  font-family: var(--fs-italic);
  font-style: italic;
  color: var(--navy);
  font-size: 22px;
  line-height: 1.45;
  font-weight: 500;
}

.wp-block-columns.section-headers {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  margin: 64px 0 32px;
}
.wp-block-columns.section-headers .wp-block-column { padding: 0; }
.wp-block-columns.section-headers h3 {
  font-family: var(--fs-italic);
  font-style: italic;
  font-weight: 600;
  font-size: 30px;
  margin: 0 0 18px;
  color: var(--ink);
}
.wp-block-columns.section-headers p {
  font-size: 15.5px;
  line-height: 1.7;
  color: var(--ink-soft);
  margin: 0;
}

.wp-block-group.two-col {
  column-count: 2;
  column-gap: 48px;
  margin-top: 48px;
}
.wp-block-group.two-col p {
  margin: 0 0 1.2em;
  break-inside: avoid;
}
@media (max-width: 720px) {
  .wp-block-columns.section-headers { grid-template-columns: 1fr; }
  .wp-block-group.two-col { column-count: 1; }
}

.wp-block-separator.is-style-ra-hairline-tick {
  border: 0;
  border-top: 1px solid var(--line);
  margin: 48px 0;
  position: relative;
  opacity: 1;
}
.wp-block-separator.is-style-ra-hairline-tick::after {
  content: "";
  position: absolute;
  top: -3px;
  left: 50%;
  transform: translateX(-50%);
  width: 5px;
  height: 5px;
  background: var(--navy);
  border-radius: 50%;
}

/* ---------- Hamburger / Offcanvas-Navigation ---------- */
.ra-hamburger,
.hamburger {
  display: none;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: var(--bg);
  color: var(--ink);
  cursor: pointer;
  transition: border-color .2s, color .2s, background .2s, transform .15s;
  -webkit-appearance: none;
  appearance: none;
}
.ra-hamburger svg { display: block; }
.ra-hamburger:hover,
.hamburger:hover {
  border-color: var(--navy);
  color: var(--navy);
}
.ra-hamburger:active { transform: scale(0.96); }
.ra-hamburger:focus-visible {
  outline: 2px solid var(--navy);
  outline-offset: 2px;
}
/* Close-Button im Drawer (oben rechts in der Sidebar) */
.ra-hamburger-close {
  position: absolute;
  top: 18px;
  right: 18px;
  background: transparent;
  border-color: var(--line-soft);
  display: none;
}
/* Hauptnavigation im Drawer (Mobile-Mirror der Topbar-Links) */
.topbar-nav-mobile {
  display: none;
  margin: 28px 0 0;
  padding: 24px 0 0;
  border-top: 1px solid var(--line-soft);
  width: 100%;
}
.topbar-nav-mobile .ra-menu {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.topbar-nav-mobile .ra-menu a {
  writing-mode: initial;
  transform: none;
  font-family: var(--fs-italic);
  font-style: italic;
  font-weight: 600;
  font-size: 22px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--ink);
  padding: 4px 0;
}
.topbar-nav-mobile .ra-menu a:hover { color: var(--navy); }

@media (max-width: 720px) {
  body.ra-mobile-nav-open {
    overflow: hidden;
  }
  body.ra-mobile-nav-open::before {
    content: "";
    position: fixed;
    inset: 0;
    background: rgba(22,22,26,.22);
    backdrop-filter: blur(2px);
    z-index: 34;
  }
  .sidebar {
    width: min(78vw, 320px);
    height: 100vh;
    padding: 88px 24px 28px;
    align-items: flex-start;
    border-right: 1px solid var(--line);
    box-shadow: 18px 0 40px rgba(22,22,26,.08);
    transform: translateX(-100%);
    transition: transform .24s ease;
    z-index: 40;
  }
  body.ra-mobile-nav-open .sidebar {
    transform: translateX(0);
  }
  .page {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .sidebar .nav,
  .sidebar .ra-menu {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    width: 100%;
    max-height: none;
  }
  .sidebar .nav li,
  .sidebar .ra-menu li {
    writing-mode: initial;
    text-orientation: initial;
    width: 100%;
  }
  .sidebar .nav a,
  .sidebar .ra-menu a {
    writing-mode: initial;
    text-orientation: initial;
    white-space: normal;
    padding: 0;
    font-size: 11px;
    letter-spacing: 0.18em;
  }
  .sidebar .meta {
    writing-mode: initial;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    margin-top: 28px;
    font-size: 9px;
    letter-spacing: 0.16em;
  }
  .sidebar .ticks,
  .sidebar .vline {
    display: none;
  }
  .topbar {
    padding: 10px 16px;
    justify-content: space-between;
    z-index: 35;
  }
  .ra-hamburger-open,
  .hamburger {
    display: inline-flex;
  }
  body.ra-mobile-nav-open .ra-hamburger-close { display: inline-flex; }
  .topbar-nav-mobile { display: block; }
  /* Header-Nav kompakt — primär Brand + Hamburger */
  .topbar .links,
  .topbar .ra-menu,
  .topbar nav,
  .topbar .search-trigger { display: none !important; }
  .topbar .brand {
    font-size: 13px;
    letter-spacing: 0.22em;
  }

  /* Comment-Form: vertikal stacken, volle Breite */
  .comment-form .row {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .comment-form input[type=text],
  .comment-form input[type=email],
  .comment-form input[type=url],
  .comment-form input[type=tel],
  .comment-form input[type=password],
  .comment-form input:not([type]) {
    width: 100%;
    min-width: 0;
    flex: none;
    font-size: 13px;
    padding: 14px;
  }
  .comment-form textarea {
    min-height: 140px;
    font-size: 16px;
    padding: 14px;
  }
  .comment-form button,
  .comment-form input[type=submit],
  .comment-form .submit {
    width: 100%;
    padding: 16px !important;
    font-size: 12px !important;
    background: var(--navy) !important;
    color: #ffffff !important;
    border: 0 !important;
    font-family: var(--fs-mono) !important;
    letter-spacing: 0.22em !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    border-radius: 3px !important;
    -webkit-appearance: none !important;
    appearance: none !important;
  }
  .comments .comment-respond,
  .comments { padding: 0; }
  .comment-list .comment {
    padding: 16px 0;
    margin: 0;
  }
  .comment-list .comment-body {
    padding: 0;
    font-size: 15px;
  }
}

/* ---------- ra_nav Shortcode-Output (wp_nav_menu) ---------- */
.ra-menu {
  list-style: none;
  margin: 0;
  padding: 0;
}
.ra-menu .menu-item { margin: 0; padding: 0; }
.ra-menu .menu-item a {
  display: block;
  text-decoration: none;
  color: var(--ink);
  font-family: var(--fs-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 4px 0;
  border-bottom: 1px solid transparent;
  transition: color .15s, border-color .15s;
}
.ra-menu .menu-item a:hover,
.ra-menu .menu-item.current-menu-item a {
  color: var(--navy);
  border-bottom-color: var(--navy);
}

/* Sidebar: vertikal */
.sidebar .ra-menu {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.sidebar .ra-menu .menu-item a {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  padding: 0;
}

@media (max-width: 720px) {
  .sidebar .ra-menu .menu-item a {
    writing-mode: initial;
    transform: none;
    border-bottom: 0;
  }
}

/* Topbar: horizontal */
.topbar .ra-menu {
  display: flex;
  flex-direction: row;
  gap: 28px;
  align-items: center;
}

/* Footer: vertikal, weiches Serif statt Mono */
.footer-magazin .ra-menu {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.footer-magazin .ra-menu .menu-item a {
  font-family: var(--fs-serif);
  font-size: 15px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--ink-soft);
  padding: 0;
}
.footer-magazin .ra-menu .menu-item a:hover {
  color: var(--navy);
}
