/* ===== Zentrum Seelenkraft – gemeinsames Stylesheet ===== */
:root{
  --ground:#f7f3fa;--ground-deep:#efe6f4;--ink:#352d3d;--ink-soft:#615869;
  --lilac:#9c7bc0;--lilac-deep:#6f4f97;--lilac-soft:#c8b1e0;--plum:#b06aa8;
  --gold:#c79a5b;--line:#e2d6ec;--white:#fffdff;--shadow:rgba(80,55,110,.14);--r:22px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Mulish',system-ui,sans-serif;background:var(--ground);color:var(--ink);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:500;line-height:1.14;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.eyebrow{font-family:'Mulish',sans-serif;font-weight:600;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--plum);display:inline-flex;align-items:center;gap:.7em}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--plum);display:inline-block}

/* Header + Dropdown-Navigation */
header{position:sticky;top:0;z-index:200;background:rgba(247,243,250,.88);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s}
header.scrolled{border-color:var(--line);box-shadow:0 6px 24px rgba(80,55,110,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:12px}
.brand .mark{width:44px;height:44px;flex:0 0 auto}
.brand .txt{line-height:1.05;font-family:'Fraunces',serif}
.brand .txt b{display:block;font-size:1.12rem;font-weight:600;letter-spacing:-.02em}
.brand .txt span{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--lilac-deep);font-family:'Mulish',sans-serif;font-weight:600}
.menu{display:flex;align-items:center;gap:4px}
.menu > a,.menu .has-sub > a{font-size:.88rem;font-weight:500;color:var(--ink-soft);padding:9px 13px;border-radius:9px;transition:color .2s,background .2s;display:inline-flex;align-items:center;gap:.35em;white-space:nowrap}
.menu > a:hover,.menu .has-sub:hover > a{color:var(--ink);background:var(--ground-deep)}
.menu > a.active,.menu .has-sub.active > a{color:var(--lilac-deep);font-weight:700}
.menu .has-sub{position:relative}
.menu .has-sub > a .ar{width:11px;height:11px;transition:transform .25s;color:var(--lilac)}
.menu .has-sub:hover > a .ar{transform:rotate(180deg)}
.submenu{position:absolute;top:calc(100% + 6px);left:0;min-width:230px;background:var(--white);border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 44px var(--shadow);padding:8px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .22s,transform .26s,visibility .22s}
.menu .has-sub:hover .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu .head{display:block;padding:10px 14px 6px;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--plum);font-weight:700}
.submenu a{display:block;padding:10px 14px;border-radius:9px;font-size:.9rem;color:var(--ink-soft);transition:.15s}
.submenu a:hover{background:var(--ground-deep);color:var(--lilac-deep)}
.submenu a.parent{font-weight:700;color:var(--ink);border-bottom:1px solid var(--line);margin-bottom:4px;border-radius:9px 9px 0 0}
.cta-btn{display:inline-flex;align-items:center;gap:.5em;background:var(--lilac-deep);color:var(--white);padding:12px 24px;border-radius:100px;font-weight:600;font-size:.88rem;transition:transform .2s,background .2s;font-family:'Mulish',sans-serif;white-space:nowrap}
.cta-btn:hover{background:var(--ink);transform:translateY(-2px);color:var(--white)}
.menu a.cta-btn{padding:12px 26px;color:var(--white)}
.burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:8px;z-index:210}
.burger span{width:24px;height:2px;background:var(--ink);transition:.3s;border-radius:2px}

/* Page hero (Unterseiten) */
.page-hero{position:relative;padding:64px 0 50px;overflow:hidden}
.page-hero .crumbs{font-size:.82rem;color:var(--ink-soft);margin-bottom:14px}
.page-hero .crumbs a:hover{color:var(--plum)}
.page-hero h1{font-size:clamp(2.4rem,5vw,3.8rem);margin-bottom:14px}
.page-hero h1 em{font-style:italic;color:var(--plum)}
.page-hero .lead{font-size:1.18rem;color:var(--ink-soft);max-width:60ch}
.page-hero .leaf{position:absolute;top:0;right:3%;width:130px;color:var(--lilac-soft);opacity:.4;pointer-events:none}

/* Content blocks */
.section{padding:40px 0 70px}
.prose{max-width:760px}
.prose p{margin-bottom:18px;font-size:1.06rem;color:var(--ink-soft)}
.prose h2{font-size:clamp(1.6rem,3.5vw,2.2rem);margin:38px 0 16px;color:var(--ink)}
.prose h3{font-size:1.3rem;margin:26px 0 10px}
.prose ul{list-style:none;margin:18px 0;display:grid;gap:10px}
.prose ul li{padding-left:30px;position:relative;color:var(--ink-soft)}
.prose ul li::before{content:"";position:absolute;left:0;top:.55em;width:14px;height:14px;background:var(--lilac-soft);border-radius:50% 50% 50% 0;transform:rotate(45deg)}
.prose blockquote{font-family:'Fraunces',serif;font-style:italic;font-size:1.4rem;line-height:1.45;color:var(--lilac-deep);border-left:3px solid var(--lilac-soft);padding:6px 0 6px 26px;margin:30px 0}
.prose blockquote cite{display:block;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--plum);font-style:normal;margin-top:12px}

