/* ============================================================
   DeppFlow — NEXUS Design System
   Completely new dark-space design with real 3D effects
   ============================================================ */

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

/* ── 1. TOKENS ─────────────────────────────────────────────── */
:root {
  /* Fonts */
  --font-display: 'Space Grotesk', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-body:    'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono:    'SF Mono', 'Cascadia Code', monospace;

  /* Spacing */
  --max-w:     1180px;
  --nav-h:     72px;
  --sec-pad:   clamp(80px, 10vw, 140px);
  --r-sm:      8px;
  --r:         14px;
  --r-lg:      20px;
  --r-xl:      28px;
  --r-2xl:     40px;

  /* Dark palette (default) */
  --bg-0:      #02040E;
  --bg-1:      #050A18;
  --bg-2:      #081022;
  --bg-card:   rgba(8, 16, 36, 0.75);
  --bg-glass:  rgba(255,255,255,0.04);
  --bg-glass-h:rgba(255,255,255,0.07);

  --cyan:      #00C8FF;
  --cyan-dim:  rgba(0,200,255,0.15);
  --purple:    #8B5CF6;
  --purple-dim:rgba(139,92,246,0.15);
  --green:     #10D9A0;
  --green-dim: rgba(16,217,160,0.15);
  --blue:      #3B82F6;
  --orange:    #F59E0B;

  --text-1:    #EDF2FF;
  --text-2:    #9DACC4;
  --text-3:    #4A5568;
  --text-inv:  #030810;

  --border:    rgba(255,255,255,0.07);
  --border-b:  rgba(0,200,255,0.25);
  --border-p:  rgba(139,92,246,0.25);

  /* Glow */
  --glow-c:    0 0 40px rgba(0,200,255,0.3),0 0 80px rgba(0,200,255,0.12);
  --glow-p:    0 0 40px rgba(139,92,246,0.3),0 0 80px rgba(139,92,246,0.12);
  --glow-g:    0 0 40px rgba(16,217,160,0.3),0 0 80px rgba(16,217,160,0.12);
  --glow-sm:   0 0 20px rgba(0,200,255,0.2);

  /* Shadows */
  --shadow:    0 4px 24px rgba(0,0,0,0.5);
  --shadow-lg: 0 16px 60px rgba(0,0,0,0.6);
  --shadow-xl: 0 32px 100px rgba(0,0,0,0.7);

  /* Easing */
  --ease:      cubic-bezier(.25,.1,.25,1);
  --ease-out:  cubic-bezier(0,0,.2,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
  --ease-expo: cubic-bezier(.19,1,.22,1);

  /* Gradient */
  --grad-primary: linear-gradient(135deg, var(--cyan) 0%, var(--purple) 100%);
  --grad-hero:    linear-gradient(180deg, rgba(0,200,255,.08) 0%, transparent 60%);
}

[data-theme="light"] {
  --bg-0:      #F4F7FF;
  --bg-1:      #EBF0FF;
  --bg-2:      #DDE6FF;
  --bg-card:   rgba(255,255,255,0.92);
  --bg-glass:  rgba(0,0,0,0.03);
  --bg-glass-h:rgba(0,0,0,0.05);

  --text-1:    #0D1225;
  --text-2:    #4A5568;
  --text-3:    #9DACC4;
  --text-inv:  #EDF2FF;

  --border:    rgba(0,0,0,0.07);
  --border-b:  rgba(0,150,200,0.2);
  --border-p:  rgba(100,50,200,0.2);

  --glow-c:    0 0 30px rgba(0,150,220,0.15),0 0 60px rgba(0,150,220,0.07);
  --glow-p:    0 0 30px rgba(100,50,200,0.15),0 0 60px rgba(100,50,200,0.07);
  --glow-g:    0 0 30px rgba(0,160,120,0.15),0 0 60px rgba(0,160,120,0.07);

  --shadow:    0 4px 24px rgba(0,0,0,0.07);
  --shadow-lg: 0 16px 60px rgba(0,0,0,0.1);
  --shadow-xl: 0 32px 100px rgba(0,0,0,0.13);
}

/* ── 2. RESET ───────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }

html {
  font-size: 16px;
  scroll-behavior: smooth;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

body {
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.7;
  color: var(--text-1);
  background: var(--bg-0);
  overflow-x: hidden;
  transition: background .3s, color .3s;
}

img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
button { font-family:inherit; cursor:pointer; }
::selection { background:rgba(0,200,255,0.25); color:var(--text-1); }

/* ── 3. UTILITIES ───────────────────────────────────────────── */
.skip-link {
  position:absolute; left:-9999px; top:4px; z-index:9999;
  padding:8px 16px; background:var(--cyan); color:#000;
  border-radius:var(--r-sm); font-weight:600;
}
.skip-link:focus { left:4px; }

.nx-container {
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 clamp(20px,4vw,48px);
}

.nx-grad-text {
  background: var(--grad-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── 4. SCROLL PROGRESS ─────────────────────────────────────── */
.scroll-bar {
  position:fixed; top:0; left:0; right:0; z-index:9999;
  height:2px; background:rgba(255,255,255,0.05);
}
.scroll-bar-fill {
  height:100%;
  background:var(--grad-primary);
  width:0; transition:width .1s linear;
}

/* ── 5. CURSOR ──────────────────────────────────────────────── */
.nx-cursor {
  position:fixed; z-index:9998;
  width:10px; height:10px;
  border-radius:50%;
  background:var(--cyan);
  pointer-events:none;
  transform:translate(-50%,-50%);
  transition:transform .1s,opacity .2s;
  mix-blend-mode:screen;
}
.nx-cursor-trail {
  position:fixed; z-index:9997;
  width:32px; height:32px;
  border-radius:50%;
  border:1px solid rgba(0,200,255,0.4);
  pointer-events:none;
  transform:translate(-50%,-50%);
  transition:transform .2s var(--ease-out), width .2s, height .2s;
}
@media (pointer:coarse) { .nx-cursor,.nx-cursor-trail { display:none; } }

/* ── 6. NAVIGATION ─────────────────────────────────────────── */
.nx-nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  transition:background .3s, backdrop-filter .3s, border-color .3s;
  border-bottom:1px solid transparent;
}
.nx-nav.scrolled {
  background:rgba(2,4,14,0.82);
  backdrop-filter:blur(20px) saturate(160%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  border-bottom-color:var(--border);
}
[data-theme="light"] .nx-nav.scrolled {
  background:rgba(244,247,255,0.85);
}

/* Inner pages: nav always shows glassmorphism (no hero behind it) */
body[data-page]:not([data-page="index.html"]) .nx-nav {
  background:rgba(2,4,14,0.88);
  backdrop-filter:blur(20px) saturate(160%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  border-bottom-color:var(--border);
}
body[data-theme="light"][data-page]:not([data-page="index.html"]) .nx-nav {
  background:rgba(244,247,255,0.92);
}

.nx-nav-inner {
  display:flex;
  align-items:center;
  gap:clamp(16px,2vw,32px);
  height:var(--nav-h);
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 clamp(20px,4vw,48px);
}

.nx-logo {
  display:flex; align-items:center; gap:10px;
  font-family:var(--font-display); font-weight:700;
  font-size:1.1rem; color:var(--text-1);
  letter-spacing:-.02em; flex-shrink:0;
  text-decoration:none;
}
.nx-logo img {
  border-radius:6px;
  filter:drop-shadow(0 0 8px rgba(0,200,255,0.4));
}

.nx-nav-links {
  display:flex; gap:2px; margin-left:auto;
}
@media(max-width:900px) { .nx-nav-links { display:none; } }

.nx-nav-link {
  position:relative; padding:6px 14px; border-radius:var(--r-sm);
  font-size:.875rem; font-weight:500; color:var(--text-2);
  text-decoration:none;
  transition:color .2s, background .2s;
}
.nx-nav-link:hover { color:var(--text-1); background:var(--bg-glass); }
.nx-nav-link.is-active { color:var(--cyan); }
.nx-nav-link.is-active::after {
  content:''; position:absolute; bottom:2px; left:50%; transform:translateX(-50%);
  width:4px; height:4px; border-radius:50%; background:var(--cyan);
}

.nx-nav-end {
  display:flex; align-items:center; gap:10px; margin-left:auto;
}
@media(max-width:900px) { .nx-nav-end { margin-left:auto; } }

/* Theme button */
.nx-theme-btn {
  display:flex; align-items:center; gap:6px;
  padding:8px 12px; border:1px solid var(--border);
  border-radius:var(--r-sm); background:var(--bg-glass);
  color:var(--text-2); font-size:.8rem;
  transition:all .2s;
}
.nx-theme-btn:hover { border-color:var(--border-b); color:var(--cyan); }
.nx-theme-icon { font-size:1rem; }

/* Burger */
.nx-burger {
  display:none; flex-direction:column; gap:5px;
  padding:8px; border:1px solid var(--border);
  border-radius:var(--r-sm); background:var(--bg-glass);
  transition:all .2s;
}
.nx-burger span {
  display:block; width:18px; height:1.5px;
  background:var(--text-1); border-radius:2px;
  transition:all .3s;
}
.nx-burger[aria-expanded="true"] span:nth-child(1) { transform:rotate(45deg) translate(4.5px,4.5px); }
.nx-burger[aria-expanded="true"] span:nth-child(2) { opacity:0; transform:scaleX(0); }
.nx-burger[aria-expanded="true"] span:nth-child(3) { transform:rotate(-45deg) translate(4.5px,-4.5px); }
@media(max-width:900px) { .nx-burger { display:flex; } }

/* Mobile nav */
.nx-mobile-nav {
  padding:20px clamp(20px,4vw,48px) 28px;
  border-top:1px solid var(--border);
  background:rgba(2,4,14,0.96);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
}
[data-theme="light"] .nx-mobile-nav { background:rgba(244,247,255,0.97); }
.nx-mobile-nav nav { display:flex; flex-direction:column; gap:2px; }
.nx-mobile-nav a {
  display:block; padding:12px 14px; border-radius:var(--r-sm);
  color:var(--text-1); font-size:1rem; font-weight:500;
  transition:background .2s, color .2s;
}
.nx-mobile-nav a:hover { background:var(--bg-glass-h); color:var(--cyan); }
.nx-mobile-nav a.active { color:var(--cyan); }

/* ── 7. BUTTONS ─────────────────────────────────────────────── */
.nx-btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:.65em 1.4em; border-radius:var(--r-sm);
  font-family:var(--font-display); font-weight:600;
  font-size:.875rem; letter-spacing:-.01em;
  border:1.5px solid transparent; cursor:pointer;
  transition:all .2s var(--ease);
  text-decoration:none; white-space:nowrap;
}
.nx-btn:focus-visible { outline:2px solid var(--cyan); outline-offset:3px; }

.nx-btn-sm { padding:.45em 1em; font-size:.8rem; }
.nx-btn-lg { padding:.85em 1.8em; font-size:1rem; }

.nx-btn-primary {
  background:var(--grad-primary);
  color:#fff;
  box-shadow:0 4px 20px rgba(0,200,255,0.25);
}
.nx-btn-primary:hover {
  transform:translateY(-2px);
  box-shadow:0 8px 32px rgba(0,200,255,0.4);
  filter:brightness(1.1);
}
.nx-btn-primary:active { transform:translateY(0); }

.nx-btn-ghost {
  background:transparent;
  color:var(--text-2);
  border-color:var(--border);
}
.nx-btn-ghost:hover { color:var(--text-1); border-color:rgba(255,255,255,0.2); background:var(--bg-glass); }

.nx-btn-outline {
  background:transparent;
  color:var(--cyan);
  border-color:var(--border-b);
}
.nx-btn-outline:hover { background:var(--cyan-dim); }

/* ── 8. HERO ────────────────────────────────────────────────── */
.nx-hero {
  position:relative;
  min-height:100svh;
  display:flex; align-items:center;
  overflow:hidden;
  padding-top:var(--nav-h);
}

.nx-hero-canvas {
  position:absolute; inset:0;
  width:100%; height:100%;
  pointer-events:none;
}

/* Orbs */
.nx-orbs { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.nx-orb {
  position:absolute; border-radius:50%;
  filter:blur(100px); opacity:0;
  animation:orb-fade 2s ease forwards;
}
.nx-orb-1 {
  width:600px; height:600px;
  background:radial-gradient(circle,rgba(0,200,255,0.15) 0%,transparent 70%);
  top:-200px; right:-100px; animation-delay:.5s;
}
.nx-orb-2 {
  width:500px; height:500px;
  background:radial-gradient(circle,rgba(139,92,246,0.12) 0%,transparent 70%);
  bottom:-100px; left:-150px; animation-delay:.8s;
}
.nx-orb-3 {
  width:400px; height:400px;
  background:radial-gradient(circle,rgba(16,217,160,0.1) 0%,transparent 70%);
  bottom:200px; right:30%; animation-delay:1.2s;
}
@keyframes orb-fade { to { opacity:1; } }

/* Grid floor */
.nx-grid-floor {
  position:absolute; bottom:0; left:0; right:0; height:40%;
  background:
    linear-gradient(rgba(0,200,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,200,255,0.04) 1px, transparent 1px);
  background-size:60px 60px;
  transform:perspective(600px) rotateX(60deg);
  transform-origin:bottom;
  mask-image:linear-gradient(to top,rgba(0,0,0,0.4) 0%,transparent 80%);
  -webkit-mask-image:linear-gradient(to top,rgba(0,0,0,0.4) 0%,transparent 80%);
  pointer-events:none;
}

/* Hero layout */
.nx-hero-layout {
  position:relative; z-index:2;
  width:100%; max-width:var(--max-w);
  margin:0 auto; padding:0 clamp(20px,4vw,48px);
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,80px);
  align-items:center;
  padding-bottom:60px;
}
@media(max-width:960px) {
  .nx-hero-layout { grid-template-columns:1fr; padding-bottom:40px; }
  .nx-hero-visual { display:none; }
}

/* Hero copy */
.nx-badge {
  display:inline-flex; align-items:center; gap:10px;
  padding:7px 16px; border-radius:100px;
  background:rgba(0,200,255,0.08); border:1px solid rgba(0,200,255,0.2);
  font-size:.75rem; font-weight:600; letter-spacing:.06em;
  text-transform:uppercase; color:var(--cyan);
  margin-bottom:28px;
}
.nx-badge-pulse {
  width:6px; height:6px; border-radius:50%; background:var(--cyan);
  box-shadow:0 0 0 0 rgba(0,200,255,0.6);
  animation:pulse-ring 2s ease infinite;
}
@keyframes pulse-ring {
  0%   { box-shadow:0 0 0 0 rgba(0,200,255,0.6); }
  70%  { box-shadow:0 0 0 8px rgba(0,200,255,0); }
  100% { box-shadow:0 0 0 0 rgba(0,200,255,0); }
}

.nx-hero-h1 {
  font-family:var(--font-display);
  font-size:clamp(2.4rem,5vw,3.8rem);
  font-weight:700; line-height:1.1;
  letter-spacing:-.03em; color:var(--text-1);
  margin-bottom:20px;
}

.nx-hero-lead {
  font-size:clamp(1rem,1.5vw,1.15rem);
  color:var(--text-2); line-height:1.75;
  max-width:540px; margin-bottom:36px;
}

.nx-hero-actions {
  display:flex; gap:12px; flex-wrap:wrap;
  margin-bottom:36px;
}

.nx-hero-chips {
  display:flex; gap:8px; flex-wrap:wrap;
}
.nx-chip {
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 14px; border-radius:100px;
  background:var(--bg-glass); border:1px solid var(--border);
  font-size:.78rem; color:var(--text-2);
}
.nx-chip span:first-child { font-size:1rem; }

/* Hero visual */
.nx-hero-visual {
  position:relative;
  display:flex; justify-content:center; align-items:center;
}

.nx-vis-panel {
  position:relative;
  width:100%; max-width:380px;
  background:rgba(8,16,36,0.85);
  border:1px solid rgba(0,200,255,0.2);
  border-radius:var(--r-xl);
  padding:0;
  overflow:hidden;
  box-shadow:var(--shadow-xl), inset 0 1px 0 rgba(255,255,255,0.06);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  transform:perspective(1000px) rotateY(-8deg) rotateX(4deg);
  transition:transform .6s var(--ease-spring);
}
.nx-vis-panel:hover {
  transform:perspective(1000px) rotateY(-3deg) rotateX(2deg);
}
[data-theme="light"] .nx-vis-panel { background:rgba(255,255,255,0.92); }

.nx-vis-glow {
  position:absolute; top:-60px; right:-60px;
  width:200px; height:200px; border-radius:50%;
  background:radial-gradient(circle,rgba(0,200,255,0.2) 0%,transparent 70%);
  pointer-events:none;
}

.nx-vis-head {
  display:flex; align-items:center; gap:10px;
  padding:14px 20px;
  border-bottom:1px solid var(--border);
  background:rgba(255,255,255,0.03);
}
.nx-vis-dots { display:flex; gap:6px; }
.vd { width:10px; height:10px; border-radius:50%; }
.vd-r { background:#EF4444; }
.vd-y { background:#F59E0B; }
.vd-g { background:#10B981; }
.nx-vis-title { flex:1; font-size:.7rem; color:var(--text-3); font-family:var(--font-mono); }
.nx-vis-live {
  display:flex; align-items:center; gap:6px;
  font-size:.7rem; color:var(--green); font-weight:600;
}

.nx-live-dot {
  width:6px; height:6px; border-radius:50%;
  background:var(--green);
  box-shadow:0 0 6px var(--green);
  animation:live-pulse 1.5s ease infinite;
}
@keyframes live-pulse {
  0%,100% { opacity:1; }
  50% { opacity:.4; }
}

.nx-vis-steps { padding:16px 20px; display:flex; flex-direction:column; gap:2px; }
.nx-vis-step {
  display:flex; align-items:center; gap:12px;
  padding:10px 12px; border-radius:var(--r-sm);
  transition:background .2s;
}
.nx-vis-step.nx-done { background:rgba(16,217,160,0.05); }
.nx-vis-step.nx-active {
  background:rgba(0,200,255,0.08);
  border:1px solid rgba(0,200,255,0.15);
}
.nx-vis-step.nx-pending { opacity:.5; }

.nx-vs-icon { font-size:1.1rem; width:28px; text-align:center; }
.nx-vs-info { flex:1; }
.nx-vs-info strong { display:block; font-size:.8rem; font-weight:600; color:var(--text-1); }
.nx-vs-info span { font-size:.7rem; color:var(--text-3); }
.nx-vs-check { font-size:.85rem; font-weight:700; }
.nx-check-done { color:var(--green); }
.nx-check-active { color:var(--cyan); animation:live-pulse 1s ease infinite; }
.nx-check-pending { color:var(--text-3); }

.nx-vis-prog { padding:14px 20px 18px; border-top:1px solid var(--border); }
.nx-vis-prog-bar {
  width:100%; height:4px; background:rgba(255,255,255,0.08);
  border-radius:2px; overflow:hidden; margin-bottom:6px;
}
.nx-vis-prog-fill {
  height:100%;
  background:linear-gradient(90deg,var(--cyan),var(--purple));
  border-radius:2px;
  position:relative;
  animation:shimmer 2s linear infinite;
}
.nx-vis-prog-fill::after {
  content:''; position:absolute; top:0; right:0;
  width:20px; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.4),transparent);
  animation:shimmer-move 2s linear infinite;
}
@keyframes shimmer-move {
  from { transform:translateX(-100%); }
  to   { transform:translateX(400%); }
}
.nx-vis-prog span { font-size:.7rem; color:var(--text-3); }

/* Floating chips */
.nx-float-chip {
  position:absolute;
  display:flex; align-items:center; gap:8px;
  padding:8px 14px; border-radius:100px;
  background:rgba(8,16,36,0.9);
  border:1px solid var(--border);
  font-size:.75rem; color:var(--text-2);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  box-shadow:var(--shadow);
  animation:float 4s ease-in-out infinite;
}
[data-theme="light"] .nx-float-chip { background:rgba(255,255,255,0.95); }
.nx-fc-1 { top:-16px; left:-20px; animation-delay:0s; }
.nx-fc-2 { bottom:40px; right:-30px; animation-delay:1.5s; }
.nx-fc-3 { bottom:-16px; left:20px; animation-delay:.8s; }
@keyframes float {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(-8px); }
}

/* Scroll hint */
.nx-scroll-hint {
  position:absolute; bottom:32px; left:50%; transform:translateX(-50%);
  z-index:2; display:flex; flex-direction:column; align-items:center;
}
.nx-scroll-line {
  width:1px; height:48px;
  background:linear-gradient(to bottom,var(--cyan),transparent);
  animation:scroll-line 2s ease infinite;
}
@keyframes scroll-line {
  0%,100% { opacity:0; transform:scaleY(0); transform-origin:top; }
  30%,70% { opacity:1; transform:scaleY(1); transform-origin:top; }
}

/* ── 9. REVEAL ANIMATIONS ───────────────────────────────────── */
.reveal {
  opacity:0; transform:translateY(28px) scale(.98);
  transition:opacity .7s var(--ease-expo), transform .7s var(--ease-expo);
}
.reveal[data-d="1"] { transition-delay:.1s; }
.reveal[data-d="2"] { transition-delay:.2s; }
.reveal[data-d="3"] { transition-delay:.3s; }
.reveal[data-d="4"] { transition-delay:.4s; }
.reveal.visible { opacity:1; transform:none; }

/* ── 10. TICKER ─────────────────────────────────────────────── */
.nx-ticker {
  position:relative;
  padding:16px 0;
  background:rgba(255,255,255,0.02);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  overflow:hidden;
  mask-image:linear-gradient(90deg,transparent,black 10%,black 90%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,black 10%,black 90%,transparent);
}
.nx-ticker-track {
  display:flex; gap:clamp(20px,3vw,40px); align-items:center;
  width:max-content;
  animation:ticker 30s linear infinite;
  font-size:.78rem; font-weight:500; color:var(--text-3);
  letter-spacing:.03em; text-transform:uppercase;
}
@keyframes ticker {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}
.nx-ticker:hover .nx-ticker-track { animation-play-state:paused; }
.nx-sep { color:var(--border-b); }

/* ── 11. SECTIONS ───────────────────────────────────────────── */
.nx-section {
  padding:var(--sec-pad) 0;
  position:relative;
}
.nx-section-alt {
  background:linear-gradient(180deg,var(--bg-1) 0%,var(--bg-0) 100%);
}
.nx-section-dark {
  background:var(--bg-1);
  position:relative;
}
.nx-section-dark::before {
  content:''; position:absolute; inset:0;
  background:
    linear-gradient(rgba(0,200,255,0.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,200,255,0.03) 1px,transparent 1px);
  background-size:80px 80px;
  pointer-events:none;
}

.nx-eyebrow {
  display:inline-block;
  font-size:.72rem; font-weight:700; letter-spacing:.1em;
  text-transform:uppercase; color:var(--cyan);
  margin-bottom:14px;
}
.nx-section-h2 {
  font-family:var(--font-display);
  font-size:clamp(1.8rem,3.5vw,2.8rem);
  font-weight:700; line-height:1.15;
  letter-spacing:-.03em; color:var(--text-1);
  margin-bottom:16px;
}
.nx-section-h2 em { font-style:normal; color:var(--cyan); }
.nx-section-lead {
  font-size:clamp(.95rem,1.4vw,1.1rem);
  color:var(--text-2); line-height:1.75;
  max-width:600px; margin-bottom:48px;
}
.nx-section-cta {
  display:flex; gap:12px; flex-wrap:wrap;
  margin-top:52px;
}

/* ── 12. PROBLEM GRID ───────────────────────────────────────── */
.nx-problem-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:20px; margin-top:48px;
}

/* Glass card */
.nx-glass-card {
  position:relative; overflow:hidden;
  padding:clamp(24px,3vw,36px);
  border-radius:var(--r-xl);
  background:var(--bg-card);
  border:1px solid var(--border);
  backdrop-filter:blur(16px) saturate(150%);
  -webkit-backdrop-filter:blur(16px) saturate(150%);
  box-shadow:var(--shadow-lg);
  transition:transform .15s ease-out, box-shadow .3s, border-color .3s;
  transform-style:preserve-3d;
  cursor:default;
}
.nx-glass-card::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height:1px; background:linear-gradient(90deg,transparent,rgba(255,255,255,0.08),transparent);
}
.nx-glass-card:hover {
  border-color:rgba(0,200,255,0.2);
  box-shadow:var(--shadow-xl), var(--glow-sm);
}

.nx-card-num {
  font-family:var(--font-mono); font-size:.72rem;
  font-weight:700; letter-spacing:.08em;
  color:var(--cyan); margin-bottom:16px;
}
.nx-card-glyph {
  font-size:2.5rem; line-height:1;
  margin-bottom:16px; opacity:.7;
}
.nx-glass-card h3 {
  font-family:var(--font-display); font-size:1.1rem;
  font-weight:700; color:var(--text-1);
  margin-bottom:10px;
}
.nx-glass-card p { font-size:.9rem; color:var(--text-2); line-height:1.65; }

/* ── 13. SOLUTIONS GRID ─────────────────────────────────────── */
.nx-sol-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:20px; margin-top:48px;
}

