/* Lokal gehostete Schriften (DSGVO) */
@font-face{font-family:"Archivo";font-style:normal;font-weight:500 800;font-display:swap;src:url("../fonts/archivo-variable.woff2") format("woff2")}
@font-face{font-family:"Hanken Grotesk";font-style:normal;font-weight:400 600;font-display:swap;src:url("../fonts/hanken-grotesk-variable.woff2") format("woff2")}
@font-face{font-family:"Hanken Grotesk";font-style:italic;font-weight:400;font-display:swap;src:url("../fonts/hanken-grotesk-italic-variable.woff2") format("woff2")}

:root{
    color-scheme:only light;
    --teal:#238481;
    --teal-deep:#1B6562;
    --teal-ink:#143F3E;
    --mint:#E6F0EE;
    --mint-2:#F2F8F6;
    --gold:#B68B3C;
    --ink:#232A2C;
    --soft:#5C666A;
    --paper:#FFFFFF;
    --line:rgba(20,50,48,.13);
    --line-soft:rgba(20,50,48,.08);
    --maxw:1180px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth;background:#fff}
  body{
    font-family:"Hanken Grotesk",system-ui,sans-serif;
    color:var(--ink);background:var(--paper);
    line-height:1.62;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  }
  h1,h2,h3,h4{font-family:"Archivo",sans-serif;line-height:1.05;letter-spacing:-.01em}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

  .eyebrow{font-family:"Archivo",sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--teal-deep)}
  .btn{
    display:inline-flex;align-items:center;gap:.5em;
    font-family:"Archivo",sans-serif;font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
    padding:.85em 1.5em;border-radius:2px;cursor:pointer;
    transition:transform .22s,background .22s,color .22s,border-color .22s;
  }
  .btn:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
  .btn-primary{background:var(--teal);color:#fff}
  .btn-primary:hover{background:var(--teal-deep);transform:translateY(-2px)}
  .btn-line{border:1.5px solid var(--teal);color:var(--teal-deep)}
  .btn-line:hover{background:var(--teal);color:#fff}
  .btn-onteal{border:1.5px solid rgba(255,255,255,.6);color:#fff}
  .btn-onteal:hover{background:#fff;color:var(--teal-deep);border-color:#fff}
  .btn .arw{transition:transform .22s}.btn:hover .arw{transform:translateX(3px)}

  /* top bar */
  header.top{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line-soft)}
  .top-inner{display:flex;align-items:center;justify-content:space-between;height:70px}
  .brand{display:flex;align-items:center;gap:12px}
  .brand img{height:42px;width:auto}
  .brand b{font-family:"Archivo";font-weight:700;font-size:1rem;color:var(--teal-deep);text-transform:uppercase;letter-spacing:.02em;line-height:1.05}
  .brand small{display:block;font-family:"Hanken Grotesk";font-weight:400;font-size:.72rem;color:var(--soft);letter-spacing:0;text-transform:none}
  .nav{display:flex;gap:26px;align-items:center}
  .nav a{font-family:"Archivo";font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);padding:6px 0;position:relative}
  .nav a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--teal);transition:width .26s}
  .nav a:hover{color:var(--teal-deep)}.nav a:hover::after{width:100%}
  .nav .tickets{background:var(--teal);color:#fff;padding:.55em 1.05em;border-radius:2px}
  .nav .tickets:hover{background:var(--teal-deep)}.nav .tickets::after{display:none}
  .burger{display:none;background:none;border:0;font-size:1.5rem;color:var(--teal-deep);cursor:pointer}

  /* hero */
  .hero{padding:60px 0 70px;position:relative;overflow:hidden}
  .hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
  .hero h1{font-size:clamp(2.7rem,6vw,4.8rem);font-weight:800;color:var(--teal);text-transform:uppercase;margin:.16em 0 .3em}
  .hero h1 span{display:block;color:var(--teal-ink);font-size:.42em;font-weight:700;letter-spacing:.01em;margin-top:.5em;text-transform:none}
  .hero .lede{font-size:1.18rem;color:var(--ink);max-width:30em}
  .hero-cta{display:flex;gap:12px;margin-top:30px;flex-wrap:wrap}

  /* featured concert card */
  .feature{background:var(--teal);color:#fff;border-radius:5px;padding:34px;position:relative;overflow:hidden}
  .feature::after{content:"Soli Deo Gloria";position:absolute;right:18px;bottom:14px;font-family:"Archivo";font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.32)}
  .feature .kl{font-family:"Archivo";font-size:.66rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#bfe6e3}
  .feature h3{font-size:2.2rem;font-weight:800;text-transform:uppercase;margin:.3em 0 .1em;line-height:1}
  .feature .op{color:#dcefee;font-size:1.02rem}
  .feature dl{margin:22px 0;border-top:1px solid rgba(255,255,255,.22);padding-top:18px}
  .feature dl div{display:flex;justify-content:space-between;gap:14px;padding:5px 0}
  .feature dt{font-family:"Archivo";font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#a9dad7}
  .feature dd{font-weight:600;text-align:right}

  /* pipe band divider */
  .pipeband{display:flex;align-items:flex-end;justify-content:center;gap:7px;height:70px;margin-top:46px}
  .pipeband span{position:relative;width:14px;border-radius:4px 4px 0 0;transform-origin:bottom;animation:rise 1s cubic-bezier(.2,.7,.2,1) backwards;overflow:hidden}
  .pipeband span::before{content:"";position:absolute;left:2px;right:2px;bottom:14px;height:2px;border-radius:1px;background:rgba(0,0,0,.32)}
  .pipeband .t{background:linear-gradient(180deg,#3aa6a2,var(--teal) 60%,var(--teal-deep))}
  .pipeband .g{background:linear-gradient(180deg,#d8b25e,var(--gold) 60%,#8a6a28)}
  @keyframes rise{from{transform:scaleY(0)}to{transform:scaleY(1)}}

  section{padding:78px 0}
  .band-mint{background:var(--mint-2)}
  .sec-head{max-width:48em;margin-bottom:44px}
  .sec-head h2{font-size:clamp(1.9rem,3.6vw,2.8rem);font-weight:700;color:var(--teal);text-transform:uppercase;margin:.2em 0 .35em}
  .sec-head p{color:var(--soft);font-size:1.06rem}
  .rule{display:flex;gap:5px;align-items:flex-end;height:18px;margin-bottom:4px}
  .rule i{width:6px;border-radius:2px 2px 0 0;display:block}
  .rule i:nth-child(1){height:45%;background:var(--teal)}
  .rule i:nth-child(2){height:80%;background:var(--gold)}
  .rule i:nth-child(3){height:100%;background:var(--teal)}
  .rule i:nth-child(4){height:60%;background:var(--teal)}

  /* ensembles register */
  .register{border-top:1px solid var(--line)}
  .reg-row{display:grid;grid-template-columns:150px 1fr auto;gap:26px;align-items:baseline;padding:24px 4px;border-bottom:1px solid var(--line);transition:background .22s,padding .22s}
  .reg-row:hover{background:#fff;padding-left:16px;padding-right:16px}
  .reg-voice{font-family:"Archivo";font-size:.66rem;letter-spacing:.13em;text-transform:uppercase;color:var(--teal-deep);font-weight:700}
  .reg-main h3{font-size:1.5rem;font-weight:700;color:var(--ink);text-transform:none;letter-spacing:-.01em;display:inline}
  .reg-main p{color:var(--soft);font-size:.98rem;margin-top:4px;max-width:44em}
  .reg-go{font-family:"Archivo";font-size:1.2rem;color:var(--line);transition:color .22s,transform .22s}
  .reg-row:hover .reg-go{color:var(--teal);transform:translateX(4px)}

  /* freundeskreis split */
  .split{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:5px;overflow:hidden;border:1px solid var(--line)}
  .split .pane{padding:54px 48px}
  .split .a{background:var(--teal);color:#fff}
  .split .a .eyebrow{color:#bfe6e3}
  .split .a h3{font-size:1.9rem;font-weight:800;text-transform:uppercase;margin:.3em 0 .5em}
  .split .a p{color:#dcefee}
  .split .b{background:#fff}
  .split .b h3{font-size:1.9rem;font-weight:800;text-transform:uppercase;color:var(--teal);margin:.3em 0 .5em}
  .split .b p{color:var(--soft)}

  /* leitung */
  .leitung{display:grid;grid-template-columns:.75fr 1.25fr;gap:50px;align-items:center}
  .portrait{aspect-ratio:4/5;background:var(--mint);border-radius:5px;overflow:hidden;border:1px solid var(--line)}
  .portrait img{width:100%;height:100%;object-fit:cover;object-position:center top}
  .leitung blockquote{font-family:"Archivo";font-weight:700;font-size:1.7rem;line-height:1.18;color:var(--teal-ink);margin-bottom:22px;letter-spacing:-.01em}
  .leitung .role{font-family:"Archivo";font-size:.7rem;letter-spacing:.13em;text-transform:uppercase;color:var(--teal-deep);font-weight:700;margin-bottom:6px}
  .leitung .name{font-family:"Archivo";font-size:1.4rem;font-weight:700;color:var(--ink)}
  .leitung p.bio{color:var(--soft);margin-top:14px;font-size:1.02rem}

  /* footer */
  footer{background:var(--teal-ink);color:#bcd3d1;padding:64px 0 28px;border-top:4px solid var(--gold)}
  .foot-grid{display:grid;grid-template-columns:2fr 1fr;gap:36px;padding-bottom:42px;border-bottom:1px solid rgba(255,255,255,.12)}
  footer h4{font-family:"Archivo";font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#8fc2bf;font-weight:700;margin-bottom:16px}
  footer a{color:#bcd3d1;transition:color .2s}footer a:hover{color:#fff}
  footer ul{list-style:none}footer li{padding:5px 0;font-size:.95rem}
  .foot-brand b{font-family:"Archivo";font-size:1.05rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.02em}
  .foot-brand p{font-size:.93rem;margin-top:11px;max-width:24em;color:#9bbdbb}
  .foot-social{display:flex;gap:14px;margin-top:18px}
  .foot-social a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);color:#bcd3d1;transition:background .2s,color .2s}
  .foot-social a:hover{background:rgba(255,255,255,.18);color:#fff}
  .foot-bottom{display:flex;justify-content:space-between;gap:18px;padding-top:22px;font-size:.82rem;color:#7ba6a3;flex-wrap:wrap}
  .foot-bottom a{color:#7ba6a3}
  .foot-account{text-align:right}
  .foot-account small{color:#5f8f8c;font-size:.78em}

  @media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}html{scroll-behavior:auto}}

  /* Schutz gegen erzwungene Dunkeldarstellung im In-App-Browser */
  @media (prefers-color-scheme: dark){
    :root{color-scheme:only light}
    html,body{background:#fff!important;color:var(--ink)!important}
    .eyebrow,.sec-head h2,.hero h1,.reg-voice,.split .b h3,.leitung .role,.leitung .name{color:var(--teal-deep)!important}
    .hero h1 span,.leitung blockquote{color:var(--teal-ink)!important}
    .band-mint{background:var(--mint-2)!important}
  }
  @media(max-width:900px){
    .nav{display:none}.burger{display:block}
    .hero-grid{grid-template-columns:1fr;gap:38px}
    .leitung{grid-template-columns:1fr;gap:30px}
    .split{grid-template-columns:1fr}
    .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
    .reg-row{grid-template-columns:1fr auto;gap:6px}
    .reg-voice{grid-column:1/-1;order:-1}
  }
  @media(max-width:620px){
    section{padding:54px 0}
    .feature{padding:26px}.feature h3{font-size:1.8rem}
    .foot-grid{grid-template-columns:1fr}
    .split .pane{padding:38px 28px}
  }


@media(max-width:900px){
  .top{position:relative}
  .nav.is-open{display:flex;flex-direction:column;align-items:flex-start;gap:0;position:absolute;top:100%;left:0;right:0;background:#fff;padding:8px 24px 16px;border-top:1px solid #e7eceb;box-shadow:0 12px 26px rgba(20,60,58,.12);z-index:60}
  .nav.is-open a{width:100%;padding:18px 2px;font-size:1.05rem;letter-spacing:.04em;border-bottom:1px solid #eef2f1}
  .nav.is-open a::after{display:none}
  .nav.is-open .tickets{margin-top:14px;text-align:center;border-bottom:0;font-size:1rem;padding:.75em 1em}
}

/* --- Seite: Mitglied werden --- */
.join{display:grid;grid-template-columns:1.4fr 1fr;gap:46px;align-items:start}
.join .left h2{font-size:2.4rem;margin:.1em 0 .5em}
.join .left p{color:var(--ink);line-height:1.7;max-width:60ch}
.join .right{background:#fff;border:1px solid #e7eceb;border-radius:4px;padding:30px 28px;box-shadow:0 14px 30px rgba(20,60,58,.07)}
.join .right h4{font-family:"Archivo";font-size:1rem;letter-spacing:.04em;text-transform:uppercase;margin:0 0 14px;color:var(--teal-deep)}
.join .right dl{margin:0}
.join .right dl > div{display:flex;justify-content:space-between;gap:16px;padding:11px 0;border-bottom:1px solid #eef2f1}
.join .right dt{font-weight:600}
.join .right dd{margin:0;color:var(--teal-deep);font-weight:700;white-space:nowrap}
@media(max-width:900px){.join{grid-template-columns:1fr;gap:30px}}

/* --- Seite: Vita & Kontakt --- */
.vk{display:grid;grid-template-columns:1.5fr 1fr;gap:48px;align-items:start}
.vk .bio-col h2{font-size:2.4rem;margin:.1em 0 .1em}
.vk .role{font-family:"Archivo";letter-spacing:.04em;text-transform:uppercase;color:var(--teal-deep);font-size:.85rem;margin-bottom:24px}
.vk .bio-col p{color:var(--ink);line-height:1.75;margin:0 0 16px;max-width:62ch}
.vk .portrait img{width:100%;border-radius:4px;box-shadow:0 16px 36px rgba(20,60,58,.14);margin-bottom:24px}
.vk .card{background:#fff;border:1px solid #e7eceb;border-radius:4px;padding:28px;box-shadow:0 14px 30px rgba(20,60,58,.07)}
.vk .card h4{font-family:"Archivo";font-size:1rem;letter-spacing:.04em;text-transform:uppercase;margin:0 0 14px;color:var(--teal-deep)}
.vk .card p{margin:0 0 4px;line-height:1.6}
.vk .card .lbl{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--soft);margin-top:16px}
.vk .card a{color:var(--teal-deep);font-weight:600}
.vk .socials{display:flex;gap:14px;margin-top:18px}
.vk .socials a{font-family:"Archivo";font-size:.78rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;border:1.5px solid var(--teal);color:var(--teal-deep);padding:.45em 1em;border-radius:2px}
.vk .socials a:hover{background:var(--teal);color:#fff}
@media(max-width:900px){.vk{grid-template-columns:1fr;gap:32px}}

/* --- Seite: Veranstaltungen (Filter + Event-Karten) --- */

  :root{
    color-scheme:only light;
    --teal:#238481;--teal-deep:#1B6562;--teal-ink:#143F3E;
    --mint:#E6F0EE;--mint-2:#F2F8F6;--gold:#B68B3C;
    --ink:#232A2C;--soft:#5C666A;--paper:#FFFFFF;
    --line:rgba(20,50,48,.13);--line-soft:rgba(20,50,48,.08);
    --maxw:1100px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth;background:#fff}
  body{font-family:"Hanken Grotesk",system-ui,sans-serif;color:var(--ink);background:var(--paper);line-height:1.62;-webkit-font-smoothing:antialiased}
  h1,h2,h3,h4{font-family:"Archivo",sans-serif;line-height:1.05;letter-spacing:-.01em}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
  .eyebrow{font-family:"Archivo";font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--teal-deep)}
  .btn{display:inline-flex;align-items:center;gap:.5em;font-family:"Archivo";font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.7em 1.25em;border-radius:2px;cursor:pointer;transition:transform .22s,background .22s,color .22s,border-color .22s}
  .btn:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
  .btn-primary{background:var(--teal);color:#fff}
  .btn-primary:hover{background:var(--teal-deep);transform:translateY(-2px)}
  .btn-line{border:1.5px solid var(--teal);color:var(--teal-deep)}
  .btn-line:hover{background:var(--teal);color:#fff}
  .btn .arw{transition:transform .22s}.btn:hover .arw{transform:translateX(3px)}

  /* top */
  header.top{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line-soft)}
  .top-inner{display:flex;align-items:center;justify-content:space-between;height:70px;max-width:var(--maxw);margin:0 auto;padding:0 28px}
  .brand{display:flex;align-items:center;gap:12px}
  .brand img{height:42px;width:auto}
  .brand b{font-family:"Archivo";font-weight:700;font-size:1rem;color:var(--teal-deep);text-transform:uppercase;letter-spacing:.02em;line-height:1.05}
  .brand small{display:block;font-weight:400;font-size:.72rem;color:var(--soft);letter-spacing:0;text-transform:none}
  .nav{display:flex;gap:26px;align-items:center}
  .nav a{font-family:"Archivo";font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);padding:6px 0;position:relative}
  .nav a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--teal);transition:width .26s}
  .nav a:hover{color:var(--teal-deep)}.nav a:hover::after,.nav a.active::after{width:100%}
  .nav a.active{color:var(--teal-deep)}
  .nav .tickets{background:var(--teal);color:#fff;padding:.55em 1.05em;border-radius:2px}
  .nav .tickets:hover{background:var(--teal-deep)}.nav .tickets::after{display:none}
  .burger{display:none;background:none;border:0;font-size:1.5rem;color:var(--teal-deep);cursor:pointer}

  /* page head */
  .pagehead{padding:46px 0 8px}
  .pagehead h1{font-size:clamp(2.4rem,5.5vw,4rem);font-weight:800;color:var(--teal);text-transform:uppercase;margin:.16em 0 .3em}
  .pagehead p{font-size:1.12rem;color:var(--soft);max-width:40em}

  /* filter */
  .filters{display:flex;gap:9px;flex-wrap:wrap;padding:26px 0 6px;position:sticky;top:70px;background:var(--paper);z-index:20}
  .chip{font-family:"Archivo";font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.55em 1.1em;border-radius:30px;border:1.5px solid var(--line);color:var(--soft);background:#fff;cursor:pointer;transition:all .2s}
  .chip:hover{border-color:var(--teal);color:var(--teal-deep)}
  .chip.on{background:var(--teal);border-color:var(--teal);color:#fff}
  .chip:focus-visible{outline:2px solid var(--gold);outline-offset:2px}

  /* events */
  .events{display:flex;flex-direction:column;gap:16px;padding:30px 0 10px}
  .event{display:grid;grid-template-columns:92px 1fr auto;gap:24px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:4px;padding:22px 24px;transition:box-shadow .22s,transform .22s,border-color .22s}
  .event:hover{box-shadow:0 10px 30px rgba(20,60,58,.09);transform:translateY(-2px);border-color:var(--teal)}
  .event[hidden]{display:none}
  .date{border-radius:4px;text-align:center;padding:11px 6px;align-self:stretch;display:flex;flex-direction:column;justify-content:center;color:#fff;background:var(--teal)}
  .date.orgel{background:var(--gold)}
  .date.gospel{background:var(--teal-deep)}
  .date.gaeste,.date.special{background:var(--teal-ink)}
  .date.seeregion{background:#4a7fb5}
  .date .d{font-family:"Archivo";font-size:1.85rem;font-weight:800;line-height:1}
  .date .m{font-family:"Archivo";font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-top:3px}
  .date .y{font-size:.68rem;opacity:.85;margin-top:2px}
  .ev-body{min-width:0}
  .tag{display:inline-block;font-family:"Archivo";font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.3em .7em;border-radius:20px;margin-bottom:8px;background:var(--mint);color:var(--teal-deep)}
  .tag.orgel{background:#f3e8d2;color:#86621f}
  .tag.gospel{background:#d9ece9;color:var(--teal-deep)}
  .tag.gaeste,.tag.special{background:#e2eae9;color:var(--teal-ink)}
  .tag.seeregion{background:#dde8f3;color:#2d5f8a}
  .ev-body h3{font-size:1.34rem;font-weight:700;color:var(--ink);letter-spacing:-.01em;line-height:1.14;margin-bottom:4px}
  .ev-body .work{color:var(--teal-deep);font-weight:600;font-size:.97rem}
  .ev-body .perf{color:var(--soft);font-size:.92rem;margin-top:6px}
  .ev-body .meta{display:flex;gap:15px;flex-wrap:wrap;margin-top:10px}
  .ev-body .meta span{font-family:"Archivo";font-size:.69rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--soft)}
  .ev-body .meta b{color:var(--ink)}
  .ev-cta{text-align:right;display:flex;flex-direction:column;gap:8px;align-items:flex-end;min-width:118px}
  .ev-cta .price{font-family:"Archivo";font-size:.8rem;font-weight:700;color:var(--teal-ink);line-height:1.3}
  .ev-cta .price small{display:block;font-weight:400;font-family:"Hanken Grotesk";font-size:.72rem;color:var(--soft)}
  .ev-cta .free{color:var(--gold)}

  .noresult{padding:40px 0;color:var(--soft);text-align:center;font-style:italic}

  /* Vergangene Veranstaltungen */
  .event.is-past{opacity:.6;filter:grayscale(.4)}
  .event.is-past:hover{opacity:.72;transform:none;box-shadow:none;border-color:var(--line)}
  .event.is-past .date{position:relative}
  .past-ribbon{
    position:absolute;bottom:0;left:0;right:0;
    background:#c0392b;color:#fff;
    font-family:"Archivo";font-size:.6rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
    text-align:center;padding:.45em 0;line-height:1;
  }
  .past-flag{display:none}

  /* info band */
  .info{background:var(--mint-2);margin-top:30px;padding:54px 0}
  .info-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
  .info h3{font-family:"Archivo";font-size:.74rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--teal-deep);margin-bottom:12px}
  .info p{color:var(--ink);font-size:1.02rem}

  /* footer */
  footer{background:var(--teal-ink);color:#bcd3d1;padding:60px 0 28px;border-top:4px solid var(--gold)}
  .foot-grid{display:grid;grid-template-columns:2fr 1fr;gap:36px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.12);max-width:var(--maxw);margin:0 auto;padding-left:28px;padding-right:28px}
  footer h4{font-family:"Archivo";font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#8fc2bf;font-weight:700;margin-bottom:16px}
  footer a{color:#bcd3d1}footer a:hover{color:#fff}
  footer ul{list-style:none}footer li{padding:5px 0;font-size:.95rem}
  .foot-brand b{font-family:"Archivo";font-size:1.05rem;font-weight:700;color:#fff;text-transform:uppercase}
  .foot-brand p{font-size:.93rem;margin-top:11px;max-width:24em;color:#9bbdbb}
  .foot-social{display:flex;gap:14px;margin-top:18px}
  .foot-social a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);color:#bcd3d1;transition:background .2s,color .2s}
  .foot-social a:hover{background:rgba(255,255,255,.18);color:#fff}
  .foot-bottom{display:flex;justify-content:space-between;gap:18px;padding-top:22px;font-size:.82rem;color:#7ba6a3;flex-wrap:wrap;max-width:var(--maxw);margin:0 auto;padding-left:28px;padding-right:28px}
  .foot-bottom a{color:#7ba6a3}
  .foot-account{text-align:right}
  .foot-account small{color:#5f8f8c;font-size:.78em}

  @media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}html{scroll-behavior:auto}}
  @media (prefers-color-scheme: dark){
    :root{color-scheme:only light}
    html,body{background:#fff!important;color:var(--ink)!important}
    .eyebrow,.pagehead h1,.ev-body .work,.info h3{color:var(--teal-deep)!important}
    .info{background:var(--mint-2)!important}
    .chip{background:#fff!important}
  }
  @media(max-width:900px){
    .nav{display:none}.burger{display:block}
    .foot-grid{grid-template-columns:1fr 1fr}
    .info-grid{grid-template-columns:1fr;gap:26px}
  }
  @media(max-width:620px){
    .event{grid-template-columns:60px 1fr;gap:14px}
    .date .d{font-size:1.45rem}
    .ev-cta{grid-column:1/-1;flex-direction:row;justify-content:space-between;align-items:center;text-align:left;border-top:1px solid var(--line-soft);padding-top:12px}
    .foot-grid{grid-template-columns:1fr}
    .filters{top:0}
  }


/* --- Klangkörper-Seiten (Detailseiten) --- */
.kk .crumb{padding:18px 0 0}
.kk .crumb a,.kk .crumb span{font-family:"Archivo";font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--soft)}
.kk .crumb a:hover{color:var(--teal-deep)}
.kk .crumb .sep{margin:0 .5em;color:var(--line)}

.kk .hero{padding:34px 0 60px;position:relative;overflow:hidden}
.kk .hero-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:48px;align-items:center}
.kk .hero h1{font-size:clamp(2.5rem,5.5vw,4.4rem);font-weight:800;color:var(--teal);text-transform:uppercase;margin:.18em 0 .3em}
.kk .hero .lede{font-size:1.16rem;color:var(--ink);max-width:30em}
.kk .hero-facts{display:flex;gap:0;margin-top:30px;border:1px solid var(--line);border-radius:3px;overflow:hidden;max-width:560px}
.kk .hero-facts div{flex:1;padding:16px 18px}
.kk .hero-facts div + div{border-left:1px solid var(--line)}
.kk .hero-facts dt{font-family:"Archivo";font-size:.62rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--teal-deep);margin-bottom:4px}
.kk .hero-facts dd{font-size:.95rem;color:var(--ink);font-weight:500}
.kk .hero-cta{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}

.kk .organ{background:var(--mint);border-radius:4px;padding:34px;display:flex;align-items:flex-end;justify-content:center;gap:8px;height:300px;position:relative}
.kk .organ::before{content:"Soli Deo Gloria";position:absolute;top:18px;left:0;right:0;text-align:center;font-family:"Archivo";font-size:.62rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--teal-deep);opacity:.65}
.kk .organ .pipe{position:relative;width:16px;border-radius:4px 4px 0 0;transform-origin:bottom;animation:rise 1s cubic-bezier(.2,.7,.2,1) backwards;overflow:hidden}
.kk .organ .pipe::before{content:"";position:absolute;left:3px;right:3px;bottom:22px;height:3px;border-radius:1px;background:rgba(0,0,0,.32)}
.kk .organ .pipe.t{background:linear-gradient(180deg,#3aa6a2,var(--teal) 60%,var(--teal-deep))}
.kk .organ .pipe.g{background:linear-gradient(180deg,#d8b25e,var(--gold) 60%,#8a6a28)}
@keyframes rise{from{transform:scaleY(0)}to{transform:scaleY(1)}}

.kk .sec-head{max-width:46em;margin-bottom:40px}
.kk .sec-head h2{font-size:clamp(1.8rem,3.4vw,2.6rem);font-weight:700;color:var(--teal);text-transform:uppercase;margin:.2em 0 .35em}
.kk .sec-head p{color:var(--soft);font-size:1.06rem}

.kk .about{display:grid;grid-template-columns:1.4fr 1fr;gap:54px;align-items:start}
.kk .about p{font-size:1.08rem;margin-bottom:1em;color:var(--ink)}
.kk .about p.lead{font-size:1.28rem;font-weight:500;color:var(--teal-ink);line-height:1.4}
.kk .sidecard{background:#fff;border:1px solid var(--line);border-radius:4px;padding:26px}
.kk .sidecard h4{font-family:"Archivo";font-size:.72rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--teal-deep);margin-bottom:14px}
.kk .sidecard dl div{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px solid var(--line-soft);font-size:.96rem}
.kk .sidecard dl div:last-child{border-bottom:0}
.kk .sidecard dt{color:var(--soft)}.kk .sidecard dd{font-weight:600;text-align:right}

/* Mitsingen-Panel (Teal-Variante, nur Klangkörper) */
.kk .join{display:grid;grid-template-columns:1.1fr .9fr;gap:0;border-radius:5px;overflow:hidden;border:1px solid var(--line)}
.kk .join .left{background:var(--teal);color:#fff;padding:48px 46px}
.kk .join .left .eyebrow{color:#bfe6e3}
.kk .join .left h2{color:#fff;font-size:2rem;font-weight:800;text-transform:uppercase;margin:.25em 0 .5em}
.kk .join .left p{color:#dcefee;font-size:1.05rem;margin-bottom:1.4em}
.kk .join .right{background:#fff;padding:48px 46px}
.kk .join .right h4{font-family:"Archivo";font-size:.72rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--teal-deep);margin-bottom:16px}
.kk .join .right dl div{display:flex;justify-content:space-between;gap:14px;padding:10px 0;border-bottom:1px solid var(--line-soft);font-size:.97rem}
.kk .join .right dt{color:var(--soft)}.kk .join .right dd{font-weight:600;text-align:right}

/* Orgeln: Disposition + Galerie */
.kk .disp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-top:8px}
.kk .disp-card{background:#fff;border:1px solid var(--line);border-radius:4px;padding:22px}
.kk .disp-card h4{font-family:"Archivo";font-size:.72rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--teal-deep);margin-bottom:12px}
.kk .disp-card ul{list-style:none}
.kk .disp-card li{padding:6px 0;font-size:.92rem;color:var(--ink);border-bottom:1px solid var(--line-soft)}
.kk .disp-card li:last-child{border-bottom:0}
.kk .disp-card li i{font-style:normal;font-family:"Archivo";font-size:.62rem;font-weight:700;letter-spacing:.08em;color:var(--gold);margin-left:6px;vertical-align:middle}
.kk .gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.kk .gallery figure{margin:0}
.kk .gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:4px;border:1px solid var(--line)}
.kk .gallery figcaption{font-size:.78rem;color:var(--soft);margin-top:6px}

@media(max-width:900px){
  .kk .hero-grid{grid-template-columns:1fr;gap:34px}
  .kk .about{grid-template-columns:1fr;gap:34px}
  .kk .join{grid-template-columns:1fr}
  .kk .gallery{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:620px){
  .kk .hero-facts{flex-direction:column}.kk .hero-facts div + div{border-left:0;border-top:1px solid var(--line)}
  .kk .join .left,.kk .join .right{padding:36px 28px}
}

/* --- Login-Formular (Mitgliederbereich, Orgel-Buchung) --- */
.login-card{max-width:420px;margin-top:30px;background:#fff;border:1px solid var(--line);border-radius:5px;padding:30px 28px;box-shadow:0 14px 30px rgba(20,60,58,.07)}
.login-card label{display:block;font-family:"Archivo";font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--teal-deep);margin-bottom:6px}
.login-card input[type=text],.login-card input[type=password]{width:100%;padding:.7em .8em;border:1.5px solid var(--line);border-radius:3px;font:inherit;margin-bottom:16px}
.login-card input:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--teal)}
.login-card .login-remember{font-family:inherit;text-transform:none;letter-spacing:0;font-weight:400;color:var(--soft);font-size:.9rem;margin-bottom:14px}
.login-card .login-remember input{width:auto;margin-right:6px}
.login-card .button,.login-card input[type=submit]{background:var(--teal);color:#fff;border:0;font-family:"Archivo";font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.85em 1.6em;border-radius:2px;cursor:pointer;transition:background .22s}
.login-card input[type=submit]:hover{background:var(--teal-deep)}
.login-hint{margin-top:18px;color:var(--soft);font-size:.92rem}
.login-hint a{color:var(--teal-deep);font-weight:600}
.intern .logout-link{font-family:"Archivo";font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--teal-deep);margin-left:14px;border-bottom:1px solid var(--teal)}

.intern .mat-chor{margin-bottom:48px}
.intern .mat-chor:last-child{margin-bottom:0}
.intern .mat-chor-title{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;color:var(--teal);text-transform:uppercase;margin:.2em 0 .6em}
.intern .mat-sub{font-family:"Archivo";font-size:.74rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--teal-deep);margin:24px 0 12px}
.intern .mat-files{list-style:none;display:flex;flex-direction:column;gap:10px}
.intern .mat-files li{display:flex;align-items:center;justify-content:space-between;gap:18px;background:#fff;border:1px solid var(--line);border-radius:4px;padding:14px 18px}
.intern .mat-name{font-weight:600;color:var(--ink)}
.intern .mat-audio{display:flex;flex-direction:column;gap:14px}
.intern .mat-track{background:#fff;border:1px solid var(--line);border-radius:4px;padding:16px 18px}
.intern .mat-track-head{display:flex;align-items:center;gap:14px;margin-bottom:10px;flex-wrap:wrap}
.intern .mat-track audio{width:100%}
.intern .voice-badge{font-family:"Archivo";font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.32em .8em;border-radius:20px;background:var(--mint);color:var(--teal-deep)}
.intern .voice-sopran{background:#f3e8d2;color:#86621f}
.intern .voice-alt{background:#d9ece9;color:var(--teal-deep)}
.intern .voice-tenor{background:#e2eae9;color:var(--teal-ink)}
.intern .voice-bass{background:#dbe9e7;color:var(--teal-deep)}
.intern .mat-dl{margin-left:auto;font-family:"Archivo";font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--teal-deep);border-bottom:1px solid var(--teal)}
@media(max-width:620px){.intern .mat-files li{flex-direction:column;align-items:flex-start;gap:10px}}

/* --- Newsletter-Seite --- */
.newsletter .nl-card{background:#fff;border:1px solid var(--line);border-radius:5px;padding:34px 32px;box-shadow:0 16px 36px rgba(20,60,58,.10)}
.newsletter .nl-card-title{font-size:1.6rem;font-weight:800;color:var(--teal);text-transform:uppercase;margin-bottom:18px}
.newsletter .nl-form label{display:block;font-family:"Archivo";font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--teal-deep);margin:14px 0 6px}
.newsletter .nl-form label .opt{color:var(--soft);font-weight:400;text-transform:none;letter-spacing:0}
.newsletter .nl-form input[type=text],.newsletter .nl-form input[type=email]{width:100%;padding:.72em .85em;border:1.5px solid var(--line);border-radius:3px;font:inherit}
.newsletter .nl-form input:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--teal)}
.newsletter .nl-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.newsletter .nl-consent{display:flex;gap:10px;align-items:flex-start;margin:20px 0 22px;font-family:inherit;font-size:.9rem;font-weight:400;letter-spacing:0;text-transform:none;color:var(--soft);line-height:1.5}
.newsletter .nl-consent input{margin-top:.25em;flex:0 0 auto}
.newsletter .nl-consent a{color:var(--teal-deep);font-weight:600}
.newsletter .nl-form .btn-primary{border:0;width:100%;justify-content:center}
.newsletter .nl-note{margin-top:16px;padding:12px 14px;background:var(--mint-2);border-left:3px solid var(--gold);font-size:.84rem;color:var(--soft);line-height:1.5}
.newsletter .nl-note code{background:rgba(20,50,48,.07);padding:.1em .4em;border-radius:3px;font-size:.92em}

/* Intern — Tabs */
.mat-tabs{margin-bottom:2rem}
.mat-tab-nav{display:flex;gap:0;border-bottom:2px solid var(--line);margin-bottom:1.5rem}
.mat-tab-btn{background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;padding:.6rem 1.2rem;font-family:"Archivo";font-size:.9rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--soft);cursor:pointer;transition:color .15s,border-color .15s}
.mat-tab-btn:hover{color:var(--fg)}
.mat-tab-btn.is-active{color:var(--accent);border-bottom-color:var(--accent)}
.mat-tab-panel{display:none}
.mat-tab-panel.is-active{display:block}
.mat-stueck{margin-bottom:1.8rem}
.mat-stueck-title{font-size:1rem;font-weight:700;color:var(--fg);margin-bottom:.75rem;padding-bottom:.35rem;border-bottom:1px solid var(--line)}

/* Orgel-Buchung */
.ob-form{max-width:640px}
.ob-row{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px}
.ob-row label{flex:1 1 160px;display:flex;flex-direction:column;gap:6px;font-size:.85rem;font-weight:600;color:var(--fg)}
.ob-row input{padding:.7rem .8rem;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:.95rem;background:#fff}
.ob-notice{padding:14px 18px;border-radius:8px;margin-bottom:20px;font-size:.92rem;line-height:1.5}
.ob-notice.ob-ok{background:#e3f3ee;color:#1d6b52;border-left:3px solid #1d6b52}
.ob-notice.ob-err{background:#fbe9e7;color:#a13a2a;border-left:3px solid #a13a2a}

/* Orgel-Belegungskalender — 30-Tage-Wochenansicht */
.ob-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-top:8px}
.ob-cal-dow{font-family:"Archivo";font-size:.74rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--soft);text-align:center;padding-bottom:6px}
.ob-cal-day{height:186px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px 7px;font-size:.82rem;overflow:hidden}
.ob-cal-day.empty{background:transparent;border-color:transparent}
.ob-cal-day.today{border-color:var(--accent);border-width:2px;padding:7px 6px}
.ob-cal-daynum{display:block;font-weight:700;color:var(--fg);font-size:.86rem;margin-bottom:5px}
.ob-cal-pill{display:block;margin-top:3px;padding:3px 6px;border-radius:4px;overflow:hidden}
.ob-cal-time{display:block;font-size:.7rem;font-weight:700;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ob-cal-label{display:block;font-size:.64rem;font-weight:400;line-height:1.3;opacity:.85;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ob-cal-pill.termin{background:#fbe9e7;color:#a13a2a}
.ob-cal-pill.orgel{background:#e3f3ee;color:#1d6b52}
.ob-cal-more{display:block;margin-top:3px;font-size:.66rem;font-weight:700;color:var(--soft)}
.ob-cal-legend{display:flex;gap:22px;flex-wrap:wrap;margin-top:20px;font-size:.82rem;color:var(--soft)}
.ob-cal-legend span{display:inline-flex;align-items:center;gap:7px}
.ob-cal-dot{display:inline-block;width:10px;height:10px;border-radius:3px}
.ob-cal-dot.termin{background:#a13a2a}
.ob-cal-dot.orgel{background:#1d6b52}
@media (max-width:900px){
  .ob-cal-day{height:150px}
}
@media (max-width:640px){
  .ob-cal-grid{gap:4px}
  .ob-cal-day{height:130px;font-size:.66rem;padding:5px 4px}
  .ob-cal-daynum{font-size:.72rem}
  .ob-cal-time{font-size:.6rem}
  .ob-cal-label{font-size:.55rem}
  .ob-cal-pill{font-size:.58rem;padding:2px 4px}
}
