/* iConference — Standpunkt (Bereich + Artikel). Baut auf colors_and_type.css + legal.css auf. */

/* Übersicht etwas breiter als die Legal-Spalte */
.doc--wide { max-width: 820px; }

/* Gemeinsame Meta-Bausteine (Artikel + Karten) */
.post-eyebrow { font-family: var(--font-mono); font-size: 12px; font-weight: 600; letter-spacing: .12em;
  text-transform: uppercase; color: var(--ochre-600); }
.post-meta-row { display: flex; align-items: center; gap: 14px; margin: 14px 0 0; }
.post-tag { font-family: var(--font-mono); font-size: 11px; font-weight: 600; letter-spacing: .08em;
  text-transform: uppercase; color: var(--ochre-700); background: var(--ochre-50);
  border: 1px solid var(--ochre-100); border-radius: var(--radius-pill); padding: 4px 11px; }
.post-date { font-family: var(--font-mono); font-size: 12px; color: var(--fg-3); }

/* ---- Artikel ---- */
.post { max-width: 680px; }
.post h1 { margin-top: 16px; font-size: 38px; line-height: 1.08; }
.post-lead { font-size: 20px; line-height: 1.55; color: var(--navy-600); margin: 22px 0 22px; text-wrap: pretty; }
.post p { font-size: 17px; line-height: 1.7; }
.post-kicker { font-family: var(--font-display); font-weight: 700; font-size: 19px; color: var(--navy-700);
  margin-top: 26px; }
.post-sign { color: var(--navy-500); font-style: italic; margin-top: 6px; }

/* Inline-Abbildung im Artikel */
.post-fig { margin: 30px 0; }
.post-fig img { display: block; width: 100%; height: auto;
  border: 1px solid var(--border-1); border-radius: var(--radius-lg); }
.post-figcap { font-family: var(--font-mono); font-size: 12px; color: var(--fg-3);
  margin-top: 10px; letter-spacing: .01em; }

/* ---- Übersicht ---- */
.sp-hero { margin-bottom: 30px; }
.sp-hero h1 { font-family: var(--font-display); font-weight: 800; font-size: 44px; letter-spacing: -.02em;
  color: var(--navy-700); margin: 10px 0 0; line-height: 1.05; }
.sp-lead { font-size: 18px; line-height: 1.6; color: var(--navy-500); margin: 12px 0 0; max-width: 56ch; text-wrap: pretty; }

.sp-list { display: flex; flex-direction: column; gap: 18px; }
.sp-card { display: block; text-decoration: none; background: var(--cream-card);
  border: 1px solid var(--border-1); border-radius: var(--radius-lg); padding: 26px 28px;
  transition: border-color .2s, transform .2s, box-shadow .2s; }
.sp-card:hover { border-color: var(--ochre-300); transform: translateY(-2px);
  box-shadow: 0 10px 28px -18px rgba(20,40,60,.35); }
.sp-card h2 { font-family: var(--font-display); font-weight: 700; font-size: 24px; line-height: 1.2;
  color: var(--navy-700); margin: 14px 0 8px; letter-spacing: -.01em; }
.sp-card p { font-size: 16px; line-height: 1.6; color: var(--navy-500); margin: 0; text-wrap: pretty; }
.sp-readmore { display: inline-flex; align-items: center; gap: 7px; margin-top: 16px;
  font-family: var(--font-display); font-weight: 600; font-size: 14px; color: var(--ochre-700); }
.sp-readmore svg { width: 15px; height: 15px; transition: transform .2s; }
.sp-card:hover .sp-readmore svg { transform: translateX(3px); }

@media (max-width: 600px) {
  .post h1 { font-size: 29px; }
  .sp-hero h1 { font-size: 33px; }
  .post-lead { font-size: 18px; }
  .sp-card { padding: 22px 20px; }
}