.nx-sol-card {
  position:relative; overflow:hidden;
  padding:clamp(24px,3vw,36px);
  border-radius:var(--r-xl);
  background:var(--bg-glass);
  border:1px solid var(--border);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  transition:all .2s var(--ease);
  transform-style:preserve-3d;
  cursor:default;
}
.nx-sol-card:hover {
  background:var(--bg-glass-h);
  transform:translateY(-4px);
}
.nx-sol-card::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height:1px; background:linear-gradient(90deg,transparent,rgba(255,255,255,0.1),transparent);
}
.nx-sol-card:hover::after {
  content:''; position:absolute; inset:0;
  background:var(--grad-primary); opacity:.03; border-radius:inherit;
  pointer-events:none;
}

/* Colored glow background */
.nx-sol-glow {
  position:absolute; top:-80px; right:-80px;
  width:200px; height:200px; border-radius:50%;
  pointer-events:none; opacity:0;
  transition:opacity .3s;
  filter:blur(60px);
}
.nx-sol-card:hover .nx-sol-glow { opacity:.5; }
.nx-glow-blue  { background:radial-gradient(circle,rgba(0,200,255,0.4) 0%,transparent 70%); }
.nx-glow-purple{ background:radial-gradient(circle,rgba(139,92,246,0.4) 0%,transparent 70%); }
.nx-glow-green { background:radial-gradient(circle,rgba(16,217,160,0.4) 0%,transparent 70%); }
.nx-glow-cyan  { background:radial-gradient(circle,rgba(0,200,255,0.5) 0%,transparent 70%); }

