/* ==========================================================================
   René Seidel — KI & Bildung
   Design tokens + base + components
   ========================================================================== */

@font-face {
  font-family: 'Cormorant Garamond';
  src: url('fonts/CormorantGaramond-VariableFont_wght.ttf') format('truetype-variations'),
       url('fonts/CormorantGaramond-VariableFont_wght.ttf') format('truetype');
  font-weight: 300 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Lora';
  src: url('fonts/Lora-VariableFont_wght.ttf') format('truetype-variations'),
       url('fonts/Lora-VariableFont_wght.ttf') format('truetype');
  font-weight: 400 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --ink: #2B2B2B;
  --grau: #5E5A56;
  --terra: #A8563A;
  --terra-deep: #8A4530;
  --terra-bright: #C46A4A;
  --terra-on-dark: #E0916F;
  --terra-tint: #EFDCD2;
  --creme: #E6DED4;
  --off: #F7F3EF;
  --sage: #566B56;
  --indigo: #3B4A6B;
  --gold: #8C6A1E;

  --terra-tint-deep: #E7C7B4;
  --indigo-tint: #DCE0E8;
  --indigo-tint-deep: #C2CADB;
  --sage-tint: #DEE6DC;
  --sage-tint-deep: #C4D3C1;
  --gold-tint: #EDE1C4;
  --gold-tint-deep: #E1CE9C;

  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Lora', Georgia, serif;

  --rule: rgba(43, 43, 43, 0.12);
  --rule-strong: rgba(43, 43, 43, 0.32);
  --rule-on-dark: rgba(247, 243, 239, 0.14);

  --radius: 4px;
  --ease: cubic-bezier(.22, .61, .36, 1);
  --t-fast: 150ms;
  --t-base: 220ms;

  --gutter: clamp(24px, 4.4vw, 48px);
  --max: 1240px;
}

.rs-site *, .rs-site *::before, .rs-site *::after { box-sizing: border-box; }

.rs-site {
  background: var(--off);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.5;
}

.rs-site h1, .rs-site h2, .rs-site h3, .rs-site p, .rs-site figure { margin: 0; }
.rs-site img { max-width: 100%; display: block; }
.rs-site [hidden] { display: none !important; }
.rs-site a { color: inherit; }
.rs-site button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; touch-action: manipulation; }
.rs-site input, .rs-site textarea { font: inherit; color: inherit; }

.rs-site a:focus-visible,
.rs-site button:focus-visible,
.rs-site input:focus-visible,
.rs-site textarea:focus-visible,
.rs-site [tabindex]:focus-visible {
  outline: 2px solid var(--ink);
  outline-offset: 3px;
  border-radius: 2px;
}
.rs-site .on-dark a:focus-visible,
.rs-site .on-dark button:focus-visible,
.rs-site .on-dark input:focus-visible {
  outline-color: var(--off);
}

.skip-link {
  position: absolute;
  left: 16px;
  top: -60px;
  z-index: 1000;
  background: var(--ink);
  color: var(--off);
  padding: 12px 18px;
  border-radius: var(--radius);
  font-family: var(--sans);
  font-size: 14px;
  text-decoration: none;
  transition: top var(--t-base) var(--ease);
}
.skip-link:focus { top: 16px; }

@media (prefers-reduced-motion: reduce) {
  .rs-site *, .rs-site *::before, .rs-site *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

.eyebrow { display: inline-block; font-family: var(--sans); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--terra); }
.on-dark .eyebrow { color: var(--terra-on-dark); }
.eyebrow-rule { display: block; width: 48px; height: 2px; background: var(--terra-bright); margin: 12px 0 20px; }
.on-dark .eyebrow-rule { background: var(--terra-on-dark); }

.h2 { font-family: var(--serif); font-weight: 600; font-size: clamp(26px, 2.2vw + 17px, 44px); line-height: 1.12; color: var(--ink); }
.h1 { font-family: var(--serif); font-weight: 600; font-size: clamp(36px, 3.6vw + 18px, 68px); line-height: 1.05; color: var(--ink); }

