/* ============================================================
   9seventy — Dark Mode · Mobile-first · Uncode-inspired
   ============================================================ */

/* 1. TOKENS ================================================== */
:root {
  --bg:            #0e1012;
  --bg-2:          #12151a;
  --bg-card:       rgba(255,255,255,0.04);
  --bg-card-h:     rgba(255,255,255,0.07);
  --accent:        #0084ff;
  --accent-2:      #00c6ff;
  --accent-dim:    rgba(0,132,255,0.12);
  --accent-glow:   rgba(0,132,255,0.3);
  --purple:        #7c3aed;
  --purple-dim:    rgba(124,58,237,0.12);
  --green:         #22c55e;
  --green-dim:     rgba(34,197,94,0.12);
  --text:          #f0f4f8;
  --text-muted:    #8896aa;
  --text-subtle:   #44556a;
  --border:        rgba(255,255,255,0.07);
  --border-h:      rgba(255,255,255,0.13);
  --border-accent: rgba(0,132,255,0.28);
  --grad-accent:   linear-gradient(135deg, #0084ff 0%, #00c6ff 100%);
  --font-h: 'Inter', system-ui, -apple-system, sans-serif;
  --font-b: 'Quicksand', system-ui, sans-serif;
  --r-sm:  0.375rem;  --r-md:  0.75rem;
  --r-lg:  1.125rem;  --r-xl:  1.5rem;
  --r-2xl: 2rem;      --r-3xl: 2.5rem;
  --ease: cubic-bezier(0.16,1,0.3,1);
}

/* 2. RESET =================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-b);font-size:1rem;line-height:1.7;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}
img,svg{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
em{font-style:normal}

/* 3. LAYOUT ================================================== */
.container{width:100%;max-width:1200px;margin-inline:auto;padding-inline:1.25rem}
.section{padding-block:5rem}
@media(min-width:768px){.container{padding-inline:2rem}}
@media(min-width:1024px){.section{padding-block:7.5rem}}

/* 4. TYPE UTILITIES ========================================== */
h1,h2,h3,h4{font-family:var(--font-h);font-weight:800;line-height:1.1;letter-spacing:-.03em}

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

.section-label{
  display:inline-block;font-family:var(--font-h);font-size:.6875rem;
  font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1rem;
}
.section-title{font-size:clamp(1.875rem,4.5vw,3rem);margin-bottom:1.125rem}
.section-description{color:var(--text-muted);font-size:1.0625rem;line-height:1.8;max-width:560px}
.section-header{text-align:center;margin-bottom:4rem}
.section-header .section-description{margin-inline:auto}

/* 5. BUTTONS ================================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.9375rem 1.875rem;border-radius:var(--r-lg);
  font-family:var(--font-h);font-size:.9375rem;font-weight:600;letter-spacing:.01em;
  border:1.5px solid transparent;white-space:nowrap;
  transition:background .2s ease,border-color .2s ease,box-shadow .25s ease,transform .25s var(--ease),filter .2s ease,color .2s ease;
}
.btn:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
.btn-primary{background:var(--grad-accent);color:#fff;box-shadow:0 4px 24px rgba(0,132,255,.28)}
.btn-primary:hover{box-shadow:0 8px 36px rgba(0,132,255,.5),0 0 0 4px var(--accent-dim);transform:translateY(-2px);filter:brightness(1.08)}
.btn-ghost{background:transparent;color:var(--text-muted);border-color:var(--border-h)}
.btn-ghost:hover{color:var(--text);border-color:rgba(255,255,255,.25);background:var(--bg-card)}
.btn-lg{padding:1.0625rem 2.25rem;font-size:1rem;border-radius:var(--r-xl)}
.btn-full{width:100%}

/* 6. NAVIGATION ============================================== */
.site-header{
  position:fixed;inset-block-start:0;inset-inline:0;z-index:100;
  padding-block:1.25rem;
  transition:background .3s ease,box-shadow .3s ease,backdrop-filter .3s ease;
}
.site-header.scrolled{
  background:rgba(14,16,18,.85);
  backdrop-filter:blur(24px) saturate(160%);
  -webkit-backdrop-filter:blur(24px) saturate(160%);
  box-shadow:0 1px 0 var(--border);
}
.nav-container{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.logo{display:inline-flex;align-items:center;transition:opacity .2s ease;flex-shrink:0}
.logo:hover{opacity:.8}
.logo-img{height:32px;width:auto;display:block}
.nav-toggle{display:none}
.nav-hamburger{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:.5rem;margin:-.5rem;z-index:110;position:relative}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:transform .3s var(--ease),opacity .2s ease;transform-origin:center}
.nav-toggle:checked + .nav-hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle:checked + .nav-hamburger span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle:checked + .nav-hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-menu{display:flex;flex-direction:column;align-items:center;position:fixed;inset:0;background:#0e1012;padding-top:5.5rem;opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:90}
.nav-toggle:checked ~ .nav-menu{opacity:1;pointer-events:all}
.nav-link{font-family:var(--font-h);font-size:1.5rem;font-weight:600;color:var(--text-muted);padding:1rem 2rem;width:100%;text-align:center;border-bottom:1px solid var(--border);transition:color .2s ease}
.nav-link:last-child{border-bottom:none}
.nav-link:hover{color:var(--text)}
.nav-cta{margin-top:2rem;background:var(--grad-accent);color:#fff!important;border-radius:var(--r-lg);width:auto;padding:.875rem 2.5rem;border-bottom:none!important}
@media(min-width:768px){
  .nav-hamburger{display:none}
  .nav-menu{position:static;flex-direction:row;align-items:center;gap:.125rem;background:none;padding:0;opacity:1;pointer-events:all}
  .nav-link{font-size:.9rem;font-weight:500;padding:.5rem .875rem;border-radius:var(--r-md);width:auto;text-align:left;border-bottom:none}
  .nav-cta{font-size:.875rem;margin-top:0;margin-left:1.25rem;padding:.5625rem 1.375rem;border-radius:var(--r-md)}
}

/* 7. HERO ==================================================== */
.hero{
  position:relative;min-height:100vh;display:flex;flex-direction:column;
  justify-content:center;padding-top:7rem;padding-bottom:4rem;overflow:hidden;
}
/* Orbs */
.hero-orb{position:absolute;border-radius:50%;pointer-events:none;filter:blur(90px)}
.hero-orb-1{width:700px;height:700px;background:radial-gradient(circle,rgba(0,132,255,.15) 0%,transparent 70%);top:-200px;left:-200px;animation:drift 18s ease-in-out infinite alternate}
.hero-orb-2{width:500px;height:500px;background:radial-gradient(circle,rgba(0,198,255,.09) 0%,transparent 70%);top:50%;right:-100px;transform:translateY(-50%);animation:drift 22s ease-in-out 4s infinite alternate-reverse}
.hero-orb-3{width:350px;height:350px;background:radial-gradient(circle,rgba(124,58,237,.07) 0%,transparent 70%);bottom:80px;left:30%;animation:drift 16s ease-in-out 8s infinite alternate}
@keyframes drift{from{transform:translate(0,0)}to{transform:translate(30px,20px)}}
/* Grid */
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 90% 80% at 50% 40%,black 20%,transparent 90%);-webkit-mask-image:radial-gradient(ellipse 90% 80% at 50% 40%,black 20%,transparent 90%);pointer-events:none}
/* Floating particles */
.particles,.section-particles,.cta-strip-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.particles span,.section-particles span,.cta-strip-particles span{
  position:absolute;width:4px;height:4px;background:var(--accent);border-radius:50%;
  opacity:0;animation:particle-float 8s ease-in-out infinite;
}
.particles span:nth-child(1){left:10%;top:20%;animation-delay:0s;animation-duration:7s}
.particles span:nth-child(2){left:25%;top:60%;animation-delay:1.2s;animation-duration:9s}
.particles span:nth-child(3){left:50%;top:15%;animation-delay:2.1s;animation-duration:6s}
.particles span:nth-child(4){left:70%;top:70%;animation-delay:.8s;animation-duration:8s}
.particles span:nth-child(5){left:85%;top:30%;animation-delay:3s;animation-duration:7.5s}
.particles span:nth-child(6){left:40%;top:80%;animation-delay:1.5s;animation-duration:10s}
.particles span:nth-child(7){left:60%;top:45%;animation-delay:2.7s;animation-duration:8.5s}
.particles span:nth-child(8){left:15%;top:90%;animation-delay:.4s;animation-duration:6.5s}
@keyframes particle-float{
  0%{opacity:0;transform:translateY(0) scale(0)}
  20%{opacity:.6;transform:translateY(-20px) scale(1)}
  80%{opacity:.3;transform:translateY(-80px) scale(.8)}
  100%{opacity:0;transform:translateY(-120px) scale(0)}
}
/* Hero inner */
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr;gap:3.5rem;align-items:center}
@media(min-width:1024px){.hero-inner{grid-template-columns:1fr 1fr;gap:4rem}}
/* Hero text */
.hero-text{display:flex;flex-direction:column;gap:1.625rem}
.hero-pill{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-h);font-size:.75rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);padding:.4375rem 1.125rem;background:var(--accent-dim);border:1px solid var(--border-accent);border-radius:999px;width:fit-content}
.hero-pill-dot{width:7px;height:7px;background:var(--accent);border-radius:50%;animation:pulse-dot 2.5s ease-in-out infinite;flex-shrink:0}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1);box-shadow:0 0 0 0 var(--accent-glow)}50%{opacity:.7;transform:scale(.8)}}
.hero-heading{font-size:clamp(3rem,7.5vw,5.75rem);font-weight:900;line-height:1.04;letter-spacing:-.045em}
.hero-sub{font-size:clamp(1rem,2vw,1.125rem);color:var(--text-muted);max-width:500px;line-height:1.8}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem}
.hero-stats{display:flex;align-items:center;gap:1rem;padding-top:1.75rem;border-top:1px solid var(--border);flex-wrap:nowrap}
.stat{display:flex;flex-direction:column;gap:.125rem;min-width:0}
.stat-value{font-family:var(--font-h);font-size:1.3rem;font-weight:800;letter-spacing:-.03em;line-height:1}
.stat-value sup{font-size:.7em}
.stat-label{font-size:.6875rem;color:var(--text-muted);white-space:nowrap}
.stat-sep{width:1px;height:2rem;background:var(--border);flex-shrink:0}
@media(min-width:640px){
  .hero-stats{gap:1.5rem}
  .stat-value{font-size:1.75rem}
  .stat-label{font-size:.8125rem}
  .stat-sep{height:2.5rem}
}
/* Scroll indicator */
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;opacity:.4}
.hero-scroll-line{width:1px;height:3.5rem;background:linear-gradient(to bottom,var(--accent),transparent);animation:scroll-line 2s ease-in-out infinite}
@keyframes scroll-line{0%{transform:scaleY(0);transform-origin:top;opacity:1}50%{transform:scaleY(1);transform-origin:top;opacity:1}100%{transform:scaleY(1);transform-origin:bottom;opacity:0}}