.nx-sol-icon {
  font-size:2rem; margin-bottom:16px;
  display:block;
  filter:drop-shadow(0 0 12px rgba(0,200,255,0.3));
}
.nx-sol-card h3 {
  font-family:var(--font-display); font-size:1.05rem; font-weight:700;
  color:var(--text-1); margin-bottom:10px;
}
.nx-sol-card p { font-size:.875rem; color:var(--text-2); line-height:1.65; margin-bottom:16px; }
.nx-sol-link {
  font-size:.8rem; font-weight:600; color:var(--cyan);
  opacity:.8; transition:opacity .2s;
  text-decoration:none;
}
.nx-sol-link:hover { opacity:1; }

/* ── 14. PROCESS ─────────────────────────────────────────────── */
.nx-process {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:0; margin-top:56px; position:relative;
}

.nx-proc-step {
  position:relative; padding:clamp(24px,3vw,36px);
  display:flex; flex-direction:column; gap:16px;
}
.nx-proc-step:not(:last-child)::after {
  content:'';
  position:absolute; top:44px; right:0;
  width:1px; height:60px;
  background:linear-gradient(to bottom,var(--border-b),transparent);
}
@media(max-width:768px) {
  .nx-proc-step:not(:last-child)::after { display:none; }
}

.nx-proc-num {
  display:inline-flex; width:48px; height:48px;
  align-items:center; justify-content:center;
  border-radius:12px;
  background:rgba(0,200,255,0.1);
  border:1px solid rgba(0,200,255,0.2);
  font-family:var(--font-mono); font-size:.75rem; font-weight:700;
  color:var(--cyan); flex-shrink:0;
}

.nx-proc-line {
  position:absolute; top:56px; left:calc(clamp(24px,3vw,36px) + 24px);
  width:calc(100% - 2*clamp(24px,3vw,36px) - 24px);
  height:1px;
  background:linear-gradient(90deg,rgba(0,200,255,0.3),transparent);
}
@media(max-width:768px) { .nx-proc-line { display:none; } }

.nx-proc-content h3 {
  font-family:var(--font-display); font-size:1rem; font-weight:700;
  color:var(--text-1); margin-bottom:8px;
}
.nx-proc-content p { font-size:.875rem; color:var(--text-2); line-height:1.65; }

/* ── 15. DEMO TERMINAL ──────────────────────────────────────── */
.nx-terminal {
  max-width:780px; margin:48px auto 0;
  border-radius:var(--r-xl); overflow:hidden;
  border:1px solid var(--border);
  background:rgba(4,8,20,0.95);
  box-shadow:var(--shadow-xl);
}
[data-theme="light"] .nx-terminal { background:rgba(240,244,255,0.97); }

