/* ============================================
   Clever Ranken – style.css
   Premium SEO: #0A0F1E Deep Navy × #00CFFF Cyan × #FF2D7B Pink
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700;800&family=Inter:wght@300;400;500;600;700&display=swap');

:root {
  --void: #0A0F1E;
  --deep: #0d1426;
  --surface: #111827;
  --surface-2: #1a2235;
  --surface-3: #1f2d47;

  --cyan: #00CFFF;
  --cyan-light: #33daff;
  --cyan-pale: #99edff;
  --cyan-80: rgba(0,207,255,0.8);
  --cyan-40: rgba(0,207,255,0.4);
  --cyan-20: rgba(0,207,255,0.2);
  --cyan-10: rgba(0,207,255,0.1);
  --cyan-05: rgba(0,207,255,0.05);

  --pink: #FF2D7B;
  --pink-light: #ff5fa0;
  --pink-80: rgba(255,45,123,0.8);
  --pink-20: rgba(255,45,123,0.2);
  --pink-10: rgba(255,45,123,0.1);

  --white: #ffffff;
  --text: #f0f4f8;
  --white-90: rgba(240,244,248,0.9);
  --white-70: rgba(240,244,248,0.7);
  --white-50: rgba(240,244,248,0.5);
  --white-30: rgba(240,244,248,0.3);
  --white-10: rgba(240,244,248,0.1);
  --white-06: rgba(240,244,248,0.06);
  --white-03: rgba(240,244,248,0.03);

  --grad-main: linear-gradient(135deg, #00CFFF 0%, #FF2D7B 100%);
  --grad-cyan: linear-gradient(135deg, #00CFFF 0%, #33daff 100%);
  --grad-text: linear-gradient(90deg, #00CFFF, #a78bfa, #FF2D7B);
  --grad-card: linear-gradient(145deg, rgba(0,207,255,0.06) 0%, rgba(255,45,123,0.03) 100%);
  --grad-hero: linear-gradient(135deg, rgba(0,207,255,0.12) 0%, rgba(255,45,123,0.06) 100%);

  --glow-cyan: 0 0 28px rgba(0,207,255,0.55), 0 0 56px rgba(0,207,255,0.2);
  --glow-pink: 0 0 28px rgba(255,45,123,0.55), 0 0 56px rgba(255,45,123,0.2);
  --glow-card: 0 8px 40px rgba(0,207,255,0.1), 0 2px 8px rgba(0,0,0,0.5);

  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 18px;
  --radius-xl: 28px;
  --t: 0.28s cubic-bezier(0.4, 0, 0.2, 1);
  --t-slow: 0.55s cubic-bezier(0.16, 1, 0.3, 1);

  --font-display: 'Space Grotesk', sans-serif;
  --font-ui: 'Space Grotesk', sans-serif;
  --font-body: 'Inter', sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-body);color:var(--text);background:var(--void);overflow-x:hidden;line-height:1.7;cursor:none;}

::-webkit-scrollbar{width:3px;}
::-webkit-scrollbar-track{background:var(--void);}
::-webkit-scrollbar-thumb{background:var(--grad-main);border-radius:2px;}

/* CURSOR */
.cursor-dot{width:7px;height:7px;background:var(--cyan);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:2147483647;will-change:transform;box-shadow:0 0 10px var(--cyan),0 0 20px rgba(0,207,255,0.4);}
.cursor-ring{width:30px;height:30px;border:1.5px solid rgba(0,207,255,0.5);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:2147483646;will-change:transform;transition:width 0.22s ease,height 0.22s ease;}

