/* ============ STARTPILOT MARKETING – Shared Styles ============ */
:root{
  --bg:#050b1a; --bg2:#100b1c; --card:#0c1a35; --line:#16294d;
  --blue:#2563eb; --blue2:#3b82f6; --cyan:#38bdf8; --glow:#60a5fa;
  --txt:#f4f7ff; --muted:#a8b6d4; --muted2:#6b7a9c;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--txt);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;line-height:1.65;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
section{padding:96px 0;position:relative}
h1,h2,h3{line-height:1.15;font-weight:800}
h2{font-size:clamp(1.8rem,3.6vw,2.7rem);margin-bottom:16px}
.center{text-align:center}
.sub{color:var(--muted);max-width:660px;margin:0 auto 52px}
.eyebrow{display:inline-block;font-size:.78rem;letter-spacing:.3em;text-transform:uppercase;color:var(--cyan);font-weight:700;margin-bottom:14px}
.grad{background:linear-gradient(100deg,var(--blue2),var(--cyan) 50%,#d8b4fe);background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradmove 6s linear infinite}
@keyframes gradmove{to{background-position:200% center}}

/* ---------- Nav ---------- */
nav{position:fixed;inset:0 0 auto 0;z-index:100;background:rgba(6,4,12,.7);backdrop-filter:blur(16px);border-bottom:1px solid rgba(139,92,246,.15)}
.nav-in{max-width:1180px;margin:0 auto;padding:10px 24px;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;font-size:1.05rem}
.brand img{width:44px;height:44px;object-fit:contain;filter:drop-shadow(0 0 10px rgba(139,92,246,.55))}
.brand b{color:var(--txt)}.brand span{color:var(--cyan)}
.menu{display:flex;gap:24px;align-items:center;font-size:.92rem}
.menu a{color:var(--muted);transition:color .2s;position:relative;padding:4px 0}
.menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:linear-gradient(90deg,var(--blue2),var(--cyan));transition:width .25s}
.menu a:hover,.menu a.aktiv{color:var(--txt)}
.menu a:hover::after,.menu a.aktiv::after{width:100%}
.menu .cta{color:#fff;background:linear-gradient(120deg,var(--blue),var(--cyan));padding:10px 20px;border-radius:10px;font-weight:700;box-shadow:0 0 26px rgba(192,132,252,.4);transition:transform .2s,box-shadow .2s}
.menu .cta:hover{transform:translateY(-2px);box-shadow:0 0 40px rgba(192,132,252,.7)}
.menu .cta::after{display:none}
.burger{display:none;background:none;border:1px solid var(--line);color:var(--txt);font-size:1.4rem;border-radius:8px;padding:2px 12px;cursor:pointer}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 30px;border-radius:12px;font-weight:700;font-size:.98rem;transition:transform .2s,box-shadow .2s;cursor:pointer;border:none}
.btn-blue{background:linear-gradient(120deg,var(--blue),var(--cyan));color:#fff;box-shadow:0 10px 34px rgba(124,58,237,.45)}
.btn-blue:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 16px 46px rgba(192,132,252,.6)}
.btn-ghost{border:1px solid rgba(168,85,247,.5);color:var(--glow);background:transparent}
.btn-ghost:hover{background:rgba(139,92,246,.1);transform:translateY(-3px)}

/* ---------- Reveal: seitliches Einfliegen (links/rechts) ---------- */
.reveal{opacity:0;transform:perspective(900px) translateY(48px) rotateX(10deg);transform-origin:50% 100%;transition:opacity .9s ease,transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.from-l{transform:perspective(900px) translateX(-90px) rotateY(10deg);transform-origin:0 50%}
.reveal.from-r{transform:perspective(900px) translateX(90px) rotateY(-10deg);transform-origin:100% 50%}
.reveal.vis{opacity:1;transform:none}
.d1{transition-delay:.12s}.d2{transition-delay:.24s}.d3{transition-delay:.36s}

/* ---------- Cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.tilt-wrap{perspective:900px}
.card{background:linear-gradient(160deg,#1c1230,#100b1c);border:1px solid var(--line);border-radius:18px;padding:36px 30px;height:100%;transform-style:preserve-3d;transition:transform .18s ease-out,border-color .3s,box-shadow .3s;position:relative;overflow:hidden}
.card:hover{border-color:rgba(192,132,252,.6);box-shadow:0 26px 60px rgba(8,4,16,.8),0 0 44px rgba(124,58,237,.15)}
.card .glare{position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .3s;background:radial-gradient(430px circle at var(--gx,50%) var(--gy,50%),rgba(168,85,247,.15),transparent 55%)}
.card:hover .glare{opacity:1}
.card .ico{width:58px;height:58px;border-radius:15px;display:flex;align-items:center;justify-content:center;background:rgba(124,58,237,.15);border:1px solid rgba(139,92,246,.4);margin-bottom:22px;transform:translateZ(30px)}
.card .ico svg{width:28px;height:28px;stroke:var(--cyan);fill:none;stroke-width:1.7}
.card h3{font-size:1.22rem;margin-bottom:12px;transform:translateZ(24px)}
.card p{color:var(--muted);font-size:.95rem;transform:translateZ(16px)}
.card ul{list-style:none;margin-top:16px;transform:translateZ(16px)}
.card li{padding:6px 0 6px 28px;position:relative;color:var(--muted);font-size:.92rem}
.card li::before{content:"✦";position:absolute;left:4px;color:var(--cyan)}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;text-align:center}
.stat{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:30px 16px;transition:transform .3s,border-color .3s}
.stat:hover{transform:translateY(-6px);border-color:rgba(192,132,252,.5)}
.stat b{display:block;font-size:2.1rem;font-weight:800;background:linear-gradient(100deg,var(--blue2),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat span{color:var(--muted);font-size:.88rem}

/* ---------- Preis-Karten ---------- */
.pgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:26px}
.pcard{background:linear-gradient(160deg,#1c1230,#100b1c);border:1px solid var(--line);border-radius:18px;padding:34px 30px;position:relative;transition:transform .3s,border-color .3s,box-shadow .3s;display:flex;flex-direction:column}
.pcard:hover{transform:translateY(-8px);border-color:rgba(192,132,252,.6);box-shadow:0 30px 60px rgba(8,4,16,.8)}
.pcard.featured{border-color:var(--cyan);box-shadow:0 0 50px rgba(192,132,252,.18)}
.pcard .badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:linear-gradient(120deg,var(--blue),var(--cyan));padding:5px 18px;border-radius:99px;font-size:.75rem;font-weight:800;letter-spacing:.08em;white-space:nowrap}
.pcard h3{font-size:1.15rem;margin-bottom:6px}
.pcard .preis{font-size:2.3rem;font-weight:800;margin:12px 0 2px}
.pcard .preis small{font-size:.95rem;color:var(--muted);font-weight:500}
.pcard .hinweis{color:var(--muted2);font-size:.8rem;margin-bottom:16px}
.pcard ul{list-style:none;margin:14px 0 24px;flex:1}
.pcard li{padding:7px 0 7px 30px;position:relative;color:var(--muted);font-size:.93rem;border-bottom:1px dashed rgba(22,41,77,.8)}
.pcard li::before{content:"✓";position:absolute;left:4px;color:var(--cyan);font-weight:800}

/* ---------- Team ---------- */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.member{background:var(--card);border:1px solid var(--line);border-radius:18px;overflow:hidden;text-align:center;transition:transform .3s,border-color .3s}
.member:hover{transform:translateY(-8px);border-color:rgba(192,132,252,.5)}
.member img{width:100%;aspect-ratio:1/1;object-fit:cover;filter:saturate(1.05)}
.member .m-in{padding:22px}
.member h3{font-size:1.15rem}
.member .rolle{color:var(--cyan);font-size:.85rem;font-weight:700;margin:4px 0 10px}
.member p{color:var(--muted);font-size:.9rem}

/* ---------- Testimonials ---------- */
.quotes{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:26px}
.quote{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:30px;transition:transform .3s,border-color .3s}
.quote:hover{transform:translateY(-6px);border-color:rgba(192,132,252,.5)}
.quote .stars{color:#facc15;letter-spacing:3px;margin-bottom:12px}
.quote p{color:var(--muted);font-size:.93rem;font-style:italic}
.quote .wer{margin-top:16px;font-weight:700;color:var(--txt);display:flex;align-items:center;gap:10px}
.quote .wer img{width:42px;height:42px;border-radius:50%;object-fit:cover;background:#fff}
.quote .wer small{display:block;color:var(--muted2);font-weight:500}

/* ---------- FAQ ---------- */
.faq-item{background:var(--card);border:1px solid var(--line);border-radius:14px;margin-bottom:14px;overflow:hidden}
.faq-item button{width:100%;background:none;border:none;color:var(--txt);font-size:1.02rem;font-weight:700;text-align:left;padding:20px 54px 20px 24px;cursor:pointer;position:relative;font-family:inherit}
.faq-item button::after{content:"+";position:absolute;right:22px;top:50%;transform:translateY(-50%);font-size:1.5rem;color:var(--cyan);transition:transform .3s}
.faq-item.open button::after{transform:translateY(-50%) rotate(45deg)}
.faq-item .antwort{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item .antwort p{padding:0 24px 22px;color:var(--muted);font-size:.95rem}

/* ---------- Kontakt ---------- */
.kontakt-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start}
.k-item{display:flex;gap:16px;align-items:flex-start;margin-bottom:20px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px 20px;transition:border-color .3s,transform .3s}
.k-item:hover{border-color:rgba(192,132,252,.5);transform:translateX(6px)}
.k-item .ico{width:44px;height:44px;flex:0 0 44px;border-radius:12px;background:rgba(124,58,237,.15);border:1px solid rgba(139,92,246,.4);display:flex;align-items:center;justify-content:center}
.k-item svg{width:20px;height:20px;stroke:var(--cyan);fill:none;stroke-width:1.8}
.k-item b{display:block}
.k-item span,.k-item a.link{color:var(--muted);font-size:.93rem}
.k-item a.link:hover{color:var(--cyan)}
.form{background:linear-gradient(160deg,#1c1230,#100b1c);border:1px solid var(--line);border-radius:18px;padding:34px}
.form label{display:block;font-size:.85rem;font-weight:700;margin:16px 0 6px;color:var(--muted)}
.form input,.form textarea{width:100%;background:#060f22;border:1px solid var(--line);border-radius:10px;padding:13px 16px;color:var(--txt);font-family:inherit;font-size:.95rem;transition:border-color .2s,box-shadow .2s}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--blue2);box-shadow:0 0 0 3px rgba(124,58,237,.25)}
.form .check{display:flex;gap:10px;align-items:flex-start;margin:18px 0;font-size:.8rem;color:var(--muted2)}
.form .check input{width:auto;margin-top:3px}

/* ---------- Footer ---------- */
footer{border-top:1px solid var(--line);padding:52px 0 30px;background:#05030a}
.f-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:36px;margin-bottom:36px}
footer h4{font-size:.82rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);margin-bottom:16px}
footer a,footer p{color:var(--muted);font-size:.92rem}
footer a{display:block;padding:4px 0;transition:color .2s}
footer a:hover{color:var(--cyan)}
.f-bottom{border-top:1px solid #0a1428;padding-top:22px;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;color:var(--muted2);font-size:.82rem}

/* ---------- Seiten-Hero (Unterseiten) ---------- */
.page-hero{padding:170px 0 70px;background:radial-gradient(800px 400px at 70% 10%,rgba(124,58,237,.18),transparent 60%),radial-gradient(600px 300px at 15% 90%,rgba(192,132,252,.08),transparent 60%)}
.page-hero h1{font-size:clamp(2.1rem,4.5vw,3.3rem);margin-bottom:16px}
.page-hero p{color:var(--muted);max-width:680px;font-size:1.05rem}

/* ---------- CTA-Band ---------- */
.cta-band{background:linear-gradient(120deg,rgba(124,58,237,.25),rgba(192,132,252,.12));border:1px solid rgba(139,92,246,.35);border-radius:22px;padding:56px 40px;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(147,197,253,.12) 50%,transparent 70%);transform:translateX(-120%);animation:ctasweep 5s ease-in-out infinite}
@keyframes ctasweep{60%,100%{transform:translateX(120%)}}

/* ---------- Sonstiges ---------- */
.logos-band{display:flex;gap:40px;align-items:center;justify-content:center;flex-wrap:wrap;opacity:.95}
.logos-band img{height:64px;width:auto;border-radius:12px;background:#fff;padding:6px;transition:transform .3s}
.logos-band img:hover{transform:scale(1.12) rotate(-2deg)}
.hinweis-box{background:rgba(250,204,21,.08);border:1px solid rgba(250,204,21,.4);border-radius:12px;padding:16px 20px;color:#fde68a;font-size:.9rem;margin:24px 0}
::selection{background:rgba(192,132,252,.4)}

/* ---------- Split-Layout: Desktop nebeneinander, Mobil Titel→Bild→Text ---------- */
.split-sec{display:grid;grid-template-columns:1.08fr 1fr;grid-template-areas:"media kopf" "media text";column-gap:56px;row-gap:8px;align-items:center;margin-bottom:96px}
.split-sec:last-child{margin-bottom:0}
.split-sec.flip{grid-template-columns:1fr 1.08fr;grid-template-areas:"kopf media" "text media"}
.split-sec .s-kopf{grid-area:kopf;align-self:end}
.split-sec .s-kopf h2{margin-bottom:10px}
.split-sec .s-media{grid-area:media}
.split-sec .s-text{grid-area:text;align-self:start;color:var(--muted)}
.split-sec .s-text p{margin-bottom:14px}
.split-sec .s-text ul{list-style:none;margin:4px 0 14px}
.split-sec .s-text li{padding:7px 0 7px 30px;position:relative}
.split-sec .s-text li::before{content:"✦";position:absolute;left:4px;color:var(--cyan)}
.split-sec .s-media img,.split-sec .s-media video{width:100%;border-radius:20px;border:1px solid var(--line);box-shadow:0 24px 60px rgba(8,4,16,.7);display:block}
.split-sec .s-media .duo{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.media-cap{color:var(--muted2);font-size:.85rem;text-align:center;margin-top:12px}
@media(max-width:900px){
  .split-sec,.split-sec.flip{grid-template-columns:1fr;grid-template-areas:"kopf" "media" "text";row-gap:20px;margin-bottom:70px}
  .split-sec .s-kopf{align-self:auto}
}

/* ---------- Vorher/Nachher-Slider ---------- */
.ba{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--line);user-select:none;touch-action:none;cursor:ew-resize;box-shadow:0 24px 60px rgba(8,4,16,.7)}
.ba img{width:100%;display:block;border:none!important;border-radius:0!important;box-shadow:none!important}
.ba .after{position:absolute;inset:0;clip-path:inset(0 0 0 50%)}
.ba .after img{height:100%;object-fit:cover}
.ba .handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:linear-gradient(var(--cyan),var(--blue));transform:translateX(-50%);pointer-events:none}
.ba .handle::after{content:"⟷";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%;background:linear-gradient(120deg,var(--blue),var(--cyan));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem;box-shadow:0 6px 24px rgba(0,0,0,.5)}
.ba .tag{position:absolute;top:12px;padding:4px 12px;border-radius:6px;font-size:.72rem;font-weight:800;letter-spacing:.1em;background:rgba(6,4,12,.78);pointer-events:none;backdrop-filter:blur(4px)}
.ba .tag.l{left:12px;color:#ccc}
.ba .tag.r{right:12px;color:var(--cyan);border:1px solid rgba(192,132,252,.4)}

/* ---------- Portfolio-Grid ---------- */
.folio{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.folio img{width:100%;border-radius:16px;border:1px solid var(--line);transition:transform .35s,box-shadow .35s,border-color .35s;display:block}
.folio img:hover{transform:scale(1.03);border-color:rgba(192,132,252,.6);box-shadow:0 24px 60px rgba(8,4,16,.8)}
@media(max-width:700px){.folio{grid-template-columns:1fr}}

/* ---------- Responsive ---------- */
@media(max-width:960px){
  .cards,.team,.stats{grid-template-columns:1fr 1fr}
  .kontakt-grid,.f-grid{grid-template-columns:1fr}
  .menu{display:none;position:absolute;top:100%;left:0;right:0;background:rgba(6,4,12,.98);flex-direction:column;padding:24px;gap:18px;border-bottom:1px solid var(--line)}
  .menu.open{display:flex}
  .burger{display:block}
}
@media(max-width:640px){.cards,.team,.stats{grid-template-columns:1fr}section{padding:70px 0}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}