.nx-term-chrome {
  display:flex; align-items:center; gap:12px;
  padding:14px 20px;
  border-bottom:1px solid var(--border);
  background:rgba(255,255,255,0.03);
}
.nx-term-dots { display:flex; gap:6px; }
.nx-td { width:10px; height:10px; border-radius:50%; }
.nx-td-r { background:#EF4444; }
.nx-td-y { background:#F59E0B; }
.nx-td-g { background:#10B981; }
.nx-term-title { flex:1; font-family:var(--font-mono); font-size:.7rem; color:var(--text-3); }
.nx-term-live {
  display:flex; align-items:center; gap:6px;
  font-size:.7rem; color:var(--green); font-weight:600;
}

.nx-term-body { padding:24px; }

.nx-demo-nodes { display:flex; flex-direction:column; gap:8px; min-height:200px; }

.nx-demo-node {
  display:flex; align-items:center; gap:14px;
  padding:14px 16px; border-radius:var(--r);
  background:rgba(255,255,255,0.03); border:1px solid var(--border);
  animation:node-slide .4s var(--ease-spring);
}
@keyframes node-slide {
  from { opacity:0; transform:translateX(-16px); }
  to   { opacity:1; transform:translateX(0); }
}
.nx-demo-node.is-hidden { display:none; }
.nx-demo-node.active {
  background:rgba(0,200,255,0.07);
  border-color:rgba(0,200,255,0.2);
}
.nx-demo-node.done {
  background:rgba(16,217,160,0.05);
  border-color:rgba(16,217,160,0.1);
}

.nx-dn-icon { font-size:1.3rem; flex-shrink:0; }
.nx-dn-content { flex:1; }
.nx-dn-content strong { display:block; font-size:.875rem; font-weight:600; color:var(--text-1); }
.nx-dn-content p { font-size:.78rem; color:var(--text-2); margin-top:2px; }
.nx-dn-tag {
  padding:3px 10px; border-radius:100px;
  background:rgba(0,200,255,0.1);
  font-size:.68rem; font-weight:600; color:var(--cyan);
  display:none;
}
.nx-demo-node.active .nx-dn-tag { display:block; }
.nx-demo-node.done .nx-dn-tag {
  display:block;
  background:rgba(16,217,160,0.1); color:var(--green);
}

.nx-demo-status {
  display:flex; align-items:center; gap:10px;
  margin-top:16px; padding:10px 16px;
  border-radius:var(--r-sm);
  background:rgba(255,255,255,0.02);
  font-size:.78rem; color:var(--text-3);
}
.nx-demo-status-val { font-weight:600; color:var(--text-1); }

.nx-demo-actions { margin-top:16px; }

/* ── 16. STATS ──────────────────────────────────────────────── */
.nx-stats-section {
  background:linear-gradient(180deg,var(--bg-1) 0%,var(--bg-0) 100%);
}
.nx-stats-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:2px;
  border:1px solid var(--border);
  border-radius:var(--r-xl); overflow:hidden;
}

.nx-stat-card {
  padding:clamp(28px,4vw,48px);
  background:var(--bg-card);
  text-align:center;
  transition:background .2s;
}
.nx-stat-card:hover { background:var(--bg-glass-h); }
.nx-stat-val {
  font-family:var(--font-display);
  font-size:clamp(2rem,4vw,3rem);
  font-weight:700; letter-spacing:-.03em;
  background:var(--grad-primary);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
  margin-bottom:8px;
}
.nx-stat-lbl { font-size:.82rem; color:var(--text-3); font-weight:500; }

/* ── 17. FAQ ────────────────────────────────────────────────── */
.nx-faq-layout {
  display:grid;
  grid-template-columns:300px 1fr;
  gap:clamp(40px,6vw,80px);
  align-items:start;
}
@media(max-width:820px) { .nx-faq-layout { grid-template-columns:1fr; } }

.nx-faq-intro .nx-btn { margin-top:32px; }
.nx-faq-list { display:flex; flex-direction:column; gap:8px; }

.faq-item {
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
  transition:border-color .2s;
}
.faq-item.open { border-color:rgba(0,200,255,0.2); }

.faq-question {
  width:100%; display:flex; align-items:center; justify-content:space-between;
  gap:16px; padding:18px 22px;
  background:var(--bg-glass); border:none;
  font-family:var(--font-display); font-size:.95rem;
  font-weight:600; color:var(--text-1);
  text-align:left; cursor:pointer;
  transition:background .2s, color .2s;
}
.faq-question:hover { background:var(--bg-glass-h); }
.faq-question span:last-child {
  font-size:1.2rem; font-weight:300; color:var(--cyan);
  flex-shrink:0; transition:transform .3s;
}
.faq-item.open .faq-question span:last-child { transform:rotate(45deg); }

.faq-answer { display:none; }
.faq-item.open .faq-answer { display:block; }
.faq-answer-inner {
  padding:0 22px 18px;
  background:var(--bg-glass);
}
.faq-answer-inner p { font-size:.875rem; color:var(--text-2); line-height:1.75; }

/* ── 18. CTA SECTION ────────────────────────────────────────── */
.nx-cta-section { overflow:hidden; }

.nx-cta-card {
  position:relative; overflow:hidden;
  padding:clamp(48px,6vw,80px);
  border-radius:var(--r-2xl);
  background:linear-gradient(135deg,rgba(0,200,255,0.06) 0%,rgba(139,92,246,0.06) 100%);
  border:1px solid rgba(0,200,255,0.15);
  text-align:center;
}
.nx-cta-glow {
  position:absolute; top:-100px; left:50%; transform:translateX(-50%);
  width:600px; height:400px; border-radius:50%;
  background:radial-gradient(ellipse,rgba(0,200,255,0.12) 0%,transparent 70%);
  pointer-events:none;
}
.nx-cta-inner { position:relative; z-index:1; max-width:640px; margin:0 auto; }
.nx-cta-inner .nx-eyebrow { margin-bottom:20px; }
.nx-cta-inner h2 {
  font-family:var(--font-display);
  font-size:clamp(1.8rem,3vw,2.6rem);
  font-weight:700; letter-spacing:-.03em;
  color:var(--text-1); margin-bottom:16px;
}
.nx-cta-inner p { color:var(--text-2); margin-bottom:36px; }
.nx-cta-actions { display:flex; gap:12px; flex-wrap:wrap; justify-content:center; }

/* ── 19. FOOTER ─────────────────────────────────────────────── */
.nx-footer {
  background:var(--bg-1);
  border-top:1px solid var(--border);
  padding-top:64px;
}
.nx-footer-grid {
  display:grid;
  grid-template-columns:1fr 2fr;
  gap:clamp(40px,6vw,80px);
  padding-bottom:48px;
}
@media(max-width:768px) { .nx-footer-grid { grid-template-columns:1fr; } }

.nx-footer-brand p {
  font-size:.875rem; color:var(--text-2); margin:16px 0;
  max-width:280px; line-height:1.65;
}
.nx-footer-contact {
  display:flex; gap:8px; align-items:center;
  font-size:.8rem; color:var(--text-3);
}
.nx-footer-contact a { color:var(--cyan); }
.nx-footer-contact a:hover { text-decoration:underline; }

.nx-footer-nav { display:flex; gap:clamp(24px,4vw,48px); flex-wrap:wrap; }
.nx-footer-col {
  display:flex; flex-direction:column; gap:10px; min-width:120px;
}
.nx-footer-col-title {
  font-size:.72rem; font-weight:700; letter-spacing:.07em;
  text-transform:uppercase; color:var(--text-3); margin-bottom:4px;
}
.nx-footer-col a {
  font-size:.82rem; color:var(--text-2);
  transition:color .2s; text-decoration:none;
}
.nx-footer-col a:hover { color:var(--cyan); }

.nx-footer-bottom {
  border-top:1px solid var(--border); padding:20px 0;
}
.nx-footer-bottom .nx-container {
  display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.nx-footer-bottom span { font-size:.78rem; color:var(--text-3); }

/* ── 20. CHAT ASSISTANT ─────────────────────────────────────── */
.chat-assistant {
  position:fixed; bottom:24px; right:24px; z-index:800;
}
@media(max-width:480px) { .chat-assistant { bottom:16px; right:16px; } }

.chat-assistant-toggle {
  display:flex; align-items:center; gap:10px;
  padding:12px 22px 12px 16px;
  border-radius:100px;
  background:linear-gradient(135deg,rgba(0,200,255,0.15),rgba(139,92,246,0.15));
  border:1px solid rgba(0,200,255,0.3);
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  color:var(--text-1); font-family:var(--font-display);
  font-weight:600; font-size:.875rem; cursor:pointer;
  box-shadow:0 8px 32px rgba(0,0,0,0.4), var(--glow-sm);
  transition:all .3s var(--ease-spring);
}
.chat-assistant-toggle:hover {
  transform:translateY(-3px) scale(1.03);
  box-shadow:0 12px 40px rgba(0,0,0,0.5), var(--glow-c);
  border-color:rgba(0,200,255,0.5);
}
.chat-assistant.is-open .chat-assistant-toggle { background:rgba(0,200,255,0.1); }

.chat-toggle-icon {
  font-size:1.1rem; color:var(--cyan);
  animation:spin-slow 8s linear infinite;
}
@keyframes spin-slow { to { transform:rotate(360deg); } }
.chat-assistant.is-open .chat-toggle-icon { animation:none; }
.chat-toggle-text { font-size:.82rem; }

.chat-assistant-panel {
  position:absolute; bottom:calc(100% + 16px); right:0;
  width:clamp(320px,90vw,400px);
  border-radius:var(--r-xl); overflow:hidden;
  background:rgba(4,10,24,0.95);
  border:1px solid rgba(0,200,255,0.15);
  backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px);
  box-shadow:var(--shadow-xl), 0 0 60px rgba(0,200,255,0.08);
  animation:chat-slide .3s var(--ease-spring);
}
@keyframes chat-slide {
  from { opacity:0; transform:translateY(16px) scale(.97); }
  to   { opacity:1; transform:none; }
}
[data-theme="light"] .chat-assistant-panel { background:rgba(240,244,255,0.97); }

.chat-assistant-head {
  display:flex; align-items:flex-start; justify-content:space-between;
  padding:20px 20px 16px;
  border-bottom:1px solid var(--border);
  background:rgba(0,200,255,0.04);
}
.chat-assistant-kicker {
  display:block; font-size:.65rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; color:var(--cyan);
  margin-bottom:4px;
}
.chat-assistant-head h2 {
  font-family:var(--font-display); font-size:1rem;
  font-weight:700; color:var(--text-1); margin:0;
}
.chat-assistant-close {
  width:28px; height:28px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:var(--bg-glass); border:1px solid var(--border);
  color:var(--text-2); font-size:1.1rem; cursor:pointer;
  transition:all .2s; flex-shrink:0;
}
.chat-assistant-close:hover { background:var(--bg-glass-h); color:var(--text-1); }

.chat-assistant-messages {
  height:300px; overflow-y:auto; padding:16px;
  display:flex; flex-direction:column; gap:12px;
  scroll-behavior:smooth;
}
.chat-assistant-messages::-webkit-scrollbar { width:4px; }
.chat-assistant-messages::-webkit-scrollbar-track { background:transparent; }
.chat-assistant-messages::-webkit-scrollbar-thumb { background:var(--border); border-radius:2px; }

.chat-message {
  display:flex; flex-direction:column; gap:4px;
  max-width:88%;
}
.chat-message--user { align-self:flex-end; align-items:flex-end; }
.chat-message--assistant { align-self:flex-start; }
.chat-message-label {
  font-size:.65rem; font-weight:700; letter-spacing:.06em;
  text-transform:uppercase; color:var(--text-3);
}
.chat-message p {
  padding:10px 14px; border-radius:var(--r-lg);
  font-size:.82rem; line-height:1.6; margin:0;
  color:var(--text-1);
}
.chat-message--user p { background:rgba(0,200,255,0.12); border:1px solid rgba(0,200,255,0.15); border-bottom-right-radius:4px; }
.chat-message--assistant p { background:var(--bg-glass); border:1px solid var(--border); border-bottom-left-radius:4px; }

/* Typing dots */
.chat-message--typing .chat-typing-dots {
  display:flex; gap:5px; padding:12px 14px;
  background:var(--bg-glass); border:1px solid var(--border);
  border-radius:var(--r-lg); border-bottom-left-radius:4px;
}
.chat-typing-dots span {
  width:6px; height:6px; border-radius:50%;
  background:var(--text-3); animation:typing .8s ease infinite;
}
.chat-typing-dots span:nth-child(2) { animation-delay:.15s; }
.chat-typing-dots span:nth-child(3) { animation-delay:.3s; }
@keyframes typing {
  0%,60%,100% { transform:translateY(0); }
  30%          { transform:translateY(-6px); }
}

/* Chat link cards */
.chat-link-cards { display:flex; flex-direction:column; gap:6px; margin-top:8px; }
.chat-link-card {
  display:flex; align-items:center; justify-content:space-between; gap:8px;
  padding:8px 12px; border-radius:var(--r-sm);
  background:rgba(0,200,255,0.06); border:1px solid rgba(0,200,255,0.12);
  font-size:.75rem; font-weight:600; color:var(--cyan);
  text-decoration:none; transition:all .2s;
}
.chat-link-card:hover { background:rgba(0,200,255,0.12); }

.chat-assistant-form { padding:16px; border-top:1px solid var(--border); }
.chat-assistant-status {
  font-size:.65rem; color:var(--text-3); margin-bottom:10px;
  display:block; line-height:1.5;
}
.chat-assistant-status a { color:var(--cyan); }
.chat-assistant-status[data-state="loading"] { color:var(--cyan); }
.chat-assistant-status[data-state="error"] { color:#EF4444; }

.chat-assistant-form textarea {
  width:100%; resize:none; overflow:hidden;
  padding:10px 14px; border-radius:var(--r);
  background:var(--bg-glass); border:1px solid var(--border);
  color:var(--text-1); font-family:var(--font-body); font-size:.82rem;
  line-height:1.5; outline:none;
  transition:border-color .2s;
}
.chat-assistant-form textarea:focus { border-color:var(--border-b); }
.chat-assistant-form textarea::placeholder { color:var(--text-3); }

.chat-assistant-actions {
  display:flex; align-items:center; justify-content:space-between; gap:8px;
  margin-top:10px;
}
.chat-assistant-actions [data-chat-status] { font-size:.65rem; }

.chat-assistant-footer {
  display:flex; gap:8px; padding:12px 16px;
  border-top:1px solid var(--border);
}
.chat-contact-link {
  flex:1; text-align:center; padding:8px 12px; border-radius:var(--r-sm);
  font-size:.72rem; font-weight:600; color:var(--text-2);
  background:var(--bg-glass); border:1px solid var(--border);
  transition:all .2s; text-decoration:none;
}
.chat-contact-link:hover { color:var(--cyan); border-color:var(--border-b); }
.chat-contact-link--transfer { color:var(--cyan); }
.chat-contact-link[aria-disabled="true"] { opacity:.4; pointer-events:none; }

/* btn-small for chat */
.btn-small {
  display:inline-flex; align-items:center;
  padding:6px 16px; border-radius:var(--r-sm);
  font-size:.75rem; font-weight:600; cursor:pointer;
  background:var(--grad-primary); color:#fff; border:none;
  transition:all .2s;
}
.btn-small:hover { filter:brightness(1.1); }
.btn-small.is-disabled { opacity:.5; pointer-events:none; }

/* ── 21. CONTACT FORM (kontakt.html) ────────────────────────── */
/* These styles apply on the /kontakt page */
.page-shell { --nav-h: 72px; }

/* Page hero for inner pages */
.page-hero {
  padding:calc(var(--nav-h) + 60px) 0 60px;
  border-bottom:1px solid var(--border);
  background:linear-gradient(180deg,var(--bg-1) 0%,var(--bg-0) 100%);
}
.page-hero .eyebrow {
  display:block; font-size:.72rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; color:var(--cyan);
  margin-bottom:12px;
}
.page-hero h1 {
  font-family:var(--font-display); font-size:clamp(2rem,4vw,3rem);
  font-weight:700; letter-spacing:-.03em; color:var(--text-1);
  margin-bottom:16px;
}
.page-hero .lead { font-size:1rem; color:var(--text-2); max-width:560px; line-height:1.75; }

/* Contact form wrapper */
.section { padding:var(--sec-pad) 0; }
.section-tight { padding:clamp(40px,6vw,80px) 0; }
.section-alt { background:var(--bg-1); }
.container { max-width:var(--max-w); margin:0 auto; padding:0 clamp(20px,4vw,48px); }
.contact-form-wrap { max-width:640px; margin:0 auto; }

.contact-form, .solution-contact-form {
  display:flex; flex-direction:column; gap:20px;
}
.form-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:16px;
}
@media(max-width:640px) { .form-grid { grid-template-columns:1fr; } }
.field-full { grid-column:1/-1; }

.field { display:flex; flex-direction:column; gap:6px; }
.field label {
  font-size:.8rem; font-weight:600; color:var(--text-2);
}
.field input,
.field select,
.field textarea {
  padding:12px 16px; border-radius:var(--r);
  background:var(--bg-card); border:1px solid var(--border);
  color:var(--text-1); font-family:var(--font-body); font-size:.9rem;
  outline:none; transition:border-color .2s, box-shadow .2s;
  -webkit-appearance:none;
}
.field select option {
  background:#050A18; color:#EDF2FF;
}
body[data-theme="light"] .field select {
  background:#fff;
}
body[data-theme="light"] .field select option {
  background:#fff; color:#0D1225;
}
.field input:focus,
.field select:focus,
.field textarea:focus {
  border-color:var(--border-b); box-shadow:0 0 0 3px rgba(0,200,255,0.1);
}
.field input::placeholder,
.field textarea::placeholder { color:var(--text-3); }
.field input.is-valid { border-color:rgba(16,217,160,0.4); }
.field input.is-invalid { border-color:rgba(239,68,68,0.5); }
.field-help {
  font-size:.72rem; color:var(--text-3);
}
.field-help.is-valid { color:var(--green); }
.field-help.is-invalid { color:#EF4444; }
.optional-marker { font-size:.7rem; font-weight:400; color:var(--text-3); margin-left:4px; }

/* Checkbox */
.checkbox-line, .consent-check {
  display:flex; align-items:flex-start; gap:10px;
  cursor:pointer; font-size:.85rem; color:var(--text-2);
}
.checkbox-line input[type=checkbox],
.consent-check input[type=checkbox] {
  width:16px; height:16px; flex-shrink:0; margin-top:2px;
  accent-color:var(--cyan); cursor:pointer;
  padding:0; border-radius:3px;
}
.consent-check a { color:var(--cyan); }

/* Submit */
.contact-response { margin-top:4px; }
.btn, [data-contact-submit] {
  display:inline-flex; align-items:center; gap:8px;
  padding:.75em 1.8em; border-radius:var(--r);
  font-family:var(--font-display); font-weight:600; font-size:.9rem;
  background:var(--grad-primary); color:#fff; border:none; cursor:pointer;
  transition:all .2s var(--ease);
  box-shadow:0 4px 20px rgba(0,200,255,0.2);
}
.btn:hover, [data-contact-submit]:hover:not(:disabled) {
  filter:brightness(1.1); transform:translateY(-2px);
  box-shadow:0 8px 32px rgba(0,200,255,0.3);
}
.btn:disabled, [data-contact-submit]:disabled,
.btn.is-disabled, [data-contact-submit].is-disabled {
  opacity:.5; cursor:not-allowed; transform:none;
}
.btn.ghost {
  background:transparent; color:var(--text-1);
  border:1px solid var(--border);
  box-shadow:none;
}
.btn.ghost:hover { background:var(--bg-glass); filter:none; }
.btn.is-success { background:linear-gradient(135deg,var(--green),var(--cyan)); }

/* Honeypot */
.hp-field { position:absolute; left:-9999px; opacity:0; pointer-events:none; }

/* Turnstile */
.turnstile-wrap { display:flex; justify-content:flex-start; overflow:hidden; }

/* Contact info cards */
.solution-card-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:20px; }
.solution-card {
  padding:24px; border-radius:var(--r-lg);
  background:var(--bg-card); border:1px solid var(--border);
}
.solution-card h3 {
  font-family:var(--font-display); font-size:.95rem; font-weight:700;
  color:var(--text-1); margin-bottom:8px;
}
.solution-card p { font-size:.85rem; color:var(--text-2); line-height:1.65; }

/* CTA panel for inner pages */
.cta-panel {
  padding:clamp(36px,5vw,60px);
  border-radius:var(--r-xl);
  background:linear-gradient(135deg,rgba(0,200,255,0.06),rgba(139,92,246,0.06));
  border:1px solid rgba(0,200,255,0.15);
  text-align:center;
}
.mini-label {
  display:block; font-size:.72rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; color:var(--cyan);
  margin-bottom:16px;
}
.cta-panel h2 {
  font-family:var(--font-display); font-size:clamp(1.5rem,2.5vw,2.2rem);
  font-weight:700; color:var(--text-1); margin-bottom:12px;
}
.cta-panel p { color:var(--text-2); margin-bottom:24px; }

/* Footer for inner pages */
.footer { background:var(--bg-1); border-top:1px solid var(--border); padding:48px 0 24px; }
.footer-grid { display:flex; flex-direction:column; gap:24px; }
.footer-brand {
  display:flex; align-items:center; gap:10px;
  font-family:var(--font-display); font-weight:700; font-size:1rem; color:var(--text-1);
}
.brand-icon { border-radius:6px; }
.brand-text { display:flex; flex-direction:column; }
.brand-name { line-height:1; }
.brand-sub { font-size:.65rem; color:var(--text-3); font-weight:400; letter-spacing:.04em; }
.footer-copy { font-size:.82rem; color:var(--text-2); margin:12px 0; max-width:320px; }
.footer-links { display:flex; gap:12px; flex-wrap:wrap; font-size:.8rem; color:var(--text-2); }
.footer-links a { color:var(--cyan); }
.footer-links--stack { flex-direction:column; gap:4px; }
.footer-links--legal { margin-top:8px; }
.footer-links .small, .small { font-size:.78rem; }

/* Scroll progress + cursor-glow for inner pages */
.scroll-progress {
  position:fixed; top:0; left:0; z-index:9999;
  height:2px; background:var(--grad-primary); width:0;
  transition:width .1s linear;
}
.cursor-glow {
  position:fixed; z-index:9997; pointer-events:none;
  width:400px; height:400px; border-radius:50%;
  background:radial-gradient(circle,rgba(0,200,255,0.04) 0%,transparent 70%);
  transition:transform .1s linear;
}

/* Topbar for inner pages (compat) */
.topbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(2,4,14,0.85); backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
[data-theme="light"] .topbar { background:rgba(244,247,255,0.92); }
.nav {
  display:flex; align-items:center; gap:16px;
  height:72px; max-width:var(--max-w); margin:0 auto;
  padding:0 clamp(20px,4vw,48px);
}
.brand {
  display:flex; align-items:center; gap:10px;
  font-family:var(--font-display); font-weight:700; font-size:1.05rem;
  color:var(--text-1); text-decoration:none; flex-shrink:0;
}
.nav-links {
  display:flex; gap:2px; margin-left:auto;
}
.nav-links a, .mobile-links a {
  padding:6px 14px; border-radius:var(--r-sm);
  font-size:.875rem; font-weight:500; color:var(--text-2);
  text-decoration:none; transition:color .2s, background .2s;
}
.nav-links a:hover, .mobile-links a:hover { color:var(--text-1); background:var(--bg-glass); }
.nav-links a.active, .mobile-links a.active { color:var(--cyan); }
.nav-actions {
  display:flex; align-items:center; gap:10px; margin-left:auto;
}
.theme-toggle {
  display:flex; align-items:center; gap:6px;
  padding:7px 12px; border:1px solid var(--border);
  border-radius:var(--r-sm); background:var(--bg-glass);
  color:var(--text-2); font-size:.78rem; cursor:pointer;
  transition:all .2s;
}
.theme-toggle:hover { color:var(--cyan); border-color:var(--border-b); }
.mobile-toggle {
  padding:8px 12px; border:1px solid var(--border);
  border-radius:var(--r-sm); background:var(--bg-glass);
  color:var(--text-1); font-size:1rem; cursor:pointer;
  display:none; transition:all .2s;
}
@media(max-width:900px) {
  .nav-links { display:none; }
  .mobile-toggle { display:block; }
}

/* Mobile panel for inner pages */
.mobile-panel {
  max-width:var(--max-w); margin:0 auto;
  padding:16px clamp(20px,4vw,48px) 20px;
  border-top:1px solid var(--border);
  background:rgba(2,4,14,0.95); backdrop-filter:blur(16px);
  display:none;
}
.mobile-panel.open { display:flex; flex-direction:column; gap:8px; }
.mobile-links { display:flex; flex-direction:column; gap:4px; }
.mobile-search { display:none; }
[data-theme="light"] .mobile-panel { background:rgba(244,247,255,0.97); }

/* Search shell (for inner pages) */
.search-shell {
  position:relative; display:flex; align-items:center;
}
.search-input {
  padding:7px 12px 7px 36px; border-radius:var(--r-sm);
  border:1px solid var(--border); background:var(--bg-glass);
  color:var(--text-1); font-size:.8rem; outline:none; width:160px;
  transition:border-color .2s, width .3s;
}
.search-input:focus { border-color:var(--border-b); width:220px; }
.search-icon {
  position:absolute; left:10px; color:var(--text-3); font-size:1rem; pointer-events:none;
}
.search-results {
  position:absolute; top:calc(100% + 8px); left:0; right:0; min-width:280px;
  background:rgba(4,10,24,0.97); border:1px solid var(--border);
  border-radius:var(--r-lg); overflow:hidden; z-index:200;
}
.search-results.hidden { display:none; }
.search-result {
  display:block; padding:12px 16px; border-bottom:1px solid var(--border);
  text-decoration:none; transition:background .15s;
}
.search-result:last-child { border-bottom:none; }
.search-result:hover { background:var(--bg-glass-h); }
.search-result h3 { font-size:.82rem; font-weight:600; color:var(--text-1); margin-bottom:2px; }
.search-result p { font-size:.72rem; color:var(--text-2); }
.search-result small { font-size:.65rem; color:var(--text-3); }
[data-theme="light"] .search-results { background:rgba(244,247,255,0.98); }

/* anchor-offset */
.anchor-offset { scroll-margin-top:calc(var(--nav-h) + 24px); }
.anchor-focus-highlight { outline:2px solid var(--cyan); outline-offset:4px; border-radius:var(--r); }

/* Eyebrow (compat alias) */
.eyebrow {
  display:inline-block; font-size:.72rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; color:var(--cyan);
  margin-bottom:12px;
}

/* Centered links in footer */
.centered-links { text-align:center; }

/* ── 22. WORKFLOW NODES (demo compat) ───────────────────────── */
.workflow-node {
  display:flex; align-items:center; gap:14px;
  padding:12px 16px; border-radius:var(--r);
  background:var(--bg-glass); border:1px solid var(--border);
  transition:all .3s;
}
.workflow-node.is-hidden { display:none; }
.workflow-node.active { background:rgba(0,200,255,0.07); border-color:rgba(0,200,255,0.2); }
.workflow-node.done { background:rgba(16,217,160,0.05); border-color:rgba(16,217,160,0.1); }
.node-status {
  font-size:.68rem; font-weight:600; color:var(--cyan);
  padding:3px 8px; border-radius:100px;
  background:rgba(0,200,255,0.1);
}
.workflow-current { margin-top:12px; padding:8px 0; }
.workflow-toolbar { margin-bottom:12px; }
.btn-row { display:flex; gap:8px; flex-wrap:wrap; }

/* ── 23. PAGE-AT-TOP / SCROLLED ─────────────────────────────── */
body.page-has-scrolled .topbar { box-shadow:0 4px 24px rgba(0,0,0,0.3); }

/* ── 24. REQUIRED MARKERS ───────────────────────────────────── */
.required-marker { color:var(--cyan); margin-left:2px; font-size:.7rem; }
.consent-wrap { display:flex; flex-direction:column; gap:6px; }

/* ── 25. FAQ EXPLORE / SEARCH (compat) ──────────────────────── */
.faq-more-compact { text-align:center; margin-top:32px; }
.faq-more-button {
  background:transparent; border:1px solid var(--border);
  color:var(--text-2); padding:.65em 1.4em; border-radius:var(--r-sm);
  font-family:var(--font-display); font-weight:600; font-size:.875rem;
  cursor:pointer; transition:all .2s;
}
.faq-more-button:hover { border-color:var(--border-b); color:var(--cyan); }
.faq-explorer { margin-top:32px; }
.faq-topic-bar { display:flex; gap:8px; flex-wrap:wrap; margin:16px 0; }
.faq-topic-chip {
  padding:5px 14px; border-radius:100px;
  border:1px solid var(--border); background:var(--bg-glass);
  font-size:.75rem; font-weight:500; color:var(--text-2); cursor:pointer;
  transition:all .2s;
}
.faq-topic-chip:hover,.faq-topic-chip.is-active {
  border-color:var(--border-b); color:var(--cyan); background:var(--cyan-dim);
}
.faq-topic-item.is-hidden { display:none; }
.faq-search {
  position:relative; margin-bottom:16px;
}
.faq-search .search-input { width:100%; }
.faq-search-results { position:absolute; top:calc(100%+8px); left:0; right:0; }

/* ── 26. MEDIA / RESPONSIVE ─────────────────────────────────── */
@media(max-width:640px) {
  .nx-hero-chips { display:none; }
  .nx-stats-grid { grid-template-columns:1fr 1fr; }
  .nx-sol-grid { grid-template-columns:1fr; }
  .nx-problem-grid { grid-template-columns:1fr; }
  .nx-footer-grid { grid-template-columns:1fr; }
}

@media(prefers-reduced-motion:reduce) {
  *,*::before,*::after { animation-duration:.01ms !important; transition-duration:.01ms !important; }
  .nx-cursor, .nx-cursor-trail { display:none; }
}

/* ── 27. IS-LOADED (body class, fade in) ────────────────────── */
body:not(.is-loaded) .nx-hero-layout { opacity:0; }
body.is-loaded .nx-hero-layout { opacity:1; transition:opacity .6s; }

/* ═══════════════════════════════════════════════════════════════
   28. INNER PAGE COMPONENTS — NEXUS Design
   ═══════════════════════════════════════════════════════════════ */

/* ── Inner page hero ─────────────────────────────────────────── */
.nx-page-hero {
  padding: calc(var(--nav-h) + 80px) 0 80px;
  position: relative; overflow: hidden;
  border-bottom: 1px solid var(--border);
  background: var(--bg-1);
}
.nx-page-hero::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 60% 50% at 70% -10%, rgba(0,200,255,0.13) 0%, transparent 55%),
    radial-gradient(ellipse 50% 40% at 15% 110%, rgba(139,92,246,0.09) 0%, transparent 55%);
}
.nx-page-hero::after {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background:
    linear-gradient(rgba(0,200,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,200,255,0.025) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 0%, black 0%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 0%, black 0%, transparent 80%);
}
.nx-page-hero-inner { position: relative; z-index: 2; }
.nx-page-hero-inner .nx-eyebrow { display: block; margin-bottom: 16px; }
.nx-page-hero-h1 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4.5vw, 3.4rem);
  font-weight: 700; line-height: 1.12;
  letter-spacing: -.03em; color: var(--text-1);
  margin-bottom: 20px; max-width: 820px;
}
.nx-page-hero-lead {
  font-size: clamp(.95rem, 1.4vw, 1.1rem);
  color: var(--text-2); line-height: 1.75;
  max-width: 640px; margin-bottom: 36px;
}
.nx-page-hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* Hero split (text left + visual right) */
.nx-page-hero-split {
  display: grid; grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(40px,5vw,80px); align-items: center;
}
@media(max-width:960px) {
  .nx-page-hero-split { grid-template-columns: 1fr; }
  .nx-page-hero-visual { display: none; }
}

