/* kbvk Theme — Startseite (self-contained) */
:root{
  --coral:#FF2E63; --coral-deep:#e01048;
  --yellow:#FFC400; --teal:#00D6C2; --teal-deep:#00a99a;
  --cream:#FFFFFF; --cream-2:#FFF6FA; --card:#FFFFFF;
  --plum:#2E1A47; --plum-soft:#5d4470;
  --ink:#1f0f33;
  --shadow:0 14px 34px rgba(46,26,71,.12);
  --shadow-lg:0 26px 60px rgba(46,26,71,.20);
  --r:26px;
  --font-d:"Fredoka",system-ui,sans-serif;
  --font-b:"Mulish",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-b);color:var(--plum);background:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--font-d);font-weight:600;line-height:1.04;letter-spacing:-.01em;color:var(--plum)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{width:min(1180px,92vw);margin-inline:auto}
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-d);font-weight:600;font-size:1.02rem;padding:.82em 1.5em;border-radius:999px;border:2.5px solid var(--plum);cursor:pointer;transition:transform .15s ease, box-shadow .15s ease;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-coral{background:var(--coral);color:#fff;border-color:var(--coral);box-shadow:0 6px 0 var(--coral-deep)}
.btn-coral:hover{box-shadow:0 8px 0 var(--coral-deep)}
.btn-teal{background:var(--teal);color:#08322e;border-color:var(--teal);box-shadow:0 6px 0 var(--teal-deep)}
.btn-teal:hover{box-shadow:0 8px 0 var(--teal-deep)}
.btn-ghost{background:transparent;color:var(--plum)}
.btn-ghost:hover{background:#fff}
.eyebrow{font-family:var(--font-d);font-weight:600;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--coral)}
.ph{background:repeating-linear-gradient(135deg,rgba(75,46,79,.05) 0 11px,rgba(75,46,79,.10) 11px 22px);display:flex;align-items:center;justify-content:center;color:var(--plum-soft);font-family:"SFMono-Regular",ui-monospace,Menlo,monospace;font-size:.72rem;letter-spacing:.05em;text-align:center}

/* ---- top strip ---- */
.strip{background:var(--plum);color:var(--cream);font-size:.86rem;font-weight:600}
.strip .wrap{display:flex;align-items:center;justify-content:center;gap:.5em;padding:.55em 0;text-align:center;white-space:nowrap;overflow:hidden}
.strip a{color:var(--yellow);text-decoration:underline;text-underline-offset:3px}
.dot{width:7px;height:7px;border-radius:50%;background:var(--yellow);flex:none}

/* ---- header ---- */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);border-bottom:2px solid rgba(46,26,71,.08)}
.nav{display:flex;align-items:center;gap:1.4rem;padding:.85rem 0}
.brand{display:flex;align-items:center;gap:.7rem}
.oldlogo{height:50px;width:auto;display:block;mix-blend-mode:multiply}
.oldlogo-foot{height:48px;width:auto;display:block;filter:invert(1);mix-blend-mode:screen}
nav.links{display:flex;gap:.3rem;margin-left:auto;list-style:none}
nav.links a{font-family:var(--font-d);font-weight:500;font-size:1rem;padding:.5em .85em;border-radius:999px;transition:background .15s,color .15s}
nav.links a:hover{background:#fff;color:var(--coral)}
nav.links li.current-menu-item>a,nav.links a.active{color:var(--coral);background:#fff;box-shadow:inset 0 0 0 2px rgba(255,46,99,.25)}
.nav .btn{padding:.6em 1.15em;font-size:.95rem}
.burger{display:none;margin-left:auto;width:46px;height:46px;border:2px solid var(--plum);border-radius:14px;background:#fff;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:4px}
.burger span{width:20px;height:2.4px;background:var(--plum);border-radius:2px}

/* ---- hero ---- */
.hero{position:relative;padding:64px 0 92px}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(2.7rem,5.4vw,4.5rem);font-weight:700}
.hero h1 .hl{position:relative;white-space:nowrap}
.hero h1 .hl::after{content:"";position:absolute;left:-2px;right:-2px;bottom:.06em;height:.36em;background:var(--yellow);z-index:-1;border-radius:6px;transform:rotate(-1.2deg)}
.hero p.lede{font-size:1.18rem;color:var(--plum-soft);margin:1.3rem 0 2rem;max-width:30ch}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap}
.hero-trust{display:flex;align-items:center;gap:1.4rem;margin-top:2.1rem;flex-wrap:wrap}
.hero-trust div{display:flex;flex-direction:column}
.hero-trust b{font-family:var(--font-d);font-size:1.5rem;color:var(--coral);line-height:1}
.hero-trust small{font-size:.82rem;color:var(--plum-soft);font-weight:600}
.hero-trust .sep{width:2px;height:34px;background:rgba(75,46,79,.12)}
.hero-art{position:relative;aspect-ratio:1/1.02}
.hero-art .photo{position:absolute;inset:6% 4% 10% 8%;border-radius:38% 62% 58% 42%/45% 38% 62% 55%;overflow:hidden;box-shadow:var(--shadow-lg);border:6px solid #fff}
.hero-art .photo .ph{width:100%;height:100%}
.hero-art .photo img{width:100%;height:100%;object-fit:cover}
.badge{position:absolute;background:#fff;border-radius:18px;box-shadow:var(--shadow);padding:.7rem .95rem;display:flex;align-items:center;gap:.6rem;font-family:var(--font-d);font-weight:600;z-index:3}
.badge b{white-space:nowrap}
.badge .ic{width:34px;height:34px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex:none}
.badge small{display:block;font-family:var(--font-b);font-weight:600;font-size:.72rem;color:var(--plum-soft)}
.badge b{font-size:.96rem;line-height:1.1}
.badge.b1{top:2%;right:-2%;transform:rotate(4deg)}
.badge.b1 .ic{background:#FFEE9E;color:#946b00}
.badge.b2{bottom:6%;left:-5%;transform:rotate(-5deg)}
.badge.b2 .ic{background:#A6F4EB;color:var(--teal-deep)}
.blob{position:absolute;border-radius:50%;filter:blur(2px);opacity:.5;z-index:0}
.b-a{width:230px;height:230px;background:var(--teal);top:-40px;left:-90px;opacity:.18}
.b-b{width:170px;height:170px;background:var(--coral);bottom:40px;right:46%;opacity:.16}
.b-c{width:120px;height:120px;background:var(--yellow);top:120px;right:-30px;opacity:.30}
.star{position:absolute;color:var(--coral);font-family:var(--font-d);z-index:1;opacity:.5}

.wave{display:block;width:100%;height:54px}

section.band{padding:78px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;margin-bottom:2.4rem;flex-wrap:wrap}
.sec-head h2{font-size:clamp(2rem,3.6vw,2.9rem);white-space:nowrap;overflow:visible}
.sec-head p{color:var(--plum-soft);max-width:42ch;margin-top:.5rem}

/* events */
.events{background:var(--cream-2)}
.events .eyebrow{color:var(--coral)}
.ev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.ev{background:var(--card);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;border:2px solid rgba(75,46,79,.06);transition:transform .16s,box-shadow .16s}
.ev:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.ev-top{position:relative;height:128px;display:flex;align-items:flex-start;justify-content:space-between;padding:1rem;background:linear-gradient(135deg,#FF6F91,#FF2E63)}
.ev-top.g-coral{background:linear-gradient(135deg,#FF6F91,#FF2E63)}
.ev-top.g-teal{background:linear-gradient(135deg,#3DE8D4,#00B8A6)}
.ev-top.g-yellow{background:linear-gradient(135deg,#FFD84D,#FFB400)}
.ev-top.g-plum{background:linear-gradient(135deg,#6B4A82,#2E1A47)}
.date-chip{background:#fff;border-radius:14px;padding:.4rem .7rem;text-align:center;box-shadow:var(--shadow);font-family:var(--font-d);line-height:1}
.date-chip b{display:block;font-size:1.5rem;color:var(--coral)}
.date-chip span{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--plum-soft)}
.ev-tag{background:var(--plum);color:#fff;font-family:var(--font-d);font-weight:500;font-size:.74rem;padding:.34em .8em;border-radius:999px;align-self:flex-start}
.ev-body{padding:1.15rem 1.25rem 1.4rem;display:flex;flex-direction:column;gap:.55rem;flex:1}
.ev-body h3{font-size:1.3rem}
.ev-meta{display:flex;flex-direction:column;gap:.3rem;font-size:.92rem;color:var(--plum-soft);font-weight:600}
.ev-meta i{font-style:normal;color:var(--coral);margin-right:.4em}
.ev-body p{font-size:.92rem;color:var(--plum-soft);margin-top:.1rem}
.ev-foot{margin-top:auto;padding-top:.9rem}
.ev-link{font-family:var(--font-d);font-weight:600;color:var(--coral);display:inline-flex;align-items:center;gap:.35em}
.ev-link:hover{gap:.7em}
.all-events{display:flex;justify-content:center;margin-top:2.4rem}

/* aktuelles / news */
.aktuelles{background:#FFFBF3}
.akt-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.akt-card{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);border:2px solid rgba(75,46,79,.06);padding:1.8rem;display:flex;flex-direction:column;gap:.7rem;transition:transform .16s,box-shadow .16s}
.akt-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.akt-meta{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}
.akt-cat{font-family:var(--font-d);font-weight:500;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:#fff;padding:.3em .85em;border-radius:999px;background:var(--coral)}
.akt-cat.c1{background:var(--coral)}
.akt-cat.c2{background:var(--teal-deep)}
.akt-date{font-family:var(--font-d);font-weight:600;font-size:.86rem;color:var(--plum-soft)}
.akt-card h3{font-size:1.4rem}
.akt-card p{color:var(--plum-soft);font-size:.98rem}
.akt-card .ev-link{margin-top:.2rem}
.akt-empty{background:#fff;border:2px dashed rgba(75,46,79,.18);border-radius:var(--r);padding:1.6rem 1.8rem;color:var(--plum-soft);font-weight:600;display:flex;align-items:center;gap:.6rem}

/* library */
.lib-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.panel{background:var(--card);border-radius:var(--r);box-shadow:var(--shadow);padding:2rem;border:2px solid rgba(75,46,79,.06)}
.panel h3{font-size:1.5rem;display:flex;align-items:center;gap:.6rem;margin-bottom:1.1rem}
.panel h3 .ic{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex:none}
.hours{list-style:none;display:flex;flex-direction:column}
.hours li{display:flex;justify-content:space-between;align-items:center;padding:.62rem 0;border-bottom:1.5px dashed rgba(75,46,79,.14);font-size:1rem}
.hours li:last-child{border-bottom:0}
.hours li b{font-family:var(--font-d);font-weight:600}
.hours li span{font-variant-numeric:tabular-nums;font-weight:600;color:var(--plum-soft)}
.hours .ferien{background:#FFF3C4;border-radius:14px;padding:.7rem .9rem;margin-top:.7rem;font-size:.86rem;color:#8a6a1f;border:1.5px dashed var(--yellow);display:flex;gap:.5rem}
.addr{display:flex;flex-direction:column;gap:1rem}
.map{height:170px;border-radius:18px;overflow:hidden;border:2px solid rgba(75,46,79,.08)}
.map .ph{width:100%;height:100%}
.addr-rows{display:flex;flex-direction:column;gap:.7rem}
.addr-row{display:flex;gap:.75rem;align-items:flex-start;font-size:1rem}
.addr-row .ic{width:34px;height:34px;border-radius:11px;background:var(--cream-2);display:flex;align-items:center;justify-content:center;font-size:1.05rem;flex:none}
.addr-row b{font-family:var(--font-d);font-weight:600;display:block;font-size:.82rem;color:var(--plum-soft);text-transform:uppercase;letter-spacing:.04em}
.dibibe{grid-column:1/-1;background:linear-gradient(120deg,var(--teal) 0%,#00B8A6 100%);color:#06302c;border-radius:var(--r);padding:2rem 2.2rem;display:grid;grid-template-columns:1fr auto;gap:1.4rem;align-items:center;box-shadow:var(--shadow)}
.dibibe h3{color:#06302c;font-size:1.6rem}
.dibibe p{color:#0a3f3a;max-width:54ch;font-weight:500;margin-top:.4rem}
.dibibe .btn{border-color:#06302c;color:#06302c;background:#fff;box-shadow:0 6px 0 rgba(6,48,44,.35)}

/* membership */
.join{background:var(--plum);color:var(--cream);position:relative;overflow:hidden}
.join .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}
.join h2{color:#fff;font-size:clamp(2rem,3.6vw,2.9rem)}
.join p{color:#e8d6ea;margin-top:1rem;max-width:42ch}
.join .eyebrow{color:var(--yellow)}
.join-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.8rem}
.join .btn-ghost{color:#fff;border-color:#fff}
.join .btn-ghost:hover{background:rgba(255,255,255,.12)}
.price-card{background:#fff;color:var(--plum);border-radius:var(--r);padding:1.8rem;box-shadow:var(--shadow-lg)}
.price-card .ribbon{display:inline-block;background:var(--yellow);color:#7a5c10;font-family:var(--font-d);font-weight:600;font-size:.78rem;padding:.3em .9em;border-radius:999px;margin-bottom:1rem}
.price-row{display:flex;justify-content:space-between;align-items:baseline;padding:.75rem 0;border-bottom:1.5px dashed rgba(75,46,79,.14)}
.price-row:last-of-type{border-bottom:0}
.price-row b{font-family:var(--font-d);font-weight:600}
.price-row .amt{font-family:var(--font-d);font-weight:700;font-size:1.5rem;color:var(--coral)}
.price-card small{display:block;color:var(--plum-soft);margin-top:1rem;font-size:.86rem}
.join-blob{position:absolute;border-radius:50%}
.jb1{width:280px;height:280px;background:#5d3b62;top:-90px;right:8%}
.jb2{width:180px;height:180px;background:var(--coral);bottom:-70px;left:4%;opacity:.5}

/* newsletter */
.news{background:var(--yellow);position:relative;overflow:hidden}
.news .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center;padding:8px 0}
.news h2{font-size:clamp(1.9rem,3.4vw,2.6rem);color:#5a3f10}
.news p{color:#6e521b;margin-top:.7rem;font-weight:500;max-width:40ch}
.news form{display:flex;gap:.7rem;background:#fff;padding:.5rem;border-radius:999px;box-shadow:var(--shadow);max-width:440px;margin-left:auto;width:100%}
.news input{flex:1;border:0;background:transparent;padding:.7em 1.1em;font-family:var(--font-b);font-size:1rem;color:var(--plum);outline:none}
.news input::placeholder{color:#b09a86}
.news .note{font-size:.8rem;color:#7a5c10;margin-top:.7rem;text-align:right}
.news-emoji{position:absolute;font-size:7rem;opacity:.16;top:-10px;right:30px;font-family:var(--font-d)}

/* pillars */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:0}
.pillar{background:var(--card);border-radius:var(--r);padding:1.7rem;box-shadow:var(--shadow);border:2px solid rgba(75,46,79,.06)}
.pillar .ic{width:54px;height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1rem}
.pillar:nth-child(1) .ic{background:#FFD3DF;color:var(--coral-deep)}
.pillar:nth-child(2) .ic{background:#A6F4EB;color:var(--teal-deep)}
.pillar:nth-child(3) .ic{background:#FFEE9E;color:#946b00}
.pillar h3{font-size:1.3rem;margin-bottom:.4rem}
.pillar p{color:var(--plum-soft);font-size:.96rem}

/* footer */
footer.site{background:#3a2440;color:#e6d6e8;padding:64px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.2rem;padding-bottom:2.5rem;border-bottom:1.5px solid rgba(255,255,255,.12)}
.foot-brand b{font-family:var(--font-d);font-weight:700;font-size:1.4rem;color:#fff;display:block;margin:.7rem 0 .5rem}
.foot-brand p{font-size:.92rem;color:#c3aec6;max-width:34ch}
.foot-col h4{font-family:var(--font-d);font-size:1rem;color:#fff;margin-bottom:.9rem}
.foot-col a,.foot-col p{display:block;font-size:.94rem;color:#c9b6cc;padding:.22rem 0}
.foot-col a:hover{color:var(--yellow)}
.foot-col ul{list-style:none}
.socials{display:flex;gap:.5rem;margin-top:.4rem}
.socials a{width:38px;height:38px;border-radius:12px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-weight:600;font-size:.9rem}
.socials a:hover{background:var(--coral);color:#fff}
.foot-bottom{display:flex;justify-content:space-between;gap:1rem;padding-top:1.6rem;font-size:.84rem;color:#a892ac;flex-wrap:wrap}
.foot-bottom a:hover{color:var(--yellow)}

@media(max-width:900px){
  .hero .wrap{grid-template-columns:1fr;gap:34px}
  .hero-art{max-width:420px;margin-inline:auto;width:100%}
  .join .wrap{grid-template-columns:1fr}
  .news .wrap{grid-template-columns:1fr;gap:1.4rem}
  .news form{margin-left:0}.news .note{text-align:left}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  nav.links,.nav>.btn{display:none}
  .burger{display:flex}
  .ev-grid{grid-template-columns:1fr}
  .akt-grid{grid-template-columns:1fr}
  .lib-grid{grid-template-columns:1fr}
  .dibibe{grid-template-columns:1fr;text-align:left}
  .pillars{grid-template-columns:1fr}
  .hero h1 .hl{white-space:normal}
  section.band{padding:54px 0}
  .hero{padding:40px 0 64px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:1.5rem}
  .foot-brand{grid-column:1/-1}
}
@media(max-width:440px){
  .foot-grid{grid-template-columns:1fr}
  .hero-trust .sep{display:none}
}

/* mobile nav drawer (shared by all templates) */
.mnav{display:none}
.mnav.open{display:block;position:fixed;inset:0;z-index:60;background:rgba(46,26,71,.45)}
.mnav .panel-m{position:absolute;top:0;right:0;width:min(80vw,320px);height:100%;background:#fff;box-shadow:var(--shadow-lg);padding:1.4rem;display:flex;flex-direction:column;gap:.3rem}
.mnav .panel-m a{font-family:var(--font-d);font-weight:600;font-size:1.1rem;padding:.7em .6em;border-radius:12px;color:var(--plum)}
.mnav .panel-m a:hover{background:var(--cream-2);color:var(--coral)}
.mnav .panel-m .x{align-self:flex-end;font-size:1.6rem;border:0;background:none;cursor:pointer;color:var(--plum);margin-bottom:.4rem}