/* 8. HERO VISUAL ============================================= */
.hero-visual{position:relative;display:none;height:420px}
@media(min-width:1024px){.hero-visual{display:block}}
/* Dashboard */
.hv-dashboard{position:absolute;top:0;left:20px;right:20px;background:rgba(18,22,30,.92);border:1px solid var(--border-h);border-radius:var(--r-xl);padding:1.5rem;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 0 0 1px rgba(255,255,255,.04) inset,0 32px 64px rgba(0,0,0,.5),0 0 60px rgba(0,132,255,.06);animation:float-main 7s ease-in-out infinite}
@keyframes float-main{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hv-dash-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem}
.hv-dash-title{font-family:var(--font-h);font-size:.9375rem;font-weight:600;color:var(--text);margin-bottom:.25rem}
.hv-dash-sub{font-size:.75rem;color:var(--text-muted)}
.hv-dash-badge{display:flex;align-items:center;gap:.375rem;font-family:var(--font-h);font-size:.6875rem;font-weight:600;color:var(--green);background:var(--green-dim);border:1px solid rgba(34,197,94,.2);padding:.25rem .625rem;border-radius:999px}
.hv-dash-badge::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse-dot 2s ease-in-out infinite}
.hv-chart{margin-bottom:1.25rem}
.hv-bars{display:flex;align-items:flex-end;gap:6px;height:100px;padding-top:.5rem}
.hv-bar{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:.375rem;height:100%}
.hv-bar-fill{width:100%;background:linear-gradient(to top,rgba(0,132,255,.25),rgba(0,198,255,.07));border-radius:4px 4px 0 0}
.hv-bar:nth-child(1) .hv-bar-fill{height:18%}.hv-bar:nth-child(2) .hv-bar-fill{height:28%}
.hv-bar:nth-child(3) .hv-bar-fill{height:42%}.hv-bar:nth-child(4) .hv-bar-fill{height:52%}
.hv-bar:nth-child(5) .hv-bar-fill{height:63%}
.hv-bar-peak .hv-bar-fill{height:97%;background:linear-gradient(to top,var(--accent),rgba(0,198,255,.4))!important;box-shadow:0 0 16px rgba(0,132,255,.4)}
.hv-bar-label{font-family:var(--font-h);font-size:.625rem;color:var(--text-subtle)}
.hv-dash-foot{display:flex;gap:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}
.hv-foot-metric{display:flex;flex-direction:column;gap:.125rem}
.hv-foot-val{font-family:var(--font-h);font-size:1.125rem;font-weight:700;letter-spacing:-.03em}
.hv-foot-val.positive{color:var(--green)}
.hv-foot-lbl{font-size:.6875rem;color:var(--text-muted)}
/* Chips */
.hv-chip{position:absolute;display:flex;align-items:center;gap:.75rem;background:rgba(18,22,30,.93);border:1px solid var(--border-h);border-radius:var(--r-lg);padding:.75rem 1rem;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 8px 32px rgba(0,0,0,.4),0 0 0 1px rgba(255,255,255,.04) inset;white-space:nowrap;z-index:2}
.hv-chip-1{right:-20px;top:24px;animation:float-a 5s ease-in-out infinite}
.hv-chip-2{left:-10px;bottom:90px;animation:float-b 6s ease-in-out 1s infinite}
.hv-chip-3{right:10px;bottom:30px;animation:float-c 5.5s ease-in-out 2s infinite}
@keyframes float-a{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes float-b{0%,100%{transform:translateY(-6px)}50%{transform:translateY(8px)}}
@keyframes float-c{0%,100%{transform:translateY(4px)}50%{transform:translateY(-10px)}}
.hv-chip-icon{width:30px;height:30px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hv-chip-icon-green{background:var(--green-dim);color:var(--green)}
.hv-chip-icon-blue{background:var(--accent-dim);color:var(--accent)}
.hv-chip-icon-purple{background:var(--purple-dim);color:#a78bfa}
.hv-chip-val{font-family:var(--font-h);font-size:.9375rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}
.hv-chip-lbl{font-size:.6875rem;color:var(--text-muted);margin-top:.0625rem}

/* 9. LEISTUNGEN — Feature Rows =============================== */
.leistungen{
  background:var(--bg-2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  position:relative;overflow:hidden;
}
/* Section animated particles */
.section-particles span:nth-child(1){left:5%;top:30%;animation-delay:0s;animation-duration:8s;background:var(--accent)}
.section-particles span:nth-child(2){left:80%;top:50%;animation-delay:2s;animation-duration:9s;background:var(--accent-2);width:3px;height:3px}
.section-particles span:nth-child(3){left:60%;top:10%;animation-delay:4s;animation-duration:7s;background:var(--accent);width:2px;height:2px}
.section-particles span:nth-child(4){left:20%;top:70%;animation-delay:1s;animation-duration:11s;background:var(--accent-2);width:3px;height:3px}
.section-particles span:nth-child(5){left:90%;top:80%;animation-delay:3s;animation-duration:8s;background:var(--accent);width:2px;height:2px}
.section-particles span:nth-child(6){left:45%;top:90%;animation-delay:5s;animation-duration:9s;background:var(--accent-2)}

.feature-row{
  display:grid;grid-template-columns:1fr;gap:3rem;
  align-items:stretch;
  padding-block:4rem;
  border-bottom:1px solid var(--border);
  position:relative;
}
.feature-row:last-child{border-bottom:none;padding-bottom:0}
.feature-row-reverse .feature-row-visual{order:1}
.feature-row-reverse .feature-row-content{order:0}
@media(min-width:1024px){
  .feature-row{grid-template-columns:1fr 1fr;gap:5rem;padding-block:5rem}
  .feature-row-reverse .feature-row-content{order:2}
  .feature-row-reverse .feature-row-visual{order:1}
}

.feature-row-content{display:flex;flex-direction:column;gap:1.25rem;position:relative;z-index:1;justify-content:center}
.feature-icon-wrap{
  width:72px;height:72px;
  background:var(--accent-dim);border:1px solid var(--border-accent);
  border-radius:var(--r-xl);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  box-shadow:0 0 30px var(--accent-dim);
  transition:box-shadow .3s ease,transform .3s var(--ease);
}
.feature-row:hover .feature-icon-wrap{box-shadow:0 0 50px rgba(0,132,255,.25);transform:scale(1.05)}
.feature-badge-wrap{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.feature-badge{
  display:inline-block;background:var(--grad-accent);color:#fff;
  font-family:var(--font-h);font-size:.6875rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  padding:.3rem .875rem;border-radius:999px;
  box-shadow:0 4px 16px rgba(0,132,255,.35);
}
.feature-badge-new{
  display:inline-block;background:var(--purple-dim);color:#a78bfa;
  border:1px solid rgba(124,58,237,.3);
  font-family:var(--font-h);font-size:.6875rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  padding:.3rem .875rem;border-radius:999px;
  margin-bottom:.25rem;
}
.feature-title{font-size:clamp(2.5rem,5vw,4rem);font-weight:900;letter-spacing:-.05em}
.feature-description{font-size:1.0625rem;color:var(--text-muted);line-height:1.8;max-width:460px}
.feature-list{display:flex;flex-direction:column;gap:.625rem}
.feature-list li{font-size:1.0625rem;color:var(--text-muted);padding-left:1.375rem;position:relative}
.feature-list li::before{content:'';position:absolute;left:0;top:.35em;width:14px;height:10px;background-color:var(--accent);-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 10'%3E%3Cpath d='M0 5h11M8 1l4 4-4 4' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 10'%3E%3Cpath d='M0 5h11M8 1l4 4-4 4' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E");-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:contain;mask-size:contain}
.feature-cta{align-self:flex-start;margin-top:.5rem}

/* ---- Feature Row Visuals ---- */
.feature-row-visual{
  position:relative;
  display:flex;align-items:stretch;justify-content:center;
  min-height:320px;
}
@media(min-width:1024px){.feature-row-visual{min-height:380px}}

/* SERP mockup */
.vis-serp{
  width:100%;max-width:460px;
  background:rgba(16,20,28,.95);border:1px solid var(--border-h);
  border-radius:var(--r-xl);padding:1.5rem;
  box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.04) inset,0 0 60px rgba(0,132,255,.05);
  position:relative;
  animation:float-main 8s ease-in-out 1s infinite;
}
.vis-serp-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;background:rgba(255,255,255,.05);border-radius:var(--r-md);padding:.5rem .875rem}
.vis-serp-bar-inner{width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent-glow);flex-shrink:0}
.vis-serp-bar span{font-size:.75rem;color:var(--text-subtle);font-family:var(--font-h)}
.vis-serp-result{padding:.875rem;margin-bottom:.5rem;border-radius:var(--r-md);transition:background .2s ease}
.vis-serp-result-ad{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05)}
.vis-serp-badge{display:inline-block;font-family:var(--font-h);font-size:.625rem;font-weight:600;color:#f59e0b;background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.2);padding:.125rem .5rem;border-radius:3px;margin-bottom:.375rem}
.vis-serp-result-first{background:linear-gradient(135deg,rgba(0,132,255,.08),rgba(0,198,255,.04));border:1px solid var(--border-accent);animation:serp-pulse 3s ease-in-out infinite;position:relative}
@keyframes serp-pulse{0%,100%{box-shadow:0 0 0 0 rgba(0,132,255,.2)}50%{box-shadow:0 0 0 6px rgba(0,132,255,0)}}
.vis-serp-rank{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--grad-accent);color:#fff;font-family:var(--font-h);font-size:.5625rem;font-weight:800;border-radius:4px;float:right;margin-left:.5rem;margin-top:.125rem}
.vis-serp-url{font-size:.6875rem;color:var(--green);margin-bottom:.25rem}
.vis-serp-title{font-family:var(--font-h);font-size:.875rem;font-weight:600;margin-bottom:.25rem}
.vis-serp-title-dim{color:var(--text-muted);font-weight:400}
.vis-serp-desc{font-size:.75rem;color:var(--text-muted);line-height:1.5}
.vis-serp-glow{position:absolute;inset:-40px;background:radial-gradient(circle at 30% 50%,rgba(0,132,255,.07),transparent 60%);pointer-events:none;z-index:-1}

/* Ads dashboard visual */
.vis-ads{
  width:100%;max-width:460px;
  background:rgba(16,20,28,.95);border:1px solid var(--border-h);
  border-radius:var(--r-xl);padding:1.5rem;
  box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.04) inset;
  animation:float-main 9s ease-in-out .5s infinite;
  display:flex;flex-direction:column;justify-content:space-between;
}
.vis-ads-head{display:flex;align-items:center;gap:.625rem;font-family:var(--font-h);font-size:.8125rem;font-weight:600;color:var(--text-muted);margin-bottom:1.25rem}
.vis-ads-dot{width:8px;height:8px;background:var(--green);border-radius:50%;animation:pulse-dot 2s ease-in-out infinite;flex-shrink:0}
.vis-ads-metrics{display:flex;gap:1.5rem;margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border)}
.vis-ads-metric{display:flex;flex-direction:column;gap:.25rem}
.vis-ads-val{font-family:var(--font-h);font-size:1.5rem;font-weight:800;letter-spacing:-.03em;color:var(--text)}
.vis-ads-val.positive{color:var(--green)}
.vis-ads-lbl{font-size:.6875rem;color:var(--text-muted)}
/* Ads campaign rows */
.vis-ads-campaigns{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.125rem}
.vis-ads-camp-lbl{font-family:var(--font-h);font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle);margin-bottom:.25rem}
.vis-ads-campaign{display:flex;align-items:center;gap:.625rem;padding:.45rem .75rem;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--r-md)}
.vis-ads-c-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.15);flex-shrink:0}
.vis-ads-c-dot.active{background:var(--green);box-shadow:0 0 6px rgba(34,197,94,.4)}
.vis-ads-c-name{flex:1;font-family:var(--font-h);font-size:.75rem;color:var(--text-muted)}
.vis-ads-c-roas{font-family:var(--font-h);font-size:.75rem;font-weight:700;color:var(--green)}

