:root{
  --bg:#ffffff;
  --ink:#0b1020;
  --muted:#5b667a;
  --line:rgba(11,16,32,.10);
  --card:#ffffff;
  --shadow:0 16px 40px rgba(11,16,32,.10);
  --radius:22px;
  --primary:#d91e18;
  --primary2:#f26c1a;
  --primary-dark:#9f1713;
  --accent:#22c55e;
  --warn:#f97316;
  --accent-red:#d90f18;
  --accent-orange:#ef6c1b;
  --accent-amber:#f3a620;
  --accent-yellow:#f2c312;
  --accent-slate:#506071;
  --accent-slate-2:#60707f;
  --text:#182234;
  --max:1120px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}

body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--ink);
  background:
    radial-gradient(900px 520px at 15% -10%, rgba(217,30,24,.28), transparent 58%),
    radial-gradient(900px 520px at 85% -10%, rgba(242,108,27,.24), transparent 58%),
    radial-gradient(900px 520px at 50% 120%, rgba(217,30,24,.12), transparent 62%),
    var(--bg);
  line-height:1.6;
}

a{color:inherit}
a:hover{opacity:.9}

.container{width:min(var(--max),92vw);margin:0 auto}

.skip{
  position:absolute;
  left:-999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}
.skip:focus{
  left:12px;
  top:12px;
  width:auto;
  height:auto;
  z-index:999;
  background:#fff;
  padding:10px;
  border-radius:14px;
  box-shadow:var(--shadow);
}

.header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.96);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}

.header-wave{
  height:5px;
  background: linear-gradient(90deg, var(--primary-dark) 0%, #d90f18 22%, #ef6c1b 46%, #f3a620 70%, #f2c312 86%, #506071 100%);
  opacity:.92;
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  padding:18px 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:0;
  flex:1 1 auto;
}

.logo{
  width:44px;
  height:44px;
  border-radius:14px;
  background: linear-gradient(135deg, var(--primary), var(--primary2));
  display:grid;
  place-items:center;
  color:#fff;
  font-weight:950;
  letter-spacing:.5px;
  box-shadow: 0 10px 24px rgba(217,30,24,.22);
}

.logo-img{
  height:100px;
  width:auto;
  display:block;
  object-fit:contain;
  flex:0 0 auto;
}

.brand h1,
.brand strong{
  margin:0;
  color:var(--text);
  font-size:clamp(1.9rem, 2.8vw, 2.45rem);
  font-weight:950;
  letter-spacing:.1px;
  line-height:1.02;
}

.brand p,
.brand small{
  margin:4px 0 0 0;
  color:var(--muted);
  font-size:clamp(.82rem, 1vw, .96rem);
  line-height:1.2;
  letter-spacing:-0.01em;
}

.nav-toggle{
  display:none;
  border:1px solid var(--line);
  background:#fff;
  padding:10px 14px;
  border-radius:14px;
  font-weight:900;
  cursor:pointer;
}

.nav ul{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}

.nav a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:16px;
  font-weight:900;
  text-decoration:none;
  border:1px solid transparent;
}

.nav a[aria-current="page"]{
  background:rgba(217,30,24,.10);
  color:var(--primary);
  border-color:rgba(217,30,24,.22);
}

.nav a:hover{
  text-decoration:none;
  background:rgba(11,16,32,.04);
}

