/* ==============================
   Design Tokens
============================== */
:root{
  --bg:#ffffff;
  --text:#0f172a;
  --muted:#475569;
  --line:#e2e8f0;
  --card:#f8fafc;
  --accent:#2563eb;
  --accent-soft:#dbeafe;
  --radius:14px;
}

/* ==============================
   Base
============================== */
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family: system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
}

/* gemeinsame Content-Breite */
.container,
.header-inner,
.footer-inner{
  max-width: 860px;
  margin: 0 auto;
  padding-left:18px;
  padding-right:18px;
}

/* ==============================
   Typography
============================== */
h1,h2,h3{
  line-height:1.25;
  margin:0 0 12px 0;
}

h1{
  font-size: clamp(1.9rem, 2.6vw, 2.4rem);
  letter-spacing:-0.02em;
}

h2{ font-size:1.25rem; }
h3{ font-size:1.05rem; }

p{ margin:0 0 14px 0; }
.lead{ font-size:1.05rem; color:var(--muted); }

ul{ margin:10px 0 0 18px; padding:0; }
li{ margin:6px 0; }

.note{ color:var(--muted); }

/* ==============================
   Links
============================== */
a{
  color:var(--accent);
  text-decoration:none;
}

a:hover{ text-decoration:underline; }

a:focus-visible{
  outline: 3px solid var(--accent-soft);
  outline-offset: 2px;
  border-radius:8px;
}

/* ==============================
   Header (ohne Linie)
============================== */
.site-header{
  background:#fff;
}

.header-inner{
  padding-top:14px;
  padding-bottom:14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}

.brand{
  font-weight:600;
  color:var(--text);
}

.main-nav{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
}

.main-nav a{
  font-size:0.95rem;
  color:var(--muted);
}

.main-nav a:hover{
  color:var(--text);
}

/* ==============================
   Layout Blocks
============================== */
.container{
  padding-top:24px;
  padding-bottom:48px;
}

/* Hero */
.hero{
  padding:22px;
  border-radius:var(--radius);
  background: linear-gradient(180deg, #ffffff 0%, var(--card) 100%);
}

.hero-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
  margin-top:12px;
}

/* Pills */
.pill-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:10px 0 0 0;
  padding:0;
  list-style:none;
}

.pill{
  font-size:0.9rem;
  padding:6px 10px;
  border-radius:999px;
  background:var(--accent-soft);
  color:#1e40af;
}

/* Buttons */
.btn{
  display:inline-block;
  padding:10px 14px;
  border-radius:10px;
  background:var(--accent);
  color:#fff;
  font-weight:600;
}

.btn:hover{ filter:brightness(0.95); }

.btn-secondary{
  background:transparent;
  color:var(--accent);
  border:1px solid var(--line);
}

/* Cards */
.card{
  margin-top:16px;
  padding:18px;
  border-radius:var(--radius);
  background:#fff;
}

.two-col{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}

.card-sub{
  padding:16px;
  border-radius:var(--radius);
  background:var(--card);
}

/* ==============================
   Footer (ohne Linie)
============================== */
.site-footer{
  margin-top:26px;
  padding-top:14px;
  font-size:0.95rem;
  color:var(--muted);
  background:#fff;
}

.site-footer a{
  color:var(--muted);
}

.site-footer a:hover{
  color:var(--text);
}

.footer-inner{
  padding-bottom:24px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}

/* ==============================
   Responsive
============================== */
@media (min-width: 780px){
  .two-col{ grid-template-columns:1fr 1fr; }
  .hero-grid{ grid-template-columns:1.2fr 0.8fr; }
}

/* Anchor Offset */
#ablauf{ scroll-margin-top:18px; }