/* ── Bento grid (Leistungen) ─────────────────────────────────── */
.nx-bento {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px; margin-top: 48px;
}
.nx-bento-card {
  position: relative; overflow: hidden;
  padding: clamp(24px,3vw,36px);
  border-radius: var(--r-xl);
  background: var(--bg-card);
  border: 1px solid var(--border);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  transition: transform .25s var(--ease), box-shadow .3s, border-color .3s;
  transform-style: preserve-3d; cursor: default;
  grid-column: span 4;
}
.nx-bento-card--wide { grid-column: span 8; display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; }
@media(max-width:960px) { .nx-bento-card { grid-column: span 6; } .nx-bento-card--wide { grid-column: span 12; grid-template-columns: 1fr; } }
@media(max-width:600px) { .nx-bento-card { grid-column: span 12; } }
.nx-bento-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0;
  height: 1px; background: linear-gradient(90deg,transparent,rgba(255,255,255,0.1),transparent);
}
.nx-bento-card:hover {
  border-color: rgba(0,200,255,0.22);
  transform: translateY(-5px);
  box-shadow: var(--shadow-xl), 0 0 28px rgba(0,200,255,0.1);
}
.nx-bento-glow {
  position: absolute; top: -60px; right: -60px;
  width: 200px; height: 200px; border-radius: 50%;
  filter: blur(50px); opacity: 0; transition: opacity .4s; pointer-events: none;
}
.nx-bento-card:hover .nx-bento-glow { opacity: .55; }
.nx-bento-tag {
  display: inline-flex; align-items: center;
  padding: 4px 12px; border-radius: 100px;
  border: 1px solid rgba(0,200,255,0.2);
  background: rgba(0,200,255,0.07);
  font-family: var(--font-mono); font-size: .68rem; font-weight: 700;
  letter-spacing: .07em; color: var(--cyan); margin-bottom: 16px;
}
.nx-bento-card h3 {
  font-family: var(--font-display); font-size: 1.1rem; font-weight: 700;
  color: var(--text-1); margin-bottom: 10px; line-height: 1.3;
}
.nx-bento-card--wide h3 { font-size: 1.35rem; }
.nx-bento-card p { font-size: .875rem; color: var(--text-2); line-height: 1.65; }
.nx-bento-widget {
  display: flex; flex-direction: column; gap: 8px;
  padding: 16px; border-radius: var(--r-lg);
  background: rgba(0,200,255,0.04); border: 1px solid rgba(0,200,255,0.08);
}
.nx-bento-widget-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; border-radius: var(--r-sm);
  background: rgba(255,255,255,0.02); font-size: .75rem;
}
.nx-bw-dot {
  width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
}
.nx-bw-lbl { flex: 1; color: var(--text-2); }
.nx-bw-val { font-weight: 600; color: var(--text-1); font-family: var(--font-mono); font-size: .7rem; }