/* MESH BLOBS */
.mesh-bg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;}
.mesh-blob{position:absolute;border-radius:50%;filter:blur(90px);opacity:0.16;animation:blobFloat 12s ease-in-out infinite;}
.mesh-blob:nth-child(1){width:600px;height:600px;background:radial-gradient(circle,#00CFFF,transparent 65%);top:-150px;left:-150px;animation-duration:15s;}
.mesh-blob:nth-child(2){width:440px;height:440px;background:radial-gradient(circle,#FF2D7B,transparent 65%);top:35%;right:-100px;animation-delay:-5s;animation-duration:11s;}
.mesh-blob:nth-child(3){width:320px;height:320px;background:radial-gradient(circle,#a78bfa,transparent 65%);bottom:-80px;left:32%;animation-delay:-9s;animation-duration:17s;}
.mesh-blob:nth-child(4){width:220px;height:220px;background:radial-gradient(circle,#33daff,transparent 65%);top:62%;left:6%;animation-delay:-3s;animation-duration:13s;}

@keyframes blobFloat{0%,100%{transform:translate(0,0) scale(1);}33%{transform:translate(40px,-30px) scale(1.08);}66%{transform:translate(-20px,20px) scale(0.94);}}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 48px;height:72px;display:flex;align-items:center;justify-content:space-between;}
.nav-inner-bg{position:absolute;inset:0;background:rgba(10,15,30,0);backdrop-filter:blur(0px);transition:all var(--t);border-bottom:1px solid transparent;z-index:-1;}
.nav.scrolled .nav-inner-bg{background:rgba(10,15,30,0.94);backdrop-filter:blur(20px);border-bottom-color:rgba(0,207,255,0.12);}

.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;}
.nav-logo img{height:36px;width:auto;}
.nav-logo-text{font-family:var(--font-display);font-size:1.2rem;font-weight:800;letter-spacing:-0.02em;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}

.nav-links{display:flex;align-items:center;gap:28px;list-style:none;}
.nav-links a{text-decoration:none;font-family:var(--font-ui);font-size:0.8rem;font-weight:500;color:var(--white-70);letter-spacing:0.02em;transition:color var(--t);position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--grad-main);transition:width var(--t);}
.nav-links a:hover{color:var(--cyan);}
.nav-links a:hover::after{width:100%;}

.nav-cta{background:var(--grad-main)!important;color:var(--void)!important;padding:9px 22px;border-radius:var(--radius-sm);font-weight:700!important;font-family:var(--font-ui)!important;box-shadow:0 0 20px rgba(0,207,255,0.25)!important;}
.nav-cta::after{display:none!important;}
.nav-cta:hover{color:var(--void)!important;transform:translateY(-2px)!important;box-shadow:var(--glow-cyan)!important;}

.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none;}
.burger span{display:block;width:24px;height:1.5px;background:var(--cyan);border-radius:1px;transition:all var(--t);}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:140px 48px 100px;}

.hero::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(0,207,255,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(0,207,255,0.04) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 20%,transparent 100%);pointer-events:none;z-index:1;}

.hero-bg-img{position:absolute;inset:0;background-image:url('/hero-bg.webp');background-size:cover;background-position:center;opacity:0.05;z-index:0;pointer-events:none;filter:saturate(0) brightness(1.5);}

.hero-orb{position:absolute;width:780px;height:780px;border-radius:50%;background:radial-gradient(circle,rgba(0,207,255,0.07) 0%,rgba(255,45,123,0.04) 40%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-58%);pointer-events:none;z-index:1;animation:orbPulse 8s ease-in-out infinite;}

@keyframes orbPulse{0%,100%{transform:translate(-50%,-58%) scale(1);opacity:1;}50%{transform:translate(-50%,-58%) scale(1.1);opacity:0.7;}}

.hero-content{position:relative;z-index:2;max-width:1100px;margin:0 auto;text-align:center;}

.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;background:var(--cyan-10);border:1px solid rgba(0,207,255,0.22);color:var(--cyan);font-family:var(--font-ui);font-size:0.72rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;padding:8px 20px;border-radius:999px;margin-bottom:32px;animation:fadeInDown 0.8s ease both;}

.hero-eyebrow-dot{width:6px;height:6px;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px var(--cyan);animation:pulse 1.8s ease-in-out infinite;flex-shrink:0;}

@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.3;transform:scale(0.5);}}

.hero h1{font-family:var(--font-display);font-size:clamp(3rem,8.5vw,8.5rem);font-weight:800;line-height:0.9;letter-spacing:-0.03em;margin-bottom:32px;animation:fadeInUp 0.9s ease 0.15s both;}