/* Ads bar chart */
.vis-ads-chart{display:flex;flex-direction:column;gap:.75rem;flex:1;justify-content:flex-end}
.vis-ads-bars{display:flex;align-items:flex-end;gap:8px;height:100px}
.vis-ads-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:2px;height:100%}
.vis-ads-bar-spend{width:100%;background:rgba(255,255,255,.12);border-radius:3px 3px 0 0}
.vis-ads-bar-rev{width:100%;background:linear-gradient(to top,var(--accent),rgba(0,198,255,.5));border-radius:3px 3px 0 0;box-shadow:0 0 8px rgba(0,132,255,.3)}
.vis-ads-col:nth-child(1) .vis-ads-bar-spend{height:15%}.vis-ads-col:nth-child(1) .vis-ads-bar-rev{height:45%}
.vis-ads-col:nth-child(2) .vis-ads-bar-spend{height:20%}.vis-ads-col:nth-child(2) .vis-ads-bar-rev{height:55%}
.vis-ads-col:nth-child(3) .vis-ads-bar-spend{height:18%}.vis-ads-col:nth-child(3) .vis-ads-bar-rev{height:62%}
.vis-ads-col:nth-child(4) .vis-ads-bar-spend{height:22%}.vis-ads-col:nth-child(4) .vis-ads-bar-rev{height:70%}
.vis-ads-col-peak .vis-ads-bar-spend{height:20%}
.vis-ads-col-peak .vis-ads-bar-rev{height:85%;box-shadow:0 0 20px rgba(0,132,255,.5)!important}
.vis-ads-legend{display:flex;gap:1rem}
.vis-ads-legend span{display:flex;align-items:center;gap:.375rem;font-size:.6875rem;color:var(--text-muted)}
.legend-dot{width:8px;height:8px;border-radius:2px;display:inline-block;flex-shrink:0}
.legend-dot-spend{background:rgba(255,255,255,.2)}
.legend-dot-rev{background:var(--accent)}

