/* pages.css — gemeinsame Styles für Inhaltsseiten (Studiengänge etc.) */
* { box-sizing: border-box; }
body {
  margin: 0; min-height: 100dvh; padding: 24px;
  font-family: system-ui, -apple-system, sans-serif;
  display: flex; flex-direction: column; gap: 20px;
  max-width: 820px;
}
.topbar { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.back, .ghost {
  background: transparent; color: var(--color-text);
  border: 2px solid var(--color-line); border-radius: 8px;
  padding: 8px 14px; font-size: 14px; cursor: pointer; text-decoration: none;
}
.controls { display: flex; gap: 8px; }
h1 { font-size: clamp(28px, 6vw, 48px); margin: 0; line-height: 1.05; }
h2 { font-size: 20px; margin: 8px 0 0; }
.muted { color: var(--color-muted); }
.lead { font-size: clamp(16px, 2.4vw, 20px); }
.facts { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.facts li { border: 2px solid var(--color-line); border-radius: 12px; padding: 12px 14px; }
.facts .l { display: block; font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-muted); }
.facts .v { font-size: 16px; font-weight: 600; }
.ph { border: 2px dashed var(--color-line); border-radius: 12px; padding: 14px; color: var(--color-muted); font-style: italic; }
.bul { padding-left: 20px; margin: 6px 0 0; display: grid; gap: 6px; }
.bul li { line-height: 1.45; }
p.para { line-height: 1.5; margin: 6px 0 0; }
a.mail { color: var(--color-text); font-weight: 600; }
.actions { display: flex; flex-wrap: wrap; gap: 10px; }
.btn {
  background: var(--color-accent-bg); color: var(--color-accent-text);
  border: none; border-radius: 10px; padding: 14px 20px;
  font-size: 16px; font-weight: 700; cursor: pointer; text-decoration: none;
  display: inline-block; text-align: center;
}
a.inline { color: var(--color-text); }
footer { margin-top: auto; }

/* ── QR-Karten für externe Links (Messestand: scannen statt wegnavigieren) ── */
.qrgrid { display: grid; gap: 14px; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.qrcard {
  display: flex; gap: 18px; align-items: center;
  border: 3px solid var(--color-line); border-radius: 16px;
  padding: 18px; text-decoration: none; color: var(--color-text);
}
.qrcard .qr {
  flex: none; width: 132px; height: 132px;
  background: #ffff00;                /* immer gelbes Tile: scannbar in beiden Modes */
  border: 2px solid #000000;
  border-radius: 10px; padding: 10px; box-sizing: border-box;
  display: flex; align-items: center; justify-content: center;
  font-size: 40px; color: #000;
}
.qrcard .qr svg { width: 100%; height: 100%; display: block; }
.qrlabel { font-size: clamp(18px, 3vw, 24px); font-weight: 800; line-height: 1.2; }
.qrhint { display: block; margin-top: 6px; font-size: 13px; color: var(--color-muted); }