.hero h1 .line-solid{display:block;color:var(--text);}
.hero h1 .line-grad{display:block;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hero h1 .line-outline{display:block;-webkit-text-stroke:1.5px rgba(0,207,255,0.3);color:transparent;}

.hero-sub{font-size:clamp(0.95rem,1.5vw,1.15rem);color:var(--white-50);max-width:640px;margin:0 auto 48px;animation:fadeInUp 0.9s ease 0.3s both;line-height:1.85;}

.hero-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;animation:fadeInUp 0.9s ease 0.45s both;}

.hero-stats{display:flex;gap:52px;justify-content:center;margin-top:80px;padding-top:48px;border-top:1px solid var(--cyan-10);animation:fadeInUp 0.9s ease 0.6s both;flex-wrap:wrap;}

.hero-stat{text-align:center;}
.hero-stat-num{font-family:var(--font-display);font-size:3rem;font-weight:800;letter-spacing:-0.025em;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;}
.hero-stat-label{font-family:var(--font-ui);font-size:0.72rem;color:var(--white-40);margin-top:6px;letter-spacing:0.06em;}

/* BUTTONS */
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--grad-main);color:var(--void);text-decoration:none;padding:15px 34px;border-radius:var(--radius-sm);font-family:var(--font-ui);font-weight:700;font-size:0.88rem;letter-spacing:0.02em;transition:all var(--t);box-shadow:0 4px 24px rgba(0,207,255,0.3);border:none;cursor:none;}
.btn-primary:hover{transform:translateY(-3px);box-shadow:var(--glow-cyan);}

.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--cyan);text-decoration:none;padding:14px 32px;border-radius:var(--radius-sm);font-family:var(--font-ui);font-weight:600;font-size:0.88rem;border:1.5px solid rgba(0,207,255,0.4);transition:all var(--t);cursor:none;}
.btn-ghost:hover{background:var(--cyan-10);border-color:var(--cyan);transform:translateY(-3px);box-shadow:var(--glow-cyan);}

.btn-outline{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--cyan-80);text-decoration:none;padding:13px 28px;border-radius:var(--radius-sm);font-family:var(--font-ui);font-weight:600;font-size:0.85rem;border:1.5px solid rgba(0,207,255,0.25);transition:all var(--t);cursor:none;}
.btn-outline:hover{border-color:var(--cyan);color:var(--white);background:var(--cyan-10);transform:translateY(-2px);}

.btn-pink{display:inline-flex;align-items:center;gap:8px;background:var(--pink);color:var(--white);text-decoration:none;padding:15px 34px;border-radius:var(--radius-sm);font-family:var(--font-ui);font-weight:700;font-size:0.88rem;transition:all var(--t);box-shadow:0 4px 24px rgba(255,45,123,0.35);border:none;cursor:none;}
.btn-pink:hover{transform:translateY(-3px);box-shadow:var(--glow-pink);background:var(--pink-light);}

/* MARQUEE */
.marquee-section{overflow:hidden;padding:18px 0;border-top:1px solid rgba(0,207,255,0.08);border-bottom:1px solid rgba(0,207,255,0.08);background:rgba(0,207,255,0.02);}
.marquee-track{display:flex;gap:48px;width:max-content;animation:marqueeLeft 26s linear infinite;}
.marquee-item{display:flex;align-items:center;gap:14px;white-space:nowrap;font-family:var(--font-display);font-size:0.88rem;font-weight:700;letter-spacing:0.06em;color:var(--white-30);flex-shrink:0;}
.marquee-item span{color:var(--cyan);}
.marquee-item .pink{color:var(--pink);}
.marquee-dot{width:4px;height:4px;border-radius:50%;background:var(--grad-main);flex-shrink:0;}

@keyframes marqueeLeft{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* SECTIONS */
.section-inner{max-width:1200px;margin:0 auto;padding:0 48px;}

.section-tag{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-ui);font-size:0.7rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--cyan);margin-bottom:16px;}
.section-tag::before{content:'◆';font-size:0.45rem;color:var(--pink);}

.section-title{font-family:var(--font-display);font-size:clamp(2.2rem,4.5vw,3.8rem);font-weight:800;letter-spacing:-0.025em;line-height:1.05;margin-bottom:20px;color:var(--text);}
.section-title .cyan{color:var(--cyan);}
.section-title .pink{color:var(--pink);}
.section-title .grad{background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}