/* ── Feature split ───────────────────────────────────────────── */
.nx-feat-split {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(40px,6vw,80px); align-items: center;
}
@media(max-width:820px) { .nx-feat-split { grid-template-columns: 1fr; } }
.nx-feat-copy .nx-eyebrow { display: block; margin-bottom: 12px; }
.nx-feat-copy h2 {
  font-family: var(--font-display); font-size: clamp(1.8rem,3vw,2.6rem);
  font-weight: 700; letter-spacing: -.03em; color: var(--text-1);
  line-height: 1.15; margin-bottom: 16px;
}
.nx-feat-copy p { color: var(--text-2); line-height: 1.75; margin-bottom: 16px; font-size: .95rem; }

/* ── Check list ──────────────────────────────────────────────── */
.nx-check-list {
  list-style: none; display: flex; flex-direction: column; gap: 10px; margin-top: 16px;
}
.nx-check-list li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: .875rem; color: var(--text-2); line-height: 1.6;
}
.nx-check-list li::before {
  content: ''; flex-shrink: 0; margin-top: 4px;
  width: 18px; height: 18px; border-radius: 50%;
  background: rgba(16,217,160,0.12) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2.5 6l2.5 2.5 4.5-5' stroke='%2310D9A0' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E") center/11px no-repeat;
  border: 1px solid rgba(16,217,160,0.25);
}

/* ── Code panel ──────────────────────────────────────────────── */
.nx-code-panel {
  position: relative; overflow: hidden; border-radius: var(--r-xl);
  background: rgba(4,8,20,0.95); border: 1px solid var(--border);
  box-shadow: var(--shadow-xl);
  transform: perspective(900px) rotateY(4deg) rotateX(-2deg);
  transition: transform .5s var(--ease-spring);
}
.nx-code-panel:hover { transform: perspective(900px) rotateY(1deg) rotateX(-1deg); }
[data-theme="light"] .nx-code-panel { background: rgba(235,240,255,0.97); }
.nx-cp-head {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 20px; border-bottom: 1px solid var(--border);
  background: rgba(255,255,255,0.02);
}
.nx-cp-dots { display: flex; gap: 6px; }
.nx-cp-dot { width: 10px; height: 10px; border-radius: 50%; }
.nx-cp-dot-r { background: #EF4444; }
.nx-cp-dot-y { background: #F59E0B; }
.nx-cp-dot-g { background: #10B981; }
.nx-cp-title { flex: 1; font-family: var(--font-mono); font-size: .7rem; color: var(--text-3); }
.nx-cp-status { font-size: .68rem; font-weight: 600; color: var(--green); display: flex; align-items: center; gap: 5px; }
.nx-cp-status::before { content: ''; width: 5px; height: 5px; border-radius: 50%; background: var(--green); animation: live-pulse 1.5s ease infinite; }
.nx-cp-body { padding: 16px; display: flex; flex-direction: column; gap: 6px; }
.nx-cp-row {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 16px; border-radius: var(--r);
  background: rgba(255,255,255,0.02); border: 1px solid transparent;
  transition: all .2s;
}
.nx-cp-row.nx-cp-active { background: rgba(0,200,255,0.08); border-color: rgba(0,200,255,0.15); }
.nx-cp-num { font-family: var(--font-mono); font-size: .68rem; color: var(--text-3); flex-shrink: 0; min-width: 22px; }
.nx-cp-text { font-family: var(--font-mono); font-size: .82rem; color: var(--text-2); flex: 1; }
.nx-cp-active .nx-cp-text { color: var(--cyan); font-weight: 600; }
.nx-cp-badge {
  padding: 2px 8px; border-radius: 100px;
  background: rgba(0,200,255,0.12); color: var(--cyan);
  font-size: .62rem; font-weight: 700; letter-spacing: .05em;
  text-transform: uppercase;
}

/* ── Process steps (3-col) ───────────────────────────────────── */
.nx-steps {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: 48px;
}
@media(max-width:768px) { .nx-steps { grid-template-columns: 1fr; } }
.nx-step-card {
  position: relative; padding: clamp(24px,3vw,36px);
  border-radius: var(--r-xl);
  background: var(--bg-card); border: 1px solid var(--border);
  backdrop-filter: blur(12px); transition: all .3s var(--ease); overflow: hidden;
}
.nx-step-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-xl), var(--glow-sm); border-color: rgba(0,200,255,0.2); }
.nx-step-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0;
  height: 2px; background: var(--grad-primary);
  transform-origin: left; transform: scaleX(0); transition: transform .4s var(--ease-expo);
}
.nx-step-card:hover::before { transform: scaleX(1); }
.nx-step-num {
  display: inline-flex; width: 52px; height: 52px;
  align-items: center; justify-content: center; border-radius: 14px;
  background: rgba(0,200,255,0.08); border: 1px solid rgba(0,200,255,0.2);
  font-family: var(--font-display); font-size: 1.4rem; font-weight: 700;
  color: var(--cyan); margin-bottom: 20px;
}
.nx-step-card h3 {
  font-family: var(--font-display); font-size: 1.05rem; font-weight: 700;
  color: var(--text-1); margin-bottom: 10px;
}
.nx-step-card p { font-size: .875rem; color: var(--text-2); line-height: 1.65; }

/* ── Offer cards (Angebote) ──────────────────────────────────── */
.nx-offer-grid {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 24px; margin-top: 48px;
}
@media(max-width:900px) { .nx-offer-grid { grid-template-columns: 1fr; } }
@media(min-width:620px) and (max-width:900px) { .nx-offer-grid { grid-template-columns: repeat(2,1fr); } }

.nx-offer-card {
  position: relative; overflow: hidden;
  padding: clamp(28px,3vw,40px) clamp(24px,3vw,36px);
  border-radius: var(--r-xl);
  background: var(--bg-card); border: 1px solid var(--border);
  backdrop-filter: blur(12px);
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
  display: flex; flex-direction: column;
}
.nx-offer-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-xl), var(--glow-sm);
  border-color: rgba(0,200,255,0.2);
}
.nx-offer-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0;
  height: 2px; background: var(--grad-primary);
  transform-origin: left; transform: scaleX(0);
  transition: transform .4s var(--ease-expo);
}
.nx-offer-card:hover::before { transform: scaleX(1); }
.nx-offer-card--highlight {
  border-color: rgba(0,200,255,0.25);
  background: rgba(0,200,255,0.03);
}
.nx-offer-card--highlight::before { transform: scaleX(1); }
body[data-theme="light"] .nx-offer-card--highlight { background: rgba(0,200,255,0.04); }

.nx-offer-badge {
  position: absolute; top: -1px; right: 20px;
  background: var(--grad-primary); color: #000;
  font-size: .68rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .1em; padding: 4px 12px;
  border-radius: 0 0 8px 8px;
}
.nx-offer-card-tag {
  display: inline-block; font-size: .7rem; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase;
  padding: 3px 10px; border-radius: 20px;
  border: 1px solid rgba(0,200,255,0.2);
  background: rgba(0,200,255,0.07); color: var(--cyan);
  margin-bottom: 20px; align-self: flex-start;
}
.nx-offer-card h3 {
  font-family: var(--font-display); font-size: 1.15rem; font-weight: 700;
  color: var(--text-1); margin-bottom: 8px; line-height: 1.25;
}
.nx-offer-card > p {
  font-size: .85rem; color: var(--text-2); line-height: 1.65; margin-bottom: 20px;
}
.nx-offer-price-wrap { margin-bottom: 24px; }
.nx-offer-price-from {
  display: block; font-size: .7rem; text-transform: uppercase;
  letter-spacing: .1em; color: var(--text-3); margin-bottom: 4px;
}
.nx-offer-price {
  font-family: var(--font-display); font-size: 2rem; font-weight: 700;
  color: var(--text-1); line-height: 1; display: block;
}
.nx-offer-price-vat {
  display: block; font-size: .75rem; color: var(--text-3); margin-top: 5px;
}
.nx-offer-divider {
  height: 1px; background: var(--border); margin-bottom: 20px;
}
.nx-offer-list {
  list-style: none; margin: 0 0 auto; padding: 0;
  display: flex; flex-direction: column; gap: 8px;
}
.nx-offer-list li {
  font-size: .82rem; color: var(--text-2); line-height: 1.5;
  padding-left: 20px; position: relative;
}
.nx-offer-list li::before {
  content: '✓'; position: absolute; left: 0;
  color: var(--cyan); font-weight: 700; font-size: .8rem;
}
.nx-offer-list--not li::before { content: '·'; color: var(--text-3); }
.nx-offer-not-label {
  font-size: .72rem; text-transform: uppercase; letter-spacing: .08em;
  color: var(--text-3); margin: 16px 0 8px; display: block;
}
.nx-offer-card-cta { margin-top: 28px; }

