:root{
  --bg:#0a0a0a;
  --bg2:#0f0f12;

  --border:rgba(255,255,255,.10);
  --text:rgba(255,255,255,.92);
  --muted:rgba(255,255,255,.60);
  --muted-2:rgba(255,255,255,.72);

  --radius:18px;
  --shadow-soft:0 10px 30px rgba(0,0,0,.35);

  --pad:20px;
  --max:920px;
}

*{box-sizing:border-box}

html{
  height:100%;
  scroll-behavior:smooth;
}

body{
  margin:0;
  min-height:100svh;
  overflow-x:hidden;
  color:var(--text);
  background:var(--bg); /* fallback */
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* Background FIX: bleibt immer gleich, auch bei langem Scroll */
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  background:
    radial-gradient(1100px 700px at 18% -12%, rgba(255,255,255,.08), transparent 70%),
    radial-gradient(980px 720px at 112% 8%, rgba(140,120,255,.11), transparent 64%),
    linear-gradient(180deg, var(--bg), var(--bg2));
}

a{color:inherit}

.container{
  max-width:var(--max);
  margin-inline:auto;
  padding:clamp(28px, 5vw, 48px) var(--pad);
  min-height:100svh;
  display:flex;
  flex-direction:column;
}

.skip-link{
  position:absolute;
  left:12px;
  top:12px;
  padding:10px 12px;
  background:rgba(0,0,0,.75);
  border:1px solid var(--border);
  border-radius:12px;
  text-decoration:none;
  transform:translateY(-140%);
  transition:transform .18s ease;
  z-index:10;
}
.skip-link:focus{transform:translateY(0)}

/* ===== BANNER ===== */
.banner{
  border:1px solid rgba(255,255,255,.10);
  border-radius:22px;
  padding:16px 18px;
  margin-bottom:14px;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(700px 220px at 15% 0%, rgba(255,255,255,.10), transparent 60%),
    radial-gradient(650px 240px at 110% 40%, rgba(140,120,255,.14), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
}

.banner::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    repeating-linear-gradient(
      90deg,
      rgba(255,255,255,.05) 0px,
      rgba(255,255,255,.05) 1px,
      transparent 1px,
      transparent 14px
    );
  opacity:.18;
  pointer-events:none;
}

.banner::after{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(500px 180px at 50% 0%, rgba(255,255,255,.10), transparent 70%);
  opacity:.6;
  pointer-events:none;
}

.banner-inner{
  position:relative;
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
}

.banner-kicker{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.20);
  font-weight:700;
  font-size:.82rem;
  letter-spacing:.2px;
}

.banner-line{
  color:rgba(255,255,255,.78);
  font-weight:600;
  letter-spacing:.2px;
}
/* ================== */

.top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:22px;
  margin-bottom:10px;
}

.hero{
  display:flex;
  align-items:center;
  gap:16px;
  min-width:0;
}

.pfp{
  width:92px;
  height:92px;
  border-radius:999px;
  object-fit:cover;
  border:1px solid var(--border);
  box-shadow:var(--shadow-soft);
}

.hero-text h1{
  margin:0;
  font-size:clamp(2.0rem, 4vw, 2.55rem);
  font-family:"MuseoModerno", system-ui, sans-serif;
  letter-spacing:.2px;
}

.sub{
  margin:.35rem 0 0;
  color:var(--muted);
  font-weight:500;
}

.nav{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  padding-top:6px;
}

.nav-link{
  display:inline-flex;
  align-items:center;
  padding:10px 14px;
  border-radius:999px;
  text-decoration:none;
  font-weight:600;
  color:var(--muted-2);
  background:transparent;
  border:1px solid transparent;
  transition:transform .12s ease, background .18s ease, border-color .18s ease, color .18s ease;
}

.nav-link:hover{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.10);
  color:var(--text);
  transform:translateY(-1px);
}

.nav-link:focus-visible,
.icon-link:focus-visible,
.card:focus-visible,
.pill:focus-visible{
  outline:2px solid rgba(255,255,255,.22);
  outline-offset:3px;
}

main{
  animation:fadein .35s ease both;
  display:flex;
  flex-direction:column;
  gap:34px;
  flex:1; /* drückt Footer sauber nach unten */
}

h2{
  margin:0 0 14px;
  font-size:1.55rem;
  letter-spacing:.2px;
}

p{margin:0;color:rgba(255,255,255,.85)}

.section-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}

.icon-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.05);
  text-decoration:none;
  color:var(--muted-2);
  transition:transform .12s ease, background .18s ease, color .18s ease;
}

.icon-link:hover{
  background:rgba(255,255,255,.08);
  color:var(--text);
  transform:translateX(2px);
}

.icon-link svg{width:20px;height:20px}

.grid{
  display:grid;
  gap:16px;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
}

.card{
  display:block;
  text-decoration:none;
  padding:18px 18px 16px;
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.04));
  transition:transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}

.card:hover{
  transform:translateY(-3px);
  border-color:rgba(255,255,255,.18);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.05));
  box-shadow:var(--shadow-soft);
}

.card h3{margin:0 0 8px;font-size:1.15rem}
.card p{margin:0 0 12px;color:rgba(255,255,255,.72);font-size:.96rem}

.meta{
  display:inline-flex;
  align-items:center;
  font-size:.88rem;
  color:rgba(255,255,255,.62);
}

.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{
  display:inline-flex;
  align-items:center;
  padding:7px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  color:rgba(255,255,255,.78);
  font-size:.86rem;
}

.links{display:flex;flex-wrap:wrap;gap:10px}
.pill{
  display:inline-flex;
  align-items:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  text-decoration:none;
  font-weight:600;
  color:rgba(255,255,255,.86);
  transition:transform .12s ease, background .18s ease, border-color .18s ease;
}

.pill:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.07);
  border-color:rgba(255,255,255,.16);
}

.footer{
  margin-top:28px;
  padding-top:16px;
  border-top:1px solid rgba(255,255,255,.08);
  text-align:center;
  color:rgba(255,255,255,.52);
  font-size:.92rem;
}

@keyframes fadein{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}

@media (max-width:720px){
  .top{flex-direction:column;align-items:flex-start}
  .nav{padding-top:0}
  .banner{padding:14px 14px}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto !important}
  main{animation:none}
  .nav-link,.icon-link,.card,.pill{transition:none !important}
  .card:hover{transform:none}
}


/* ===== CTA Button (Banner) ===== */
.btn{
  margin-left:auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.08);
  color:rgba(255,255,255,.92);
  text-decoration:none;
  font-weight:700;
  letter-spacing:.15px;
  transition:transform .12s ease, background .18s ease, border-color .18s ease;
}

.btn:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.11);
  border-color:rgba(255,255,255,.22);
}

.btn:active{transform:translateY(0)}

.btn:focus-visible{
  outline:2px solid rgba(255,255,255,.22);
  outline-offset:3px;
}

@media (max-width:720px){
  .btn{margin-left:0}
}

/* ===== Sticky Banner ===== */
.banner{
  position: sticky;
  top: 14px;
  z-index: 30;

  /* nice glass look beim Scroll */
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);

  box-shadow: 0 10px 30px rgba(0,0,0,.22);
  transform: translateZ(0);
}

@media (max-width:720px){
  .banner{ top: 10px; }
}