.site-header { display: flex; align-items: center; justify-content: space-between; padding: clamp(18px, 2.4vw, 28px) var(--gutter); position: sticky; top: 0; z-index: 40; background: var(--off); border-bottom: 1px solid transparent; transition: border-color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease); }
.site-header.is-scrolled { border-bottom-color: var(--rule); box-shadow: 0 1px 0 rgba(43,43,43,0.02); }

.brand { display: flex; align-items: baseline; gap: 8px; text-decoration: none; }
.brand-mark { width: 30px; height: 30px; object-fit: contain; margin-bottom: -5px; }
.brand-name { font-family: var(--serif); font-size: 28px; color: var(--ink); line-height: 1; }

.menu-toggle { display: flex; align-items: center; gap: 10px; padding: 10px 4px; font-family: var(--sans); font-size: 13px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink); min-height: 44px; }
.menu-toggle-icon { display: flex; width: 18px; height: 18px; }
.menu-toggle-icon svg { width: 18px; height: 18px; }
.icon-close { display: none; }
.menu-open .icon-menu { display: none; }
.menu-open .icon-close { display: block; }

.menu-overlay { position: fixed; inset: 0; z-index: 200; background: var(--off); display: flex; flex-direction: column; overflow-y: auto; transform: translateY(-8px); opacity: 0; pointer-events: none; transition: opacity var(--t-base) var(--ease), transform var(--t-base) var(--ease); }
.menu-overlay[data-open] { opacity: 1; transform: translateY(0); pointer-events: auto; }
.menu-overlay-header { display: flex; align-items: center; justify-content: space-between; padding: clamp(18px, 2.4vw, 28px) var(--gutter); }
.menu-body { flex: 1; padding: 0 var(--gutter); display: flex; flex-direction: column; justify-content: center; gap: 0; }
.menu-list { list-style: none; margin: 0; padding: 0; }
.menu-item { display: flex; align-items: baseline; gap: 24px; padding: 18px 0; border-bottom: 1px solid var(--rule); text-decoration: none; transition: opacity var(--t-fast) ease; }
.menu-item:hover, .menu-item:focus-visible { opacity: 0.6; }
.menu-item-num { font-family: var(--sans); font-size: 14px; color: var(--terra); width: 28px; flex-shrink: 0; }
.menu-item-label { font-family: var(--serif); font-size: clamp(32px, 5vw + 16px, 64px); font-weight: 600; color: var(--ink); line-height: 1; }
.menu-item[aria-current="page"] .menu-item-label { color: var(--terra); }
.menu-series { display: flex; flex-wrap: wrap; gap: 14px 28px; padding: 22px 0 18px 52px; }
.menu-series a { font-family: var(--sans); font-size: 14px; color: var(--grau); text-decoration: none; }
.menu-series a:hover, .menu-series a:focus-visible { color: var(--ink); }
.menu-footer { padding: clamp(18px, 2.4vw, 28px) var(--gutter); display: flex; justify-content: space-between; align-items: center; border-top: 1px solid var(--rule); flex-wrap: wrap; gap: 12px; }
.menu-footer span { font-family: var(--sans); font-size: 13px; color: var(--grau); }

body.menu-locked { overflow: hidden; }

.section { padding: clamp(56px, 9vw, 110px) var(--gutter); }
.section-top-flush { padding-top: 0; }
.band { padding: clamp(56px, 9vw, 110px) var(--gutter); text-align: center; }
.on-dark { background: var(--ink); color: var(--off); }
.on-creme { background: var(--creme); }

.container { max-width: var(--max); margin: 0 auto; }

.grid-two { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.grid-about { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: clamp(32px, 6vw, 64px); align-items: center; }
.grid-kontakt { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(40px, 6vw, 80px); }
.grid-leist-a { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px, 4vw, 48px); align-items: center; }
.grid-leist-b { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px, 4vw, 48px); align-items: center; }

@media (max-width: 860px) {
  .grid-two, .grid-about, .grid-kontakt, .grid-leist-a, .grid-leist-b { grid-template-columns: 1fr !important; }
}

.btn { display: inline-flex; align-items: center; gap: 10px; background: var(--terra); color: var(--off); border: 0; padding: 14px 26px; border-radius: var(--radius); font-family: var(--sans); font-size: 15px; font-weight: 500; text-decoration: none; min-height: 44px; transition: background var(--t-fast) ease, transform var(--t-fast) ease; }
.btn:hover { background: var(--terra-deep); color: var(--off); }
.btn:active { transform: translateY(1px); }