.section-sub{color:var(--white-50);font-size:1rem;max-width:600px;line-height:1.85;}

/* SERVICE / LEISTUNGS CARDS */
.services{padding:120px 0;}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:72px;background:rgba(0,207,255,0.07);border:1px solid rgba(0,207,255,0.1);border-radius:var(--radius-lg);overflow:hidden;}

.service-card{background:var(--void);padding:40px 30px;position:relative;overflow:hidden;transition:all var(--t-slow);text-decoration:none;color:inherit;display:block;}
.service-card::before{content:'';position:absolute;inset:0;background:var(--grad-card);opacity:0;transition:opacity var(--t-slow);}
.service-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad-main);transform:scaleX(0);transition:transform var(--t-slow);}
.service-card:hover::before{opacity:1;}
.service-card:hover::after{transform:scaleX(1);}
.service-card:hover{transform:translateY(-4px);}

.service-num{font-family:var(--font-ui);font-size:0.65rem;font-weight:600;letter-spacing:0.2em;color:rgba(0,207,255,0.35);margin-bottom:18px;display:block;}
.service-card-icon{width:48px;height:48px;background:var(--cyan-05);border:1px solid rgba(0,207,255,0.15);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:18px;font-size:1.3rem;transition:all var(--t);}
.service-card:hover .service-card-icon{background:var(--cyan-10);border-color:rgba(0,207,255,0.4);box-shadow:0 0 16px rgba(0,207,255,0.2);}
.service-card h3{font-family:var(--font-ui);font-size:1rem;font-weight:700;color:var(--text);margin-bottom:10px;position:relative;}
.service-card p{color:var(--white-50);font-size:0.86rem;line-height:1.75;position:relative;margin-bottom:20px;}
.service-arrow{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-ui);font-size:0.7rem;font-weight:700;letter-spacing:0.08em;color:var(--cyan);transition:gap var(--t);}
.service-card:hover .service-arrow{gap:12px;}

/* PRICING */
.pricing{padding:120px 0;}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:72px;}

.price-card{background:var(--surface);border:1px solid var(--white-06);border-radius:var(--radius-lg);padding:44px 36px;text-align:center;position:relative;overflow:hidden;transition:all var(--t-slow);display:flex;flex-direction:column;}
.price-card:not(.featured):hover{border-color:rgba(0,207,255,0.25);transform:translateY(-6px);box-shadow:var(--glow-card);}
.price-card.featured{background:var(--void);border:1px solid rgba(0,207,255,0.4);box-shadow:0 0 40px rgba(0,207,255,0.08);transform:scale(1.04);}
.price-card.featured::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad-main);box-shadow:0 0 12px var(--cyan);}

.price-badge{display:inline-block;background:var(--grad-main);color:var(--void);font-family:var(--font-ui);font-size:0.58rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;padding:4px 14px;border-radius:999px;margin-bottom:20px;}
.price-title{font-family:var(--font-ui);font-size:1rem;font-weight:600;color:var(--white-70);margin-bottom:8px;}
.price-sub{font-size:0.78rem;color:var(--white-40);margin-bottom:16px;font-family:var(--font-ui);}
.price-amount{font-family:var(--font-display);font-size:4rem;font-weight:800;letter-spacing:-0.03em;line-height:1;margin:8px 0 4px;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.price-netto{font-size:0.7rem;color:var(--white-40);margin-bottom:28px;font-family:var(--font-ui);}
.price-features{list-style:none;text-align:left;margin-bottom:32px;flex:1;}
.price-features li{padding:8px 0;font-size:0.86rem;color:var(--white-80);display:flex;align-items:flex-start;gap:10px;border-bottom:1px solid var(--white-06);}
.price-features li::before{content:'◆';color:var(--cyan);font-size:0.4rem;flex-shrink:0;margin-top:7px;}
.price-disclaimer{font-size:0.72rem;color:var(--white-30);margin-bottom:20px;line-height:1.7;padding:12px 0;border-top:1px solid var(--white-06);}

/* CTA BAND */
.cta-band{padding:100px 0;text-align:center;position:relative;overflow:hidden;background:var(--surface);}
.cta-band::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cyan),var(--pink),transparent);opacity:0.5;}
.cta-band::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--pink),var(--cyan),transparent);opacity:0.5;}
.cta-band h2{font-family:var(--font-display);font-size:clamp(2rem,4.5vw,3.6rem);font-weight:800;letter-spacing:-0.025em;color:var(--text);position:relative;margin-bottom:16px;line-height:1.05;}
.cta-band p{color:var(--white-50);font-size:1rem;position:relative;margin-bottom:40px;max-width:580px;margin-left:auto;margin-right:auto;}
.cta-group{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;position:relative;}