.nx-offer-rabatt {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 20px; border-radius: var(--r);
  background: rgba(16,217,160,0.08); border: 1px solid rgba(16,217,160,0.2);
  margin-bottom: 40px;
}
.nx-offer-rabatt-icon { font-size: 1.3rem; flex-shrink: 0; }
.nx-offer-rabatt strong { color: var(--green); font-weight: 700; }
.nx-offer-rabatt span { font-size: .875rem; color: var(--text-2); }
body[data-theme="light"] .nx-offer-rabatt { background: rgba(16,217,160,0.06); }

.nx-offer-legal {
  font-size: .78rem; color: var(--text-3); line-height: 1.65;
  padding: 16px 20px; border-radius: var(--r);
  background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.06);
  margin-top: 32px;
}
body[data-theme="light"] .nx-offer-legal {
  background: rgba(0,0,0,0.02); border-color: rgba(0,0,0,0.07);
}

/* ── Booking Widget ──────────────────────────────────── */
.booking-wrap {
  max-width: 660px; margin: 48px auto 0;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-xl); padding: clamp(28px,4vw,48px);
  backdrop-filter: blur(12px);
}

/* Step indicator */
.bk-steps {
  display: flex; align-items: center; margin-bottom: 36px;
}
.bk-step-item { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.bk-step-dot {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--bg-glass); border: 1px solid var(--border);
  color: var(--text-3); font-family: var(--font-display);
  font-size: .78rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  transition: all .3s var(--ease); flex-shrink: 0;
}
.bk-step-dot--active {
  background: var(--cyan); border-color: var(--cyan);
  color: #000; box-shadow: 0 0 14px rgba(0,200,255,.4);
}
.bk-step-dot--done {
  background: rgba(0,200,255,.12); border-color: rgba(0,200,255,.3); color: var(--cyan);
}
.bk-step-label {
  font-size: .65rem; color: var(--text-3);
  text-align: center; white-space: nowrap;
}
.bk-step-line {
  flex: 1; height: 1px; background: var(--border);
  margin-bottom: 20px; min-width: 12px;
}

/* Panels */
.bk-panel { display: none; }
.bk-panel--active { display: block; animation: bkFadeIn .2s var(--ease); }
@keyframes bkFadeIn { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:none; } }

.bk-panel-title {
  font-family: var(--font-display); font-size: 1.1rem; font-weight: 700;
  color: var(--text-1); margin-bottom: 20px;
}
.bk-label {
  font-size: .75rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: .08em; color: var(--text-3); margin-bottom: 12px; display: block;
}

/* Type cards */
.bk-type-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media(max-width:480px) { .bk-type-grid { grid-template-columns: 1fr; } }

.bk-type-card {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 20px 16px; border-radius: var(--r);
  background: var(--bg-glass); border: 2px solid var(--border);
  cursor: pointer; transition: all .2s var(--ease); text-align: center;
}
.bk-type-card:hover {
  border-color: rgba(0,200,255,.25);
  background: rgba(0,200,255,.04);
}
.bk-type-card--active {
  border-color: var(--cyan);
  background: rgba(0,200,255,.08);
}
.bk-type-icon { font-size: 1.5rem; }
.bk-type-card strong {
  font-family: var(--font-display); font-size: .9rem; font-weight: 700; color: var(--text-1);
}
.bk-type-sub { font-size: .78rem; color: var(--text-3); }

/* Actions */
.bk-actions { display: flex; justify-content: flex-end; margin-top: 28px; gap: 12px; }
.bk-actions--start { justify-content: flex-start; margin-top: 16px; }

/* Calendar */
.bk-cal-nav {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px;
}
.bk-cal-title {
  font-family: var(--font-display); font-size: 1rem; font-weight: 700; color: var(--text-1);
}
.bk-cal-nav-btn {
  width: 34px; height: 34px; border-radius: var(--r);
  background: var(--bg-glass); border: 1px solid var(--border);
  color: var(--text-2); font-size: 1.2rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .2s var(--ease); line-height: 1;
}
.bk-cal-nav-btn:hover { border-color: rgba(0,200,255,.3); color: var(--cyan); }

.bk-cal-grid {
  display: grid; grid-template-columns: repeat(7,1fr); gap: 4px;
}
.bk-cal-head {
  font-size: .68rem; font-weight: 600; text-align: center;
  color: var(--text-3); text-transform: uppercase; letter-spacing: .05em; padding: 6px 0;
}
.bk-cal-empty { /* spacer */ }
.bk-cal-day {
  aspect-ratio: 1; border-radius: 8px; font-size: .82rem; font-weight: 500;
  background: transparent; border: 1px solid transparent; color: var(--text-2);
  cursor: pointer; transition: all .15s var(--ease);
  display: flex; align-items: center; justify-content: center;
}
.bk-cal-day--available:hover {
  background: rgba(0,200,255,.08); border-color: rgba(0,200,255,.2); color: var(--text-1);
}
.bk-cal-day--selected {
  background: var(--cyan) !important; border-color: var(--cyan) !important;
  color: #000 !important; font-weight: 700;
}
.bk-cal-day--today { border-color: rgba(0,200,255,.35); }
.bk-cal-day--disabled { color: var(--text-3); opacity: .3; cursor: not-allowed; }

/* Slots */
.bk-date-label { font-size: .875rem; color: var(--text-2); margin-bottom: 16px; }
.bk-slots-grid { display: flex; flex-wrap: wrap; gap: 8px; min-height: 52px; }
.bk-slot {
  padding: 9px 18px; border-radius: var(--r);
  background: var(--bg-glass); border: 1px solid var(--border);
  color: var(--text-2); font-size: .875rem; font-weight: 600;
  font-family: var(--font-display); cursor: pointer;
  transition: all .2s var(--ease);
}
.bk-slot:hover { border-color: rgba(0,200,255,.3); color: var(--cyan); background: rgba(0,200,255,.06); }
.bk-slot--selected { background: var(--cyan); border-color: var(--cyan); color: #000; }
.bk-slot-loading, .bk-no-slots { font-size: .85rem; color: var(--text-3); padding: 12px 0; }

/* Form */
.bk-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media(max-width:520px) { .bk-form-grid { grid-template-columns: 1fr; } }

/* Error */
.bk-error {
  padding: 12px 16px; border-radius: var(--r);
  background: rgba(239,68,68,.08); border: 1px solid rgba(239,68,68,.2);
  color: #EF4444; font-size: .85rem; margin-bottom: 16px;
}

/* Confirmation */
.bk-confirm-check {
  width: 56px; height: 56px; border-radius: 50%;
  background: rgba(16,217,160,.1); border: 1px solid rgba(16,217,160,.3);
  color: var(--green); font-size: 1.5rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center; margin-bottom: 16px;
}
.bk-confirm-lead { font-size: .9rem; color: var(--text-2); margin-bottom: 20px; }
.bk-confirm-details {
  background: var(--bg-glass); border: 1px solid var(--border);
  border-radius: var(--r); padding: 16px 20px; margin-bottom: 24px;
}
.bk-confirm-details p { font-size: .875rem; color: var(--text-2); margin: 6px 0; }
.bk-confirm-details strong { color: var(--text-1); }
.bk-confirm-details a { color: var(--cyan); text-decoration: underline; word-break: break-all; }

/* Light theme overrides */
body[data-theme="light"] .bk-type-card--active { background: rgba(0,200,255,.1); }
body[data-theme="light"] .bk-slot--selected { color: #fff; }
body[data-theme="light"] .bk-cal-day--selected { color: #fff !important; }

/* ── Split section ───────────────────────────────────────────── */
.nx-split {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(40px,5vw,64px); align-items: start;
}
@media(max-width:820px) { .nx-split { grid-template-columns: 1fr; } }
.nx-split-copy .nx-eyebrow { display: block; margin-bottom: 12px; }
.nx-split-copy h2 {
  font-family: var(--font-display); font-size: clamp(1.6rem,2.8vw,2.3rem); font-weight: 700;
  letter-spacing: -.03em; color: var(--text-1); margin-bottom: 16px; line-height: 1.2;
}
.nx-split-copy p { font-size: .9rem; color: var(--text-2); line-height: 1.75; }
.nx-split-card {
  padding: clamp(24px,3vw,36px); border-radius: var(--r-xl);
  background: var(--bg-card); border: 1px solid var(--border); backdrop-filter: blur(12px);
}
.nx-split-card h3 {
  font-family: var(--font-display); font-size: 1rem; font-weight: 700;
  color: var(--text-1); margin-bottom: 14px;
}

/* ── Sector grid (Einsatzbereiche) ───────────────────────────── */
.nx-sector-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-top: 48px;
}
@media(max-width:900px) { .nx-sector-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:560px) { .nx-sector-grid { grid-template-columns: 1fr; } }
.nx-sector-card {
  position: relative; overflow: hidden; padding: clamp(24px,3vw,32px);
  border-radius: var(--r-xl); background: var(--bg-card); border: 1px solid var(--border);
  backdrop-filter: blur(12px); transition: all .3s var(--ease); transform-style: preserve-3d;
}
.nx-sector-card::after {
  content: ''; position: absolute; top: 0; left: 0; right: 0;
  height: 3px; border-radius: var(--r-xl) var(--r-xl) 0 0;
  background: var(--grad-primary); opacity: 0; transition: opacity .3s;
}
.nx-sector-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-xl), var(--glow-sm); border-color: rgba(0,200,255,0.2); }
.nx-sector-card:hover::after { opacity: 1; }
.nx-sector-badge {
  display: inline-flex; align-items: center; justify-content: center;
  width: 48px; height: 48px; border-radius: 14px;
  background: rgba(0,200,255,0.08); border: 1px solid rgba(0,200,255,0.15);
  font-size: 1.4rem; margin-bottom: 16px;
}
.nx-sector-card h3 {
  font-family: var(--font-display); font-size: .95rem; font-weight: 700;
  color: var(--text-1); margin-bottom: 8px;
}
.nx-sector-card p { font-size: .82rem; color: var(--text-2); line-height: 1.65; }

/* ── Animated flow diagram ───────────────────────────────────── */
.nx-flow-diagram {
  position: relative; overflow: hidden;
  padding: 28px; border-radius: var(--r-xl);
  background: var(--bg-card); border: 1px solid var(--border); backdrop-filter: blur(12px);
  display: flex; flex-direction: column; align-items: center; gap: 0;
}
.nx-flow-node {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 20px; border-radius: var(--r-lg);
  background: rgba(255,255,255,0.02); border: 1px solid var(--border);
  width: 100%; transition: all .4s var(--ease);
}
.nx-flow-node.nx-fnode-active {
  background: rgba(0,200,255,0.08); border-color: rgba(0,200,255,0.25);
  box-shadow: 0 0 20px rgba(0,200,255,0.12);
}
.nx-flow-node.nx-fnode-done {
  background: rgba(16,217,160,0.05); border-color: rgba(16,217,160,0.15);
}
.nx-flow-icon {
  width: 36px; height: 36px; border-radius: 10px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,200,255,0.1); border: 1px solid rgba(0,200,255,0.15);
  font-size: 1rem;
}
.nx-fnode-done .nx-flow-icon { background: rgba(16,217,160,0.1); border-color: rgba(16,217,160,0.2); }
.nx-flow-node-txt strong { display: block; font-size: .82rem; font-weight: 700; color: var(--text-1); }
.nx-flow-node-txt span { font-size: .72rem; color: var(--text-3); }
.nx-flow-node-status {
  margin-left: auto; width: 24px; height: 24px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .7rem; font-weight: 700; background: var(--border); color: var(--text-3);
}
.nx-fnode-active .nx-flow-node-status { background: rgba(0,200,255,0.15); color: var(--cyan); animation: live-pulse 1.2s ease infinite; }
.nx-fnode-done .nx-flow-node-status { background: rgba(16,217,160,0.15); color: var(--green); }
.nx-flow-line {
  width: 1px; height: 24px; margin: 2px 0;
  background: linear-gradient(to bottom, rgba(0,200,255,0.3), rgba(0,200,255,0.05));
}
.nx-flow-drop {
  width: 6px; height: 6px; border-radius: 50%; background: var(--cyan);
  margin: -3px 0; animation: flow-drop 2s ease infinite;
}
@keyframes flow-drop {
  0%,100% { opacity: 0; transform: translateY(-6px); }
  40%,70%  { opacity: 1; transform: translateY(0); }
}