/* AI visual */
.vis-ai{
  width:100%;max-width:460px;
  background:rgba(16,20,28,.95);border:1px solid var(--border-h);
  border-radius:var(--r-xl);padding:1.5rem;
  box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.04) inset,0 0 60px rgba(124,58,237,.06);
  animation:float-main 10s ease-in-out 2s infinite;
  display:flex;flex-direction:column;justify-content:space-between;
}
.vis-ai-head{display:flex;align-items:center;gap:.625rem;margin-bottom:1.25rem}
.vis-ai-icon{width:28px;height:28px;background:var(--purple-dim);border:1px solid rgba(124,58,237,.3);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-family:var(--font-h);font-size:.6rem;font-weight:800;color:#a78bfa;flex-shrink:0}
.vis-ai-head>span{font-family:var(--font-h);font-size:.8125rem;font-weight:600;color:var(--text-muted);flex:1}
.vis-ai-live{font-family:var(--font-h);font-size:.6875rem;font-weight:600;color:var(--green);background:var(--green-dim);border:1px solid rgba(34,197,94,.2);padding:.2rem .5rem;border-radius:999px;display:flex;align-items:center;gap:.3rem}
.vis-ai-live::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--green);animation:pulse-dot 2s ease-in-out infinite}
.vis-ai-prompt{font-size:.8125rem;color:var(--text-muted);background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--r-md);padding:.75rem 1rem;margin-bottom:1rem;font-style:italic}
.vis-ai-response{flex:1;min-height:80px;padding:.75rem 1rem;background:rgba(124,58,237,.05);border:1px solid rgba(124,58,237,.15);border-radius:var(--r-md);margin-bottom:1rem}
.vis-ai-typing{font-size:.8125rem;color:var(--text-muted);line-height:1.65}
.vis-ai-cursor{display:inline-block;width:2px;height:1em;background:var(--accent);vertical-align:middle;animation:blink .8s ease-in-out infinite;margin-left:1px}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.vis-ai-sources{display:flex;flex-direction:column;gap:.375rem}
.vis-ai-source{display:flex;align-items:center;gap:.5rem;font-family:var(--font-h);font-size:.6875rem;color:var(--text-subtle)}
.vis-ai-source-dot{width:6px;height:6px;background:var(--accent);border-radius:50%;flex-shrink:0}

/* AI platform visibility bars */
.vis-ai-platforms{display:flex;flex-direction:column;gap:.55rem;padding-bottom:1rem;margin-bottom:1rem;border-bottom:1px solid var(--border)}
.vis-ai-plat-lbl{font-family:var(--font-h);font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle);margin-bottom:.25rem}
.vis-ai-platform{display:flex;align-items:center;gap:.625rem}
.vis-ai-plat-name{font-family:var(--font-h);font-size:.6875rem;color:var(--text-muted);width:88px;flex-shrink:0}
.vis-ai-plat-bar{flex:1;height:5px;background:rgba(255,255,255,.07);border-radius:999px;overflow:hidden}
.vis-ai-plat-fill{height:100%;background:linear-gradient(90deg,var(--accent),#a78bfa);border-radius:999px}
.vis-ai-plat-pct{font-family:var(--font-h);font-size:.6875rem;font-weight:700;color:#a78bfa;width:30px;text-align:right;flex-shrink:0}

/* 10. PROZESS — Interactive Timeline ========================= */
.prozess{background:var(--bg)}
.prozess-scroll-track{position:relative;height:300vh}
.prozess-sticky{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center;background:var(--bg);padding-block:2rem}
.prozess-sticky .section-header{margin-bottom:2rem}
.prozess-sticky .container{width:100%}
.prozess-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 100%,rgba(0,132,255,.05) 0%,transparent 70%);pointer-events:none}
.prozess-grid{
  position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(0,132,255,.15) 1px,transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,black,transparent);
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,black,transparent);
  animation:grid-drift 25s linear infinite;
  opacity:.3;
}
@keyframes grid-drift{from{background-position:0 0}to{background-position:40px 40px}}

/* ── TIMELINE — vertical nav + right panel ─────────────────── */
.tl-wrap{
  position:relative;z-index:1;
  display:grid;
  grid-template-columns:1fr;
  gap:2rem;
}
@media(min-width:768px){
  .tl-wrap{grid-template-columns:200px 1fr;gap:3.5rem;align-items:center}
}

/* Left column: vertical step list */
.tl-steps{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:0;
}

/* Vertical connecting track */
.tl-track{
  display:block;
  position:absolute;
  left:21px;           /* centre of 44 px circle */
  top:22px;
  bottom:22px;
  width:2px;
  height:auto;
  background:var(--border);
  z-index:0;
}
.tl-track-fill{
  width:100%;
  height:0%;
  background:var(--grad-accent);
  border-radius:999px;
  transition:height .5s var(--ease);
  box-shadow:0 0 8px rgba(0,132,255,.5);
}