/* FEATURES GRID */
.why-us{padding:120px 0;background:var(--surface);position:relative;overflow:hidden;}
.why-us::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);opacity:0.35;}
.why-us::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--pink),transparent);opacity:0.35;}
.why-us-deco{position:absolute;top:-250px;right:-250px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(0,207,255,0.05),transparent 65%);pointer-events:none;animation:blobFloat 14s ease-in-out infinite;}

.features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:72px;}
.feature-item{display:flex;gap:20px;align-items:flex-start;padding:30px;background:var(--void);border:1px solid var(--white-06);border-radius:var(--radius-md);transition:all var(--t-slow);position:relative;overflow:hidden;}
.feature-item::before{content:'';position:absolute;inset:0;background:var(--grad-card);opacity:0;transition:opacity var(--t-slow);}
.feature-item::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad-main);transform:scaleX(0);transition:transform var(--t-slow);}
.feature-item:hover::before{opacity:1;}
.feature-item:hover::after{transform:scaleX(1);}
.feature-item:hover{border-color:rgba(0,207,255,0.2);transform:translateY(-3px);box-shadow:var(--glow-card);}
.feature-num{flex-shrink:0;font-family:var(--font-display);font-size:2rem;font-weight:800;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;opacity:0.4;}
.feature-item:hover .feature-num{opacity:1;}
.feature-text{position:relative;}
.feature-text h3{font-family:var(--font-ui);font-size:0.95rem;font-weight:700;color:var(--text);margin-bottom:8px;}
.feature-text p{color:var(--white-50);font-size:0.85rem;line-height:1.75;}

/* CITY GRID */
.city-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px;}
.city-card{background:var(--surface);border:1px solid var(--white-06);border-radius:var(--radius-md);padding:28px 24px;transition:all var(--t-slow);text-decoration:none;color:inherit;display:block;position:relative;overflow:hidden;}
.city-card::before{content:'';position:absolute;inset:0;background:var(--grad-card);opacity:0;transition:opacity var(--t-slow);}
.city-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--grad-main);transform:scaleX(0);transition:transform var(--t-slow);}
.city-card:hover::before{opacity:1;}
.city-card:hover::after{transform:scaleX(1);}
.city-card:hover{border-color:rgba(0,207,255,0.2);transform:translateY(-3px);}
.city-card h3{font-family:var(--font-ui);font-size:1rem;font-weight:700;color:var(--text);margin-bottom:6px;position:relative;}
.city-card p{color:var(--white-50);font-size:0.84rem;line-height:1.7;position:relative;}
.city-tag{display:inline-block;font-family:var(--font-ui);font-size:0.65rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--cyan);margin-bottom:10px;position:relative;}

/* FAQ */
.faq{padding:120px 0;}
.faq-list{max-width:800px;margin:72px auto 0;}
.faq-item{border-bottom:1px solid rgba(0,207,255,0.08);}
.faq-question{width:100%;text-align:left;padding:22px 0;background:none;border:none;cursor:none;display:flex;align-items:center;justify-content:space-between;gap:16px;font-family:var(--font-ui);font-size:0.93rem;font-weight:600;color:var(--white-70);transition:color var(--t);}
.faq-question:hover{color:var(--cyan);}
.faq-arrow{flex-shrink:0;width:28px;height:28px;border-radius:50%;border:1.5px solid rgba(0,207,255,0.25);display:flex;align-items:center;justify-content:center;transition:all var(--t);font-size:0.65rem;color:var(--cyan);}
.faq-item.open .faq-arrow{background:var(--grad-main);border-color:transparent;color:var(--void);transform:rotate(180deg);box-shadow:0 0 12px rgba(0,207,255,0.35);}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.5s ease;}
.faq-answer-inner{padding:0 0 22px;color:var(--white-50);line-height:1.8;font-size:0.92rem;}
.faq-item.open .faq-answer{max-height:400px;}

