/*
 * AI-Act-Kompass — Marketing-Website.
 * Anti-AI-Design: ein fortlaufendes technisches Dokument, keine
 * SaaS-Landingpage. Keine Icon-Kacheln, keine Gradient-Buttons, keine
 * Schatten, keine alternierenden Farbbänder — Gliederung ausschließlich
 * über Linien, Nummerierung und Typografie, wie in einem Amtsblatt.
 */
:root {
  --paper: #f4f1ea;
  --ink: #14120e;
  --muted: #6b675e;
  --hairline: #c9c4b8;
  --accent: #a3271e;
  --serif: 'Iowan Old Style', 'Palatino Linotype', Palatino, Georgia, 'Times New Roman', serif;
  --mono: ui-monospace, 'SF Mono', Menlo, Consolas, 'Courier New', monospace;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--serif);
  line-height: 1.6;
  font-size: 17px;
}
a { color: inherit; text-decoration-color: var(--hairline); }
a:hover { color: var(--accent); text-decoration-color: var(--accent); }
.wrap { max-width: 800px; margin: 0 auto; padding: 0 24px; }

/* Kopfleiste: Aktenzeichen statt Marketing-Header */
.masthead { border-bottom: 1px solid var(--ink); font-family: var(--mono); font-size: 11px; letter-spacing: 0.03em; color: var(--muted); text-transform: uppercase; }
.masthead .wrap { padding: 7px 24px; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 6px; }

header.site { border-bottom: 3px double var(--ink); padding: 20px 0; }
header.site .wrap { display: flex; align-items: baseline; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.brand { font-size: 21px; font-weight: 700; letter-spacing: 0.01em; }
nav.main { display: flex; gap: 20px; align-items: center; flex-wrap: wrap; }
nav.main a { color: var(--ink); text-decoration: none; font-family: var(--mono); font-size: 12px; text-transform: uppercase; letter-spacing: 0.05em; border-bottom: 1px solid transparent; }
nav.main a:hover { color: var(--accent); border-bottom-color: var(--accent); }
.lang-switch { display: flex; gap: 0; border: 1px solid var(--ink); }
.lang-switch a { padding: 4px 8px; border-right: 1px solid var(--ink); font-size: 10px; text-decoration: none; color: var(--ink); }
.lang-switch a:last-child { border-right: none; }
.lang-switch a.active { background: var(--ink); color: var(--paper); }

/* Titelblock: Zeitungsschlagzeile, kein Hero-mit-Mockup */
.hero { padding: 44px 0 34px; }
.eyebrow { font-family: var(--mono); font-size: 11.5px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); border-bottom: 1px solid var(--hairline); padding-bottom: 10px; margin-bottom: 4px; }
h1.hero-title { font-size: 46px; margin: 14px 0 16px; font-weight: 700; letter-spacing: -0.01em; }
.hero-sub { font-size: 19px; color: var(--muted); font-style: italic; max-width: 620px; margin: 0 0 24px; }
.cta-row { display: flex; gap: 0; flex-wrap: wrap; margin-bottom: 16px; border: 1px solid var(--ink); align-self: flex-start; width: fit-content; }
.btn { display: inline-block; padding: 12px 22px; font-family: var(--mono); font-size: 12.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.03em; text-decoration: none; border: none; border-right: 1px solid var(--ink); }
.cta-row .btn:last-child { border-right: none; }
.btn.primary { background: var(--ink); color: var(--paper); }
.btn.primary:hover { background: var(--accent); color: var(--paper); }
.btn.ghost { color: var(--ink); background: transparent; }
.btn.ghost:hover { color: var(--accent); }
.trust-line { font-family: var(--mono); font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.03em; }

section { padding: 40px 0; border-top: 1px solid var(--hairline); }
section:first-of-type { border-top: none; }
h2.section-title { font-family: var(--mono); font-size: 13px; text-transform: uppercase; letter-spacing: 0.06em; margin: 0 0 24px; color: var(--muted); }
.problem-body { font-size: 17px; max-width: 700px; }
.problem-body::first-letter { font-size: 3.4em; float: left; line-height: 0.85; padding: 0.03em 0.09em 0 0; font-weight: 700; }

