:root{
  --bg:#ffffff;
  --bg-alt:#f5f7fa;
  --text:#1f2933;
  --muted:#5b6775;
  --border:#e2e6ee;
  --primary:#4b55c4;
  --primary-dark:#2f358a;
  --shadow:0 14px 40px rgba(15, 23, 42, .08);
  --shadow-soft:0 10px 26px rgba(15, 23, 42, .06);
  --radius:16px;
  --max:1120px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.55;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{max-width:100%;height:auto;display:block}
a{color:inherit}
a:hover{color:var(--primary)}

.container{width:min(var(--max),calc(100% - 2rem));margin-inline:auto}

.site-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(226,230,238,.9);
}

.header-inner{display:flex;align-items:center;gap:1rem;padding:.85rem 0}
.brand{display:flex;align-items:center;gap:.65rem;text-decoration:none}
.brand img{height:74px;width:auto;max-width:280px;object-fit:contain}

.nav{
  margin-left:auto;
  display:flex;
  align-items:center;
  gap:.2rem;
  flex-wrap:wrap;
}

.nav a,.nav button{
  border:1px solid transparent;
  background:transparent;
  padding:.55rem .7rem;
  border-radius:12px;
  cursor:pointer;
  font:inherit;
  text-decoration:none;
}

.nav a:hover,.nav button:hover{background:var(--bg-alt);border-color:var(--border)}
.nav a[aria-current="page"]{background:var(--bg-alt);border-color:var(--border)}

.dropdown{position:relative}
.dropdown>button{display:flex;align-items:center;gap:.35rem}
.dropdown>button::after{content:"▾";color:var(--muted);font-size:.9em}

.dropdown-menu{
  position:absolute;
  top:calc(100% + .4rem);
  left:0;
  min-width:240px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:.35rem;
  display:none;
}

.dropdown-menu a{display:block;padding:.65rem .7rem;border-radius:12px}
.dropdown-menu a:hover{background:var(--bg-alt)}
.dropdown:hover .dropdown-menu,
.dropdown:focus-within .dropdown-menu{display:block}

.header-cta{display:flex;gap:.6rem;margin-left:.6rem}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.65rem .95rem;
  border-radius:12px;
  border:1px solid rgba(226,230,238,.95);
  background:#fff;
  text-decoration:none;
  box-shadow:0 1px 0 rgba(15, 23, 42, .02);
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease, background .12s ease;
}

.btn:hover{
  border-color:rgba(75,85,196,.45);
  box-shadow:0 10px 22px rgba(15, 23, 42, .08);
  transform:translateY(-1px);
}
.btn:active{transform:translateY(0)}

.btn-primary{
  color:#fff;
  border-color:rgba(75,85,196,.9);
  background:linear-gradient(180deg, rgba(75,85,196,1) 0%, rgba(47,53,138,1) 100%);
  box-shadow:0 14px 34px rgba(47,53,138,.22);
}
.btn-primary:hover{
  border-color:rgba(47,53,138,.95);
  box-shadow:0 18px 44px rgba(47,53,138,.26);
}

details.mobile-nav{display:none}

@media(max-width:900px){
  .nav,.header-cta{display:none}
  .brand img{height:64px;max-width:260px}

  details.mobile-nav{
    display:block;
    margin-left:auto;
    position:relative;
  }

  details.mobile-nav > summary.mobile-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    list-style:none;
    user-select:none;
  }
  details.mobile-nav > summary.mobile-toggle::-webkit-details-marker{display:none}

  details.mobile-nav .mobile-links{
    display:none;
    position:absolute;
    right:0;
    top:calc(100% + .6rem);
    width:min(92vw, 360px);
    background:#fff;
    border:1px solid var(--border);
    border-radius:16px;
    box-shadow:var(--shadow);
    padding:.8rem;
    z-index:1001;
  }

  details.mobile-nav[open] .mobile-links{
    display:grid;
    gap:.45rem;
  }

  .mobile-links > a{
    padding:.7rem .9rem;
    border:1px solid var(--border);
    border-radius:14px;
    background:var(--bg-alt);
    text-decoration:none;
  }
  .mobile-links a[aria-current="page"]{font-weight:700}

  .mobile-ctas{
    display:flex;
    gap:.6rem;
    padding-top:.8rem;
    flex-wrap:wrap;
  }

  .mobile-ctas .btn{
    background:#fff;
    border:1px solid rgba(226,230,238,.95);
  }
  .mobile-ctas .btn-primary{
    color:#fff;
    border-color:rgba(75,85,196,.9);
    background:linear-gradient(180deg, rgba(75,85,196,1) 0%, rgba(47,53,138,1) 100%);
    box-shadow:0 14px 34px rgba(47,53,138,.22);
  }
}