/* Step buttons */
.tl-step{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:1rem;
  padding:.875rem 0;
  border:none;
  background:transparent;
  cursor:pointer;
  text-align:left;
  width:100%;
  position:relative;
  z-index:1;
}
.tl-step-circle{
  width:44px;height:44px;
  border-radius:50%;
  background:var(--bg);
  border:2px solid var(--border-h);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  transition:background .3s ease,border-color .3s ease,box-shadow .3s ease;
}
.tl-step-circle span{
  font-family:var(--font-h);font-size:.6875rem;font-weight:700;
  color:var(--text-muted);letter-spacing:.04em;
}
.tl-step.is-done .tl-step-circle{
  background:var(--accent);
  border-color:var(--accent);
  box-shadow:0 0 12px var(--accent-glow);
}
.tl-step.is-done .tl-step-circle span{color:#fff}
.tl-step.is-active .tl-step-circle{
  background:var(--grad-accent);
  border-color:transparent;
  box-shadow:0 0 20px var(--accent-glow);
}
.tl-step.is-active .tl-step-circle span{color:#fff}

.tl-step-label{
  font-family:var(--font-h);font-size:.9375rem;font-weight:600;
  color:var(--text-muted);transition:color .25s ease;
}
.tl-step.is-done .tl-step-label{color:rgba(255,255,255,.5)}
.tl-step.is-active .tl-step-label{color:var(--text)}

/* Suppress all transitions instantly (used when going backward or re-filling) */
.tl-no-anim .tl-step-circle,
.tl-no-anim .tl-step-label{transition:none!important}

/* Right column: panels — grid overlay for smooth cross-fade */
.tl-panels{display:grid}
.tl-panel{
  grid-area:1/1;
  opacity:0;
  transform:translateX(14px);
  transition:opacity .5s ease,transform .5s ease;
  pointer-events:none;
  display:flex;flex-direction:column; /* lets inner fill height */
}
.tl-panel.is-active{
  opacity:1;
  transform:none;
  pointer-events:auto;
  z-index:1;
}

.tl-panel-inner{
  flex:1; /* fill panel height */
  display:grid;grid-template-columns:1fr;gap:1.5rem;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border-h);
  border-radius:var(--r-2xl);
  padding:2rem;
}
@media(min-width:900px){.tl-panel-inner{grid-template-columns:1fr 1fr;gap:2rem;align-items:stretch}}

/* ── Mobile timeline — disable sticky, show as vertical stack ── */
@media(max-width:767px){
  /* Remove sticky scroll entirely */
  .prozess-scroll-track{height:auto}
  .prozess-sticky{position:static;height:auto;overflow-x:clip;padding-block:3rem 4rem;display:block}

  /* Section header: fully visible */
  .prozess-sticky .section-header{margin-bottom:2rem}
  .prozess-sticky .section-description{display:block}
  /* Remove the extra width:100% override so container padding applies normally */
  .prozess-sticky .container{width:auto;padding-inline:1.25rem}

  /* Hide step nav — panels are self-explanatory */
  .tl-steps{display:none}
  .tl-wrap{gap:0}

  /* All panels visible, stacked */
  .tl-panels{display:flex;flex-direction:column;gap:1.5rem}
  .tl-panel{opacity:1;transform:none;pointer-events:auto;position:static;grid-area:unset;min-width:0;width:100%}

  /* Panel inner: match other cards */
  .tl-panel-inner{padding:1.25rem;gap:1.25rem;min-width:0;overflow:hidden}

  /* Visuals visible again (no 100vh constraint anymore) */
  .tl-vis{display:flex;min-width:0}
}

.tl-panel-left{display:flex;flex-direction:column;gap:1rem;align-self:stretch}
.tl-panel-icon{
  width:48px;height:48px;
  background:var(--accent-dim);border:1px solid var(--border-accent);
  border-radius:var(--r-lg);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 20px rgba(0,132,255,.15);
}
.tl-panel-title{font-size:clamp(1.25rem,2.2vw,1.625rem);font-weight:800;letter-spacing:-.035em}
.tl-panel-desc{color:var(--text-muted);font-size:1.0625rem;line-height:1.8}
.tl-panel-list{display:flex;flex-direction:column;gap:.4rem}
.tl-panel-list li{font-size:1.0625rem;color:var(--text-muted);padding-left:1.75rem;position:relative}
.tl-panel-list li::before{
  content:'✓';position:absolute;left:0;top:.15em;
  width:1.25rem;height:1.25rem;border-radius:50%;
  background:var(--green-dim);border:1px solid rgba(34,197,94,.25);
  color:var(--green);font-size:.6rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}

/* ── Common vis card ─────────────────────────────────────── */
.tl-vis{
  background:rgba(16,20,28,.95);
  border:1px solid var(--border-h);
  border-radius:var(--r-xl);
  padding:1.5rem;
  display:flex;flex-direction:column;gap:1rem;
  box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.04) inset,0 0 60px rgba(0,132,255,.05);
  /* stretch to match sibling column height */
  align-self:stretch;
  justify-content:space-between;
}

/* ── Shared micro-components ─────────────────────────────── */
.vis-badge{
  font-size:.65rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  color:var(--accent);background:var(--accent-dim);border:1px solid var(--border-accent);
  padding:.2rem .6rem;border-radius:999px;
}
.vis-ts{font-size:.78rem;color:var(--text-muted)}