/* FOOTER */
.footer{background:var(--surface);border-top:1px solid rgba(0,207,255,0.1);padding:64px 0 0;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;}
.footer-brand h3{font-family:var(--font-display);font-size:1.4rem;font-weight:800;letter-spacing:-0.02em;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px;}
.footer-brand p{font-size:0.86rem;color:var(--white-50);max-width:280px;line-height:1.8;margin-bottom:24px;}
.footer-col h4{font-family:var(--font-ui);font-size:0.68rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--cyan);margin-bottom:20px;}
.footer-col ul{list-style:none;}
.footer-col ul li{margin-bottom:10px;}
.footer-col ul li a{color:var(--white-50);text-decoration:none;font-size:0.86rem;transition:color var(--t);}
.footer-col ul li a:hover{color:var(--cyan);}
.footer-contact-item{display:flex;align-items:flex-start;gap:10px;font-size:0.86rem;margin-bottom:10px;color:var(--white-50);}
.footer-contact-item a{color:inherit;text-decoration:none;transition:color var(--t);}
.footer-contact-item a:hover{color:var(--cyan);}
.footer-medienplus{margin-top:16px;padding:14px 18px;background:var(--cyan-05);border:1px solid rgba(0,207,255,0.15);border-radius:var(--radius-md);font-size:0.82rem;color:var(--white-50);line-height:1.6;}
.footer-medienplus a{color:var(--cyan);text-decoration:none;font-weight:600;}
.footer-medienplus a:hover{color:var(--pink);}
.footer-bottom{border-top:1px solid var(--white-06);padding:24px 0;display:flex;align-items:center;justify-content:space-between;font-size:0.76rem;color:var(--white-30);font-family:var(--font-ui);flex-wrap:wrap;gap:12px;}
.footer-bottom a{color:var(--white-30);text-decoration:none;transition:color var(--t);}
.footer-bottom a:hover{color:var(--cyan);}

/* PAGE HERO */
.page-hero{padding:160px 0 100px;position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(0,207,255,0.035) 1px,transparent 1px),linear-gradient(90deg,rgba(0,207,255,0.035) 1px,transparent 1px);background-size:56px 56px;}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0.06;z-index:0;pointer-events:none;filter:saturate(0) brightness(1.5);}
.page-hero-deco{position:absolute;top:-200px;right:-200px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(0,207,255,0.07) 0%,rgba(255,45,123,0.03) 50%,transparent 65%);pointer-events:none;animation:orbPulse 10s ease-in-out infinite;}
.page-hero .section-inner{position:relative;z-index:1;}
.page-hero h1{font-family:var(--font-display);font-size:clamp(2.5rem,6vw,5rem);font-weight:800;letter-spacing:-0.025em;line-height:1.05;color:var(--text);margin-bottom:20px;}
.page-hero p{font-size:1.05rem;color:var(--white-50);max-width:660px;line-height:1.85;}

/* CONTENT */
.content-section{padding:80px 0;}
.content-section:nth-child(even){background:var(--surface);}
.content-2col{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.content-2col.reverse{direction:rtl;}
.content-2col.reverse>*{direction:ltr;}

.content-img{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--white-06);position:relative;}
.content-img::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,207,255,0.1),rgba(255,45,123,0.06) 60%,transparent);mix-blend-mode:overlay;pointer-events:none;}
.content-img img{width:100%;height:420px;object-fit:cover;display:block;transition:transform 0.8s ease;filter:brightness(0.82) saturate(1.1);}
.content-img:hover img{transform:scale(1.04);}

.content-body h2{font-family:var(--font-display);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;letter-spacing:-0.025em;color:var(--text);line-height:1.1;margin-bottom:20px;}
.content-body p{color:var(--white-50);font-size:0.93rem;line-height:1.85;margin-bottom:16px;}
.content-body ul{list-style:none;margin:20px 0;}
.content-body ul li{padding:8px 0 8px 22px;position:relative;color:var(--white-50);font-size:0.93rem;}
.content-body ul li::before{content:'◆';position:absolute;left:0;top:11px;font-size:0.4rem;color:var(--cyan);}

