/* kbvk WPBakery elements — combined styles (generated from theme assets) */

/* ===== shared.css ===== */
/* ===========================================================
   kbvk Kallnach — Richtung A · altes Logo · knallige Farben
   Geteiltes Stylesheet für alle Innenseiten
   =========================================================== */
:root{
  --coral:#FF2E63; --coral-deep:#e01048;
  --yellow:#FFC400; --teal:#00D6C2; --teal-deep:#00a99a;
  --cream:#FFFFFF; --cream-2:#FFF6FA; --cream-3:#FFFBF3; --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}

/* ---- buttons ---- */
.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}
.btn-sm{padding:.6em 1.15em;font-size:.95rem}

.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}

/* ---- announcement 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{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}
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 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}

/* ---- page hero ---- */
.phero{position:relative;overflow:hidden;padding:54px 0 64px}
.phero .wrap{position:relative;z-index:2}
.phero .crumb{font-family:var(--font-d);font-weight:500;font-size:.9rem;color:var(--plum-soft);margin-bottom:1.1rem;display:flex;gap:.45em;align-items:center}
.phero .crumb a:hover{color:var(--coral)}
.phero .crumb .sl{opacity:.5}
.phero h1{font-size:clamp(2.4rem,5vw,4rem);font-weight:700;max-width:18ch}
.phero h1 .hl{position:relative;white-space:nowrap}
.phero 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)}
.phero p.lede{font-size:1.18rem;color:var(--plum-soft);margin-top:1.2rem;max-width:52ch}
.phero.coral{background:var(--cream-2)}
.phero.teal{background:#EAFBF8}
.phero.yellow{background:#FFF7DA}
.phero.plum{background:var(--plum)}
.phero.plum h1,.phero.plum .crumb,.phero.plum p.lede{color:#fff}
.phero.plum .crumb{color:#cdb9d2}
.phero.plum p.lede{color:#e8d6ea}
.phero.plum .eyebrow{color:var(--yellow)}
.phero.cream{background:var(--cream-3)}
/* decorative blobs in hero */
.phero .blob{position:absolute;border-radius:50%;z-index:0;filter:blur(1px)}
.phero .pb1{width:240px;height:240px;background:var(--teal);top:-70px;right:-40px;opacity:.16}
.phero .pb2{width:150px;height:150px;background:var(--coral);bottom:-50px;right:22%;opacity:.14}
.phero .star{position:absolute;color:var(--coral);font-family:var(--font-d);z-index:1;opacity:.5}
.phero.plum .pb1{background:#5d3b62;opacity:.5}
.phero.plum .pb2{background:var(--coral);opacity:.4}

/* ---- wave divider ---- */
.wave{display:block;width:100%;height:54px}

/* ---- sections ---- */
section.band{padding:72px 0}
.band.alt{background:var(--cream-2)}
.band.cream3{background:var(--cream-3)}
.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(1.9rem,3.4vw,2.7rem)}
.sec-head p{color:var(--plum-soft);max-width:46ch;margin-top:.5rem}

/* ---- panels ---- */
.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}

/* ---- event card (shared) ---- */
.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}
.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}

/* ---- pills / chips ---- */
.chiprow{display:flex;flex-wrap:wrap;gap:.55rem}
.chip{font-family:var(--font-d);font-weight:500;font-size:.9rem;padding:.45em 1em;border-radius:999px;border:2px solid rgba(46,26,71,.14);color:var(--plum);background:#fff}
.chip.is-on{background:var(--plum);color:#fff;border-color:var(--plum)}

/* ---- DiBiBe band ---- */
.dibibe{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)}

/* ---- 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)}

/* ---- footer ---- */
footer{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)}
.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)}

/* ---- responsive ---- */
@media(max-width:900px){
  .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}
  .dibibe{grid-template-columns:1fr;text-align:left}
  section.band{padding:52px 0}
  .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}
}


