:root{
  /* Unified palette to match Anleitung.css */
  --accent:#0b6ef6;
  --accent-2:#67e8f9;
  --bg:#0a0a0a;
  --card:#14161a;
  --muted:#a3abb8;

  /* Glass/Ring/Radii (shared tokens) */
  --glass-strong-top: linear-gradient(180deg, rgba(16,20,28,.78), rgba(16,20,28,.48));
  --glass-strong: linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.06));
  --ring: 0 0 0 1.5px rgba(11,110,246,.55), 0 10px 26px rgba(11,110,246,.2);
  --radius-xl: 26px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
html{scroll-behavior:smooth}
body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:#fff;overflow-x:hidden}

/* ===== Hintergrund ===== */
#starfield{position:fixed;inset:0;z-index:-2;background:
  radial-gradient(1200px 800px at 50% -20%, #0b0f19 30%, transparent 60%),
  linear-gradient(#05060b,#070a13 60%, #06070d)}
#aurora{position:fixed;inset:-12% -22%;z-index:-1;pointer-events:none;filter:blur(52px) saturate(115%);opacity:.55;background:
  radial-gradient(ellipse at 18% 78%, rgba(0,0,0,.38), transparent 46%),
  radial-gradient(ellipse at 82% 22%, rgba(70,70,70,.32), transparent 46%),
  radial-gradient(ellipse at 60% 92%, rgba(30,30,30,.30), transparent 50%),
  radial-gradient(ellipse at 12% 18%, rgba(90,90,90,.22), transparent 50%);}

}
@keyframes dsBgShift{
  0%{background-position:0% 0%,100% 0%,50% 100%,0% 0%}
  100%{background-position:28% 18%,82% 8%,50% 82%,0% 0%}
}

/* ===== Header ===== */
header.hdr{
  position:relative; min-height:56vh;
  display:flex; align-items:center; justify-content:center;
  text-align:center;
  padding:110px 20px 40px;
  opacity:0; transform:translateY(-12px);
  transition:opacity .9s, transform .9s;
}
/* Support both body.ready and .visible triggers */
body.ready header.hdr, header.hdr.visible{opacity:1; transform:none}
header .logo{margin-bottom:12px}
header h1{font-size:42px;margin:14px 0 6px}
header p{color:var(--muted);font-size:18px}

/* ===== Mini-Banner (vereinheitlicht) ===== */
.mini-banner{
  position:fixed; top:10px; left:50%; transform:translateX(-50%); z-index:1000;
  background:var(--glass-strong-top);
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(12px) saturate(125%); -webkit-backdrop-filter:blur(12px) saturate(125%);
  border-radius:999px; padding:6px;
  max-width:min(1100px, calc(100vw - 32px));
  box-shadow:0 8px 22px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.10);
  transition:opacity .25s ease, transform .25s ease, box-shadow .25s ease;
}
.mini-banner .clip{position:relative;overflow:visible}
.mini-banner .track{display:flex;align-items:center}
.mini-banner .lane{display:flex;gap:10px;align-items:center;flex-wrap:nowrap}
.mini-banner .mini-item{
  --pad-x:14px; --pad-y:10px;
  display:inline-flex;align-items:center;gap:10px;
  padding:var(--pad-y) var(--pad-x);
  border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.18);
  color:#eef3ff;text-decoration:none;font-weight:700;letter-spacing:.2px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10);
  transition:transform .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease, background .18s ease;
  min-height:40px; outline:0; white-space:nowrap;
}
.mini-banner .mini-item:hover{transform:translateY(-1px);border-color:rgba(11,110,246,.45);color:#d9e7ff;box-shadow:var(--ring), inset 0 1px 0 rgba(255,255,255,.12)}
.mini-banner .mini-item:focus-visible{box-shadow:var(--ring), inset 0 1px 0 rgba(255,255,255,.12)}
.mini-banner .emoji{font-size:16px}
.mini-banner .mini-icon{width:18px;height:18px;object-fit:contain;vertical-align:middle}
@media (max-width:700px){
  .mini-banner{padding:4px}
  .mini-banner .lane{gap:8px}
  .mini-banner .mini-item{--pad-x:12px; --pad-y:9px; font-size:14px}
  .mini-banner .emoji{font-size:14px}
}

/* ===== Buttons (Basis aus Anleitung) ===== */
.btn{
  display:inline-block;background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.25);
  color:#f9fafb;padding:10px 16px;border-radius:10px;cursor:pointer;
  transition:transform .25s, border-color .25s, color .25s, box-shadow .25s, background .25s;
  backdrop-filter:blur(6px);
}
.btn:hover{background:rgba(255,255,255,0.18);border-color:rgba(255,255,255,0.4);transform:translateY(-2px);box-shadow:0 10px 28px rgba(255,255,255,0.25)}