.hero{
  padding:2.2rem 0 3rem;
  background:linear-gradient(180deg,var(--bg-alt),#fff);
  border-bottom:1px solid var(--border);
  position:relative;
  overflow:hidden;
}

.hero::before{
  content:"";
  position:absolute;
  inset:-20% -10% auto auto;
  width:820px;
  height:560px;
  background: radial-gradient(closest-side at 70% 35%, rgba(75,85,196,.18), rgba(75,85,196,0) 70%);
  filter:blur(2px);
  pointer-events:none;
}

.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)' opacity='.18'/%3E%3C/svg%3E");
  opacity:.055;
  mix-blend-mode:multiply;
  pointer-events:none;
}

@media(max-width:980px){
  .hero{padding:3rem 0 2.2rem;}
  .hero::before{width:560px;height:420px;inset:-25% -25% auto auto;opacity:.9}
  .hero::after{opacity:.04}
}

.hero-grid{
  position:relative;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:2rem;
  align-items:start;
}

@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:1.4rem;}
}

@media(min-width:1100px){
  .hero-visual{ margin-right: 2.6rem; }
}

@media(min-width:981px){
  .hero-visual{
    grid-column: 2;
    grid-row: 2;
    justify-self: end;
    align-self: start;
    margin-top: -26rem;
    margin-right: 2.2rem;

   
    transform: translateX(32px);
  }
}


@media(max-width:1100px){
  .hero-visual{ transform: translateX(18px); }
}


@media(max-width:980px){
  .hero-visual{
    grid-column: 1;
    grid-row: auto;
    margin: 0;
    justify-self: center;
    align-self: start;
    transform: none;
  }
}

.hero-visual img{
  display:block;
  width: 560px;
  max-width: 100%;
  height:auto;
}

@media(min-width:1400px){
  .hero-visual img{ width: 600px; }
}

@media(max-width:980px){
  .hero-visual img{
    width: min(360px, 70vw);
    max-width: 100%;
  }
}

.hero h1{
  margin:.45rem 0 .8rem;
  font-size:clamp(2rem,3.2vw,3rem);
  line-height:1.1;
}

.hero-location{font-size:0.95rem;color:var(--muted);margin:.4rem 0 .9rem}
.lead{margin:0 0 1.1rem;color:var(--muted);font-size:1.05rem}
.kicker{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:.82rem}

.hero-actions{
  display:flex;
  gap:.7rem;
  flex-wrap:wrap;
  margin-top:1rem;
}


.card{
  background:rgba(255,255,255,.88);
  border:1px solid rgba(226,230,238,.95);
  border-radius:var(--radius);
  padding:1.1rem;
  box-shadow:var(--shadow-soft);
  backdrop-filter:blur(6px);
}
.card h2,.card h3{margin:.1rem 0 .65rem}
.card p{color:var(--muted);margin:.4rem 0}

.hr{
  height:1px;
  background:rgba(226,230,238,.95);
  margin:.85rem 0;
}

.section{padding:4.2rem 0}
.section.alt{
  background:var(--bg-alt);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}

.section-head{margin-bottom:1.5rem}
.section-head h2{margin:0 0 .35rem;font-size:clamp(1.5rem,2.1vw,2.1rem)}

