/* article.css — Blog-/Artikel-Typografie für caltrix.de
   Handgeschrieben (kein Tailwind-Rebuild nötig), markenkonform zum Caltrix-Design-System.
   Wird nur auf Blog-Seiten (Artikel, Übersicht, Kategorie) eingebunden. */

:root {
  --cx-primary: #1f628e;
  --cx-primary-dark: #195170;
  --cx-accent: #e09d71;
  --cx-cream: #fdfcfb;
  --cx-surface: #f8f4ef;
  --cx-muted: #4d6478;
  --cx-dark: #1a2e3b;
  --cx-border: #e4d9ce;
  --cx-fh: "DM Sans", system-ui, sans-serif;
  --cx-fb: "Lora", Georgia, serif;
}

/* ─── Layout ──────────────────────────────────────────────────────────────── */
.cx-wrap { max-width: 760px; margin: 0 auto; padding: 0 1.5rem; }
.cx-wrap--wide { max-width: 1080px; }

/* ─── Breadcrumb ──────────────────────────────────────────────────────────── */
.cx-breadcrumb { font-family: var(--cx-fh); font-size: .8rem; color: var(--cx-muted); margin: 2rem 0 1rem; }
.cx-breadcrumb a { color: var(--cx-muted); text-decoration: none; }
.cx-breadcrumb a:hover { color: var(--cx-primary); }
.cx-breadcrumb span { margin: 0 .4rem; opacity: .6; }

/* ─── Artikel-Kopf ────────────────────────────────────────────────────────── */
.cx-cat { display: inline-block; font-family: var(--cx-fh); font-size: .7rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em; color: var(--cx-primary);
  background: var(--cx-surface); border: 1px solid var(--cx-border); border-radius: 999px;
  padding: .25rem .7rem; text-decoration: none; }