.hero{padding: 28px 0 12px;}
.hero-wrap{
  position:relative;
  border-radius: calc(var(--radius) + 8px);
  overflow:hidden;
  box-shadow: var(--shadow);
  border:1px solid var(--line);
  background:
    linear-gradient(135deg, rgba(217,30,24,.20), rgba(242,108,27,.16)),
    #fff;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 18px;
  padding: 22px;
  align-items: center;
}
.hero h2{margin: 12px 0 10px;font-size: clamp(2.0rem, 3.6vw, 3.3rem);line-height: 1.02;letter-spacing: -0.02em;}
.hero p{margin:0;color:var(--muted);max-width:72ch;font-size:1.05rem}
.badge-row{display:flex;gap:10px;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#fff;border:1px solid var(--line);font-weight:900;color:rgba(11,16,32,.80)}
.dot{width:10px;height:10px;border-radius:999px;background:var(--primary);box-shadow:0 0 0 3px rgba(217,30,24,.16)}
.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:11px 14px;border-radius:16px;font-weight:950;text-decoration:none;border:1px solid var(--line);background:#fff}
.btn.primary{border-color: transparent;background: linear-gradient(135deg, #c81814, #f26c1a);color:#fff}
.btn.primary:hover{text-decoration:none;opacity:.95}
.btn.ghost:hover{text-decoration:none;background:rgba(11,16,32,.04)}
.hero-photo{border-radius: var(--radius);overflow:hidden;border:1px solid var(--line);transform: rotate(1.2deg);box-shadow: 0 22px 42px rgba(11,16,32,.14);background:#fff;display:flex;align-items:center;justify-content:center;padding:10px}
.hero-photo img{width:100%;height:420px;object-fit:contain;object-position:center center;border-radius:0;display:block}
.wave{position:absolute;left:-10%;right:-10%;bottom:-30px;height:90px;background: radial-gradient(closest-side, rgba(255,255,255,1) 85%, transparent 86%);opacity:1;transform: rotate(-1.5deg)}

.main{padding: 18px 0 48px}
.section{margin-top: 18px;border-radius: calc(var(--radius) + 8px);border:1px solid var(--line);background: rgba(255,255,255,.72);backdrop-filter: blur(10px);box-shadow: var(--shadow);padding: 18px}
.section-title{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom: 10px}
.section-title h3{margin:0;font-size:1.2rem}
.kicker{font-weight:950;letter-spacing:.12em;text-transform:uppercase;font-size:.78rem;color: rgba(11,16,32,.62)}
.cards{display:grid;grid-template-columns: repeat(3, 1fr);gap: 14px}
.card{border:1px solid var(--line);border-radius: var(--radius);background: #fff;box-shadow: 0 10px 26px rgba(11,16,32,.08);padding: 16px}
.card h4{margin:10px 0 8px;font-size:1.05rem}
.card p{margin:0;color:var(--muted)}
.icon{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;background: rgba(217,30,24,.10);border:1px solid rgba(217,30,24,.20);font-weight:950}
.icon.purple{background: rgba(217,30,24,.10);border-color: rgba(217,30,24,.18)}
.icon.orange{background: rgba(249,115,22,.10);border-color: rgba(249,115,22,.18)}
.table{width:100%;border-collapse:collapse}
.table th,.table td{border-bottom:1px solid var(--line);padding:10px 6px;text-align:left}
.table th{color:var(--muted);font-weight:900;font-size:.9rem}
.gallery{display:grid;grid-template-columns: repeat(12, 1fr);gap: 10px}
.tile{position:relative;border-radius: 20px;overflow:hidden;border:1px solid var(--line);box-shadow: 0 12px 30px rgba(11,16,32,.10)}
.tile img{width:100%;height:100%;object-fit:cover;border-radius:0;display:block}
.tile::after{content:"";position:absolute;inset:0;background: linear-gradient(to top, rgba(11,16,32,.38), transparent 55%)}
.tile span{position:absolute;left:12px;bottom:10px;color:#fff;font-weight:950;z-index:2}
.span-4{grid-column: span 4;}
.span-6{grid-column: span 6;}
.span-3{grid-column: span 3;}
.note{color:var(--muted);font-size:.95rem}

.footer{border-top:1px solid var(--line);padding:26px 0;color:var(--muted)}
.footer a{color:var(--muted)}
.footer-inner{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}

@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr}
  .hero-photo{transform:none}
  .hero-photo img{height:320px;object-fit:contain}
  .cards{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(6,1fr)}
  .span-6{grid-column: span 6;}
  .span-4{grid-column: span 6;}
  .span-3{grid-column: span 6;}
}

@media (max-width: 760px){
  .header-inner{align-items:flex-start;flex-wrap:wrap;gap:12px;padding:14px 0}
  .brand{width:100%;gap:10px;align-items:flex-start}
  .logo-img{height:80px;margin-top:2px}
  .brand h1,.brand strong{font-size:1.55rem;line-height:1.06}
  .brand p,.brand small{font-size:.8rem;line-height:1.18;margin-top:3px}
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center;margin-left:auto}
  .nav{display:none;width:100%}
  .nav.open{display:block;margin-top:4px}
  .nav ul{width:100%;display:flex;flex-direction:column;gap:6px;padding:10px;background:rgba(255,255,255,.98);border:1px solid var(--line);border-radius:18px;box-shadow:0 12px 30px rgba(11,16,32,.08)}
  .nav li{width:100%}
  .nav a{width:100%;justify-content:flex-start;padding:12px 14px;border-radius:14px}
}

@media (max-width: 640px){
  .gallery{grid-template-columns:repeat(2,1fr)}
  .span-6,.span-4,.span-3{grid-column: span 2}
}

.chronik-content{max-width: 74ch;margin-top: 18px;line-height: 1.85;font-size: 1.02rem;position: relative}
.chronik-content h1,.chronik-content h2,.chronik-content h3{font-size: 1.05rem;font-weight: 900;letter-spacing: -0.01em;margin: 28px 0 10px;color: rgba(11,16,32,.88)}
.chronik-content h1{ margin-top: 34px; }
.chronik-content p{margin: 8px 0;color: rgba(11,16,32,.92)}
.chronik-content em{ color: rgba(11,16,32,.84); }
.chronik-content strong{ color: rgba(11,16,32,.92); }
.chronik-content hr{border: 0;border-top: 1px solid rgba(11,16,32,.08);margin: 16px 0}
.chronik-content img{max-width: min(520px, 100%);height: auto;display:block;margin: 10px 0 18px;border-radius: 12px;border: 1px solid rgba(11,16,32,.10);box-shadow: none}
.chronik-content p:has(img){margin: 12px 0 18px}
.chronik-content > * + *{margin-top: 10px}
.chronik-content br{ line-height: 1.9; }
.year{color:var(--primary)}
.year-block{position: relative;padding: 8px 0 22px 2.2rem;margin: 0 0 18px;border-left: 2px solid rgba(11,16,32,.08)}
.year-block::before{content: "";position: absolute;left: .6rem;top: 2.4rem;bottom: 0;width: 2px;background: linear-gradient(to bottom, rgba(217,30,24,.22), rgba(242,108,27,.12))}
.year-block:last-child::before{bottom: 1rem}
.year-block--preface{border-left: 0;padding-left: 1rem !important}
.year-block--preface::before{display: none !important}
.chronik-content .year{position: relative;padding-left: .6rem;margin: 18px 0 10px;font-size: 1.2rem;font-weight: 950;letter-spacing: -0.01em;color: rgba(11,16,32,.92)}
.year::before{content: "";position: absolute;left: -1.1rem;top: .5rem;width: 12px;height: 12px;border-radius: 50%;background: #ffffff;border: 3px solid var(--primary);box-shadow: 0 0 0 4px rgba(217,30,24,.10)}
.entry-title,.entry-lead,.year-block > p,.year-block > div,.year-block > h3{position: relative}
.entry-title::before,.year-block > h3::before{content: "";position: absolute;left: -1.55rem;top: .7rem;width: 9px;height: 9px;border-radius: 50%;background: linear-gradient(135deg, var(--accent-orange), var(--accent-yellow));box-shadow: 0 0 0 4px rgba(239,108,27,.10)}
.year-block--preface .entry-title::before{display: none !important}
@media (max-width: 640px){.year-block{ padding-left: 14px; }.year-block:not(.year-block--preface) .year::before{ left:-6px; }}
.gallery-grid{margin-top: 18px;display: grid;grid-template-columns: repeat(auto-fill, minmax(220px,1fr));gap: 14px}
.gallery-item img{width: 100%;height: auto;display:block;border-radius: 14px;border: 1px solid rgba(11,16,32,.10)}
.chor-image{margin: 14px 0 18px}
.chor-image img{max-width: min(640px,100%);width: 100%}
.event-card h4{ margin-top: 12px; }
.content-card{background: #fff;border-radius: 22px;padding: 26px;box-shadow: 0 10px 30px rgba(11,16,32,.08)}
.impressum-content h3{margin: 22px 0 8px;font-size: 1.1rem}
.impressum-content h4{margin: 18px 0 8px;font-size: 1rem}
.impressum-content p{margin: 0 0 14px}