/* Funktionen als nummerierte Paragraphen statt Icon-Kacheln */
.clause-list { max-width: 720px; }
.clause { display: grid; grid-template-columns: 44px 1fr; gap: 4px 18px; padding: 16px 0; border-bottom: 1px solid var(--hairline); }
.clause:last-child { border-bottom: none; }
.clause .num { font-family: var(--mono); font-size: 15px; color: var(--accent); font-weight: 700; padding-top: 2px; }
.clause h3 { font-size: 17px; margin: 0 0 6px; grid-column: 2; }
.clause p { font-size: 15px; color: var(--muted); margin: 0; grid-column: 2; }

.steps { max-width: 720px; }
.step { display: grid; grid-template-columns: 44px 1fr; gap: 4px 18px; padding: 14px 0; }
.step .num { font-family: var(--mono); font-size: 15px; font-weight: 700; padding-top: 2px; }
.step h3 { margin: 0 0 4px; font-size: 16.5px; grid-column: 2; }
.step p { font-size: 15px; color: var(--muted); margin: 0; grid-column: 2; }

/* Preise als Gebührenordnung/Tarifschema statt Pricing-Karten */
table.tariff { border-collapse: collapse; width: 100%; max-width: 720px; font-size: 15px; }
table.tariff th, table.tariff td { border: 1px solid var(--hairline); padding: 10px 14px; text-align: left; vertical-align: top; }
table.tariff thead th { font-family: var(--mono); font-size: 11.5px; text-transform: uppercase; letter-spacing: 0.04em; background: transparent; border-bottom: 2px solid var(--ink); color: var(--muted); }
table.tariff thead th.plan-col { color: var(--ink); font-weight: 700; }
table.tariff tbody td.plan-col { font-family: var(--mono); font-size: 13.5px; }
table.tariff tfoot td { font-family: var(--mono); font-size: 15px; font-weight: 700; border-top: 2px solid var(--ink); }
.pricing-note { font-size: 13.5px; color: var(--muted); margin-top: 14px; max-width: 700px; }

.faq-item { border-bottom: 1px solid var(--hairline); padding: 16px 0; max-width: 720px; }
.faq-item:last-child { border-bottom: none; }
.faq-item h3 { font-size: 16px; margin: 0 0 6px; }
.faq-item p { font-size: 15px; color: var(--muted); margin: 0; }

footer.site { border-top: 3px double var(--ink); padding: 28px 0; }
footer.site .wrap { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 14px; align-items: flex-start; }
.foot-disclaimer { font-family: var(--mono); font-size: 10.5px; color: var(--muted); max-width: 560px; border-left: 3px solid var(--accent); padding-left: 12px; }
.foot-links { display: flex; gap: 16px; flex-wrap: wrap; }
.foot-links a { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.03em; color: var(--ink); text-decoration: none; }
.foot-links a:hover { color: var(--accent); }
.foot-copy { font-family: var(--mono); font-size: 10.5px; color: var(--muted); margin-top: 8px; }

.legal-page .wrap { max-width: 720px; padding-top: 44px; padding-bottom: 60px; }
.legal-page h1 { font-size: 28px; border-bottom: 3px double var(--ink); padding-bottom: 12px; }
.legal-page h2 { font-size: 17px; margin-top: 28px; }
.legal-page p, .legal-page li { font-size: 15px; }
.legal-page .placeholder { background: transparent; border: 1.5px dashed var(--accent); color: var(--accent); padding: 10px 14px; font-family: var(--mono); font-size: 12px; }

@media (max-width: 680px) {
  body { font-size: 16px; }
  h1.hero-title { font-size: 32px; }
  .hero-sub { font-size: 16px; }
  nav.main { order: 3; width: 100%; justify-content: space-between; }
  .clause, .step { grid-template-columns: 32px 1fr; gap: 3px 12px; }
  table.tariff { font-size: 13px; }
  table.tariff th, table.tariff td { padding: 7px 8px; }
}