.grid{display:grid;gap:1rem}
.grid.three{grid-template-columns:repeat(3,1fr)}
.grid.two{grid-template-columns:repeat(2,1fr)}
@media(max-width:980px){.grid.three{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.grid.two,.grid.three{grid-template-columns:1fr}}

.list-check{list-style:none;padding:0;margin:.65rem 0 0}
.list-check li{position:relative;padding-left:1.35rem;margin:.35rem 0;color:var(--muted)}
.list-check li::before{
  content:"✓";
  position:absolute;
  left:0;
  color:var(--primary);
  font-weight:700;
}

.hero-bullets{
  margin-top: .9rem;
  padding: .9rem 1.1rem;
  background: linear-gradient( 180deg, rgba(75,85,196,.06), rgba(75,85,196,.02) );
  border-radius: 14px;
}
@media (max-width:640px){ .hero-bullets{ padding: .8rem .9rem; } }


.footer{border-top:1px solid var(--border);padding:2rem 0;background:#fff}
.footer-inner{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;color:var(--muted)}
.footer a{color:var(--muted);text-decoration:none}
.footer a:hover{color:var(--primary)}
.footer-claim{display:inline-block;margin-top:.35rem;font-size:.95rem;color:var(--muted)}


.legal{padding:1.2rem}
.legal p{color:var(--muted);margin:.65rem 0}
.legal a{color:var(--primary);text-decoration:underline;text-underline-offset:3px}
.legal a:hover{color:var(--primary-dark)}

.legal-grid{display:grid;grid-template-columns:320px 1fr;gap:1.2rem;align-items:start}
@media(max-width:980px){.legal-grid{grid-template-columns:1fr}}

.toc{
  position:sticky;
  top:92px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:#fff;
  box-shadow:var(--shadow);
  padding:1rem;
}
@media(max-width:980px){.toc{position:static}}
.toc a{color:var(--text);text-decoration:none}
.toc a:hover{color:var(--primary);text-decoration:underline;text-underline-offset:3px}


.badge{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  font-size:.85rem;
  padding:.25rem .6rem;
  border:1px solid rgba(226,230,238,.95);
  border-radius:999px;
  background:rgba(255,255,255,.85);
  color:var(--muted);
  backdrop-filter:blur(6px);
}

.trust-row{display:flex;flex-wrap:wrap;gap:.5rem;margin:.35rem 0 .25rem}
.muted{color:var(--muted);margin:0}

.cta-row{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1.1rem}

.package-card.pro{
  border-color: rgba(75,85,196,.35);
  box-shadow: 0 18px 44px rgba(47,53,138,.12);
  position:relative;
}
.package-card.pro::before{
  content:"Empfohlen";
  position:absolute;
  top:14px;
  right:14px;
  font-size:.78rem;
  color:#fff;
  background: linear-gradient(180deg, rgba(75,85,196,1), rgba(47,53,138,1));
  border-radius:999px;
  padding:.25rem .55rem;
}

.profile-card{display:flex;gap:1.1rem;align-items:flex-start}
.profile-card img{
  width:112px;
  height:112px;
  border-radius:18px;
  object-fit:cover;
  border:1px solid var(--border);
  box-shadow: 0 10px 24px rgba(0,0,0,.08);
}
@media(max-width:640px){
  .profile-card{align-items:center}
  .profile-card img{width:104px;height:104px;border-radius:999px}
}

.cta-panel{
  display:grid;
  grid-template-columns: 1.3fr .7fr;
  gap:1.2rem;
  align-items:start;
  border:1px solid var(--border);
  background:#fff;
  border-radius: var(--radius);
  padding:1.2rem;
  box-shadow: var(--shadow);
}
@media(max-width:980px){ .cta-panel{grid-template-columns:1fr} }

.cta-facts{display:grid;gap:.75rem}
.fact{border:1px solid var(--border);border-radius:14px;padding:.75rem .9rem;background: var(--bg-alt)}
.fact strong{display:block}
.fact span{color:var(--muted);display:block;margin-top:.15rem;font-size:.95rem}

.hero--compact{padding:2.8rem 0 2.2rem}
.hero-grid--contact{align-items:start}

.contact-badges{display:flex;gap:.5rem;flex-wrap:wrap;margin-top: 1rem;}
.contact-card h2{margin:.35rem 0 .2rem;font-size: 1.25rem;}
.contact-card-head{margin-bottom: .6rem;}
.contact-list{list-style:none;padding:0;margin: .8rem 0 0;display:grid;gap:.85rem;}
.contact-list li{display:flex;gap:.75rem;align-items:flex-start;}
.contact-ico{
  width: 38px;height: 38px;border-radius: 14px;border:1px solid var(--border);
  background: var(--bg-alt);display:flex;align-items:center;justify-content:center;
  flex: 0 0 auto;color: var(--primary);
}
.contact-label{font-size: .9rem;color: var(--muted);}
.contact-list a{text-decoration:none;font-weight: 600;}
.contact-list a:hover{text-decoration: underline;text-underline-offset: 3px;}
.contact-cta .btn{width:100%;}
@media (max-width: 900px){.contact-cta .btn{ width:100%; }}


.faq-grid{ gap: 1rem; }

details.faq-item{
  padding: 0;
  overflow: hidden;
}

details.faq-item > summary{
  list-style: none;
  cursor: pointer;
  user-select: none;
  padding: 1.05rem 1.1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .9rem;
  font-weight: 700;
  color: var(--text);
}

details.faq-item > summary::-webkit-details-marker{ display:none; }

details.faq-item > summary::after{
  content: "›";
  font-size: 1.35rem;
  line-height: 1;
  color: var(--muted);
  transform: rotate(90deg);
  transition: transform .16s ease, color .16s ease;
}

details.faq-item[open] > summary::after{
  transform: rotate(-90deg);
  color: var(--primary);
}

details.faq-item > summary:hover{
  background: linear-gradient(180deg, rgba(75,85,196,.06), rgba(75,85,196,.02));
}

details.faq-item > summary:focus-visible{
  outline: 2px solid rgba(75,85,196,.45);
  outline-offset: 3px;
  border-radius: 14px;
}

.faq-body{
  padding: 0 1.1rem 1.1rem;
  border-top: 1px solid rgba(226,230,238,.95);
  background: rgba(255,255,255,.55);
}

.faq-body p{
  margin: .85rem 0 0;
  color: var(--muted);
  max-width: 72ch;
}

.faq-body p strong{ color: var(--text); }

@media (max-width: 980px){
  details.faq-item > summary{ padding: 1rem 1rem; }
  .faq-body{ padding: 0 1rem 1rem; }
}



.contact-media{
  display: grid;
  grid-template-columns: 112px 1fr;
  gap: 1rem;
  align-items: center;
  margin-top: .85rem;
}

.contact-photo{
  width: 112px;
  height: 112px;
  border-radius: 18px;
  object-fit: cover;
  object-position: 50% 18%;
  border: 1px solid var(--border);
  box-shadow: 0 14px 30px rgba(15,23,42,.16);
  background: var(--bg-alt);
  cursor: default;
  user-select: none;
  -webkit-user-drag: none;
}

@media (hover:hover) and (pointer:fine){
  .contact-photo:hover{
    transform: none;
    border-color: var(--border);
    box-shadow: 0 14px 30px rgba(15,23,42,.16);
  }
}
.contact-photo:focus,
.contact-photo:focus-visible{
  outline: none;
}

.contact-details{
  display: grid;
  gap: .4rem;
  font-size: .96rem;
  color: var(--muted);
}

.contact-row{
  display: flex;
  gap: .45rem;
  align-items: baseline;
  line-height: 1.4;
  padding: .35rem .45rem;
  border-radius: 10px;
}

.contact-row strong{
  color: var(--text);
  font-weight: 600;
  white-space: nowrap;
}

.contact-row a{
  font-weight: 650;
  color: var(--primary);
  text-decoration: none;
  position: relative;
  padding: .1rem 0;
}

.contact-row a::after{
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 1px;
  background: currentColor;
  opacity: .45;
  transition: opacity .15s ease, transform .15s ease;
  transform: scaleX(.92);
  transform-origin: left;
}

.contact-row a:hover{
  color: var(--primary-dark);
}

.contact-row a:hover::after{
  opacity: 1;
  transform: scaleX(1);
}

.contact-row a:focus-visible{
  outline: 2px solid rgba(75,85,196,.45);
  outline-offset: 3px;
  border-radius: 6px;
}

.contact-cta-btn{
  width: 100%;
  justify-content: center;
  padding: .95rem 1rem;
  border-radius: 14px;
  font-weight: 700;
  letter-spacing: .01em;
  box-shadow: 0 14px 34px rgba(47,53,138,.22);
}

@media (max-width: 640px){
  .contact-media{
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
  }

  .contact-photo{
    width: 132px;
    height: 132px;
    border-radius: 22px;
    object-position: 50% 16%;
  }

  .contact-details{
    width: 100%;
    text-align: left;
  }
}


.breadcrumbs{
  padding:.9rem 0;
  color:var(--muted);
  font-size:.92rem;
}
.breadcrumbs a{ color:var(--muted); text-decoration:none; }
.breadcrumbs a:hover{ color:var(--primary); text-decoration:underline; text-underline-offset:3px; }

.search-page .section{ padding-top: 1.6rem; }
.search-wrap{ max-width: 980px; }

.search-head h1{
  margin:.2rem 0 .45rem;
  font-size: clamp(1.9rem, 2.6vw, 2.4rem);
  letter-spacing: -.01em;
}
.search-head .lead{
  max-width: 72ch;
  margin: 0 0 1.1rem;
}

.search-card{
  padding: 1.25rem;
}
@media(max-width:640px){
  .search-card{ padding: 1rem; }
}

.search-input-row{
  display:flex;
  align-items:center;
  gap:.75rem;
  flex-wrap:wrap;
}

.search-input{
  flex: 1;
  min-width: 260px;
  padding: .95rem 1rem;
  border: 1px solid rgba(226,230,238,.95);
  border-radius: 14px;
  background: rgba(255,255,255,.9);
  box-shadow: inset 0 1px 0 rgba(15,23,42,.03);
  outline: none;
  transition: border-color .12s ease, box-shadow .12s ease;
}
.search-input:focus{
  border-color: rgba(75,85,196,.55);
  box-shadow: 0 0 0 4px rgba(75,85,196,.14);
}

.search-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.8rem;
  flex-wrap:wrap;
  margin-top: .9rem;
  color: var(--muted);
  font-size: .95rem;
}
.search-meta .pill{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  padding:.25rem .6rem;
  border-radius:999px;
  border:1px solid rgba(226,230,238,.95);
  background: rgba(255,255,255,.75);
}

.search-results{
  margin-top: 1rem;
  display:grid;
  gap: .85rem;
}

.search-result{
  padding: 1.05rem;
}
.search-result-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 1rem;
  flex-wrap:wrap;
}
.search-result-title{
  margin: .05rem 0 .35rem;
  font-size: 1.08rem;
  line-height: 1.25;
}
.search-result-title a{
  text-decoration:none;
}
.search-result-title a:hover{
  text-decoration:underline;
  text-underline-offset: 3px;
}
.search-result-excerpt{
  margin: .25rem 0 0;
  color: var(--muted);
  max-width: 78ch;
}

.search-tags{
  display:flex;
  gap:.45rem;
  flex-wrap:wrap;
  margin-top: .7rem;
}
.search-tag{
  display:inline-flex;
  align-items:center;
  padding:.2rem .55rem;
  border-radius:999px;
  border:1px solid rgba(226,230,238,.95);
  background: rgba(245,247,250,.85);
  color: var(--muted);
  font-size: .82rem;
}

mark.search-hl{
  background: rgba(75,85,196,.16);
  color: inherit;
  padding: 0 .18em;
  border-radius: .35em;
}

.search-empty{
  padding: 1rem;
}
.search-empty strong{ display:block; margin-bottom:.25rem; }

.search-help{
  margin-top: .75rem;
  color: var(--muted);
  font-size: .93rem;
}

.search-page .hero--compact{ padding: 2.2rem 0 1.6rem; }