.angebot-note{background:var(--cyan-05);border-left:2px solid var(--cyan);padding:18px 22px;border-radius:0 var(--radius-md) var(--radius-md) 0;font-size:0.9rem;color:var(--white-50);margin-top:32px;}
.angebot-note a{color:var(--cyan);text-decoration:none;}
.angebot-note a:hover{color:var(--pink);}

/* DISCLAIMER BOX */
.disclaimer-box{background:rgba(255,45,123,0.06);border:1px solid rgba(255,45,123,0.2);border-radius:var(--radius-md);padding:20px 24px;margin-top:32px;font-size:0.88rem;color:var(--white-50);line-height:1.75;}
.disclaimer-box strong{color:var(--pink);}

/* BREADCRUMB */
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:0.72rem;font-family:var(--font-ui);color:var(--white-40);margin-bottom:24px;}
.breadcrumb a{color:var(--white-40);text-decoration:none;transition:color var(--t);}
.breadcrumb a:hover{color:var(--cyan);}
.breadcrumb span{color:var(--cyan-80);}

/* LEGAL */
.legal-content{max-width:800px;margin:0 auto;padding:120px 48px 100px;}
.legal-content h1{font-family:var(--font-display);font-size:3.5rem;font-weight:800;letter-spacing:-0.025em;color:var(--text);margin-bottom:48px;}
.legal-content h2{font-family:var(--font-ui);font-size:1.15rem;font-weight:700;color:var(--text);margin:40px 0 12px;}
.legal-content p,.legal-content li{color:var(--white-50);font-size:0.93rem;line-height:1.85;margin-bottom:12px;}
.legal-content ul{padding-left:20px;}
.legal-content a{color:var(--cyan);text-decoration:none;}
.legal-content a:hover{color:var(--pink);}