/* ===== Content & Cards ===== */
main{max-width:980px;margin:0 auto;padding:10px 20px 40px}
.card{
  background:color-mix(in oklab, var(--card) 92%, #0b0f19);
  border:1px solid #23262f;
  border-radius:14px;
  padding:18px 20px;
  margin:16px 0;
  box-shadow:0 6px 18px rgba(0,0,0,.38);
  transition:transform .35s, box-shadow .35s, border-color .35s;
}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(0,0,0,.5);border-color:#2b3340}
h2{font-size:24px;margin:4px 0 10px;text-wrap:balance}
h3{font-size:18px;margin:12px 0 6px}
p{color:#dbe2f1}
ul{margin:10px 0 10px 18px}
li{margin:6px 0}
a{color:#9ec1ff;text-decoration:none;border-bottom:1px dashed rgba(158,193,255,.45)}
a:hover{color:#fff;border-color:var(--accent)}

/* ===== Footer (Bugfix: var usage) ===== */
footer{
  text-align:center;padding:24px 20px 46px;
  color:var(--muted);
  font-size:14px;
}
footer a{color:#9ec1ff;text-decoration:underline;font-weight:600}
footer a:hover{color:#ffffff;text-decoration:underline}

/* ===== Floating Startseite Button ===== */
.floating-home{
  position:fixed; right:16px; bottom:16px; z-index:900;
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 14px; border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.18);
  color:#eef3ff; text-decoration:none; font-weight:700; letter-spacing:.2px;
  box-shadow:0 8px 22px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.10);
  transition:transform .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease, background .18s ease;
}
.floating-home:hover{transform:translateY(-1px);border-color:rgba(11,110,246,.45);color:#d9e7ff;box-shadow:var(--ring), inset 0 1px 0 rgba(255,255,255,.12)}
.floating-home:focus-visible{outline:none; box-shadow:var(--ring), inset 0 1px 0 rgba(255,255,255,.12)}
.floating-home .home-emoji{font-size:16px; line-height:1}

/* ===== Quick Modal (beibehalten & leicht verfeinert) ===== */
.qmodal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.6);z-index:10000}
.qmodal.open{display:flex}
.qmodal .panel{
  position:relative;width:min(1300px, 98vw);height:min(92vh, 1000px);
  background:linear-gradient(180deg, rgba(18,20,26,.96), rgba(15,17,22,.94));
  border:1px solid rgba(255,255,255,.14); border-radius:16px;
  box-shadow:0 20px 60px rgba(0,0,0,.6); overflow:hidden;display:flex; flex-direction:column;
}
.qmodal .head{display:flex;align-items:center;gap:10px; padding:12px 14px; border-bottom:1px solid rgba(255,255,255,.08)}
.qmodal .title{font-weight:700}
.qmodal .close{margin-left:auto; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.25);color:#fff; padding:8px 10px; border-radius:10px; cursor:pointer;backdrop-filter:blur(6px)}
.qmodal .close:hover{background:rgba(255,255,255,.18); border-color:rgba(255,255,255,.4)}
.qmodal .body{flex:1;display:flex;min-height:0}
/* Info-Panel */
.info-wrap{display:flex; gap:10px; width:100%; height:100%; padding:10px}
.info-side{width:260px; flex:0 0 260px; overflow:auto}
.info-main{flex:1; min-width:0; border-left:1px solid rgba(255,255,255,.08)}
.info-btn{width:100%; display:flex; align-items:center; gap:10px;padding:10px 12px; margin:8px 0; border-radius:10px;background:linear-gradient(180deg, rgba(35,39,47,.9), rgba(24,27,33,.9));border:1px solid rgba(255,255,255,.12); color:#eef2ff; cursor:pointer;}
.info-btn:hover{border-color:rgba(11,110,246,.36)}
.info-main iframe{width:100%; height:100%; border:0; display:block}
@media (max-width:900px){
  .info-wrap{flex-direction:column}
  .info-side{width:auto; flex:none; display:flex; overflow:auto; border-bottom:1px solid rgba(255,255,255,.08); padding-bottom:8px}
  .info-btn{width:auto; white-space:nowrap; margin:6px 6px 0 0}
  .info-main{border-left:0}
}

/* ===== Videos (beibehalten) ===== */
.qv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;width:100%;height:100%;padding:6px;overflow:auto}
@media(max-width:900px){.qv-grid{grid-template-columns:1fr}}
.qv-card{background:transparent;border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 14px rgba(0,0,0,.28)}
.qv-card video{width:100%;height:auto;display:block;background:#000;aspect-ratio:16/9}
.qv-ctrls{display:flex;gap:8px;align-items:center;padding:8px;border-top:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg, rgba(35,39,47,.75), rgba(24,27,33,.75))}
.qv-btn{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.22);color:#eef2ff;padding:6px 10px;border-radius:10px;cursor:pointer}
.qv-btn:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.35)}
.qv-slider{flex:1;appearance:none;height:6px;border-radius:999px;background:rgba(255,255,255,.16);outline:none}
.qv-slider::-webkit-slider-thumb{appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;border:0;box-shadow:0 0 0 3px rgba(255,255,255,.25)}
.qv-cap{padding:10px 12px;border-top:1px solid rgba(255,255,255,.08)}
.qv-title{font-weight:700;margin-bottom:4px}
.qv-desc{color:#cfd6e6;font-size:14px;line-height:1.55}

/* ================== Termine & Events (wie Anleitung.css) ================== */
.ev-wrap{
  width:100%;
  padding:20px 10px 40px;
  display:flex; flex-direction:column; align-items:center; gap:18px;
}
.ev-intro{
  padding:10px 12px; border:1px solid rgba(255,255,255,.10); border-radius:12px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  color:#cfd6e6; max-width:880px; width:100%;
}
.ev-grid{ display:flex; flex-direction:column; gap:18px; width:100%; max-width:880px; }
.ev-item{
  width:100%; border:1px solid rgba(255,255,255,.12); border-radius:16px;
  background:linear-gradient(180deg, rgba(22,26,34,.85), rgba(16,19,26,.85));
  box-shadow:0 6px 18px rgba(0,0,0,.4); padding:16px 18px;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.ev-item:hover{transform:translateY(-4px); border-color:rgba(11,110,246,.36); box-shadow:0 14px 36px rgba(0,0,0,.55);}
.ev-head{display:flex; align-items:center; gap:10px; margin-bottom:10px;}
.ev-dot{width:12px; height:12px; border-radius:50%; background:linear-gradient(180deg, var(--accent), var(--accent-2)); box-shadow:0 0 10px rgba(11,110,246,.7);} 
.ev-title{margin:0; font-size:20px; font-weight:800; letter-spacing:.2px;}
.ev-meta{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:6px; color:#d7deee; font-size:14px;}
.ev-meta li{position:relative; padding-left:22px; line-height:1.55;}
.ev-meta li::before{content:"\1F4C5"; position:absolute; left:0; top:-1px; opacity:.9;} /* 🗓 */

/* Aktionen: 2-spaltiges Grid – links Join, rechts Kalender (untereinander) */
.ev-actions{
  margin-top:12px;
  display:grid;
  grid-template-columns:auto 1fr;  /* linke Spalte: Join; rechte Spalte: Kalender */
  column-gap:16px;
  row-gap:8px;
  align-items:start;
  justify-items:end;              /* rechte Spalte rechtsbündig */
}
.ev-actions .ev-btnwrap{grid-column:2;}      /* standard: rechte Spalte */
.ev-actions .ev-btnwrap:first-child{grid-column:1; justify-self:start;} /* erster = Zoom links */

/* Button-Varianten passend zur Anleitung */
.ev-link, .ev-add{ @apply btn; }
.ev-link, .ev-add{ text-decoration:none; display:inline-block; padding:10px 14px; border-radius:10px;
  border:1px solid rgba(255,255,255,.25); color:#eaf0ff; background:rgba(255,255,255,0.08);
  transition: transform .2s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease; }
.ev-link:hover, .ev-add:hover{ transform:translateY(-1px); box-shadow:0 10px 28px rgba(59,130,246,.25);} 
.ev-link{ background:rgba(59,130,246,.12); border-color:rgba(59,130,246,.45);} 
.ev-link:hover{ background:rgba(59,130,246,.22); border-color:rgba(59,130,246,.6);} 
.ev-add{ background:rgba(16,185,129,.10); border-color:rgba(16,185,129,.35);} 
.ev-add:hover{ background:rgba(16,185,129,.20); border-color:rgba(16,185,129,.55);} 

/* Tooltip / Popup-Info – kleiner, links vom Button */
.ev-btnwrap{ position:relative; display:flex; }
.ev-tip{
  position:absolute; right:100%; top:50%; transform:translateY(-50%); margin-right:8px;
  max-width:220px; padding:6px 8px; font-size:11px; line-height:1.35; color:#eaf0ff;
  background:linear-gradient(180deg, rgba(23,27,35,.98), rgba(16,19,26,.95));
  border:1px solid rgba(255,255,255,.15); border-radius:8px; box-shadow:0 10px 24px rgba(0,0,0,.4);
  opacity:0; pointer-events:none; transition:opacity .16s ease;
}
.ev-tip::after{ content:""; position:absolute; left:100%; top:50%; transform:translateY(-50%);
  border:6px solid transparent; border-left-color:rgba(255,255,255,.15); }
.ev-btnwrap:hover .ev-tip,
.ev-btnwrap:focus-within .ev-tip,
.ev-btnwrap.open .ev-tip{ opacity:1; pointer-events:auto; }

/* Hinweisbox unten */
.ev-note{ max-width:880px; margin-top:2px; padding:14px 16px; border:1px dashed rgba(255,255,255,.2); border-radius:12px; color:#d6def2; background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)); }
.ev-note strong{ color:#eaf0ff; }

/* === Lang Toggle (kleiner Button links neben Titel) === */
.qmodal .head{ position:relative; }
.qmodal .lang-toggle{
  margin-right:8px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.25);
  color:#eaf0ff;
  font-size:12px;
  line-height:1;
  padding:6px 8px;
  border-radius:8px;
  cursor:pointer;
}
.qmodal .lang-toggle:hover{
  background:rgba(255,255,255,.18);
  border-color:rgba(11,110,246,.45);
}
.qmodal .lang-toggle:focus-visible{
  outline:none;
  box-shadow:var(--ring);
}