.link-underline { font-family: var(--sans); font-size: 14px; color: var(--ink); text-decoration: none; border-bottom: 1px solid var(--ink); padding-bottom: 2px; display: inline-block; }
.on-dark .link-underline { color: var(--off); border-bottom-color: var(--off); }

.hero { position: relative; overflow: hidden; min-height: clamp(420px, 56vh, 600px); display: flex; align-items: flex-end; }
.hero-media { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: 50% 28%; }
.elementor-widget-html { margin-block-end: 0 !important; }
.hero-scrim { position: absolute; inset: 0; background: linear-gradient(0deg, rgba(23,20,18,0.8) 0%, rgba(23,20,18,0.42) 40%, rgba(23,20,18,0.06) 65%, transparent 82%); pointer-events: none; }
.hero-content { position: relative; max-width: 620px; padding: clamp(32px, 6vw, 64px) var(--gutter) clamp(48px, 7vw, 72px); }
.hero-kicker { font-family: var(--sans); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--terra-on-dark); }
.hero-title { font-family: var(--serif); font-weight: 600; font-size: clamp(44px, 6vw + 16px, 96px); line-height: 1.03; color: var(--off); margin: 18px 0 0; }
.hero-rule { display: block; width: 48px; height: 2px; background: var(--terra-on-dark); margin: 28px 0 22px; }
.hero-lede { font-family: var(--sans); font-size: 17px; line-height: 1.65; color: rgba(247, 243, 239, 0.92); max-width: 460px; }
.hero-actions { display: flex; align-items: center; gap: 26px; margin-top: 34px; flex-wrap: wrap; }
.hero-arrow { font-family: var(--serif); }

.photo-band { position: relative; overflow: hidden; height: clamp(320px, 42vw, 560px); }
.photo-band img { width: 100%; height: 100%; object-fit: cover; display: block; }
.photo-band img.pos-top { object-position: 50% 10%; }

.cover-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 3.6vw, 44px) clamp(24px, 3.2vw, 40px); }
@media (max-width: 700px) { .cover-grid { grid-template-columns: 1fr; } }

.cover-card { display: flex; flex-direction: column; text-decoration: none; color: inherit; }
.cover-card-art { position: relative; overflow: hidden; border-radius: 8px; aspect-ratio: 16 / 11; background: var(--cc-tint, var(--terra-tint)); display: flex; align-items: center; justify-content: center; }
.cover-card-art::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 22% 18%, rgba(255,255,255,0.55), transparent 60%); pointer-events: none; }
.cover-card-art img { width: 62%; max-width: 220px; object-fit: contain; filter: drop-shadow(0 6px 18px rgba(43,43,43,0.08)); transition: transform var(--t-base) var(--ease); }
.cover-card:hover .cover-card-art img, .cover-card:focus-visible .cover-card-art img { transform: scale(1.05) rotate(-2deg); }
.cover-card-number { position: absolute; left: 18px; top: 14px; font-family: var(--serif); font-size: 16px; color: var(--cc-color, var(--terra)); opacity: 0.75; }
.cover-card-meta { padding-top: 22px; display: flex; flex-direction: column; gap: 8px; }
.cover-card-label { font-family: var(--sans); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--cc-color, var(--terra)); }
.cover-card-title { font-family: var(--serif); font-weight: 500; font-size: 27px; color: var(--ink); margin: 0; }
.cover-card-teaser { font-family: var(--sans); font-size: 14.5px; line-height: 1.55; color: var(--grau); margin: 0; }
.cover-card-cta { margin-top: 6px; font-family: var(--sans); font-size: 14px; color: var(--ink); display: inline-flex; align-items: center; gap: 8px; }
.cover-card-cta span { color: var(--cc-color, var(--terra)); font-family: var(--serif); font-size: 18px; transition: transform var(--t-fast) ease; }
.cover-card:hover .cover-card-cta span, .cover-card:focus-visible .cover-card-cta span { transform: translateX(4px); }
.is-hub .cover-card-art { aspect-ratio: 16 / 10; }
.is-hub .cover-card-title { font-size: 30px; }