/* ── Analyse: Findings Card ──────────────────────────────── */
.vis-findings{display:flex;flex-direction:column;gap:.875rem}
.vis-findings-head{display:flex;justify-content:space-between;align-items:center;gap:.5rem;flex-wrap:wrap}
.vis-findings-title{font-family:var(--font-h);font-size:.8125rem;font-weight:600;color:var(--text-muted)}
.vis-findings-domain{font-family:var(--font-h);font-size:.78rem;color:var(--text-subtle);background:rgba(255,255,255,.05);border:1px solid var(--border);padding:.2rem .6rem;border-radius:999px}
.vis-findings-metrics{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--r-md);
  padding:.75rem .5rem;
}
.vis-findings-metric{display:flex;flex-direction:column;gap:.2rem;align-items:center;text-align:center;padding:.25rem .5rem;border-right:1px solid var(--border)}
.vis-findings-metric:last-child{border-right:none}
.vis-findings-val{font-family:var(--font-h);font-size:1.25rem;font-weight:400;letter-spacing:-.01em;color:var(--accent)}
.vis-findings-val.warn{color:#f59e0b}
.vis-findings-val.accent{color:var(--accent)}
.vis-findings-lbl{font-size:.68rem;color:var(--text-subtle);text-transform:uppercase;letter-spacing:.03em}
@media(max-width:767px){
  .vis-findings-domain{display:none}
  .vis-findings-metric{padding:.25rem .2rem}
  .vis-findings-lbl{font-size:.6rem;letter-spacing:0}
  .vis-findings-val{font-size:1.1rem}
}
.vis-findings-section{font-family:var(--font-h);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle)}
.vis-findings-actions{list-style:none;display:flex;flex-direction:column;gap:.4rem;flex:1;justify-content:space-evenly}
.vis-findings-action{display:flex;align-items:center;gap:.625rem;padding:.4rem .75rem;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--r-md)}
.vfa-badge{font-family:var(--font-h);font-size:.55rem;font-weight:700;letter-spacing:.05em;padding:.15rem .4rem;border-radius:3px;flex-shrink:0;min-width:3rem;text-align:center}
.vfa-badge.high{background:rgba(239,68,68,.12);color:#f87171;border:1px solid rgba(239,68,68,.25)}
.vfa-badge.mid{background:rgba(245,158,11,.1);color:#fbbf24;border:1px solid rgba(245,158,11,.22)}
.vfa-text{font-family:var(--font-h);font-size:.78rem;color:var(--text-muted)}

/* ── Strategie: KPI Goals + Roadmap ─────────────────────── */
.vis-strategy-label{
  font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-subtle);
}
.vis-strategy-kpis{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--r-md);
  padding:.75rem .5rem;
}
.vis-kpi{
  display:flex;flex-direction:column;align-items:center;gap:.25rem;
  padding:.25rem .5rem;
  border-right:1px solid var(--border);
}
.vis-kpi:last-child{border-right:none}
.vis-kpi-num{
  font-size:1.25rem;font-weight:700;letter-spacing:-.03em;color:var(--accent);
  opacity:0;transform:translateY(8px);
  transition:opacity .6s ease,transform .6s ease;
}
.tl-panel.is-active .vis-kpi-num{opacity:1;transform:none}
.tl-panel.is-active .vis-kpi:nth-child(2) .vis-kpi-num{transition-delay:.15s}
.tl-panel.is-active .vis-kpi:nth-child(3) .vis-kpi-num{transition-delay:.3s}
.vis-kpi-lbl{font-size:.68rem;color:var(--text-subtle);text-align:center;line-height:1.3}
.vis-strategy-road{display:flex;flex-direction:column;gap:0;position:relative}
.vsr{display:flex;align-items:flex-start;gap:.75rem;padding:.5rem 0;position:relative}
.vsr:not(:last-child)::after{
  content:'';position:absolute;left:9px;top:26px;
  width:2px;height:calc(100% - 6px);
  background:var(--border);
}
.vsr-dot{
  width:20px;height:20px;border-radius:50%;flex-shrink:0;margin-top:1px;
  background:var(--bg);border:2px solid var(--border-h);
  position:relative;z-index:1;
  transition:background .3s,border-color .3s,box-shadow .3s;
}
.vsr.done .vsr-dot{background:var(--accent);border-color:var(--accent);box-shadow:0 0 10px rgba(0,132,255,.5)}
.vsr.active .vsr-dot{border-color:var(--accent)}
.vsr.active .vsr-dot::after{content:'';position:absolute;inset:3px;border-radius:50%;background:var(--accent);animation:pulse-dot 2s ease infinite}
.vsr-body{display:flex;flex-direction:column;gap:.1rem}
.vsr-body strong{font-size:.8125rem;font-weight:600}
.vsr-body span{font-size:.78rem;color:var(--text-muted)}
.vsr.done .vsr-body span{color:#22c55e}
.vsr.active .vsr-body span{color:var(--accent)}

/* ── Umsetzung: Live Progress Bars ───────────────────────── */
.vis-live-header{
  display:flex;align-items:center;gap:.5rem;
  font-size:.8125rem;font-weight:600;
}
.vis-live-pulse{
  width:8px;height:8px;border-radius:50%;
  background:#22c55e;box-shadow:0 0 8px #22c55e;
  animation:pulse-dot 2s ease infinite;
}
.vis-live-kw{margin-left:auto;font-size:.78rem;color:var(--text-muted)}
.vis-live-bars{display:flex;flex-direction:column;gap:.875rem}
.vis-lbar{display:flex;flex-direction:column;gap:.35rem}
.vis-lbar-meta{display:flex;justify-content:space-between;align-items:baseline}
.vis-lbar-meta label{font-size:.78rem;color:var(--text-muted)}
.vis-lbar-meta span{font-size:.78rem;font-weight:700;color:var(--accent)}
.vis-lbar-track{height:5px;background:rgba(255,255,255,.06);border-radius:999px;overflow:hidden}
.vis-lbar-fill{
  height:100%;background:var(--grad-accent);border-radius:999px;
  width:0;
  transition:width 1s cubic-bezier(.4,0,.2,1);
}
.tl-panel.is-active .vis-lbar-fill{width:calc(var(--pct) * 1%)}
.tl-panel.is-active .vis-lbar:nth-child(2) .vis-lbar-fill{transition-delay:.15s}
.tl-panel.is-active .vis-lbar:nth-child(3) .vis-lbar-fill{transition-delay:.3s}
.vis-live-total{display:flex;flex-direction:column;gap:.35rem;padding-top:.25rem;border-top:1px solid var(--border)}
.vis-lbar-track-total{height:8px}
.vis-live-total-pct{font-size:.78rem;font-weight:700;color:var(--accent)}
.vis-live-footer{
  display:flex;align-items:center;gap:.5rem;
  font-size:.78rem;color:var(--text-muted);padding-top:.25rem;
  border-top:1px solid var(--border);
}
.vis-tasks-chip{
  background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.22);
  color:#22c55e;font-size:.78rem;font-weight:700;
  padding:.15rem .5rem;border-radius:999px;
}

/* ── Reporting: Performance Dashboard ───────────────────── */
.vis-report-header{
  display:flex;justify-content:space-between;align-items:center;
  font-size:.8125rem;font-weight:600;
}

/* KPI row — same grid style as Analyse/Strategie */
.vis-report-kpis{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--r-md);
  padding:.75rem .5rem;
}
.vis-report-kpi{
  display:flex;flex-direction:column;align-items:center;gap:.25rem;
  padding:.25rem .5rem;border-right:1px solid var(--border);
}
.vis-report-kpi:last-child{border-right:none}
.vis-report-kpi-val{font-family:var(--font-h);font-size:1.25rem;font-weight:700;letter-spacing:-.03em;color:var(--accent)}
.vis-report-kpi-lbl{font-size:.68rem;color:var(--text-subtle);text-align:center;line-height:1.3}

/* Two charts side by side */
.vis-report-charts{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;flex:1}
.vis-report-chart-block{display:flex;flex-direction:column;gap:.4rem}
.vis-report-chart-lbl{font-family:var(--font-h);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-subtle)}

/* Line / area chart */
.vis-linechart{width:100%;flex:1;overflow:visible}
.lc-area{fill:url(#lcg1);opacity:0;transition:opacity .8s ease}
.lc-line{
  fill:none;stroke:var(--accent);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:160;stroke-dashoffset:160;
  transition:stroke-dashoffset 1.2s cubic-bezier(.4,0,.2,1);
}
.lc-dot{fill:var(--accent);opacity:0;transition:opacity .4s ease 1s}
.tl-panel.is-active .lc-line{stroke-dashoffset:0}
.tl-panel.is-active .lc-area{opacity:1}
.tl-panel.is-active .lc-dot{opacity:1}
.vis-report-months{display:flex;justify-content:space-between}
.vis-report-months span{font-size:.6rem;color:var(--text-subtle)}

/* Bar chart */
.vis-report-bars{
  display:flex;align-items:flex-end;gap:6px;flex:1;
  background:rgba(255,255,255,.02);border:1px solid var(--border);
  border-radius:var(--r-md);padding:.5rem .625rem;
}
.vis-rbar-group{flex:1;display:flex;gap:2px;align-items:flex-end;height:100%}
.vis-rbar{width:100%;border-radius:2px 2px 0 0;height:0;transition:height .7s cubic-bezier(.4,0,.2,1)}
.vis-rbar-spend{background:rgba(255,255,255,.12)}
.vis-rbar-rev{background:linear-gradient(to top,var(--accent),rgba(0,198,255,.6))}
.vis-rbar-peak{box-shadow:0 -4px 12px rgba(0,132,255,.4)}
.tl-panel.is-active .vis-rbar{height:var(--h)}
.tl-panel.is-active .vis-rbar-group:nth-child(2) .vis-rbar{transition-delay:.15s}
.tl-panel.is-active .vis-rbar-group:nth-child(3) .vis-rbar{transition-delay:.3s}
.vis-report-bar-legend{display:flex;gap:.75rem}
.vis-report-bar-legend span{display:flex;align-items:center;gap:.3rem;font-size:.6rem;color:var(--text-subtle)}

.vis-report-foot{font-size:.78rem;color:var(--text-muted);text-align:center}

/* 11. TESTIMONIALS — Video Cards ============================= */
.referenzen{background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.testimonials-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:640px){.testimonials-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.testimonials-grid{grid-template-columns:repeat(3,1fr)}}

.testimonial{
  background:rgba(16,20,28,.95);border:1px solid var(--border-h);border-radius:var(--r-xl);
  box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.04) inset,0 0 60px rgba(0,132,255,.05);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:border-color .25s ease,transform .3s var(--ease),box-shadow .25s ease;
}
.testimonial:hover{border-color:rgba(0,132,255,.3);transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.4),0 0 40px rgba(0,132,255,.06)}