/* ANIMATIONS */
@keyframes fadeInDown{from{opacity:0;transform:translateY(-24px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(40px);}to{opacity:1;transform:translateY(0);}}

.animate-on-scroll{opacity:0;transform:translateY(36px);transition:opacity 0.7s ease,transform 0.7s ease;}
.animate-on-scroll.visible{opacity:1;transform:translateY(0);}
.delay-1{transition-delay:0.1s;}
.delay-2{transition-delay:0.2s;}
.delay-3{transition-delay:0.3s;}
.delay-4{transition-delay:0.4s;}
.delay-5{transition-delay:0.5s;}

/* FLOAT CTA */
.float-cta{position:fixed;bottom:32px;right:32px;z-index:999;}
.float-cta a{display:flex;align-items:center;gap:10px;background:var(--grad-main);color:var(--void);text-decoration:none;padding:13px 22px;border-radius:var(--radius-sm);font-family:var(--font-ui);font-weight:700;font-size:0.85rem;box-shadow:0 0 24px rgba(0,207,255,0.35);transition:all var(--t);cursor:none;}
.float-cta a:hover{transform:scale(1.05);box-shadow:var(--glow-cyan);}

/* RESPONSIVE */
@media(max-width:1024px){.services-grid{grid-template-columns:repeat(2,1fr);}.pricing-grid{grid-template-columns:1fr;}.footer-grid{grid-template-columns:1fr 1fr;}.features-grid{grid-template-columns:1fr;}.city-grid{grid-template-columns:repeat(2,1fr);}.nav{padding:0 24px;}}
@media(max-width:768px){.nav-links{display:none;}.burger{display:flex;}.services-grid{grid-template-columns:1fr;}.pricing-grid{grid-template-columns:1fr;}.price-card.featured{transform:scale(1);}.content-2col{grid-template-columns:1fr;gap:40px;}.content-2col.reverse{direction:ltr;}.features-grid{grid-template-columns:1fr;}.footer-grid{grid-template-columns:1fr;gap:32px;}.city-grid{grid-template-columns:1fr;}.float-cta{bottom:16px;right:16px;}.float-cta a{padding:11px 16px;font-size:0.82rem;}.section-inner{padding:0 20px;}.hero{padding:120px 20px 80px;}.hero-stats{gap:28px;}body{cursor:auto;}.cursor-dot,.cursor-ring{display:none;}}
@media(max-width:480px){.hero-btns{flex-direction:column;align-items:center;}.hero-btns a{width:100%;text-align:center;justify-content:center;}.cta-group{flex-direction:column;align-items:center;}}

.nav-links.open{display:flex;flex-direction:column;position:fixed;top:72px;left:0;right:0;background:rgba(10,15,30,0.97);backdrop-filter:blur(20px);padding:32px 24px;gap:24px;z-index:999;border-bottom:1px solid rgba(0,207,255,0.12);animation:fadeInDown 0.3s ease;}

/* ============================================
   DROPDOWN NAVIGATION
   ============================================ */
.nav-links .has-dropdown {
  position: relative;
}

.nav-links .has-dropdown > a {
  display: flex;
  align-items: center;
  gap: 5px;
}

.nav-links .has-dropdown > a::after {
  display: none;
}

.nav-links .has-dropdown > a .drop-arrow {
  font-size: 0.55rem;
  color: var(--cyan-40);
  transition: transform var(--t), color var(--t);
  flex-shrink: 0;
}

.has-dropdown:hover > a .drop-arrow,
.has-dropdown:focus-within > a .drop-arrow {
  transform: rotate(180deg);
  color: var(--cyan);
}

.dropdown {
  position: absolute;
  top: calc(100% + 14px);
  left: 50%;
  transform: translateX(-50%);
  background: rgba(10,15,30,0.97);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(0,207,255,0.15);
  border-radius: var(--radius-md);
  padding: 8px;
  min-width: 210px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
  transform: translateX(-50%) translateY(-6px);
  z-index: 2000;
  box-shadow: 0 16px 40px rgba(0,0,0,0.6), 0 0 0 1px rgba(0,207,255,0.08);
}

.dropdown::before {
  content: '';
  position: absolute;
  top: -6px;
  left: 50%;
  transform: translateX(-50%);
  width: 12px;
  height: 6px;
  background: rgba(0,207,255,0.15);
  clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
}

.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.dropdown a {
  display: block;
  padding: 9px 14px;
  border-radius: var(--radius-sm);
  font-family: var(--font-ui);
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--white-70) !important;
  text-decoration: none;
  transition: all var(--t);
  letter-spacing: 0.01em;
  white-space: nowrap;
}

.dropdown a:hover {
  background: rgba(0,207,255,0.08);
  color: var(--cyan) !important;
  padding-left: 18px;
}

.dropdown a::after {
  display: none !important;
}

.dropdown .drop-overview {
  font-weight: 700;
  color: var(--cyan-80) !important;
  border-bottom: 1px solid rgba(0,207,255,0.1);
  margin-bottom: 4px;
  padding-bottom: 10px;
}

.dropdown .drop-overview:hover {
  color: var(--cyan) !important;
}

/* Mobile dropdown */
@media (max-width: 768px) {
  .dropdown {
    position: static;
    transform: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    background: rgba(0,207,255,0.04);
    border: none;
    border-left: 2px solid rgba(0,207,255,0.2);
    border-radius: 0;
    box-shadow: none;
    padding: 4px 0 4px 16px;
    display: none;
    min-width: 0;
  }
  .dropdown::before { display: none; }
  .has-dropdown.open .dropdown { display: block; }
  .has-dropdown > a .drop-arrow { display: inline; }
}

/* ============================================
   DROPDOWN FIX – hover delay + bridge
   ============================================ */

/* Delay closing so mouse can travel to dropdown */
.has-dropdown .dropdown {
  transition: opacity 0.18s ease 0s, visibility 0.18s ease 0s, transform 0.18s ease 0s;
}

.has-dropdown:not(:hover) .dropdown {
  transition: opacity 0.18s ease 0.22s, visibility 0.18s ease 0.22s, transform 0.18s ease 0.22s;
}

/* Invisible bridge fills gap between nav item and dropdown */
.has-dropdown::after {
  content: '';
  position: absolute;
  top: 100%;
  left: -20px;
  right: -20px;
  height: 20px;
  background: transparent;
}