:root{
  --bg:#f2efe9;
  --ink:#1f1f1f;
  --muted:#5b5b5b;
  --card:#ffffffcc;
  --shadow: 0 10px 30px rgba(0,0,0,.10);
  --radius:18px;
  --max: 980px;
}

/* Layout-Fix: Footer überlappt nichts, bleibt am Ende */
html, body { height: 100%; }

body{
  margin:0;
  min-height: 100vh;
  display:flex;
  flex-direction:column;

  font-family:"Crimson Pro", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  color:var(--ink);
  background: radial-gradient(1200px 700px at 50% 10%, #ffffff 0%, var(--bg) 60%);
}

.site-header{
  padding:48px 16px 18px;
  text-align:center;
}

h1{
  margin:0 0 10px;
  font-size: clamp(1.35rem, 2.2vw, 2rem);
  letter-spacing:.2px;
  font-weight:650;
}

.sub{
  margin:0;
  color:var(--muted);
  font-size: clamp(.98rem, 1.6vw, 1.05rem);
  line-height:1.4;
}

.site-main{
  flex:1;
  width:100%;
  max-width:var(--max);
  margin:0 auto;
  padding: 18px 16px 56px; /* mehr Luft vor Footer */
}

.cards{
  display:grid;
  gap:18px;
  grid-template-columns: 1fr;
  align-items:center;
  justify-items:center;
}

@media (min-width: 860px){
  .cards{ grid-template-columns: 1fr 1fr; }
}

.card{
  margin:0;
  width:100%;
  background:var(--card);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
  border: 1px solid rgba(0,0,0,.06);
}

.card img{
  width:100%;
  height:auto;
  display:block;
}

.site-footer{
  margin-top:24px;
  text-align:center;
  padding: 14px 16px 28px;
  color:var(--muted);
  font-size:.95rem;
  position:relative;
  z-index:0;
}

.status-line{
  margin:0 0 10px;
  font-size:1rem;
  color:var(--ink);
}

.links{
  margin-top:10px;
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
}

.badge{
  display:inline-block;
  padding:10px 14px;
  border-radius:999px;
  background: rgba(255,255,255,.65);
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
  text-decoration:none;
  color:inherit;
}

.copy{ margin-top:10px; }

a{ text-underline-offset: 3px; }
	  
.credits{
  margin-top:10px;
  font-size:.9rem;
  color:var(--muted);
}
.credits a{ color:inherit; }
