/* Selbst-gehostete Schriften (kein Drittanbieter-Load, DSGVO-freundlich) */
@font-face{font-family:'Inter';font-style:normal;font-weight:300;font-display:swap;src:url('assets/fonts/inter-latin-300.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Inter';font-style:normal;font-weight:300;font-display:swap;src:url('assets/fonts/inter-latin-ext-300.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/inter-latin-400.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/inter-latin-ext-400.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('assets/fonts/inter-latin-500.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('assets/fonts/inter-latin-ext-500.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/inter-latin-600.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/inter-latin-ext-600.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/fraunces-latin-400.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/fraunces-latin-ext-400.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:500;font-display:swap;src:url('assets/fonts/fraunces-latin-500.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:500;font-display:swap;src:url('assets/fonts/fraunces-latin-ext-500.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/fraunces-latin-600.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/fraunces-latin-ext-600.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}

:root{
  --brombeer:#6B2D5C;
  --brombeer-dark:#461E3C;
  --brombeer-soft:#8A4A78;
  --rosa:#F4DEE8;
  --rosa-deep:#E7BBCF;
  --rosa-tint:#FBEFF4;
  --text:#33292E;
  --muted:#7A6E74;
  --bg:#FBF8F9;
  --white:#FFFFFF;
  --line:#ECE0E7;
  --shadow:0 10px 40px rgba(70,30,60,.07);
  --shadow-sm:0 4px 18px rgba(70,30,60,.06);
  --radius:18px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--text);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:500;line-height:1.18;color:var(--brombeer-dark);letter-spacing:-.01em}
h1{font-size:clamp(2.1rem,5vw,3.4rem)}
h2{font-size:clamp(1.7rem,3.5vw,2.4rem)}
h3{font-size:1.3rem}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
.muted{color:var(--muted)}
.center{text-align:center}

/* NAV */
header{position:sticky;top:0;z-index:100;background:rgba(251,248,249,.9);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{font-family:'Fraunces',serif;font-size:1.15rem;font-weight:600;color:var(--brombeer);letter-spacing:.01em}
.brand small{display:block;font-family:'Inter';font-size:.62rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.menu{display:flex;gap:4px;align-items:center}
.menu>a,.dropdown>a{padding:9px 15px;border-radius:30px;font-size:.92rem;font-weight:500;color:var(--text);transition:.2s;cursor:pointer;display:inline-block}
.menu>a:hover,.dropdown>a:hover{background:var(--rosa-tint);color:var(--brombeer)}
.menu>a.active,.dropdown>a.active{background:var(--brombeer);color:#fff}
.menu>a.cta{background:var(--rosa-deep);color:var(--brombeer-dark)}
.menu>a.cta:hover{background:var(--brombeer);color:#fff}
.dropdown{position:relative}
.submenu{position:absolute;top:calc(100% + 4px);left:0;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:8px;min-width:250px;flex-direction:column;opacity:0;visibility:hidden;transform:translateY(6px);transition:.18s}
.dropdown:hover .submenu{opacity:1;visibility:visible;transform:none;display:flex}
.submenu a{padding:10px 14px;border-radius:10px;font-size:.9rem;color:var(--text);white-space:nowrap}
.submenu a:hover{background:var(--rosa-tint);color:var(--brombeer)}
.burger{display:none;background:none;border:0;cursor:pointer;font-size:1.5rem;color:var(--brombeer)}

/* ICONS */
.ic svg{width:24px;height:24px;fill:none;stroke:var(--brombeer);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}

/* SECTIONS */
section.block{padding:72px 0}
section.block.tight{padding:48px 0}
.page-hero{background:linear-gradient(160deg,var(--rosa-tint) 0%,var(--bg) 70%);padding:64px 0 56px}
.page-hero .eyebrow{display:inline-block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brombeer-soft);font-weight:600;margin-bottom:14px}
.page-hero h1{max-width:20ch}
.page-hero .lead{font-size:1.12rem;color:var(--muted);margin:18px 0 28px;max-width:54ch}

/* HERO (home) */
.hero{background:linear-gradient(160deg,var(--rosa-tint) 0%,var(--bg) 60%)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:center;padding:64px 0}
.hero .eyebrow{display:inline-block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brombeer-soft);font-weight:600;margin-bottom:18px;background:#fff;padding:7px 16px;border-radius:30px;box-shadow:var(--shadow-sm)}
.hero .lead{font-size:1.15rem;color:var(--muted);margin:22px 0 30px;max-width:34ch}
.hero-img{position:relative}
.hero-img img{width:100%;border-radius:24px;box-shadow:var(--shadow);aspect-ratio:4/4.6;object-fit:cover;object-position:center 20%}
.hero-badge{position:absolute;bottom:-18px;left:-18px;background:#fff;border-radius:16px;padding:16px 20px;box-shadow:var(--shadow);font-size:.9rem}
.hero-badge b{font-family:'Fraunces',serif;font-size:1.5rem;color:var(--brombeer);display:block}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:32px;font-weight:600;font-size:.95rem;cursor:pointer;border:0;transition:.2s;font-family:inherit}
.btn-primary{background:var(--brombeer);color:#fff}
.btn-primary:hover{background:var(--brombeer-dark);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--brombeer);border:1.5px solid var(--rosa-deep)}
.btn-ghost:hover{background:var(--rosa-tint)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap}

/* AUDIENCE */
.aud-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:14px}
.aud{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;transition:.25s;display:block}
.aud:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--rosa-deep)}
.aud .ic{width:50px;height:50px;border-radius:12px;background:var(--rosa-tint);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.aud h3{margin-bottom:8px}
.aud .arrow{color:var(--brombeer);font-weight:600;font-size:.9rem;margin-top:14px;display:inline-block}

/* SECTION HEAD */
.sec-head{max-width:62ch;margin-bottom:42px}
.sec-head .eyebrow{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brombeer-soft);font-weight:600;display:block;margin-bottom:12px}

/* OFFERS */
.offer-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.offer{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:.25s}
.offer:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--rosa-deep)}
.offer .ph{height:190px;background:var(--rosa-tint);overflow:hidden}
.offer .ph img{width:100%;height:100%;object-fit:cover}
.offer .body{padding:26px 26px 28px;flex:1;display:flex;flex-direction:column}
.offer .tag{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brombeer-soft);font-weight:600;margin-bottom:10px}
.offer h3{margin-bottom:10px}
.offer p{color:var(--muted);font-size:.95rem;flex:1}
.offer .lnk{margin-top:18px;color:var(--brombeer);font-weight:600;font-size:.92rem}

/* INFO / LISTS */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.two-col h3{margin-bottom:14px}
.ticks{list-style:none;display:flex;flex-direction:column;gap:10px}
.ticks li{position:relative;padding-left:28px;color:#4a3f45}
.ticks li:before{content:"";position:absolute;left:0;top:9px;width:8px;height:8px;border-radius:50%;background:var(--rosa-deep)}
.infobox{background:#fff;border:1px solid var(--line);border-left:4px solid var(--brombeer);border-radius:14px;padding:26px 30px;box-shadow:var(--shadow-sm)}
.infobox h3{margin-bottom:10px}
.notice{background:var(--rosa-tint);border:1px dashed var(--rosa-deep);border-radius:12px;padding:12px 16px;font-size:.85rem;color:var(--brombeer-dark);margin-top:16px}

/* CHIPS */
.chips{display:flex;flex-wrap:wrap;gap:12px}
.chip-big{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 22px;font-weight:500;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-sm)}
.chip-big .dot{width:9px;height:9px;border-radius:50%;background:var(--rosa-deep);flex:none}

/* ABOUT / FEATURE SPLIT */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:center}
.about-grid img{width:100%;border-radius:20px;box-shadow:var(--shadow);object-fit:cover;aspect-ratio:4/5}
.about-grid .eyebrow{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brombeer-soft);font-weight:600;display:block;margin-bottom:12px}
.about-grid p{margin-bottom:16px;color:#4a3f45}
.quali{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.quali span{background:var(--rosa-tint);color:var(--brombeer-dark);padding:7px 14px;border-radius:20px;font-size:.82rem;font-weight:500}
.stat-row{display:flex;gap:40px;margin:30px 0;flex-wrap:wrap}
.stat b{font-family:'Fraunces',serif;font-size:2.2rem;color:var(--brombeer);display:block}
.stat span{font-size:.85rem;color:var(--muted)}

/* CALENDAR */
.filterbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:30px}
.filterbar button{padding:10px 20px;border-radius:30px;border:1.5px solid var(--line);background:#fff;cursor:pointer;font-family:inherit;font-weight:500;font-size:.9rem;color:var(--text);transition:.2s}
.filterbar button:hover{border-color:var(--rosa-deep)}
.filterbar button.active{background:var(--brombeer);color:#fff;border-color:var(--brombeer)}
.events{display:flex;flex-direction:column;gap:16px}
.event{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px 26px;display:grid;grid-template-columns:auto 1fr auto;gap:26px;align-items:center;transition:.2s}
.event:hover{box-shadow:var(--shadow-sm)}
.event .date{text-align:center;background:var(--rosa-tint);border-radius:12px;padding:12px 16px;min-width:78px}
.event .date b{font-family:'Fraunces',serif;font-size:1.5rem;color:var(--brombeer);display:block;line-height:1}
.event .date span{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.event .meta .badge{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;padding:3px 10px;border-radius:20px;background:var(--rosa-deep);color:var(--brombeer-dark);margin-bottom:7px;display:inline-block}
.event .meta h3{font-size:1.1rem;margin-bottom:4px}
.event .meta p{font-size:.85rem;color:var(--muted)}

/* MATERIALS */
.mat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.mat{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;display:flex;flex-direction:column;transition:.25s}
.mat:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--rosa-deep)}
.mat .pdfic{width:42px;height:42px;border-radius:11px;background:var(--rosa-tint);color:var(--brombeer);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.72rem;margin-bottom:16px;letter-spacing:.04em}
.mat .tag{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--brombeer-soft);font-weight:600;margin-bottom:8px}
.mat h3{font-size:1.08rem;margin-bottom:8px}
.mat p{font-size:.86rem;color:var(--muted);flex:1;margin-bottom:18px}
.mat .price{font-family:'Fraunces',serif;font-size:1.5rem;color:var(--brombeer);margin-bottom:2px}
.mat .vat{font-size:.72rem;color:var(--muted);margin-bottom:16px}
.mat .btn{justify-content:center;width:100%}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.field{margin-bottom:18px}
.field label{display:block;font-size:.85rem;font-weight:500;margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:.95rem;background:#fff;transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--brombeer-soft)}
.contact-side{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px}
.contact-side .row{display:flex;gap:14px;align-items:flex-start;margin-bottom:22px}
.contact-side .row .ic{flex:none}

/* INSTA / CTA */
.insta{background:linear-gradient(135deg,var(--brombeer) 0%,var(--brombeer-soft) 100%);border-radius:var(--radius);padding:48px;color:#fff;text-align:center}
.insta h2{color:#fff}
.insta p{color:rgba(255,255,255,.85);max-width:46ch;margin:14px auto 26px}
.insta .btn{background:#fff;color:var(--brombeer)}
.cta-band{background:var(--rosa-tint);border-radius:var(--radius);padding:50px;text-align:center}
.cta-band p{max-width:50ch;margin:12px auto 24px;color:var(--muted)}

/* FOOTER */
footer{background:var(--brombeer-dark);color:rgba(255,255,255,.8);padding:54px 0 30px;margin-top:20px}
.foot-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:36px;margin-bottom:36px}
footer h4{color:#fff;font-family:'Inter';font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px;font-weight:600}
footer a{display:block;color:rgba(255,255,255,.75);padding:5px 0;font-size:.92rem}
footer a:hover{color:#fff}
.foot-brand{font-family:'Fraunces',serif;font-size:1.4rem;color:#fff;margin-bottom:10px}
.foot-grid>div>p{max-width:42ch;font-size:.92rem}
.foot-bottom{border-top:1px solid rgba(255,255,255,.15);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.82rem;color:rgba(255,255,255,.6)}

/* RESPONSIVE */
@media(max-width:900px){
  .hero-grid,.about-grid,.contact-grid{grid-template-columns:1fr;gap:34px}
  .two-col{grid-template-columns:1fr;gap:28px}
  .aud-grid,.mat-grid{grid-template-columns:1fr 1fr}
  .offer-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .menu{position:fixed;top:72px;left:0;right:0;background:var(--bg);flex-direction:column;align-items:stretch;padding:14px 24px;gap:4px;border-bottom:1px solid var(--line);box-shadow:var(--shadow);display:none}
  .menu.open{display:flex}
  .menu>a,.dropdown>a{padding:13px 16px}
  .dropdown{position:static}
  .submenu{position:static;opacity:1;visibility:visible;transform:none;display:flex;box-shadow:none;border:0;padding:0 0 6px 14px;min-width:0}
  .burger{display:block}
  .event{grid-template-columns:auto 1fr;gap:16px}
  .event .actbtn{grid-column:1/-1}
}
@media(max-width:560px){
  .aud-grid,.mat-grid{grid-template-columns:1fr}
  .stat-row{gap:24px}
}

/* ===== Startseite: Positionierung ===== */
.intro{padding:70px 0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.intro .wrap{max-width:860px;text-align:center}
.intro .eyebrow{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brombeer-soft);font-weight:600;display:block;margin-bottom:18px}
.intro p{font-size:clamp(1.25rem,2.4vw,1.6rem);line-height:1.55;font-family:'Fraunces',serif;color:var(--brombeer-dark);font-weight:400}

/* ===== Startseite: Leistungen-Teaser (redaktionell) ===== */
.svc-list{display:flex;flex-direction:column}
.svc-line{display:grid;grid-template-columns:auto 1fr auto;gap:30px;align-items:center;padding:28px 0;border-top:1px solid var(--line);transition:.2s}
.svc-list .svc-line:last-child{border-bottom:1px solid var(--line)}
.svc-line:hover{padding-left:8px}
.svc-line .n{font-family:'Fraunces',serif;color:var(--rosa-deep);font-size:1.15rem;font-weight:600;min-width:34px}
.svc-line .c h3{margin-bottom:5px}
.svc-line .c p{color:var(--muted);font-size:.96rem;max-width:62ch}
.svc-line .go{color:var(--brombeer);font-weight:600;white-space:nowrap;font-size:.92rem}

/* ===== Startseite: Über-mich-Teaser ===== */
.ueber-teaser{display:grid;grid-template-columns:.8fr 1.2fr;gap:50px;align-items:center}
.ueber-teaser img{width:100%;border-radius:20px;box-shadow:var(--shadow);object-fit:cover;aspect-ratio:4/5}
.ueber-teaser .eyebrow{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brombeer-soft);font-weight:600;display:block;margin-bottom:12px}
.ueber-teaser p{color:#4a3f45;margin:14px 0 22px;max-width:54ch}

/* ===== Angebote: redaktionelle Reihen ===== */
.editorial{display:flex;flex-direction:column}
.svc{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;padding:60px 0;border-top:1px solid var(--line)}
.editorial .svc:first-child{border-top:0;padding-top:8px}
.svc-media{border-radius:20px;overflow:hidden;aspect-ratio:5/4;box-shadow:var(--shadow)}
.svc-media img{width:100%;height:100%;object-fit:cover}
.svc.rev .svc-media{order:2}
.svc-num{font-family:'Fraunces',serif;font-size:.95rem;color:var(--rosa-deep);font-weight:600;letter-spacing:.12em}
.svc-tag{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brombeer-soft);font-weight:600;margin-left:12px}
.svc-body h2{margin:10px 0 14px}
.svc-body>p{color:#4a3f45;margin-bottom:18px}
.svc-body .ticks{margin-bottom:24px}

/* ===== Über mich: Veröffentlichungen ===== */
.books{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.book .cover{aspect-ratio:3/4;border-radius:12px;background:linear-gradient(150deg,var(--brombeer) 0%,var(--brombeer-soft) 100%);box-shadow:var(--shadow);display:flex;align-items:flex-end;padding:22px;color:#fff;margin-bottom:18px;position:relative}
.book .cover .t{font-family:'Fraunces',serif;font-size:1.15rem;line-height:1.25;opacity:.95}
.book .cover .ph-label{position:absolute;top:14px;left:14px;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;background:rgba(255,255,255,.22);padding:4px 9px;border-radius:20px}
.book h3{font-size:1.1rem;margin-bottom:3px}
.book .year{font-size:.8rem;color:var(--muted);margin-bottom:8px}
.book p{font-size:.9rem;color:var(--muted)}

@media(max-width:900px){
  .svc{grid-template-columns:1fr;gap:26px;padding:44px 0}
  .svc.rev .svc-media{order:0}
  .ueber-teaser{grid-template-columns:1fr;gap:30px}
  .books{grid-template-columns:1fr 1fr}
  .svc-line{grid-template-columns:auto 1fr;gap:18px}
  .svc-line .go{grid-column:2;justify-self:start;margin-top:2px}
}
@media(max-width:560px){
  .books{grid-template-columns:1fr;max-width:320px;margin:0 auto}
}

/* ===== Instagram-Icon in der Navigation ===== */
.nav-ig{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;color:var(--brombeer);transition:.2s;margin-left:6px;flex:none}
.nav-ig svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.7}
.nav-ig:hover{background:var(--rosa-tint)}
@media(max-width:900px){.nav-ig{width:auto;height:auto;border-radius:30px;justify-content:flex-start;gap:10px;padding:13px 16px;margin-left:0}.nav-ig:after{content:"Instagram";font-size:.92rem;font-weight:500}}

/* ===== Testimonial-Slider ===== */
.tslider{position:relative;max-width:840px;margin:0 auto;overflow:hidden}
.ttrack{display:flex;transition:transform .5s ease}
.tslide{min-width:100%;padding:0 8px}
.tcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:46px 48px;box-shadow:var(--shadow-sm);text-align:center}
.tcard .stars{color:var(--rosa-deep);letter-spacing:4px;margin-bottom:18px;font-size:1.1rem}
.tcard .quote{font-family:'Fraunces',serif;font-size:1.3rem;line-height:1.55;color:var(--brombeer-dark);margin-bottom:24px}
.tcard .who{font-weight:600;color:var(--brombeer)}
.tcard .role{font-size:.85rem;color:var(--muted)}
.tnav{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:28px}
.tnav button{width:46px;height:46px;border-radius:50%;border:1.5px solid var(--rosa-deep);background:#fff;cursor:pointer;color:var(--brombeer);font-size:1.3rem;line-height:1;transition:.2s}
.tnav button:hover{background:var(--brombeer);color:#fff;border-color:var(--brombeer)}
.tdots{display:flex;gap:8px}
.tdots span{width:9px;height:9px;border-radius:50%;background:var(--rosa-deep);opacity:.4;cursor:pointer;transition:.25s}
.tdots span.active{opacity:1;width:26px;border-radius:6px}

/* ===== Qualifikationen ===== */
.qual-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:46px;align-items:center}
.qual-grid .frame{border-radius:16px;overflow:hidden;box-shadow:var(--shadow);background:#fff}
.qual-grid .frame img{width:100%;display:block}
.qual-grid .eyebrow{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brombeer-soft);font-weight:600;display:block;margin-bottom:12px}
.qual-grid p{color:#4a3f45;margin:12px 0}

/* ===== FAQ-Akkordeon ===== */
.faq{max-width:840px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:24px 0;font-family:'Fraunces',serif;font-size:1.18rem;color:var(--brombeer-dark);display:flex;justify-content:space-between;align-items:center;gap:24px}
.faq-q .pm{flex:none;width:28px;height:28px;border-radius:50%;background:var(--rosa-tint);color:var(--brombeer);display:flex;align-items:center;justify-content:center;font-size:1.3rem;transition:transform .25s}
.faq-item.open .faq-q .pm{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a .inner{padding:0 0 24px;color:#4a3f45}
.faq-a p{margin-bottom:12px}
.faq-a ul{margin:0 0 12px;padding-left:20px}
.faq-a li{margin-bottom:6px}

/* ===== Rechtstexte ===== */
.legal{max-width:780px;margin:0 auto}
.legal h2{font-size:1.35rem;margin:34px 0 8px}
.legal h2:first-child{margin-top:0}
.legal p{margin-bottom:12px;color:#4a3f45}
.legal address{font-style:normal;color:#4a3f45;line-height:1.85;margin-bottom:12px}
.legal a{color:var(--brombeer);font-weight:500;text-decoration:underline}

@media(max-width:900px){
  .qual-grid{grid-template-columns:1fr;gap:28px}
  .tcard{padding:36px 28px}
}

/* ===== Ablauf-Schritte (Leistungsseiten) ===== */
.steps{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;margin-top:8px}
.step{display:flex;gap:16px;align-items:flex-start}
.step .sn{flex:none;width:42px;height:42px;border-radius:50%;background:var(--brombeer);color:#fff;font-family:'Fraunces',serif;display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.step h4{font-family:'Fraunces',serif;font-weight:500;font-size:1.08rem;color:var(--brombeer-dark);margin-bottom:5px}
.step p{font-size:.92rem;color:var(--muted)}
.lead-block{max-width:760px}
.lead-block p{margin-bottom:14px;color:#4a3f45}
@media(max-width:700px){.steps{grid-template-columns:1fr}}

/* ===== Erstgespräch-Modal ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(70,30,60,.45);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;z-index:1000;padding:20px}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:var(--radius);max-width:540px;width:100%;padding:38px 38px 32px;box-shadow:var(--shadow);position:relative;max-height:90vh;overflow:auto;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.modal .eyebrow{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brombeer-soft);font-weight:600;display:block;margin-bottom:10px}
.modal h3{font-size:1.5rem;margin-bottom:8px}
.modal .sub{color:var(--muted);font-size:.93rem;margin-bottom:22px}
.modal .x{position:absolute;top:14px;right:18px;background:none;border:0;font-size:1.7rem;line-height:1;cursor:pointer;color:var(--muted)}
.modal .x:hover{color:var(--brombeer)}
.modal .btn{width:100%;justify-content:center;margin-top:4px}
.modal .note{font-size:.8rem;color:var(--muted);margin-top:14px;text-align:center}
.modal .note a{color:var(--brombeer);font-weight:600}

/* ===== Referenzen-Logowand ===== */
.reflogos{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.reflogo{aspect-ratio:3/2;border:1px dashed var(--rosa-deep);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--brombeer-soft);font-size:.78rem;background:#fff;text-align:center;padding:10px}
@media(max-width:760px){.reflogos{grid-template-columns:repeat(2,1fr)}}

/* ===== Hervorhebungs-Callout (z. B. Therapie-Abgrenzung) ===== */
.callout{background:var(--rosa-tint);border-radius:var(--radius);padding:30px 34px}
.callout .eyebrow{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brombeer-soft);font-weight:600;display:block;margin-bottom:10px}
.callout h3{margin-bottom:10px}
.callout p{color:#4a3f45;margin-bottom:10px}

/* ===== Newsletter (helle, zweispaltige Karte) ===== */
.newsletter{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;background:#fff;border:1px solid var(--line);border-left:5px solid var(--brombeer);border-radius:var(--radius);padding:42px 46px;box-shadow:var(--shadow-sm)}
.newsletter .nl-intro{display:flex;gap:18px;align-items:flex-start}
.newsletter .nl-ic{flex:none;width:52px;height:52px;border-radius:14px;background:var(--rosa-tint);display:flex;align-items:center;justify-content:center}
.newsletter .nl-ic svg{width:26px;height:26px;fill:none;stroke:var(--brombeer);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.newsletter .eyebrow{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brombeer-soft);font-weight:600;display:block;margin-bottom:8px}
.newsletter h2{font-size:1.6rem;margin-bottom:8px}
.newsletter p{color:var(--muted);font-size:.95rem;margin:0}
.nl-form{display:flex;gap:10px;flex-wrap:wrap}
.nl-form input{flex:1;min-width:200px;padding:13px 16px;border:1.5px solid var(--line);border-radius:30px;font-family:inherit;font-size:.95rem;color:var(--text);transition:.2s}
.nl-form input:focus{outline:0;border-color:var(--brombeer-soft)}
.nl-consent{display:flex;gap:10px;align-items:flex-start;margin-top:14px;font-size:.78rem;color:var(--muted);line-height:1.5}
.nl-consent input{margin-top:3px;flex:none}
.nl-consent a{color:var(--brombeer);text-decoration:underline}
@media(max-width:820px){.newsletter{grid-template-columns:1fr;gap:24px;padding:34px 28px}}

/* ===== Kontakt-Detailzeilen ===== */
.contact-side .row b{color:var(--brombeer-dark)}
.contact-side .resp{background:var(--rosa-tint);border-radius:12px;padding:14px 16px;font-size:.86rem;color:var(--brombeer-dark);margin-top:6px}

/* ============================================================
   MOBILE-OPTIMIERUNG (Feinschliff für Smartphones)
   ============================================================ */
body{overflow-x:clip}
*{ -webkit-tap-highlight-color:rgba(107,45,92,.15); }

@media(max-width:760px){
  section.block{padding:52px 0}
  section.block.tight{padding:36px 0}
  .page-hero{padding:44px 0 34px}
  .hero-grid{padding:38px 0;gap:30px}
  .sec-head{margin-bottom:30px}
  .cta-band{padding:34px 22px}
  .insta{padding:36px 24px}
  .intro{padding:46px 0}
  .modal{padding:30px 22px}
  .newsletter{padding:30px 24px}

  /* Hero-Badge: kein absoluter Überlauf mehr */
  .hero-badge{position:static;display:inline-flex;align-items:center;gap:8px;margin-top:16px;left:auto;bottom:auto;padding:12px 18px}
  .hero-badge b{display:inline;font-size:1.2rem}

  /* Footer einspaltig + Abstände */
  .foot-grid{grid-template-columns:1fr;gap:26px;margin-bottom:30px}
  .foot-bottom{flex-direction:column;gap:6px}

  /* Lange Links/Adressen sauber umbrechen */
  .legal a, .legal address, .contact-side a, .modal .note a{overflow-wrap:anywhere}

  /* Termin-Karten: Datum oben, Inhalt darunter, Button voll */
  .event{grid-template-columns:auto 1fr}
}

@media(max-width:600px){
  /* CTAs volle Breite & gestapelt – besser tippbar */
  .btn{width:100%;justify-content:center}
  .btn-row{flex-direction:column;align-items:stretch;width:100%}
  .nl-form{flex-direction:column}
  .nl-form input{min-width:0;width:100%}
  h1{font-size:1.95rem}
  h2{font-size:1.5rem}
  .tcard{padding:30px 22px}
  .tcard .quote{font-size:1.12rem}
  .qual-grid .frame{max-width:340px;margin:0 auto}
}

@media(max-width:400px){
  .wrap{padding:0 18px}
  .brand{font-size:1.02rem}
  .brand small{font-size:.56rem;letter-spacing:.12em}
  .reflogos{grid-template-columns:1fr 1fr;gap:12px}
  .chip-big{width:100%}
}

/* ===== Platzhalter-Bilder ===== */
.ph-box{aspect-ratio:4/5;border-radius:20px;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;background:var(--rosa-tint);border:1px dashed var(--rosa-deep);color:var(--brombeer-soft);font-weight:500;width:100%}
.svc-media .ph-fill{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--rosa-tint);color:var(--brombeer-soft);font-weight:500}

/* ===== Cross-Browser: iOS-Auto-Zoom bei Formularen verhindern ===== */
@media(max-width:600px){
  .field input,.field select,.field textarea,.nl-form input,.modal input,.modal select,.modal textarea{font-size:16px}
}

/* ===== Newsletter: ActiveCampaign-Variante (gestapelt) ===== */
.nl-form.nl-col{flex-direction:column;align-items:stretch;gap:12px}
.nl-form.nl-col input{width:100%;min-width:0}
.nl-form.nl-col .btn{width:100%}
.nl-thanks{background:var(--rosa-tint);border-radius:12px;padding:16px 18px;color:var(--brombeer-dark);font-weight:500}

/* ===== Bücher: echte Cover ===== */
.book img{width:100%;border-radius:12px;box-shadow:var(--shadow);margin-bottom:18px;display:block;background:#fff}
.books.books-2{grid-template-columns:repeat(2,1fr);gap:34px;max-width:760px}
@media(max-width:560px){.books.books-2{grid-template-columns:1fr;max-width:320px;margin:0 auto}}