/* ── Accordion (Über mich) ───────────────────────────────────── */
.nx-accordion { display: flex; flex-direction: column; gap: 12px; margin-top: 48px; }
.nx-accordion-card {
  position: relative; overflow: hidden; border-radius: var(--r-xl);
  border: 1px solid var(--border); background: var(--bg-card);
  backdrop-filter: blur(12px); transition: border-color .3s;
}
.nx-accordion-card[open] { border-color: rgba(0,200,255,0.25); }
.nx-accordion-summary {
  display: flex; align-items: center; gap: 16px;
  padding: clamp(20px,3vw,28px); cursor: pointer;
  list-style: none;
}
.nx-accordion-summary::-webkit-details-marker,
.nx-accordion-summary::marker { display: none; }
.nx-accordion-icon {
  display: flex; align-items: center; justify-content: center;
  width: 46px; height: 46px; border-radius: 13px; flex-shrink: 0;
  background: rgba(0,200,255,0.08); border: 1px solid rgba(0,200,255,0.15);
  font-size: 1.25rem; transition: all .3s;
}
.nx-accordion-card[open] .nx-accordion-icon { background: rgba(0,200,255,0.15); border-color: rgba(0,200,255,0.3); }
.nx-accordion-info { flex: 1; }
.nx-accordion-label {
  display: block; font-size: .68rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase; color: var(--cyan); margin-bottom: 4px;
}
.nx-accordion-info h3 {
  font-family: var(--font-display); font-size: 1rem; font-weight: 700;
  color: var(--text-1); line-height: 1.3; margin-bottom: 0;
}
.nx-accordion-preview { font-size: .82rem; color: var(--text-2); margin-top: 4px; line-height: 1.55; }
.nx-accordion-chevron {
  width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--border); color: var(--text-3); font-size: .8rem;
  transition: transform .3s, background .2s, color .2s;
}
.nx-accordion-card[open] .nx-accordion-chevron {
  transform: rotate(45deg); background: var(--cyan-dim); color: var(--cyan);
}
.nx-accordion-body {
  padding: 0 clamp(20px,3vw,28px) clamp(20px,3vw,28px);
  padding-left: calc(clamp(20px,3vw,28px) + 46px + 16px);
  border-top: 1px solid var(--border);
  padding-top: 20px;
}
.nx-accordion-body ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.nx-accordion-body li {
  display: flex; gap: 10px; font-size: .875rem; color: var(--text-2); line-height: 1.65;
}
.nx-accordion-body li::before { content: '→'; color: var(--cyan); flex-shrink: 0; margin-top: 1px; }

/* ── Workflow demo cards (Beispiele) ─────────────────────────── */
.nx-demo-grid { display: flex; flex-direction: column; gap: 24px; margin-top: 40px; }
.nx-flow-card {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  border-radius: var(--r-xl); overflow: hidden;
  border: 1px solid var(--border); background: var(--bg-card);
  backdrop-filter: blur(12px); transition: border-color .3s, box-shadow .3s;
}
.nx-flow-card:hover { border-color: rgba(0,200,255,0.2); box-shadow: var(--shadow-lg); }
@media(max-width:768px) { .nx-flow-card { grid-template-columns: 1fr; } }
.nx-flow-copy {
  padding: clamp(28px,4vw,48px);
  border-right: 1px solid var(--border);
}
@media(max-width:768px) { .nx-flow-copy { border-right: none; border-bottom: 1px solid var(--border); } }
.nx-flow-tag {
  display: inline-block; padding: 4px 12px; border-radius: 100px;
  background: rgba(0,200,255,0.08); border: 1px solid rgba(0,200,255,0.15);
  font-size: .7rem; font-weight: 600; letter-spacing: .04em;
  color: var(--cyan); margin-bottom: 14px;
}
.nx-flow-copy h3 {
  font-family: var(--font-display); font-size: 1.2rem; font-weight: 700;
  color: var(--text-1); margin-bottom: 10px;
}
.nx-flow-copy p { font-size: .875rem; color: var(--text-2); line-height: 1.65; margin-bottom: 20px; }
.nx-flow-snapshot { display: flex; flex-direction: column; gap: 8px; margin-top: 16px; padding: 14px 16px; border-radius: var(--r-lg); background: rgba(255,255,255,0.02); border: 1px solid var(--border); }
.nx-flow-snap-row { display: flex; gap: 10px; font-size: .78rem; align-items: flex-start; }
.nx-flow-snap-row strong { color: var(--text-3); flex-shrink: 0; min-width: 60px; }
.nx-flow-snap-row span { color: var(--text-2); }
.nx-flow-dashboard { padding: 20px; background: rgba(2,4,14,0.5); }
[data-theme="light"] .nx-flow-dashboard { background: rgba(220,228,255,0.4); }

/* ── Outcome cards (Beispiele) ───────────────────────────────── */
.nx-outcome-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 40px;
}
@media(max-width:768px) { .nx-outcome-grid { grid-template-columns: 1fr; } }
.nx-outcome-card {
  position: relative; overflow: hidden; padding: clamp(28px,3.5vw,40px);
  border-radius: var(--r-xl); background: var(--bg-card); border: 1px solid var(--border);
  backdrop-filter: blur(12px); transition: all .3s var(--ease);
}
.nx-outcome-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-xl); border-color: rgba(0,200,255,0.2); }
.nx-outcome-num {
  font-family: var(--font-display); font-size: 3rem; font-weight: 700;
  letter-spacing: -.05em; line-height: 1; margin-bottom: 16px;
  background: var(--grad-primary);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.nx-outcome-card h3 {
  font-family: var(--font-display); font-size: 1rem; font-weight: 700;
  color: var(--text-1); margin-bottom: 10px;
}
.nx-outcome-card p { font-size: .875rem; color: var(--text-2); line-height: 1.65; }

/* ── Note box ────────────────────────────────────────────────── */
.nx-note {
  padding: 16px 20px; border-radius: var(--r-lg); margin-top: 24px;
  background: rgba(0,200,255,0.04); border: 1px solid rgba(0,200,255,0.1);
  font-size: .82rem; color: var(--text-2); line-height: 1.65;
}
.nx-note strong { color: var(--text-1); }

/* ── Pills + trust (Über mich) ───────────────────────────────── */
.nx-pills { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 24px; }
.nx-pill {
  padding: 6px 16px; border-radius: 100px;
  background: rgba(0,200,255,0.08); border: 1px solid rgba(0,200,255,0.18);
  font-size: .78rem; font-weight: 600; color: var(--cyan);
}
.nx-trust { display: flex; gap: 20px; flex-wrap: wrap; margin-top: 24px; }
.nx-trust-item { display: flex; align-items: center; gap: 8px; font-size: .8rem; color: var(--text-2); }
.nx-trust-item::before {
  content: ''; flex-shrink: 0;
  width: 18px; height: 18px; border-radius: 50%;
  background: rgba(16,217,160,0.12) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2.5 6l2.5 2.5 4.5-5' stroke='%2310D9A0' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E") center/11px no-repeat;
  border: 1px solid rgba(16,217,160,0.25);
}

/* Über mich hero floating deco */
.nx-ueber-deco { display: flex; flex-direction: column; gap: 12px; }
.nx-ueber-deco-card {
  padding: 18px 22px; border-radius: var(--r-xl);
  background: var(--bg-card); border: 1px solid var(--border); backdrop-filter: blur(12px);
  transform: perspective(700px) rotateY(-6deg) rotateX(2deg);
  transition: transform .4s var(--ease-spring);
  animation: float 5s ease-in-out infinite;
}
.nx-ueber-deco-card:nth-child(2) { animation-delay: 1.4s; transform: perspective(700px) rotateY(-6deg) rotateX(2deg) translateX(16px); }
.nx-ueber-deco-card:nth-child(3) { animation-delay: 2.8s; transform: perspective(700px) rotateY(-6deg) rotateX(2deg) translateX(-8px); }
.nx-ueber-deco-card:hover { transform: perspective(700px) rotateY(-2deg) rotateX(1deg) translateX(0) !important; }
.nx-deco-label {
  font-size: .65rem; font-weight: 700; letter-spacing: .07em;
  text-transform: uppercase; color: var(--text-3); margin-bottom: 6px;
}
.nx-deco-val {
  font-family: var(--font-display); font-size: .95rem; font-weight: 700;
  color: var(--text-1); margin-bottom: 3px;
}
.nx-deco-sub { font-size: .75rem; color: var(--text-2); }
.nx-deco-bar {
  height: 3px; border-radius: 2px; margin-top: 10px;
  background: var(--grad-primary); opacity: .6;
}

/* ── Page-level CTA ──────────────────────────────────────────── */
.nx-page-cta {
  position: relative; overflow: hidden; padding: clamp(48px,6vw,80px);
  border-radius: var(--r-2xl); text-align: center;
  background: linear-gradient(135deg,rgba(0,200,255,0.06),rgba(139,92,246,0.06));
  border: 1px solid rgba(0,200,255,0.12);
}
.nx-page-cta::before {
  content: ''; position: absolute; top: -120px; left: 50%; transform: translateX(-50%);
  width: 700px; height: 450px; border-radius: 50%;
  background: radial-gradient(ellipse, rgba(0,200,255,0.1) 0%, transparent 65%); pointer-events: none;
}
.nx-page-cta-inner { position: relative; z-index: 1; max-width: 600px; margin: 0 auto; }
.nx-page-cta .nx-eyebrow { display: block; margin-bottom: 16px; }
.nx-page-cta h2 {
  font-family: var(--font-display); font-size: clamp(1.6rem,2.8vw,2.4rem);
  font-weight: 700; letter-spacing: -.03em; color: var(--text-1); margin-bottom: 14px;
}
.nx-page-cta p { color: var(--text-2); margin-bottom: 28px; font-size: .95rem; line-height: 1.7; }
.nx-page-cta-actions { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }

/* ── Section head variants ───────────────────────────────────── */
.nx-section-head { margin-bottom: 0; }
.nx-section-head .nx-eyebrow { display: block; margin-bottom: 12px; }
.nx-section-head h2 {
  font-family: var(--font-display); font-size: clamp(1.8rem,3.2vw,2.7rem);
  font-weight: 700; letter-spacing: -.03em; color: var(--text-1);
  line-height: 1.15; margin-bottom: 14px;
}
.nx-section-head p { font-size: clamp(.9rem,1.3vw,1rem); color: var(--text-2); line-height: 1.75; max-width: 620px; }
.nx-section-head--center { text-align: center; }
.nx-section-head--center p { margin-left: auto; margin-right: auto; }

/* ── Process grid (3-col bordered) ───────────────────────────── */
.nx-proc-grid {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 0; margin-top: 48px;
  border: 1px solid var(--border); border-radius: var(--r-xl); overflow: hidden;
  background: var(--bg-card); backdrop-filter: blur(12px);
}
@media(max-width:768px) {
  .nx-proc-grid { grid-template-columns: 1fr; }
  .nx-proc-grid .nx-proc-step { border-right: none !important; border-bottom: 1px solid var(--border) !important; }
  .nx-proc-grid .nx-proc-step:last-child { border-bottom: none !important; }
}

/* ── Responsive helpers ──────────────────────────────────────── */
@media(max-width:640px) {
  .nx-page-hero { padding-top: calc(var(--nav-h) + 48px); padding-bottom: 48px; }
  .nx-page-cta { padding: 40px 24px; border-radius: var(--r-xl); }
  .nx-steps { gap: 16px; }
  .nx-outcome-grid { gap: 16px; }
  .nx-bento { gap: 12px; }
}