/* Info-Box (Preise/Termine) */
.infobox{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:30px 32px;box-shadow:0 16px 40px var(--shadow);margin:30px 0}
.infobox h3{font-size:1.2rem;margin-bottom:16px;color:var(--lilac-deep)}
.infobox .row{display:flex;gap:14px;padding:10px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.infobox .row:last-child{border-bottom:none}
.infobox .row b{font-family:'Fraunces',serif;color:var(--ink);min-width:120px}
.infobox .row span{color:var(--ink-soft)}
.infobox .price{font-family:'Fraunces',serif;color:var(--gold);font-weight:600;font-size:1.15rem}
.disclaimer{font-size:.86rem;color:var(--ink-soft);font-style:italic;background:var(--ground-deep);border-radius:12px;padding:14px 18px;margin-top:22px}

/* Sub-offer cards (Unterkategorien auf der Oberseite) */
.subgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-top:14px}
.subcard{background:var(--white);border:1px solid var(--line);border-radius:18px;padding:26px;transition:transform .25s,box-shadow .25s,border-color .25s;position:relative;overflow:hidden}
.subcard::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--lilac);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.subcard:hover{transform:translateY(-5px);box-shadow:0 22px 46px var(--shadow);border-color:transparent}
.subcard:hover::before{transform:scaleX(1)}
.subcard .ic{width:50px;height:50px;border-radius:14px;background:var(--ground-deep);display:flex;align-items:center;justify-content:center;color:var(--lilac-deep);margin-bottom:16px}
.subcard h3{font-size:1.22rem;margin-bottom:8px}
.subcard p{font-size:.95rem;color:var(--ink-soft)}

/* CTA strip */
.cta-strip{background:linear-gradient(135deg,var(--lilac-deep),var(--plum));color:#fff;border-radius:28px;padding:54px 50px;text-align:center;margin:60px 0 0;position:relative;overflow:hidden}
.cta-strip h2{color:#fff;font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:14px}
.cta-strip p{color:rgba(255,253,255,.85);max-width:46ch;margin:0 auto 26px}
.cta-strip .cta-btn{background:var(--gold)}
.cta-strip .cta-btn:hover{background:#fff;color:var(--lilac-deep)}

/* Footer */
footer{background:var(--ink);color:#d6cfdd;padding:60px 0 26px;margin-top:80px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:38px;margin-bottom:44px}
.foot-brand .brand .txt b{color:var(--white)}
.foot-brand .brand .txt span{color:var(--lilac-soft)}
.foot-brand p{margin-top:16px;font-size:.92rem;color:#a89fb0;max-width:30ch}
footer h4{font-family:'Mulish',sans-serif;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--lilac-soft);margin-bottom:16px}
footer ul{list-style:none}
footer ul li{margin-bottom:9px}
footer ul a{font-size:.92rem;color:#bdb4c5;transition:color .2s}
footer ul a:hover{color:var(--lilac-soft)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.84rem;color:#8b8293;align-items:center}
.foot-bottom a:hover{color:var(--lilac-soft)}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* Responsive Navigation */
@media(max-width:1024px){
  .menu{position:fixed;inset:76px 0 auto 0;background:var(--ground);flex-direction:column;align-items:stretch;gap:0;padding:12px 22px 28px;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .35s;box-shadow:0 14px 30px var(--shadow);max-height:calc(100vh - 76px);overflow-y:auto}
  .menu.open{transform:none}
  .menu > a,.menu .has-sub > a{width:100%;padding:13px 6px;border-radius:0;border-bottom:1px solid var(--line)}
  .menu .has-sub > a .ar{margin-left:auto}
  .submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;background:transparent;padding:0 0 8px 16px;min-width:0;display:none}
  .menu .has-sub.open-sub .submenu{display:block}
  .menu .has-sub:hover .submenu{opacity:1}
  .submenu a{padding:9px 8px}
  .menu .cta-btn{margin-top:14px;justify-content:center}
  .burger{display:flex}
}
@media(max-width:680px){
  .foot-grid{grid-template-columns:1fr 1fr;gap:28px}
  .cta-strip{padding:40px 24px}
  .infobox{padding:24px}
}
@media(max-width:480px){.foot-grid{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){*{animation:none!important}.reveal{transition:none}}
