:root {
  --bg: #f4f3f8;
  --bg-2: #ffffff;
  --purple: #8b5cf6;
  --purple-d: #7c3aed;
  --tint: #ede9fe;
  --ink: #15121f;
  --muted: #6b6577;
  --dark: #1c1730;
  --body: 'Inter', system-ui, sans-serif;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}
* { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; scroll-padding-top:90px; }
body { font-family:var(--body); background:var(--bg); color:var(--ink); line-height:1.6; -webkit-font-smoothing:antialiased; overflow-x:hidden; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }
img { display:block; max-width:100%; }
.grad { background:linear-gradient(100deg, var(--purple), #c084fc); -webkit-background-clip:text; background-clip:text; color:transparent; }
.center { text-align:center; }
.skip-link { position:absolute; left:-999px; }
.skip-link:focus { left:8px; top:8px; background:var(--purple); color:#fff; padding:8px 14px; z-index:999; }
:focus-visible { outline:2px solid var(--purple); outline-offset:3px; }
.js .reveal { opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.js .reveal.is-visible { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} .js .reveal{opacity:1!important;transform:none!important} }

.ico { width:1.4em; height:1.4em; display:inline-block; vertical-align:middle; flex:none; }
.kicker { display:inline-block; font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.14em; color:var(--purple); margin-bottom:1rem; }
.btn { display:inline-flex; align-items:center; justify-content:center; gap:.4rem; padding:.8rem 1.7rem; border-radius:2rem; font-weight:600; font-size:.9rem; border:1px solid transparent; cursor:pointer; transition:all .25s var(--ease); }
.btn-purple { background:var(--purple); color:#fff; border-color:var(--purple); }
@media (hover: hover) { .btn-purple:hover { background:var(--purple-d); transform:translateY(-2px); box-shadow:0 10px 22px rgba(139,92,246,.3); } }
.btn-purple.lg { padding:1rem 2.2rem; }
.btn-outline { background:transparent; color:var(--ink); border-color:#dcd8e6; }
@media (hover: hover) { .btn-outline:hover { border-color:var(--purple); color:var(--purple); } }
.btn-light { background:#fff; color:var(--ink); }
@media (hover: hover) { .btn-light:hover { background:var(--tint); } }
.full { width:100%; }
.text-link { font-weight:600; font-size:.92rem; color:var(--ink); }
@media (hover: hover) { .text-link:hover { color:var(--purple); } }

/* Header */
#siteHeader { position:sticky; top:0; z-index:100; background:rgba(244,243,248,.9); backdrop-filter:blur(8px); transition:box-shadow .3s; }
#siteHeader.scrolled { box-shadow:0 6px 20px rgba(28,23,48,.07); }
.head-inner { max-width:1280px; margin:0 auto; padding:1.1rem 2rem; display:flex; align-items:center; gap:1.5rem; }
.brand { display:inline-flex; align-items:center; gap:.55rem; font-weight:800; font-size:1.25rem; }
.logo-mark { width:24px; height:24px; border-radius:7px; background:linear-gradient(135deg, var(--purple), #c084fc); display:inline-block; }
.nav-links { display:flex; gap:1.8rem; margin:0 auto; }
.nav-links a { font-size:.92rem; font-weight:500; color:var(--muted); }
@media (hover: hover) { .nav-links a:hover { color:var(--ink); } }
.mobile-menu-btn { display:none; background:none; border:none; cursor:pointer; width:40px; height:40px; align-items:center; justify-content:center; }
.burger, .burger::before, .burger::after { content:""; display:block; width:24px; height:2px; background:var(--ink); transition:transform .3s var(--ease), opacity .2s; }
.burger { position:relative; } .burger::before { position:absolute; top:-7px; } .burger::after { position:absolute; top:7px; }
#siteHeader.nav-open .burger { background:transparent; }
#siteHeader.nav-open .burger::before { transform:translateY(7px) rotate(45deg); }
#siteHeader.nav-open .burger::after { transform:translateY(-7px) rotate(-45deg); }

/* Hero */
.hero { max-width:1280px; margin:0 auto; padding:3.5rem 2rem 4rem; display:grid; grid-template-columns:1.1fr 1fr; gap:3rem; align-items:center; }
.hero-text h1 { font-size:clamp(2.4rem,5.2vw,4.4rem); font-weight:900; line-height:1.02; letter-spacing:-.02em; text-transform:uppercase; margin-bottom:1.4rem; }
.hero-text p { color:var(--muted); font-size:1.1rem; max-width:440px; margin-bottom:2rem; }
.hero-cta { display:flex; align-items:center; gap:1.5rem; flex-wrap:wrap; }
.hero-visual { position:relative; min-height:440px; }
.hv-main { position:absolute; top:0; right:0; width:80%; border-radius:1.4rem; overflow:hidden; aspect-ratio:4/3; box-shadow:0 30px 60px rgba(28,23,48,.18); }
.hv-main img, .hv-sub img { width:100%; height:100%; object-fit:cover; }
.hv-sub { position:absolute; bottom:0; left:0; width:46%; border-radius:1.2rem; overflow:hidden; aspect-ratio:1; border:5px solid var(--bg); box-shadow:0 20px 40px rgba(28,23,48,.16); }
.hv-badge { position:absolute; top:1rem; left:0; background:var(--purple); color:#fff; border-radius:1rem; padding:.8rem 1.1rem; box-shadow:0 14px 30px rgba(139,92,246,.4); }
.hv-badge strong { display:block; font-size:1.3rem; font-weight:800; }
.hv-badge span { font-size:.72rem; opacity:.9; }
.hv-chip { position:absolute; bottom:1.5rem; right:0; background:#fff; border-radius:1rem; padding:.7rem 1rem; display:flex; align-items:center; gap:.6rem; box-shadow:0 14px 30px rgba(28,23,48,.14); }
.hv-chip strong { color:var(--purple); }
.hv-chip span { font-size:.78rem; }
.avatars { display:flex; }
.avatars span { width:30px; height:30px; border-radius:50%; background:var(--tint); color:var(--purple-d); border:2px solid #fff; display:flex; align-items:center; justify-content:center; font-size:.62rem; font-weight:700; margin-left:-8px; }
.avatars span:first-child { margin-left:0; }

/* Services */
.services { padding:3rem 2rem; }
.serv-panel { max-width:1280px; margin:0 auto; background:#eceaf3; border-radius:2rem; padding:3rem; }
.serv-head { text-align:center; margin-bottom:2.5rem; }
.serv-head h2 { font-size:clamp(1.8rem,3.5vw,2.6rem); font-weight:800; }
.serv-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.3rem; }
.serv { background:#fff; border-radius:1.2rem; padding:2rem; transition:transform .3s var(--ease), box-shadow .3s; }
@media (hover: hover) { .serv:hover { transform:translateY(-5px); box-shadow:0 18px 40px rgba(28,23,48,.1); } }
.serv-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:.8rem; }
.serv h3 { font-size:1.3rem; font-weight:700; }
.serv-ic { width:44px; height:44px; background:var(--tint); border-radius:.7rem; display:flex; align-items:center; justify-content:center; color:var(--purple); flex:none; }
.serv-ic .ico { width:24px; height:24px; }
.serv p { color:var(--muted); font-size:.95rem; }

/* Why */
.why { max-width:1280px; margin:0 auto; padding:4rem 2rem; }
.why-media { position:relative; border-radius:1.8rem; overflow:hidden; min-height:520px; display:flex; align-items:flex-end; padding:2.5rem; }
.why-media > img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.why-media::after { content:""; position:absolute; inset:0; background:linear-gradient(120deg, rgba(28,23,48,.7), rgba(28,23,48,.2)); }
.pill-float { position:absolute; z-index:2; background:rgba(255,255,255,.95); border-radius:2rem; padding:.5rem 1.1rem; font-size:.82rem; font-weight:600; box-shadow:0 8px 20px rgba(0,0,0,.15); }
.p1 { top:1.5rem; left:1.5rem; } .p2 { top:1.5rem; right:1.5rem; } .p3 { top:6rem; right:4rem; } .p4 { top:4rem; left:3rem; }
.why-card { position:relative; z-index:2; background:#fff; border-radius:1.4rem; padding:2rem; max-width:460px; }
.why-card h3 { font-size:1.5rem; font-weight:800; margin-bottom:.8rem; }
.why-card p { color:var(--muted); margin-bottom:1.3rem; }

/* Pricing */
.pricing { max-width:980px; margin:0 auto; padding:4rem 2rem; }
.pricing h2 { font-size:clamp(1.8rem,3.5vw,2.6rem); font-weight:800; margin-bottom:1.5rem; }
.toggle { display:flex; align-items:center; justify-content:center; gap:1rem; margin-bottom:2.5rem; }
.t-label { font-size:.92rem; font-weight:600; color:var(--muted); }
.t-label.active { color:var(--ink); }
.t-label em { color:var(--purple); font-style:normal; font-size:.78rem; }
.switch { width:52px; height:28px; border-radius:2rem; border:none; background:var(--purple); position:relative; cursor:pointer; padding:0; }
.knob { position:absolute; top:3px; left:3px; width:22px; height:22px; border-radius:50%; background:#fff; transition:transform .25s var(--ease); }
.switch[aria-checked="true"] .knob { transform:translateX(24px); }
.price-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }
.price-card { background:#fff; border-radius:1.4rem; padding:2.2rem; position:relative; border:1px solid #e7e4ef; }
.price-card.dark { background:var(--dark); color:#fff; border-color:transparent; }
.badge { position:absolute; top:1.5rem; right:1.5rem; background:var(--purple); color:#fff; font-size:.7rem; font-weight:700; padding:.25rem .8rem; border-radius:2rem; }
.price-card h3 { font-size:1.3rem; font-weight:700; margin-bottom:.6rem; }
.amount { font-size:2.6rem; font-weight:800; margin-bottom:1.4rem; }
.amount .per { font-size:.85rem; font-weight:500; color:var(--muted); }
.price-card.dark .amount .per { color:rgba(255,255,255,.6); }
.price-card ul { display:flex; flex-direction:column; gap:.7rem; margin-bottom:1.8rem; }
.price-card li { font-size:.92rem; padding-left:1.4rem; position:relative; }
.price-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.25rem;
  width: 1.2em;
  height: 1.2em;
  background-image: url('data:image/svg+xml;utf8,<svg viewBox="0 0 24 24" fill="none" stroke="%238b5cf6" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><polyline points="20 6 9 17 4 12"/></svg>');
  background-size: contain;
  background-repeat: no-repeat;
}
.price-card.dark li::before {
  background-image: url('data:image/svg+xml;utf8,<svg viewBox="0 0 24 24" fill="none" stroke="%23c084fc" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><polyline points="20 6 9 17 4 12"/></svg>');
}

/* FAQ */
.faq { max-width:760px; margin:0 auto; padding:4rem 2rem; }
.faq h2 { font-size:clamp(1.8rem,3.5vw,2.4rem); font-weight:800; margin-bottom:2rem; }
.faq-list { display:flex; flex-direction:column; gap:.8rem; }
.faq details { background:#fff; border-radius:1rem; padding:1.2rem 1.5rem; border:1px solid #e7e4ef; }
.faq summary { font-weight:600; cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; }
.faq summary::after { content:"+"; color:var(--purple); font-size:1.4rem; }
.faq details[open] summary::after { content:"–"; }
.faq details p { color:var(--muted); margin-top:.8rem; font-size:.95rem; }

/* CTA */
.cta { padding:2rem 2rem 5rem; }
.cta-inner { max-width:1280px; margin:0 auto; background:var(--dark); color:#fff; border-radius:1.8rem; padding:4.5rem 3rem; text-align:center; }
.cta-inner h2 { font-size:clamp(2rem,4.5vw,3.4rem); font-weight:800; margin-bottom:.8rem; }
.cta-inner p { color:rgba(255,255,255,.75); margin-bottom:2rem; }
.cta-form { display:flex; gap:.7rem; max-width:460px; margin:0 auto; flex-wrap:wrap; }
.cta-form input { flex:1; min-width:200px; padding:.9rem 1.2rem; border-radius:2rem; border:1px solid rgba(255,255,255,.25); background:rgba(255,255,255,.08); color:#fff; font-family:var(--body); }
.cta-form input::placeholder { color:rgba(255,255,255,.6); }
.cta-form input:focus { outline:none; border-color:var(--purple); }
.form-note { margin-top:1rem; color:#c084fc; }

/* Footer */
.site-footer { padding:3rem 2rem; }
.foot-inner { max-width:1280px; margin:0 auto; display:flex; justify-content:space-between; align-items:center; gap:1.5rem; flex-wrap:wrap; }
.foot-inner .brand { font-size:1.3rem; }
.foot-inner > div:first-child p { color:var(--muted); font-size:.85rem; margin-top:.4rem; }
.foot-contact { display:flex; flex-direction:column; gap:.3rem; font-weight:600; }
@media (hover: hover) { .foot-contact a:hover { color:var(--purple); } }
.foot-legal { display:flex; gap:1.2rem; align-items:center; font-size:.85rem; color:var(--muted); flex-wrap:wrap; }
@media (hover: hover) { .foot-legal a:hover { color:var(--ink); } }

@media (max-width:900px){
  .hero { grid-template-columns:1fr; }
  .hero-visual { min-height:360px; margin-top:1rem; }
  .serv-grid, .price-grid { grid-template-columns:1fr; }
  .serv-panel { padding:2rem 1.5rem; }
}
@media (max-width:680px){
  /* Hero-Visual: absolute Collage -> statischer, gestapelter Block (kein Overlap/Overflow) */
  .hero-visual { position:static; min-height:0; display:flex; flex-direction:column; gap:.9rem; margin-top:1.5rem; }
  .hv-main, .hv-sub, .hv-badge, .hv-chip { position:static; top:auto; right:auto; bottom:auto; left:auto; width:100%; }
  .hv-main { order:1; aspect-ratio:16/10; }
  .hv-sub { order:2; aspect-ratio:16/9; border-width:0; }
  .hv-badge { order:3; width:auto; align-self:flex-start; }
  .hv-chip { order:4; width:auto; align-self:flex-start; }
}
@media (max-width:600px){
  .head-inner { gap:1rem; }
  .nav-links { display:none; position:absolute; top:100%; left:0; width:100%; flex-direction:column; gap:0; background:var(--bg); padding:.5rem 2rem 1rem; margin:0; }
  #siteHeader.nav-open .nav-links { display:flex; }
  .nav-links a { padding:.8rem 0; border-bottom:1px solid #e2def0; }
  .head-inner > .btn-purple { display:none; }
  .mobile-menu-btn { display:flex; }
  .why-media { min-height:600px; }
  .p3, .p4 { display:none; }
  .cta-inner { padding:2.5rem 1.5rem; }
  .foot-inner { flex-direction:column; align-items:flex-start; }
}
@media (max-width:480px){
  .serv-grid, .price-grid { grid-template-columns:1fr; }
  .hero { padding:2.5rem 1.25rem 3rem; }
  .why { padding:2.5rem 1.25rem; }
  .why-media { min-height:480px; padding:1.5rem; }
  .pricing, .faq { padding:2.5rem 1.25rem; }
  .services { padding:2rem 1.25rem; }
  .cta { padding:1.5rem 1.25rem 3rem; }
  .cta-inner { padding:2rem 1.25rem; }
  .cta-form { flex-direction:column; }
  .cta-form input { min-width:0; flex:1 1 auto; }
  .cta-form .btn { width:100%; }
}