.statement-band { position: relative; overflow: hidden; }
.statement-band-mark { position: absolute; right: -60px; bottom: -60px; width: 260px; height: 260px; object-fit: contain; opacity: 0.08; pointer-events: none; }
.statement-text { position: relative; font-family: var(--serif); font-weight: 600; font-size: clamp(24px, 2vw + 18px, 44px); line-height: 1.25; color: var(--off); max-width: 820px; margin: 0 auto; }

.preview-card { display: flex; flex-direction: column; gap: 18px; }
.preview-num { font-family: var(--serif); font-size: 15px; color: var(--terra); }
.preview-title { font-family: var(--serif); font-weight: 500; font-size: 24px; color: var(--ink); }
.preview-desc { font-family: var(--sans); font-size: 15px; line-height: 1.6; color: var(--grau); }

.about-photo { height: clamp(280px, 22vw, 340px); border-radius: var(--radius); overflow: hidden; }
.about-photo img { width: 100%; height: 100%; object-fit: cover; }
.about-title { font-family: var(--serif); font-weight: 500; font-size: 32px; color: var(--ink); margin: 0 0 20px; line-height: 1.15; }
.about-text { font-family: var(--sans); font-size: 16px; line-height: 1.65; color: var(--grau); max-width: 520px; margin: 0 0 24px; }

.cta-title { font-family: var(--serif); font-weight: 600; font-size: clamp(28px, 4vw + 12px, 48px); color: var(--off); margin: 20px 0 32px; }

.site-footer { background: var(--ink); color: var(--off); padding: clamp(48px, 7vw, 72px) var(--gutter) 24px; }
.site-header, .site-footer { max-width: none !important; width: 100% !important; margin-inline: 0 !important; }
.footer-top { display: grid; grid-template-columns: 1fr 2fr; gap: 48px; padding-bottom: 44px; border-bottom: 1px solid var(--rule-on-dark); }
.footer-brand { display: flex; align-items: baseline; gap: 8px; text-decoration: none; }
.footer-brand img { width: 34px; height: 34px; object-fit: contain; margin-bottom: -6px; }
.footer-brand span { font-family: var(--serif); font-size: 34px; color: var(--off); line-height: 1; }
.footer-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.footer-col-title { display: block; font-family: var(--sans); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--terra-on-dark); margin-bottom: 16px; }
.footer-col a { display: block; font-family: var(--sans); font-size: 14px; color: var(--off); text-decoration: none; margin-bottom: 10px; opacity: 0.85; }
.footer-col a:hover, .footer-col a:focus-visible { opacity: 1; }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 24px; flex-wrap: wrap; gap: 16px; }
.footer-bottom span, .footer-bottom a { font-family: var(--sans); font-size: 12px; color: rgba(247,243,239,0.6); text-decoration: none; }
.footer-bottom a:hover, .footer-bottom a:focus-visible { color: var(--off); }
.footer-legal { display: flex; gap: 24px; }

@media (max-width: 860px) {
  .footer-top { grid-template-columns: 1fr; gap: 32px; }
  .footer-cols { grid-template-columns: 1fr 1fr; }
}

@media (prefers-reduced-motion: no-preference) {
  [data-reveal] { opacity: 0; transform: translateY(14px); transition: opacity 0.6s var(--ease), transform 0.6s var(--ease); }
  [data-reveal].is-visible { opacity: 1; transform: translateY(0); }
}

/* Elementor editor safety: don't hide content while editing */
.elementor-editor-active [data-reveal] { opacity: 1 !important; transform: none !important; }

/* ==========================================================================
   RESTORED — missing since original deployment (image-slot, serie detail,
   ueber-topic, quote-band, credentials, leistungen, kontakt, legal)
   ========================================================================== */