/* Portrait image */
.t-photo-wrap{
  position:relative;aspect-ratio:4/4;overflow:hidden;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.t-photo-blue  {background:linear-gradient(160deg,#0a1628 0%,#0d2d5c 60%,#0a1628 100%)}
.t-photo-green {background:linear-gradient(160deg,#061a10 0%,#0a3320 60%,#061a10 100%)}
.t-photo-purple{background:linear-gradient(160deg,#130a2c 0%,#281050 60%,#130a2c 100%)}
.t-photo-wrap::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(255,255,255,.03),transparent 40%,rgba(0,0,0,.3));pointer-events:none}
/* Real photo: add <img class="t-portrait-img"> inside .t-photo-wrap */
.t-portrait-img{width:100%;height:100%;object-fit:cover;display:block;position:relative;z-index:1}
.t-portrait-icon{width:64px;opacity:.3}

/* Card body */
.t-body{padding:1.375rem;display:flex;flex-direction:column;gap:.875rem;flex-grow:1}
.t-info{display:flex;flex-direction:column;gap:.125rem}
.t-name{font-family:var(--font-h);font-size:1.0625rem;font-weight:600;color:var(--text)}
.t-company{font-size:1.0625rem;color:var(--text-subtle);margin-top:.0625rem}
.t-stars{color:#f59e0b;font-size:1.0625rem;letter-spacing:.1em;flex-shrink:0}
.t-quote{font-size:1.0625rem;color:var(--text-muted);line-height:1.8;border-left:2px solid var(--accent-dim);padding-left:.875rem;flex-grow:1}
.t-result{
  display:inline-flex;align-items:center;gap:.375rem;
  font-family:var(--font-h);font-size:.75rem;font-weight:600;color:var(--green);
  background:var(--green-dim);border:1px solid rgba(34,197,94,.2);
  padding:.3rem .75rem;border-radius:999px;align-self:flex-start;
}

/* 12. ÜBER UNS =============================================== */
.ueber-uns{background:var(--bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.uu-grid{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center}
@media(min-width:600px){.uu-grid{grid-template-columns:1fr 1fr;gap:4rem}}

/* Photo */
.uu-team-img { width:100%; height:100%; object-fit:cover; border-radius:inherit; }
.uu-photo-wrap{position:relative}
.uu-photo{
  position:relative;aspect-ratio:4/3;
  border-radius:var(--r-2xl);
  background:linear-gradient(145deg,#141a26 0%,#0c111a 100%);
  border:1px solid var(--border-h);
  overflow:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:flex-end;
}
.uu-team-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;border-radius:inherit}
.uu-orb{position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none}
.uu-orb-1{width:260px;height:260px;background:rgba(0,132,255,.12);top:-40px;left:-40px}
.uu-orb-2{width:200px;height:200px;background:rgba(0,198,255,.08);bottom:40px;right:-20px}
.uu-silhouettes{width:90%;max-width:420px;margin-bottom:1.5rem;position:relative;z-index:1}
.uu-photo-label{
  position:relative;z-index:1;
  font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.2);padding:.75rem;margin-bottom:.25rem;
}
/* Floating stat badge */
.uu-photo-badge{
  position:absolute;bottom:1.5rem;right:1.5rem;z-index:2;
  display:flex;align-items:center;gap:.75rem;
  background:rgba(10,14,22,.75);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid var(--border-accent);
  border-radius:var(--r-xl);padding:.875rem 1.25rem;
  box-shadow:0 8px 32px rgba(0,0,0,.4);
}
.uu-badge-num{font-size:2rem;font-weight:800;letter-spacing:-.05em;line-height:1}
.uu-badge-lbl{font-size:.75rem;color:var(--text-muted);line-height:1.4}

/* Text content */
.uu-content{display:flex;flex-direction:column;gap:1.25rem}
.uu-title{
  font-size:clamp(2rem,4vw,3rem);font-weight:800;
  letter-spacing:-.04em;line-height:1.15;
  margin:0;
}
.uu-desc{color:var(--text-muted);font-size:1.0625rem;line-height:1.8}
.uu-stats{
  display:flex;gap:2rem;flex-wrap:wrap;
  padding:1.5rem 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  margin:.25rem 0;
}
.uu-stat{display:flex;flex-direction:column;gap:.25rem}
.uu-stat-num{font-size:2rem;font-weight:800;letter-spacing:-.05em;line-height:1}
.uu-stat-lbl{font-size:.8125rem;color:var(--text-muted)}

/* 13. CTA STRIP ============================================== */
.cta-strip{
  position:relative;
  background:linear-gradient(135deg,rgba(0,132,255,.12) 0%,rgba(0,198,255,.05) 50%,rgba(124,58,237,.07) 100%);
  border-top:1px solid var(--border-accent);border-bottom:1px solid var(--border-accent);
  padding-block:5rem;overflow:hidden;
}
@media(max-width:767px){.cta-strip{padding-bottom:7rem}}
.cta-strip-orb{position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(0,132,255,.18) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);filter:blur(80px);pointer-events:none;animation:drift 14s ease-in-out infinite alternate}
.cta-strip-particles span:nth-child(1){left:5%;top:20%;animation-delay:0s;background:var(--accent)}
.cta-strip-particles span:nth-child(2){left:90%;top:70%;animation-delay:1.5s;background:var(--accent-2);width:3px;height:3px}
.cta-strip-particles span:nth-child(3){left:40%;top:80%;animation-delay:3s;background:var(--accent);width:2px;height:2px}
.cta-strip-particles span:nth-child(4){left:70%;top:10%;animation-delay:.8s;background:var(--accent-2)}
.cta-strip-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:2.5rem;text-align:center}
@media(min-width:768px){.cta-strip-inner{flex-direction:row;justify-content:space-between;text-align:left;gap:3rem}}
.cta-strip-text{flex:1}
.cta-strip-title{font-size:clamp(1.875rem,4vw,2.875rem);font-weight:800;line-height:1.15;letter-spacing:-.03em}

/* 13. KONTAKT ================================================ */
.kontakt{background:var(--bg-2)}
.kontakt-layout{display:grid;grid-template-columns:1fr;gap:4rem}
@media(min-width:1024px){.kontakt-layout{grid-template-columns:1fr 1.2fr;align-items:start;gap:5rem}}
.kontakt-info{display:flex;flex-direction:column;gap:1.25rem}
.kontakt-info .section-title{font-size:clamp(1.75rem,3.5vw,2.5rem)}
.kontakt-description{color:var(--text-muted);font-size:1.0625rem;line-height:1.8}
.kontakt-usps{display:flex;flex-direction:column;gap:1rem;margin-top:.5rem}
.kontakt-usps li{display:flex;align-items:center;gap:.875rem;font-size:.9375rem;color:var(--text-muted)}
.usp-icon{width:1.75rem;height:1.75rem;border-radius:50%;background:var(--green-dim);border:1px solid rgba(34,197,94,.25);color:var(--green);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.kontakt-form-wrapper{background:rgba(16,20,28,.95);border:1px solid var(--border-h);border-radius:var(--r-xl);padding:1.5rem;position:relative;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.04) inset,0 0 60px rgba(0,132,255,.05)}
@media(min-width:640px){.kontakt-form-wrapper{padding:2.5rem}}
.kontakt-form-wrapper::before{content:'';position:absolute;top:0;left:2rem;right:2rem;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}
.kontakt-form{display:flex;flex-direction:column;gap:1.25rem}
.form-row{display:grid;grid-template-columns:1fr;gap:1.25rem}
@media(min-width:480px){.form-row{grid-template-columns:repeat(2,1fr)}}
.form-group{display:flex;flex-direction:column;gap:.5rem}
.form-label{font-family:var(--font-h);font-size:.8125rem;font-weight:500;color:var(--text-muted)}
.form-input{font-family:var(--font-b);font-size:.9375rem;color:var(--text);background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--r-md);padding:.875rem 1rem;width:100%;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;-webkit-appearance:none;appearance:none}
.form-input::placeholder{color:var(--text-subtle)}
.form-input:hover{border-color:var(--border-h)}
.form-input:focus{outline:none;border-color:var(--accent);background:rgba(0,132,255,.04);box-shadow:0 0 0 3px var(--accent-dim)}
.form-input:invalid:not(:placeholder-shown):not(:focus){border-color:rgba(239,68,68,.5)}
.form-textarea{resize:vertical;min-height:130px;line-height:1.65}
.form-disclaimer{font-size:.8rem;color:var(--text-subtle);text-align:center;line-height:1.6}
.form-success{font-size:.9375rem;color:var(--green);text-align:center;padding:.75rem 1rem;border-radius:var(--r-md);background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.2);margin-top:.5rem}
.form-error{font-size:.9375rem;color:#f87171;text-align:center;padding:.75rem 1rem;border-radius:var(--r-md);background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.2);margin-top:.5rem}
.form-link{color:var(--accent);text-decoration:underline;text-underline-offset:2px}

/* 14. COOKIE CONSENT ========================================= */
.cc-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:9998;backdrop-filter:blur(2px)}
.cc-banner{
  position:fixed;bottom:0;left:0;right:0;
  z-index:9999;
  background:rgba(16,20,28,.98);
  border-top:1px solid var(--border-h);
  border-radius:var(--r-xl) var(--r-xl) 0 0;
  box-shadow:0 -8px 40px rgba(0,0,0,.5),0 0 60px rgba(0,132,255,.07);
  padding:1.25rem 1.25rem calc(1.25rem + env(safe-area-inset-bottom));
}
@media(min-width:600px){
  .cc-banner{
    bottom:1.25rem;left:50%;right:auto;
    transform:translateX(-50%);
    width:min(calc(100vw - 2rem),820px);
    border-radius:var(--r-xl);
    border:1px solid var(--border-h);
    padding:1.5rem;
  }
}
.cc-banner-inner{display:flex;flex-direction:column;gap:1rem}
@media(min-width:768px){.cc-banner-inner{flex-direction:row;align-items:center;gap:2rem}}
.cc-banner-text{flex:1}
.cc-banner-title{font-family:var(--font-h);font-size:1rem;font-weight:700;color:var(--text);margin-bottom:.3rem}
.cc-banner-desc{font-size:.8125rem;color:var(--text-muted);line-height:1.55}
.cc-banner-actions{display:flex;flex-direction:column;gap:.5rem;flex-shrink:0}
@media(min-width:600px){.cc-banner-actions{flex-direction:row;flex-wrap:wrap;gap:.625rem;align-items:center}}
.cc-btn{font-family:var(--font-h);font-size:.875rem;font-weight:600;padding:.625rem 1.125rem;border-radius:var(--r-md);border:none;cursor:pointer;transition:opacity .18s ease,background .18s ease;text-align:center}
.cc-btn-accept{background:var(--accent);color:#fff}
.cc-btn-accept:hover{opacity:.88}
.cc-btn-reject{background:transparent;color:var(--text-muted);border:1px solid var(--border-h)}
.cc-btn-reject:hover{color:var(--text);border-color:var(--border-accent)}
.cc-btn-settings{background:transparent;color:var(--text-muted);padding:.5rem 0;text-decoration:underline;text-underline-offset:3px;border:none}
.cc-btn-settings:hover{color:var(--text)}
@media(max-width:599px){
  .cc-btn-accept,.cc-btn-reject{width:100%;justify-content:center}
  .cc-btn-settings{text-align:center}
}
/* Modal */
.cc-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}
.cc-modal[hidden]{display:none!important}
.cc-modal-box{width:min(100%,520px);background:rgba(16,20,28,.98);border:1px solid var(--border-h);border-radius:var(--r-xl);box-shadow:0 32px 80px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.04) inset;overflow:hidden}
.cc-modal-head{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}
.cc-modal-title{font-family:var(--font-h);font-size:1rem;font-weight:700;color:var(--text)}
.cc-modal-close{background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;line-height:1;padding:.25rem}
.cc-modal-close:hover{color:var(--text)}
.cc-modal-body{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem}
.cc-category{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--r-md);padding:1rem 1.125rem}
.cc-cat-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.cc-cat-info{flex:1}
.cc-cat-name{font-family:var(--font-h);font-size:.9375rem;font-weight:600;color:var(--text);margin-bottom:.2rem}
.cc-cat-desc{font-size:.8125rem;color:var(--text-muted);line-height:1.55}
/* "Immer aktiv" badge */
.cc-toggle-disabled{display:flex;align-items:center}
.cc-toggle-label{font-size:.75rem;font-weight:600;color:var(--green);background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.2);border-radius:2rem;padding:.2rem .65rem;white-space:nowrap}
/* Toggle switch */
.cc-toggle-switch{cursor:pointer;display:inline-flex;align-items:center;flex-shrink:0}
.cc-toggle-input{position:absolute;width:1px;height:1px;opacity:0}
.cc-toggle-track{width:2.75rem;height:1.5rem;background:rgba(255,255,255,.1);border:1px solid var(--border-h);border-radius:2rem;position:relative;transition:background .2s ease,border-color .2s ease}
.cc-toggle-thumb{position:absolute;top:50%;left:.2rem;transform:translateY(-50%);width:1.1rem;height:1.1rem;border-radius:50%;background:var(--text-muted);transition:transform .2s ease,background .2s ease}
.cc-toggle-input:checked + .cc-toggle-track{background:var(--accent);border-color:var(--accent)}
.cc-toggle-input:checked + .cc-toggle-track .cc-toggle-thumb{transform:translate(1.25rem,-50%);background:#fff}
.cc-modal-foot{display:flex;justify-content:flex-end;gap:.625rem;padding:1rem 1.5rem;border-top:1px solid var(--border)}

/* 15. FOOTER ================================================= */
.site-footer{background:var(--bg-2);border-top:1px solid var(--border);padding-block:1.75rem}
.footer-inner{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}
@media(min-width:640px){.footer-inner{flex-direction:row;justify-content:space-between;text-align:left}}
.footer-copy{font-size:.875rem;color:var(--text-subtle)}
.footer-nav{display:flex;gap:1.5rem}
.footer-link{font-size:.875rem;color:var(--text-subtle);transition:color .2s ease}
.footer-link:hover{color:var(--text)}
.footer-cookie-btn{background:none;border:none;cursor:pointer;font-family:inherit;padding:0}

/* 15. FADE-IN ================================================ */
.fade-in{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.fade-in.visible{opacity:1;transform:translateY(0)}
.feature-row:nth-child(2).fade-in{transition-delay:.1s}
.feature-row:nth-child(3).fade-in{transition-delay:.2s}
.testimonials-grid .testimonial:nth-child(2){transition-delay:.1s}
.testimonials-grid .testimonial:nth-child(3){transition-delay:.2s}
.cta-strip .btn{transition-delay:.15s}

/* 16. FOCUS + REDUCED MOTION ================================= */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:var(--r-sm)}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;animation-iteration-count:1!important}
  html{scroll-behavior:auto}
  .fade-in{opacity:1;transform:none}
  .hero-orb-1,.hero-orb-2,.hero-orb-3,.hv-dashboard,.hv-chip-1,.hv-chip-2,.hv-chip-3,
  .hero-scroll-line,.hero-pill-dot,.vis-serp-result-first,.prozess-grid,
  .t-play-ring,.t-waveform span,.cta-strip-orb{animation:none}
}
