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