.image-slot { width: 100%; display: flex; align-items: center; justify-content: center; text-align: center; border-radius: var(--radius); position: relative; overflow: hidden; background: linear-gradient(155deg, var(--terra-tint), var(--creme)); border: 1px solid var(--rule); color: var(--grau); font-family: var(--sans); font-size: 13px; letter-spacing: 0.04em; padding: 24px; }
.image-slot.shape-rounded { border-radius: 8px; }
.image-slot::after { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 30% 20%, rgba(255,255,255,0.5), transparent 55%); pointer-events: none; }
.image-slot-label { position: relative; max-width: 220px; }
.image-slot-mark { width: 34px; height: 34px; object-fit: contain; opacity: 0.5; margin: 0 auto 14px; position: relative; }
.image-slot.is-filled { background: none; border: 0; padding: 0; }
.image-slot.is-filled::after { content: none; }
.image-slot img { width: 100%; height: 100%; object-fit: cover; display: block; position: relative; }
.image-slot img.pos-top { object-position: 50% 10%; }
.image-slot.tint-indigo { background: linear-gradient(155deg, var(--indigo-tint), var(--creme)); }
.image-slot.tint-sage { background: linear-gradient(155deg, var(--sage-tint), var(--creme)); }
.image-slot.tint-gold { background: linear-gradient(155deg, var(--gold-tint), var(--creme)); }

.ueber-title { font-family: var(--serif); font-weight: 600; font-size: clamp(34px, 3.4vw + 18px, 56px); color: var(--ink); margin: 0 0 28px; line-height: 1.08; }
.ueber-text { font-family: var(--sans); font-size: 17px; line-height: 1.7; color: var(--grau); max-width: 560px; margin: 0 0 22px; }
.ueber-topic { padding: clamp(48px, 7vw, 80px) var(--gutter); }
.ueber-topic-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(32px, 6vw, 64px); align-items: center; }
.ueber-topic:nth-of-type(even) .ueber-topic-grid { grid-template-columns: 1.15fr 0.85fr; }
.ueber-topic:nth-of-type(even) .ueber-topic-art { order: 2; }
.ueber-topic-art { height: clamp(220px, 22vw, 300px); }
.ueber-topic-title { font-family: var(--serif); font-weight: 500; font-size: clamp(24px, 2vw + 14px, 32px); color: var(--ink); margin: 0 0 16px; line-height: 1.15; }
.ueber-topic-text { font-family: var(--sans); font-size: 16px; line-height: 1.7; color: var(--grau); max-width: 520px; margin: 0; }
@media (max-width: 700px) {
  .ueber-topic-grid, .ueber-topic:nth-of-type(even) .ueber-topic-grid { grid-template-columns: 1fr; }
  .ueber-topic:nth-of-type(even) .ueber-topic-art { order: 0; }
}

.quote-band { position: relative; overflow: hidden; }
.quote-mark { position: absolute; left: -50px; top: -50px; width: 220px; height: 220px; object-fit: contain; opacity: 0.08; pointer-events: none; }
.quote-text { position: relative; font-family: var(--serif); font-weight: 600; font-size: clamp(24px, 2.2vw + 16px, 40px); line-height: 1.3; color: var(--off); max-width: 780px; margin: 0 auto; }
.quote-attr { position: relative; display: block; margin-top: 24px; font-family: var(--sans); font-size: 13px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--terra-on-dark); }

.credentials-list { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 28px 40px; }
@media (max-width: 700px) { .credentials-list { grid-template-columns: 1fr; } }
.credential-item { display: flex; gap: 16px; align-items: flex-start; }
.credential-icon { flex-shrink: 0; width: 40px; height: 40px; border-radius: 50%; background: var(--terra-tint); display: flex; align-items: center; justify-content: center; color: var(--terra); }
.credential-icon svg { width: 18px; height: 18px; }
.credential-text { font-family: var(--sans); font-size: 15px; line-height: 1.55; color: var(--ink); padding-top: 8px; }