/* ===== home.css ===== */
/* 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}


/* ===== veranstaltungen.css ===== */
/* Veranstaltungen (archive) */
.ev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.month-head{display:flex;align-items:center;gap:1rem;margin:0 0 1.6rem}
.month-head h2{font-size:1.7rem;white-space:nowrap}
.month-head .ln{height:2px;flex:1;background:repeating-linear-gradient(90deg,rgba(46,26,71,.18) 0 8px,transparent 8px 14px)}
.month-head .cnt{font-family:var(--font-d);font-weight:600;font-size:.82rem;color:#fff;background:var(--coral);padding:.2em .7em;border-radius:999px}
.month-block{margin-bottom:3.2rem}
.past{background:var(--cream-2)}
.past-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.past-card{border-radius:20px;overflow:hidden;box-shadow:var(--shadow);border:2px solid rgba(75,46,79,.06);background:#fff}
.past-card .ph{height:130px}
.past-card .cap{padding:.85rem 1rem}
.past-card .cap b{font-family:var(--font-d);font-weight:600;font-size:1.02rem;display:block}
.past-card .cap span{font-size:.82rem;color:var(--plum-soft);font-weight:600}
@media(max-width:900px){.ev-grid{grid-template-columns:1fr 1fr}.past-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.ev-grid{grid-template-columns:1fr}.past-grid{grid-template-columns:1fr 1fr}}


/* ===== detail.css ===== */
/* Veranstaltung (single) */
.detail-grid{display:grid;grid-template-columns:1.55fr .95fr;gap:2.4rem;align-items:start}
.hero-photo{aspect-ratio:16/10;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-lg);border:6px solid #fff;margin-bottom:2rem}
.hero-photo .ph{width:100%;height:100%}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.tagrow{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}
.tag-pill{font-family:var(--font-d);font-weight:500;font-size:.78rem;padding:.34em .9em;border-radius:999px}
.tag-pill.cat{background:var(--plum);color:#fff}
.tag-pill.free{background:#FFEE9E;color:#946b00}
.prose h2{font-size:1.55rem;margin:2rem 0 .7rem}
.prose p{color:var(--plum-soft);margin-bottom:1rem;font-size:1.04rem}
.prose ul{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin:.4rem 0 1rem;padding:0}
.prose ul li{display:flex;gap:.7rem;align-items:flex-start;color:var(--plum-soft);font-size:1.04rem}
.prose ul li::before{content:"✦";color:var(--coral);font-family:var(--font-d);flex:none;margin-top:.05em}
.steps{counter-reset:s;display:flex;flex-direction:column;gap:.9rem;margin-top:.6rem}
.step{display:flex;gap:1rem;align-items:flex-start}
.step .n{counter-increment:s;width:34px;height:34px;border-radius:50%;background:var(--coral);color:#fff;font-family:var(--font-d);font-weight:600;display:flex;align-items:center;justify-content:center;flex:none}
.step .n::before{content:counter(s)}
.step b{font-family:var(--font-d);font-weight:600}
.infocard{background:#fff;border-radius:var(--r);box-shadow:var(--shadow-lg);border:2px solid rgba(75,46,79,.06);padding:1.8rem;position:sticky;top:90px}
.info-row{display:flex;gap:.85rem;align-items:flex-start;padding:.8rem 0;border-bottom:1.5px dashed rgba(75,46,79,.14)}
.info-row:last-of-type{border-bottom:0}
.info-row .ic{width:38px;height:38px;border-radius:12px;background:var(--cream-2);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex:none}
.info-row b{font-family:var(--font-d);font-weight:600;display:block;font-size:.74rem;color:var(--plum-soft);text-transform:uppercase;letter-spacing:.05em}
.info-row span.v{font-weight:600;font-size:1.02rem}
.infocard .btn{width:100%;justify-content:center;margin-top:1.3rem}
.minimap{height:150px;border-radius:16px;overflow:hidden;border:2px solid rgba(75,46,79,.08);margin-top:1.2rem}
.minimap .ph{width:100%;height:100%}
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media(max-width:860px){.detail-grid{grid-template-columns:1fr}.infocard{position:static}.rel-grid{grid-template-columns:1fr}}


/* ===== bibliothek.css ===== */
/* Bibliothek */
.lib-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:0}
.fact{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:var(--shadow);border:2px solid rgba(75,46,79,.06);text-align:center}
.fact b{font-family:var(--font-d);font-weight:700;font-size:2.1rem;color:var(--coral);display:block;line-height:1}
.fact span{font-size:.92rem;color:var(--plum-soft);font-weight:600}
.media-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.3rem}
.book{display:flex;flex-direction:column;gap:.6rem}
.cover{aspect-ratio:2/3;border-radius:14px;overflow:hidden;box-shadow:var(--shadow);border:2px solid rgba(75,46,79,.06);position:relative;transition:transform .16s}
.book:hover .cover{transform:translateY(-5px)}
.cover .ph{width:100%;height:100%}
.cover img{width:100%;height:100%;object-fit:cover}
.cover .nu{position:absolute;top:.5rem;left:.5rem;background:var(--coral);color:#fff;font-family:var(--font-d);font-weight:600;font-size:.66rem;padding:.22em .6em;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}
.book b{font-family:var(--font-d);font-weight:600;font-size:.96rem;line-height:1.15}
.book span{font-size:.84rem;color:var(--plum-soft);font-weight:600}
.book .cat{font-size:.72rem;color:var(--teal-deep);font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.dibibe-feat{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2rem}
.dstep{background:rgba(255,255,255,.85);border-radius:20px;padding:1.5rem}
.dstep .n{width:40px;height:40px;border-radius:12px;background:#06302c;color:#fff;font-family:var(--font-d);font-weight:600;display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin-bottom:.9rem}
.dstep h4{font-size:1.15rem;color:#06302c;margin-bottom:.3rem}
.dstep p{color:#0a3f3a;font-size:.94rem;font-weight:500}
@media(max-width:900px){.lib-grid{grid-template-columns:1fr}.facts{grid-template-columns:1fr 1fr}.media-grid{grid-template-columns:repeat(3,1fr)}.dibibe-feat{grid-template-columns:1fr}}
@media(max-width:560px){.media-grid{grid-template-columns:repeat(2,1fr)}}


/* ===== verein.css ===== */
/* Verein */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.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}
.story{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.story .ph{aspect-ratio:4/3;border-radius:var(--r);border:6px solid #fff;box-shadow:var(--shadow-lg)}
.story p{color:var(--plum-soft);font-size:1.06rem;margin-bottom:1rem}
.timeline{position:relative;margin-top:1rem;padding-left:2rem}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:3px;background:repeating-linear-gradient(var(--plum) 0 8px,transparent 8px 16px);border-radius:2px}
.tl{position:relative;padding:0 0 1.6rem}
.tl::before{content:"";position:absolute;left:-2rem;top:4px;width:17px;height:17px;border-radius:50%;background:var(--coral);border:3px solid #fff;box-shadow:0 0 0 2px var(--coral)}
.tl:nth-child(2)::before{background:var(--teal);box-shadow:0 0 0 2px var(--teal)}
.tl:nth-child(3)::before{background:var(--yellow);box-shadow:0 0 0 2px var(--yellow)}
.tl b{font-family:var(--font-d);font-weight:700;color:var(--coral);font-size:1.1rem;display:block}
.tl:nth-child(2) b{color:var(--teal-deep)}
.tl:nth-child(3) b{color:#946b00}
.tl h4{font-size:1.15rem;margin:.1rem 0 .3rem}
.tl p{color:var(--plum-soft);font-size:.96rem;margin:0}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.member{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);border:2px solid rgba(75,46,79,.06);text-align:center}
.member .ph{aspect-ratio:1/1}
.member img{aspect-ratio:1/1;width:100%;object-fit:cover}
.member .body{padding:1.1rem 1rem 1.4rem}
.member b{font-family:var(--font-d);font-weight:600;font-size:1.12rem;display:block}
.member .role{color:var(--coral);font-weight:700;font-size:.86rem;text-transform:uppercase;letter-spacing:.05em;margin-top:.1rem}
.member small{display:block;color:var(--plum-soft);font-size:.86rem;margin-top:.5rem}
.cta-band{background:var(--plum);color:#fff;border-radius:var(--r);padding:3rem;text-align:center;position:relative;overflow:hidden}
.cta-band h2{color:#fff;font-size:clamp(1.8rem,3.4vw,2.6rem)}
.cta-band p{color:#e8d6ea;max-width:48ch;margin:.8rem auto 1.6rem}
.cta-band .btn-ghost{color:#fff;border-color:#fff}
.cta-band .cta-row{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}
.cta-blob{position:absolute;border-radius:50%;background:#5d3b62;width:240px;height:240px;top:-90px;right:-40px;opacity:.5}
@media(max-width:900px){.story{grid-template-columns:1fr}.team-grid{grid-template-columns:1fr 1fr}.pillars{grid-template-columns:1fr}}
@media(max-width:520px){.team-grid{grid-template-columns:1fr}}


/* ===== mitglied.css ===== */
/* Mitglied werden */
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.benefit{background:#fff;border-radius:var(--r);padding:1.7rem;box-shadow:var(--shadow);border:2px solid rgba(75,46,79,.06)}
.benefit .ic{width:50px;height:50px;border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:.9rem}
.benefit:nth-child(1) .ic{background:#FFD3DF;color:var(--coral-deep)}
.benefit:nth-child(2) .ic{background:#A6F4EB;color:var(--teal-deep)}
.benefit:nth-child(3) .ic{background:#FFEE9E;color:#946b00}
.benefit h3{font-size:1.2rem;margin-bottom:.3rem}
.benefit p{color:var(--plum-soft);font-size:.95rem}
.signup{display:grid;grid-template-columns:1.3fr .9fr;gap:2.4rem;align-items:start}
.formcard{background:#fff;border-radius:var(--r);box-shadow:var(--shadow-lg);border:2px solid rgba(75,46,79,.06);padding:2.2rem}
.formcard h2{font-size:1.7rem;margin-bottom:.3rem}
.formcard .sub{color:var(--plum-soft);margin-bottom:1.6rem}
.field{margin-bottom:1.2rem}
.field label{font-family:var(--font-d);font-weight:600;font-size:.92rem;display:block;margin-bottom:.4rem}
.field input,.field textarea{width:100%;border:2px solid rgba(46,26,71,.16);border-radius:14px;padding:.8em 1em;font-family:var(--font-b);font-size:1rem;color:var(--plum);outline:none;background:var(--cream-3);transition:border-color .15s}
.field input:focus,.field textarea:focus{border-color:var(--coral);background:#fff}
.two{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.plans{display:flex;flex-direction:column;gap:.8rem;margin-bottom:1.4rem}
.plan{display:flex;align-items:center;gap:1rem;border:2px solid rgba(46,26,71,.16);border-radius:16px;padding:1rem 1.2rem;cursor:pointer;transition:border-color .15s,background .15s}
.plan:hover{border-color:var(--coral)}
.plan input{accent-color:var(--coral);width:20px;height:20px;flex:none}
.plan .pt{flex:1}
.plan .pt b{font-family:var(--font-d);font-weight:600;font-size:1.05rem}
.plan .pt small{display:block;color:var(--plum-soft);font-size:.86rem}
.plan .amt{font-family:var(--font-d);font-weight:700;font-size:1.3rem;color:var(--coral)}
.plan.checked{border-color:var(--coral);background:var(--cream-2)}
.check{display:flex;gap:.7rem;align-items:flex-start;margin-bottom:1.4rem;font-size:.92rem;color:var(--plum-soft)}
.check input{accent-color:var(--coral);width:20px;height:20px;flex:none;margin-top:.1em}
.formcard .btn{width:100%;justify-content:center}
.formnote{font-size:.82rem;color:var(--plum-soft);text-align:center;margin-top:1rem}
.price-card{background:var(--plum);color:#fff;border-radius:var(--r);padding:1.9rem;box-shadow:var(--shadow-lg);position:sticky;top:90px}
.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-card h3{color:#fff;font-size:1.4rem;margin-bottom:1rem}
.price-row{display:flex;justify-content:space-between;align-items:baseline;padding:.75rem 0;border-bottom:1.5px dashed rgba(255,255,255,.18)}
.price-row:last-of-type{border-bottom:0}
.price-row b{font-family:var(--font-d);font-weight:600}
.price-row small{color:#cdb9d2}
.price-row .amt{font-family:var(--font-d);font-weight:700;font-size:1.4rem;color:var(--yellow)}
.price-card .info{font-size:.86rem;color:#e8d6ea;margin-top:1.1rem;line-height:1.5}
.faq{max-width:760px;margin-inline:auto}
.qa{background:#fff;border-radius:18px;border:2px solid rgba(75,46,79,.06);box-shadow:var(--shadow);padding:1.3rem 1.5rem;margin-bottom:1rem}
.qa b{font-family:var(--font-d);font-weight:600;font-size:1.1rem;display:flex;gap:.6rem;align-items:flex-start}
.qa b::before{content:"?";background:var(--coral);color:#fff;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex:none}
.qa p{color:var(--plum-soft);margin-top:.5rem;padding-left:2.2rem;font-size:.96rem}
@media(max-width:900px){.signup{grid-template-columns:1fr}.price-card{position:static}.benefits{grid-template-columns:1fr}}
@media(max-width:520px){.two{grid-template-columns:1fr}}


/* ===== kontakt.css ===== */
/* Kontakt & Impressum */
.k-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:2.4rem;align-items:start}
.contact-cards{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-bottom:1.4rem}
.ccard{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:var(--shadow);border:2px solid rgba(75,46,79,.06)}
.ccard .ic{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin-bottom:.8rem}
.ccard:nth-child(1) .ic{background:#FFD3DF;color:var(--coral-deep)}
.ccard:nth-child(2) .ic{background:#A6F4EB;color:var(--teal-deep)}
.ccard:nth-child(3) .ic{background:#FFEE9E;color:#946b00}
.ccard:nth-child(4) .ic{background:#E7D5F0;color:#6b3b86}
.ccard b{font-family:var(--font-d);font-weight:600;font-size:.78rem;color:var(--plum-soft);text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:.2rem}
.ccard span,.ccard a{font-size:1.02rem;font-weight:600;display:block;line-height:1.35}
.ccard a:hover{color:var(--coral)}
.map-lg{height:240px;border-radius:var(--r);overflow:hidden;border:2px solid rgba(75,46,79,.08);box-shadow:var(--shadow)}
.map-lg .ph{width:100%;height:100%}
.formcard{background:#fff;border-radius:var(--r);box-shadow:var(--shadow-lg);border:2px solid rgba(75,46,79,.06);padding:2.2rem}
.formcard h2{font-size:1.6rem;margin-bottom:.3rem}
.formcard .sub{color:var(--plum-soft);margin-bottom:1.6rem}
.field{margin-bottom:1.2rem}
.field label{font-family:var(--font-d);font-weight:600;font-size:.92rem;display:block;margin-bottom:.4rem}
.field input,.field textarea,.field select{width:100%;border:2px solid rgba(46,26,71,.16);border-radius:14px;padding:.8em 1em;font-family:var(--font-b);font-size:1rem;color:var(--plum);outline:none;background:var(--cream-3);transition:border-color .15s}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--coral);background:#fff}
.field textarea{resize:vertical;min-height:120px}
.two{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.formcard .btn{width:100%;justify-content:center}
.formnote{font-size:.82rem;color:var(--plum-soft);text-align:center;margin-top:1rem}
.imp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.imp{background:#fff;border-radius:20px;padding:1.6rem;box-shadow:var(--shadow);border:2px solid rgba(75,46,79,.06)}
.imp h3{font-size:1.15rem;margin-bottom:.7rem;display:flex;gap:.5rem;align-items:center}
.imp p{color:var(--plum-soft);font-size:.96rem;margin-bottom:.4rem}
.imp a{color:var(--coral);font-weight:600}
@media(max-width:900px){.k-grid{grid-template-columns:1fr}.imp-grid{grid-template-columns:1fr}}
@media(max-width:520px){.contact-cards{grid-template-columns:1fr}.two{grid-template-columns:1fr}}


/* ===== geschichte.css ===== */
/* Geschichte */
.intro{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center}
.intro p{color:var(--plum-soft);font-size:1.08rem;margin-bottom:1rem}
.intro .ph{aspect-ratio:4/3;border-radius:var(--r);border:6px solid #fff;box-shadow:var(--shadow-lg)}
.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.fact{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:var(--shadow);border:2px solid rgba(75,46,79,.06);text-align:center}
.fact b{font-family:var(--font-d);font-weight:700;font-size:2.1rem;color:var(--coral);display:block;line-height:1}
.fact:nth-child(2) b{color:var(--teal-deep)}
.fact:nth-child(3) b{color:#946b00}
.fact:nth-child(4) b{color:#6b3b86}
.fact span{font-size:.92rem;color:var(--plum-soft);font-weight:600}
.htl{position:relative;max-width:880px;margin:0 auto;padding-left:0}
.htl::before{content:"";position:absolute;left:120px;top:10px;bottom:10px;width:3px;background:repeating-linear-gradient(var(--plum) 0 9px,transparent 9px 18px);border-radius:2px}
.era{position:relative;display:grid;grid-template-columns:120px 1fr;gap:2rem;padding:0 0 2.4rem}
.era:last-child{padding-bottom:0}
.era .year{font-family:var(--font-d);font-weight:700;font-size:1.5rem;color:var(--coral);text-align:right;padding-top:.2rem;padding-right:1.5rem}
.era:nth-child(2) .year{color:var(--teal-deep)}
.era:nth-child(3) .year{color:#946b00}
.era:nth-child(4) .year{color:#6b3b86}
.era:nth-child(5) .year{color:var(--coral)}
.era .node{position:absolute;left:120px;top:6px;transform:translateX(-50%);width:20px;height:20px;border-radius:50%;background:var(--coral);border:4px solid #fff;box-shadow:0 0 0 3px var(--coral);z-index:2}
.era:nth-child(2) .node{background:var(--teal);box-shadow:0 0 0 3px var(--teal)}
.era:nth-child(3) .node{background:var(--yellow);box-shadow:0 0 0 3px var(--yellow)}
.era:nth-child(4) .node{background:#9a5fc0;box-shadow:0 0 0 3px #9a5fc0}
.era:nth-child(5) .node{background:var(--coral);box-shadow:0 0 0 3px var(--coral)}
.era .card{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);border:2px solid rgba(75,46,79,.06);padding:1.7rem 1.9rem;margin-left:1.4rem}
.era .card h3{font-size:1.45rem;margin-bottom:.5rem}
.era .card p{color:var(--plum-soft);font-size:1rem}
.era .card .ph{height:170px;border-radius:16px;margin-top:1.1rem}
.era .tag{display:inline-block;font-family:var(--font-d);font-weight:500;font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--plum-soft);background:var(--cream-2);padding:.3em .8em;border-radius:999px;margin-bottom:.7rem}
.quote{background:var(--plum);color:#fff;border-radius:var(--r);padding:3rem;text-align:center;position:relative;overflow:hidden}
.quote .mark{font-family:var(--font-d);font-weight:700;font-size:5rem;color:var(--yellow);line-height:.5;opacity:.5}
.quote p{font-family:var(--font-d);font-weight:500;font-size:clamp(1.3rem,2.6vw,1.9rem);color:#fff;max-width:24ch;margin:1rem auto;line-height:1.3}
.quote .by{color:#cdb9d2;font-size:.95rem;font-weight:600}
.quote .qblob{position:absolute;border-radius:50%;background:#5d3b62;width:220px;height:220px;bottom:-90px;left:-50px;opacity:.5}
@media(max-width:900px){.intro{grid-template-columns:1fr}.facts{grid-template-columns:1fr 1fr}}
@media(max-width:640px){
  .htl::before{left:8px}
  .era{grid-template-columns:1fr;gap:.3rem;padding-left:2rem}
  .era .year{text-align:left;padding-right:0}
  .era .node{left:8px}
  .era .card{margin-left:0}
}


/* ===== theme.css ===== */
/* kbvk Theme — global cross-cutting bits (loaded on every page) */

/* WP nav menu structure inside <nav class="links"><ul class="menu"> */
nav.links ul.menu{display:flex;gap:.3rem;list-style:none;margin:0;padding:0;align-items:center}
nav.links ul.menu li{list-style:none}
nav.links ul.menu a{font-family:var(--font-d);font-weight:500;font-size:1rem;padding:.5em .85em;border-radius:999px;transition:background .15s,color .15s;display:inline-block}
nav.links ul.menu a:hover{background:#fff;color:var(--coral)}
nav.links ul.menu li.current-menu-item>a,
nav.links ul.menu li.current_page_item>a,
nav.links ul.menu a.active{color:var(--coral);background:#fff;box-shadow:inset 0 0 0 2px rgba(255,46,99,.25)}

/* custom logo (Customizer › Site Identity) falls back to bundled logo */
.brand .custom-logo{height:50px;width:auto;display:block;mix-blend-mode:multiply}
.foot-brand .custom-logo{height:48px;width:auto;display:block;filter:invert(1);mix-blend-mode:screen}

/* footer nav menu as plain list */
.foot-col ul.menu{list-style:none;margin:0;padding:0}
.foot-col ul.menu a{display:block;font-size:.94rem;color:#c9b6cc;padding:.22rem 0}
.foot-col ul.menu a:hover{color:var(--yellow)}

/* mobile nav drawer */
.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:0 26px 60px rgba(46,26,71,.30);padding:1.4rem;display:flex;flex-direction:column;gap:.2rem;overflow:auto}
.mnav .panel-m a{font-family:var(--font-d);font-weight:600;font-size:1.1rem;padding:.7em .6em;border-radius:12px;color:#2E1A47;display:block}
.mnav .panel-m li{list-style:none}
.mnav .panel-m a:hover{background:#FFF6FA;color:#FF2E63}
.mnav .panel-m .x{align-self:flex-end;font-size:1.7rem;line-height:1;border:0;background:none;cursor:pointer;color:#2E1A47;margin-bottom:.4rem}
.mnav .panel-m .btn{margin-top:.6rem;justify-content:center}

/* WP core alignment helpers for page content inside .prose / editor */
.aligncenter{margin-inline:auto;display:block}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* generic page / post content (page.php, single.php, search, index) */
.entry-content{max-width:760px}
.entry-content > *{margin-bottom:1.05rem}
.entry-content h2{font-size:1.7rem;margin:2rem 0 .6rem}
.entry-content h3{font-size:1.35rem;margin:1.6rem 0 .5rem}
.entry-content p,.entry-content li{color:#5d4470;font-size:1.06rem;line-height:1.7}
.entry-content ul,.entry-content ol{padding-left:1.3rem}
.entry-content a{color:#FF2E63;text-decoration:underline;text-underline-offset:3px}
.entry-content img{border-radius:18px;box-shadow:0 14px 34px rgba(46,26,71,.12)}
.entry-content blockquote{border-left:4px solid #FFC400;padding-left:1.1rem;margin:1.4rem 0;color:#2E1A47;font-family:var(--font-d)}
.post-list{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
@media(max-width:760px){.post-list{grid-template-columns:1fr}}
.backlink{display:inline-flex;align-items:center;gap:.4em;margin-top:2rem;font-family:var(--font-d);font-weight:600;color:#FF2E63}
.pagination{display:flex;gap:.5rem;justify-content:center;margin-top:2.4rem;flex-wrap:wrap}
.pagination .page-numbers{font-family:var(--font-d);font-weight:600;padding:.5em .9em;border-radius:999px;border:2px solid rgba(46,26,71,.14);color:#2E1A47}
.pagination .page-numbers.current{background:#2E1A47;color:#fff;border-color:#2E1A47}
.pagination a.page-numbers:hover{border-color:#FF2E63;color:#FF2E63}


/* ===== WPBakery element overrides ===== */
.band.white{background:#fff}
.band.none{background:transparent}
.kbvk-price{background:#fff;color:var(--plum);border-radius:var(--r);padding:1.9rem;box-shadow:var(--shadow-lg)}
.kbvk-price.is-dark{background:var(--plum);color:#fff}
.kbvk-price .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}
.kbvk-price h3{font-size:1.4rem;margin-bottom:1rem}
.kbvk-price.is-dark h3{color:#fff}
.kbvk-price-row{display:flex;justify-content:space-between;align-items:baseline;padding:.75rem 0;border-bottom:1.5px dashed rgba(75,46,79,.14)}
.kbvk-price-row:last-of-type{border-bottom:0}
.kbvk-price.is-dark .kbvk-price-row{border-color:rgba(255,255,255,.18)}
.kbvk-price-row b{font-family:var(--font-d);font-weight:600}
.kbvk-price-row small{color:var(--plum-soft)}
.kbvk-price.is-dark .kbvk-price-row small{color:#cdb9d2}
.kbvk-price-row .amt{font-family:var(--font-d);font-weight:700;font-size:1.5rem;color:var(--coral)}
.kbvk-price.is-dark .kbvk-price-row .amt{color:var(--yellow)}
.kbvk-price-note{display:block;margin-top:1rem;font-size:.86rem;color:var(--plum-soft)}
.kbvk-price.is-dark .kbvk-price-note{color:#e8d6ea}
.kbvk-embed{border-radius:18px;overflow:hidden;border:2px solid rgba(75,46,79,.08)}
.kbvk-embed iframe{display:block;width:100%;border:0;min-height:220px}
.sec-head.center{justify-content:center;text-align:center}
.sec-head.center > div{margin-inline:auto}
.sec-head.center p{margin-inline:auto}
.kbvk-btn-row{display:flex;gap:.8rem;flex-wrap:wrap}
.kbvk-center{text-align:center}
.kbvk-center .kbvk-btn-row{justify-content:center}


/* ---- feine Deko-Symbole (ersetzen die farbigen Punkte/Blobs) ---- */
.deco{position:absolute;z-index:0;pointer-events:none;color:var(--plum);opacity:.11;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.deco.tint-teal{color:var(--teal-deep);opacity:.15}
.deco.tint-coral{color:var(--coral);opacity:.12}
.phero.plum .deco{color:#fff;opacity:.13}
.phero.plum .deco.tint-teal{color:var(--teal);opacity:.18}
.phero.plum .deco.tint-coral{color:#FF8FAE;opacity:.16}
.deco-host{position:relative;overflow:hidden}
@media(max-width:760px){.deco{display:none}}