.cx-cat:hover { background: #fff; }
.cx-title { font-family: var(--cx-fh); font-weight: 800; font-size: 2.25rem; line-height: 1.2;
  color: var(--cx-dark); margin: 1rem 0 .75rem; }
.cx-meta { font-family: var(--cx-fh); font-size: .85rem; color: var(--cx-muted);
  display: flex; flex-wrap: wrap; gap: .25rem 1rem; margin-bottom: 2rem; }
.cx-meta a { color: inherit; text-decoration: underline; text-underline-offset: 2px; }
.cx-meta a:hover { color: var(--cx-primary); }

/* ─── Prosa ───────────────────────────────────────────────────────────────── */
.cx-prose { font-family: var(--cx-fb); font-size: 1.075rem; line-height: 1.75; color: #28323b; }
.cx-prose > p:first-of-type { font-size: 1.2rem; color: var(--cx-muted); line-height: 1.65; }
.cx-prose h2 { font-family: var(--cx-fh); font-weight: 800; font-size: 1.55rem; line-height: 1.3;
  color: var(--cx-dark); margin: 2.5rem 0 .9rem; }
.cx-prose h3 { font-family: var(--cx-fh); font-weight: 700; font-size: 1.2rem;
  color: var(--cx-dark); margin: 1.8rem 0 .6rem; }
.cx-prose p { margin: 0 0 1.2rem; }
.cx-prose ul { margin: 0 0 1.4rem; padding-left: 1.3rem; }
.cx-prose li { margin: 0 0 .6rem; }
.cx-prose a { color: var(--cx-primary); text-decoration: underline; text-underline-offset: 2px; }
.cx-prose a:hover { color: var(--cx-primary-dark); }
.cx-prose strong { font-weight: 700; color: var(--cx-dark); }

/* ─── CTA am Artikelende ──────────────────────────────────────────────────── */
.cx-cta { background: linear-gradient(135deg, var(--cx-primary) 0%, #2a7aad 100%);
  border-radius: 14px; padding: 2rem; margin: 3rem 0 1rem; color: #fff; }
.cx-cta h3 { font-family: var(--cx-fh); font-weight: 800; font-size: 1.25rem; margin: 0 0 .5rem; color: #fff; }
.cx-cta p { font-family: var(--cx-fb); margin: 0 0 1.2rem; color: rgba(236,220,200,.92); line-height: 1.6; }
.cx-cta a { display: inline-block; background: var(--cx-accent); color: #fff; font-family: var(--cx-fh);
  font-weight: 700; font-size: .92rem; padding: .65rem 1.4rem; border-radius: 8px; text-decoration: none; }

/* ─── Blogübersicht / Kategorie ───────────────────────────────────────────── */
.cx-list-head { text-align: center; margin: 1.5rem 0 2.5rem; }
.cx-list-head h1 { font-family: var(--cx-fh); font-weight: 800; font-size: 2.25rem; color: var(--cx-dark); margin: 0 0 .5rem; }
.cx-list-head p { font-family: var(--cx-fb); color: var(--cx-muted); font-size: 1.05rem; margin: 0; }
.cx-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.5rem; margin-bottom: 3rem; }
.cx-card { display: flex; flex-direction: column; gap: .6rem; background: #fff; border: 1px solid var(--cx-border);
  border-radius: 14px; padding: 1.4rem 1.5rem; transition: box-shadow .15s, transform .15s; }
.cx-card:hover { box-shadow: 0 8px 24px rgba(31,98,142,.1); transform: translateY(-2px); }
.cx-card__title { font-family: var(--cx-fh); font-weight: 700; font-size: 1.1rem; line-height: 1.3;
  color: var(--cx-dark); text-decoration: none; }
.cx-card__title:hover { color: var(--cx-primary); }
.cx-card__excerpt { font-family: var(--cx-fb); font-size: .92rem; color: var(--cx-muted); line-height: 1.6; margin: 0; }
.cx-card__meta { font-family: var(--cx-fh); font-size: .78rem; color: var(--cx-muted); margin-top: auto; }

/* ─── Seiten-Hero (Feature/Vergleich/Autor) ───────────────────────────────── */
.cx-eyebrow { font-family: var(--cx-fh); font-size: .72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .1em; color: var(--cx-primary); margin: 2rem 0 .5rem; }
.cx-lead { font-family: var(--cx-fb); font-size: 1.2rem; line-height: 1.6; color: var(--cx-muted); margin: 0 0 2rem; }

/* ─── Vergleichstabelle ───────────────────────────────────────────────────── */
.cx-compare { width: 100%; border-collapse: collapse; margin: 1.5rem 0 2rem; font-family: var(--cx-fh); font-size: .92rem; }
.cx-compare th, .cx-compare td { text-align: left; padding: .85rem 1rem; border-bottom: 1px solid var(--cx-border); vertical-align: top; }
.cx-compare thead th { font-weight: 700; color: var(--cx-dark); border-bottom: 2px solid var(--cx-border); }
.cx-compare th:first-child, .cx-compare td:first-child { color: var(--cx-muted); font-weight: 600; }
.cx-compare .cx-col-caltrix { background: var(--cx-surface); color: var(--cx-primary-dark); font-weight: 600; }
.cx-compare thead .cx-col-caltrix { color: var(--cx-primary); }
.cx-check { color: #2f8f5b; font-weight: 700; }
.cx-cross { color: #b4543f; font-weight: 700; }
@media (max-width: 640px) { .cx-compare { font-size: .82rem; } .cx-compare th, .cx-compare td { padding: .6rem .5rem; } }

/* ─── Autorenseite ────────────────────────────────────────────────────────── */
.cx-author { display: flex; gap: 1.5rem; align-items: center; margin: 1rem 0 2rem; flex-wrap: wrap; }
.cx-avatar { width: 110px; height: 110px; border-radius: 50%; flex-shrink: 0; display: flex; align-items: center;
  justify-content: center; background: linear-gradient(135deg, var(--cx-primary) 0%, #2a7aad 100%);
  color: #fff; font-family: var(--cx-fh); font-weight: 800; font-size: 2.4rem; }
.cx-author__role { font-family: var(--cx-fh); color: var(--cx-muted); font-size: .95rem; margin: .25rem 0 0; }
.cx-linklist { list-style: none; padding: 0; margin: 1.5rem 0; display: grid; gap: .6rem; }
.cx-linklist a { font-family: var(--cx-fh); font-weight: 600; color: var(--cx-primary); text-decoration: none;
  display: inline-flex; align-items: center; gap: .5rem; }
.cx-linklist a:hover { color: var(--cx-primary-dark); text-decoration: underline; }

/* ─── Content-Komponenten (für editor-geschriebenes HTML) ─────────────────── */
/* Callout-Box (portiert aus eid-hub styles.ts, an Caltrix-Palette angepasst) */
.callout { background: var(--cx-surface); border-radius: 12px; padding: 18px 20px; margin: 26px 0;
  display: flex; gap: 14px; align-items: flex-start; }
.callout__icon { font-size: 1.1rem; flex-shrink: 0; margin-top: 2px; }
.callout__text { font-family: var(--cx-fb); font-size: .95rem; line-height: 1.65; color: #28323b; min-width: 0; }
.callout__text strong { color: var(--cx-dark); }
/* Tag-Cluster */
.tag-cluster { display: flex; flex-wrap: wrap; gap: 7px; margin: 28px 0 0; }
.tag { display: inline-block; font-family: var(--cx-fh); font-size: .72rem; font-weight: 600; letter-spacing: .05em;
  text-transform: uppercase; padding: 4px 11px; border-radius: 50px; border: 1px solid var(--cx-border);
  color: var(--cx-muted); background: #fff; text-decoration: none; }
.tag:hover { border-color: var(--cx-primary); color: var(--cx-primary); }
/* Responsive Tabellen-Wrapper (enhance-Schritt) */
.table-wrap { overflow-x: auto; margin: 1.5rem 0; -webkit-overflow-scrolling: touch; }
.table-wrap > .cx-compare { margin: 0; }

/* ─── Newsletter-Formular ([NEWSLETTER …], postet cross-origin an eid-hub.de) ── */
.cx-nl { background: var(--cx-surface); border: 1px solid var(--cx-border); border-radius: 14px; padding: 1.5rem; margin: 2rem 0; }
.cx-nl h3 { font-family: var(--cx-fh); font-weight: 800; font-size: 1.15rem; color: var(--cx-dark); margin: 0 0 .25rem; }
.cx-nl p { font-family: var(--cx-fb); color: var(--cx-muted); margin: 0 0 1rem; font-size: .95rem; }
.cx-nl__row { display: flex; flex-wrap: wrap; gap: .6rem; }
.cx-nl input[type=text], .cx-nl input[type=email] { flex: 1; min-width: 160px; font-family: var(--cx-fh);
  font-size: .9rem; padding: .6rem .8rem; border: 1px solid var(--cx-border); border-radius: 8px; }
.cx-nl__check { display: flex; gap: .5rem; align-items: flex-start; font-family: var(--cx-fh); font-size: .8rem;
  color: var(--cx-muted); margin: .8rem 0; }
.cx-nl__check a { color: var(--cx-primary); }
.cx-nl__btn { font-family: var(--cx-fh); font-weight: 700; font-size: .9rem; background: var(--cx-primary);
  color: #fff; border: none; border-radius: 8px; padding: .65rem 1.4rem; cursor: pointer; }
.cx-nl__btn:hover { background: var(--cx-primary-dark); }
.cx-nl__hp { position: absolute; left: -5000px; }

/* ─── FAQ-Akkordeon (aus dem faq-Array) ───────────────────────────────────── */
.cx-faq { margin: 2.5rem 0; }
.cx-faq__title { font-family: var(--cx-fh); font-weight: 800; font-size: 1.4rem; color: var(--cx-dark); margin: 0 0 1rem; }
.cx-faq__item { border-bottom: 1px solid var(--cx-border); padding: .9rem 0; }
.cx-faq__item summary { font-family: var(--cx-fh); font-weight: 600; font-size: 1rem; color: var(--cx-dark);
  cursor: pointer; list-style: none; display: flex; justify-content: space-between; gap: 1rem; }
.cx-faq__item summary::after { content: "+"; color: var(--cx-primary); font-weight: 700; }
.cx-faq__item[open] summary::after { content: "–"; }
.cx-faq__a { font-family: var(--cx-fb); font-size: .95rem; line-height: 1.65; color: var(--cx-muted); margin-top: .7rem; }

/* ─── Quiz (aus dem quiz-Array) ───────────────────────────────────────────── */
.cx-quiz { background: var(--cx-surface); border: 1px solid var(--cx-border); border-radius: 14px; padding: 1.5rem; margin: 2.5rem 0; }
.cx-quiz__title { font-family: var(--cx-fh); font-weight: 800; font-size: 1.3rem; color: var(--cx-dark); margin: 0 0 1.2rem; }
.cx-quiz__q { margin-bottom: 1.2rem; }
.cx-quiz__qt { font-family: var(--cx-fh); font-weight: 600; font-size: .98rem; color: var(--cx-dark); margin: 0 0 .6rem; }
.cx-quiz__opts { display: grid; gap: .4rem; }
.cx-quiz__opt { display: flex; gap: .6rem; align-items: center; font-family: var(--cx-fh); font-size: .92rem;
  color: #28323b; padding: .5rem .7rem; border: 1px solid var(--cx-border); border-radius: 8px; cursor: pointer; background: #fff; }
.cx-quiz__opt.is-correct { border-color: #2f8f5b; background: #eef7f1; }
.cx-quiz__opt.is-wrong { border-color: #b4543f; background: #fbeeea; }
.cx-quiz__btn { font-family: var(--cx-fh); font-weight: 700; font-size: .9rem; background: var(--cx-primary); color: #fff;
  border: none; border-radius: 8px; padding: .6rem 1.3rem; cursor: pointer; margin-top: .5rem; }
.cx-quiz__btn:disabled { opacity: .55; cursor: default; }
.cx-quiz__result { font-family: var(--cx-fh); font-weight: 700; color: var(--cx-primary-dark); margin-top: 1rem; }

@media (max-width: 640px) {
  .cx-title { font-size: 1.7rem; }
  .cx-list-head h1 { font-size: 1.7rem; }
}