.back-link { display: inline-flex; align-items: center; gap: 6px; font-family: var(--sans); font-size: 14px; color: var(--grau); text-decoration: none; }
.back-link:hover, .back-link:focus-visible { color: var(--serie-color, var(--terra)); }
.serie-header { position: relative; overflow: hidden; background: var(--serie-tint, var(--terra-tint)); padding: clamp(40px, 6vw, 72px) var(--gutter) clamp(56px, 7vw, 80px); }
.serie-header-inner { position: relative; max-width: var(--max); margin: 0 auto; }
.serie-header-mark { position: absolute; right: -70px; top: -90px; width: clamp(280px, 32vw, 460px); height: clamp(280px, 32vw, 460px); object-fit: contain; opacity: 0.5; pointer-events: none; }
.serie-header-number { position: absolute; right: clamp(0px, 4vw, 24px); bottom: -0.28em; font-family: var(--serif); font-weight: 400; font-size: clamp(90px, 16vw, 220px); line-height: 1; color: var(--serie-color, var(--terra)); opacity: 0.14; pointer-events: none; }
.serie-eyebrow { color: var(--serie-color, var(--terra)); }
.serie-rule { background: var(--serie-color, var(--terra-bright)); }
.serie-headline { position: relative; font-family: var(--serif); font-weight: 600; font-size: clamp(30px, 4.6vw + 12px, 56px); color: var(--ink); margin: 0 0 24px; line-height: 1.08; max-width: 720px; }
.serie-sub { position: relative; font-family: var(--sans); font-size: 17px; line-height: 1.65; color: var(--grau); max-width: 640px; }
.serie-placeholder-note { position: relative; font-family: var(--sans); font-size: 13px; line-height: 1.5; color: var(--grau); max-width: 640px; margin: 14px 0 0; opacity: 0.75; }
.parts-list { list-style: none; margin: 0; padding: 0; }
.part-row { display: flex; gap: 28px; padding: 26px 0; border-top: 1px solid var(--rule); }
.part-mark { font-family: var(--serif); font-size: 20px; color: var(--serie-color, var(--terra)); width: 40px; flex-shrink: 0; }
.part-body { flex: 1; }
.part-eyebrow { font-family: var(--sans); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--grau); }
.part-title { font-family: var(--serif); font-weight: 500; font-size: 22px; margin: 6px 0 8px; color: var(--ink); }
.part-desc { font-family: var(--sans); font-size: 14px; line-height: 1.55; color: var(--grau); margin: 0 0 12px; max-width: 600px; }
.part-progress { height: 3px; background: var(--rule); border-radius: 2px; max-width: 280px; overflow: hidden; }
.part-progress-fill { height: 100%; background: var(--serie-color, var(--terra)); border-radius: 2px; }
@media (max-width: 480px) { .part-row { gap: 16px; } .part-mark { width: 30px; } }

.leist-block { padding: 0 var(--gutter) clamp(56px, 9vw, 96px); }
.leist-image { height: clamp(260px, 26vw, 360px); }
.leist-num { font-family: var(--serif); font-size: 16px; color: var(--terra); }
.leist-title { font-family: var(--serif); font-weight: 500; font-size: 30px; margin: 8px 0 18px; color: var(--ink); }
.leist-desc { font-family: var(--sans); font-size: 15px; line-height: 1.65; color: var(--grau); margin: 0 0 22px; max-width: 460px; }
.leist-bullets { list-style: none; margin: 0 0 26px; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.leist-bullets li { font-family: var(--sans); font-size: 14px; color: var(--ink); padding-left: 18px; position: relative; }
.leist-bullets li::before { content: '\2022'; position: absolute; left: 0; color: var(--terra); }

.kontakt-title { font-family: var(--serif); font-weight: 600; font-size: clamp(28px, 4vw + 12px, 48px); color: var(--ink); margin: 0 0 24px; line-height: 1.1; }
.kontakt-lede { font-family: var(--sans); font-size: 16px; line-height: 1.65; color: var(--grau); max-width: 380px; margin: 0 0 32px; }
.kontakt-photo { height: clamp(320px, 28vw, 420px); }
.kontakt-row { display: flex; align-items: center; gap: 10px; color: var(--ink); margin-bottom: 14px; position: relative; }
.kontakt-row:last-of-type { margin-bottom: 0; }
.kontakt-row svg { width: 18px; height: 18px; flex-shrink: 0; }
.kontakt-row a { font-family: var(--sans); font-size: 15px; color: var(--ink); text-decoration: none; border-bottom: 1px solid var(--ink); }
.kontakt-row.is-primary svg { width: 22px; height: 22px; color: var(--terra); }
.kontakt-row.is-primary a { font-family: var(--serif); font-size: clamp(20px, 1.6vw + 14px, 26px); color: var(--ink); border-bottom-color: transparent; transition: color var(--t-fast) ease, border-color var(--t-fast) ease; }
.kontakt-row.is-primary a:hover, .kontakt-row.is-primary a:focus-visible { color: var(--terra-deep); border-bottom-color: var(--terra); }
.contact-card { position: relative; overflow: hidden; background: var(--creme); border-radius: var(--radius); padding: clamp(32px, 4vw, 48px); display: flex; flex-direction: column; justify-content: center; gap: 22px; min-height: clamp(320px, 28vw, 420px); }
.contact-card-mark { position: absolute; right: -40px; bottom: -40px; width: 200px; height: 200px; object-fit: contain; opacity: 0.1; pointer-events: none; }
.contact-card-note { position: relative; font-family: var(--sans); font-size: 13px; color: var(--grau); margin: 6px 0 0; }

.legal-content { max-width: 720px; }
.legal-content h2 { font-family: var(--serif); font-weight: 400; font-size: 24px; margin: 40px 0 12px; }
.legal-content h2:first-child { margin-top: 0; }
.legal-content p { font-family: var(--sans); font-size: 15px; line-height: 1.7; color: var(--grau); margin: 0 0 14px; }
.legal-todo { background: var(--terra-tint); border-radius: var(--radius); padding: 14px 18px; font-family: var(--sans); font-size: 13px; color: var(--terra-deep); }

/* ==========================================================================
   Article (individual blog posts — cleaned Avada content)
   ========================================================================== */

.article-container { max-width: 760px; margin: 0 auto; }
.article-content .back-link { display: inline-block; margin-top: clamp(28px, 3.4vw, 36px); }
.article-header { padding: 8px var(--gutter) 40px; }
.article-header .eyebrow { color: var(--serie-color, var(--terra)); }
.article-header .eyebrow-rule { background: var(--serie-color, var(--terra-bright)); }
.article-title { font-family: var(--serif); font-weight: 600; font-size: clamp(28px, 3.4vw + 14px, 48px); color: var(--ink); line-height: 1.15; margin: 12px 0 0; }
.article-body { padding: 0 var(--gutter) clamp(56px, 9vw, 96px); font-family: var(--sans); font-size: 17px; line-height: 1.75; color: var(--ink); }
.article-body h3 { font-family: var(--serif); font-weight: 600; font-size: clamp(22px, 1.6vw + 16px, 30px); color: var(--ink); margin: 44px 0 16px; line-height: 1.2; }
.article-body h3:first-child { margin-top: 0; }
.article-body h4 { font-family: var(--serif); font-weight: 600; font-size: clamp(19px, 1vw + 15px, 22px); color: var(--serie-color, var(--terra)); margin: 36px 0 12px; line-height: 1.3; }
.article-body p { margin: 0 0 20px; }
.article-body > p:first-of-type { font-family: var(--serif); font-size: 20px; font-style: italic; color: var(--grau); line-height: 1.5; }
.article-body strong { color: var(--ink); font-weight: 600; }
.article-body hr { border: 0; border-top: 1px solid var(--rule); margin: 40px 0; }
.article-body blockquote { border-left: 3px solid var(--serie-color, var(--terra)); padding-left: 24px; margin: 32px 0; font-family: var(--serif); font-size: 20px; font-style: italic; color: var(--ink); line-height: 1.5; }
.article-body blockquote p { margin-bottom: 8px; }
.article-body blockquote p:last-child { margin-bottom: 0; }
.article-body ul, .article-body ol { margin: 0 0 20px; padding-left: 22px; }
.article-body li { margin-bottom: 8px; }
.article-body a { color: var(--serie-color, var(--terra)); text-decoration: underline; text-underline-offset: 2px; }
.article-body a:hover, .article-body a:focus-visible { color: var(--ink); }
.article-body a.btn { text-decoration: none; color: var(--off); }
.article-body a.btn:hover { color: var(--off); }
.article-toggle { border: 1px solid var(--rule); border-radius: var(--radius); padding: 18px 22px; margin: 0 0 16px; }
.article-toggle summary { font-family: var(--sans); font-weight: 600; font-size: 15px; color: var(--ink); cursor: pointer; }
.article-toggle[open] summary { margin-bottom: 14px; }
.article-toggle p { margin: 0 0 12px; font-size: 15px; }
.article-toggle p:last-child { margin-bottom: 0; }


