/* ============================================================================
   BRINGEFUL — Design System  ("Editorial Tech-Atelier")
   Webdesign & KI-Automation · Greußen, Thüringen
   Ein gemeinsames Stylesheet für alle Seiten. Self-hosted Fonts (DSGVO).
   ============================================================================ */

/* ---------- FONTS (self-hosted, woff2, latin) ---------- */
@font-face{font-family:"Bricolage";src:url(fonts/bricolage-600.woff2) format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Bricolage";src:url(fonts/bricolage-700.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Bricolage";src:url(fonts/bricolage-800.woff2) format("woff2");font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken";src:url(fonts/hanken-400.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken";src:url(fonts/hanken-500.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken";src:url(fonts/hanken-600.woff2) format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken";src:url(fonts/hanken-700.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"GeistMono";src:url(fonts/geistmono-400.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"GeistMono";src:url(fonts/geistmono-500.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}

/* ============================ TOKENS ============================ */
:root{
  --font-display:"Bricolage","Hanken",-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;
  --font-text:"Hanken",-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;
  --font-mono:"GeistMono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;

  /* DARK (Default) — warmes Tiefschwarz mit grünem Unterton */
  --bg:#0B0F0D;
  --bg-2:#0E1411;
  --surface:#121A16;
  --card:#141D18;
  --card-2:#18221C;
  --line:rgba(232,242,236,.09);
  --line-2:rgba(232,242,236,.16);
  --ink:#ECF3EE;
  --ink-soft:#A2B3AA;
  --ink-faint:#8A9E95;
  --brand:#54BE97;          /* helles Teal — auf Dunkel */
  --brand-2:#7FE3BE;
  --brand-ink:#04130D;      /* Text auf Teal-Flächen */
  --brand-glow:rgba(84,190,151,.30);
  --brand-tint:rgba(84,190,151,.10);
  --brand-line:rgba(84,190,151,.28);
  --accent:#E7C16B;         /* warmes Gold — sparsam */
  --accent-ink:#1c1404;
  --danger:#f08a8a;

  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow:0 24px 60px -24px rgba(0,0,0,.7);
  --shadow-lg:0 50px 90px -40px rgba(0,0,0,.85);
  --radius:18px;
  --radius-lg:26px;
  --radius-sm:12px;
  --wrap:1240px;
  --gutter:clamp(20px,5vw,52px);
  --ease:cubic-bezier(.16,1,.3,1);
  --expo:linear(0 0%,.0085 31.26%,.0167 40.94%,.0289 48.86%,.0471 55.92%,.0717 61.99%,.1038 67.32%,.1443 72.07%,.1989 76.7%,.2659 80.89%,.3465 84.71%,.4419 88.22%,.554 91.48%,.6835 94.51%,.8316 97.34%,1 100%);
  --spark:#8BF7CD;   /* elektrisches Mint */
  --ion:#5FD8FF;     /* Ion-Cyan */
  --grad-anim:linear-gradient(100deg,var(--brand) 0%,var(--spark) 35%,var(--ion) 60%,var(--brand) 100%);
  --bg-rgb:11,15,13;
  --grain:.035;
  color-scheme:dark;
}

html[data-theme="light"]{
  /* LIGHT — warmes Editorial-Papier statt Reinweiß */
  --bg:#F4F1E8;
  --bg-2:#EFEBE0;
  --surface:#FBFAF4;
  --card:#FFFFFF;
  --card-2:#FBFAF4;
  --line:rgba(19,26,22,.12);
  --line-2:rgba(19,26,22,.20);
  --ink:#141C18;
  --ink-soft:#4C584F;
  --ink-faint:#5D685F;
  --brand:#1C7A5B;          /* dunkles Teal — AA auf Papier */
  --brand-2:#15976C;
  --brand-ink:#FFFFFF;
  --brand-glow:rgba(28,122,91,.20);
  --brand-tint:rgba(28,122,91,.08);
  --brand-line:rgba(28,122,91,.26);
  --accent:#9A6A0F;
  --accent-ink:#fff;
  --danger:#b91c1c;
  --shadow-sm:0 1px 2px rgba(40,50,44,.10);
  --shadow:0 24px 50px -28px rgba(30,45,38,.34);
  --shadow-lg:0 50px 90px -44px rgba(30,45,38,.40);
  --bg-rgb:244,241,232;
  --grain:.02;
  color-scheme:light;
}

/* ============================ RESET ============================ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:96px}
body{
  font-family:var(--font-text);
  background:var(--bg);
  color:var(--ink);
  line-height:1.65;
  font-size:17px;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  position:relative;
  min-height:100vh;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
::selection{background:var(--brand);color:var(--brand-ink)}
:focus-visible{outline:2.5px solid var(--brand);outline-offset:3px;border-radius:4px}

/* feines Papierkorn über alles für Tiefe/Atmosphäre */
body::after{
  content:"";position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:var(--grain);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

/* ============================ LAYOUT ============================ */
.wrap{max-width:var(--wrap);margin:0 auto;padding-inline:var(--gutter);width:100%}
.wrap-tight{max-width:920px;margin:0 auto;padding-inline:var(--gutter);width:100%}
.section{padding-block:clamp(80px,11vw,160px);position:relative}
.section-sm{padding-block:clamp(56px,8vw,100px);position:relative}
.divider{height:1px;background:var(--line);border:0}

/* Eyebrow / Mono-Label */
.eyebrow{
  font-family:var(--font-mono);font-size:12.5px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;color:var(--brand);
  display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--brand);opacity:.7;display:inline-block}
.eyebrow.no-line::before{display:none}
.eyebrow .idx{color:var(--ink-faint)}

.section-head{max-width:760px;margin-bottom:clamp(44px,6vw,72px)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head.center .eyebrow{justify-content:center}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.04;letter-spacing:-.02em;color:var(--ink)}
.section-title{font-size:clamp(34px,5.2vw,62px);margin-top:20px}
.lead{font-size:clamp(17px,2vw,21px);color:var(--ink-soft);line-height:1.6;max-width:62ch;margin-top:22px}

.brand-text{color:var(--brand)}
.accent-text{color:var(--accent)}
/* Outline-Wort als Display-Akzent */
.outline-text{
  color:transparent;-webkit-text-stroke:1.4px var(--ink-faint);
}

/* ============================ HEADER ============================ */
.site-header{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  transition:transform .5s var(--ease),background .4s,border-color .4s,backdrop-filter .4s;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:color-mix(in srgb,var(--bg) 82%,transparent);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:var(--line);
}
.site-header.hidden{transform:translateY(-101%)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;height:74px}
.brand{
  font-family:var(--font-display);font-weight:800;font-size:21px;letter-spacing:.18em;
  color:var(--ink);display:inline-flex;align-items:center;gap:9px;flex-shrink:0;
}
.brand .dot{width:8px;height:8px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 4px var(--brand-tint);animation:pulse 2.6s var(--ease) infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px var(--brand-tint)}50%{box-shadow:0 0 0 7px transparent}}

.nav-menu{display:flex;gap:6px;list-style:none}
.nav-menu a{
  font-size:14px;font-weight:500;color:var(--ink-soft);padding:9px 14px;border-radius:9px;
  transition:color .25s,background .25s;position:relative;
}
.nav-menu a:hover{color:var(--ink);background:var(--brand-tint)}

.nav-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.icon-btn{
  width:42px;height:42px;border-radius:11px;border:1px solid var(--line-2);
  display:inline-flex;align-items:center;justify-content:center;color:var(--ink-soft);
  transition:all .3s var(--ease);
}
.icon-btn:hover{color:var(--brand);border-color:var(--brand-line);transform:translateY(-1px)}
.icon-btn svg{width:18px;height:18px}
.theme-toggle .icon-sun{display:none}
html[data-theme="light"] .theme-toggle .icon-sun{display:block}
html[data-theme="light"] .theme-toggle .icon-moon{display:none}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-text);font-weight:600;font-size:14.5px;letter-spacing:.01em;
  padding:13px 22px;border-radius:11px;transition:all .3s var(--ease);
  border:1px solid transparent;white-space:nowrap;line-height:1;
}
.btn svg{width:17px;height:17px;transition:transform .3s var(--ease)}
.btn--primary{background:var(--brand);color:var(--brand-ink);box-shadow:0 8px 24px -10px var(--brand-glow)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 16px 36px -12px var(--brand-glow)}
.btn--primary:hover svg{transform:translateX(3px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn--ghost:hover{border-color:var(--brand-line);color:var(--brand);transform:translateY(-2px)}
.btn--lg{padding:16px 28px;font-size:15.5px;border-radius:13px}
.btn--block{width:100%}

.burger{display:none;width:44px;height:44px;border-radius:11px;border:1px solid var(--line-2);align-items:center;justify-content:center}
.burger span{position:relative;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}
.burger span::before{top:-6px}.burger span::after{top:6px}
.burger.active span{background:transparent}
.burger.active span::before{top:0;transform:rotate(45deg)}
.burger.active span::after{top:0;transform:rotate(-45deg)}

/* Mobile-Menü */
.mobile-menu{
  position:fixed;inset:0;z-index:995;background:var(--bg-2);
  display:flex;flex-direction:column;justify-content:center;gap:6px;padding:90px var(--gutter) 40px;
  opacity:0;visibility:hidden;transform:translateY(-12px);transition:opacity .35s var(--ease),transform .35s var(--ease),visibility .35s;
}
.mobile-menu.open{opacity:1;visibility:visible;transform:none}
.mobile-menu a.m-link{
  font-family:var(--font-display);font-size:clamp(30px,9vw,46px);font-weight:700;color:var(--ink);
  letter-spacing:-.02em;padding:8px 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;
}
.mobile-menu a.m-link .num{font-family:var(--font-mono);font-size:13px;color:var(--ink-faint);font-weight:400}
.mobile-menu a.m-link:active{color:var(--brand)}
.mobile-cta{display:flex;flex-direction:column;gap:12px;margin-top:30px}

/* ============================ HERO ============================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;padding-top:clamp(120px,15vh,168px);padding-bottom:clamp(80px,10vw,120px);overflow:hidden}
.hero-content{max-width:960px;margin-inline:auto;text-align:center;position:relative}
.hero-content .hero-eyebrow{justify-content:center}
.hero-content .hero-lead{margin-inline:auto}
.hero-content .hero-actions,.hero-content .hero-trust{justify-content:center}
.hero-content .hero-trust .t{align-items:center;text-align:center}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
/* feines Basisraster */
.hero-bg .grid{
  position:absolute;inset:-2px;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(120% 90% at 70% 0%,#000 25%,transparent 75%);
  mask-image:radial-gradient(120% 90% at 70% 0%,#000 25%,transparent 75%);
  opacity:.6;
}
.hero-bg .aurora{
  position:absolute;width:760px;height:760px;top:-340px;right:-160px;border-radius:50%;
  background:radial-gradient(circle,var(--brand) 0%,transparent 62%);
  opacity:.16;filter:blur(40px);animation:drift 22s var(--ease) infinite alternate;
}
.hero-bg .aurora.two{top:auto;bottom:-440px;left:-220px;right:auto;width:620px;height:620px;background:radial-gradient(circle,var(--brand-2) 0%,transparent 62%);opacity:.10;animation-duration:28s}
@keyframes drift{to{transform:translate3d(-60px,40px,0) scale(1.12)}}

.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(36px,5vw,72px);align-items:center}
.hero-eyebrow{margin-bottom:26px}
.hero h1{font-size:clamp(44px,7.4vw,92px);font-weight:800;letter-spacing:-.035em}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .reveal-word{display:inline-block}
.hero-lead{font-size:clamp(17px,1.7vw,20px);color:var(--ink-soft);max-width:50ch;margin-top:28px;line-height:1.6}
.hero-lead strong{color:var(--ink);font-weight:600}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:36px}
.hero-trust{display:flex;gap:28px;flex-wrap:wrap;margin-top:44px;padding-top:30px;border-top:1px solid var(--line)}
.hero-trust .t{display:flex;flex-direction:column;gap:3px}
.hero-trust .t b{font-family:var(--font-display);font-size:26px;font-weight:700;color:var(--ink);letter-spacing:-.02em}
.hero-trust .t span{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}

/* Automations-Konsole (Hero rechts) */
.console{
  background:linear-gradient(180deg,var(--card) 0%,var(--card-2) 100%);
  border:1px solid var(--line-2);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);
  overflow:hidden;position:relative;
}
.console::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(160deg,var(--brand-line),transparent 40%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.console-bar{display:flex;align-items:center;gap:8px;padding:14px 18px;border-bottom:1px solid var(--line)}
.console-bar .dots{display:flex;gap:6px}
.console-bar .dots i{width:10px;height:10px;border-radius:50%;background:var(--line-2)}
.console-bar .dots i:first-child{background:var(--brand)}
.console-bar .title{font-family:var(--font-mono);font-size:12px;color:var(--ink-faint);letter-spacing:.08em;margin-left:6px}
.console-body{padding:20px 18px 24px;font-family:var(--font-mono);font-size:13.5px;line-height:1.5}
.console-row{display:flex;align-items:center;gap:11px;padding:9px 0;opacity:0;transform:translateY(6px);animation:logIn .5s var(--ease) forwards}
.console-row:nth-child(1){animation-delay:.2s}
.console-row:nth-child(2){animation-delay:1.0s}
.console-row:nth-child(3){animation-delay:1.8s}
.console-row:nth-child(4){animation-delay:2.6s}
.console-row:nth-child(5){animation-delay:3.4s}
@keyframes logIn{to{opacity:1;transform:none}}
.console-row .tick{width:18px;height:18px;border-radius:50%;background:var(--brand-tint);color:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.console-row .tick svg{width:11px;height:11px}
.console-row .t{color:var(--ink-soft)}
.console-row .t b{color:var(--ink);font-weight:500}
.console-row .ms{margin-left:auto;color:var(--ink-faint);font-size:11.5px}
.console-foot{display:flex;align-items:center;gap:9px;padding:14px 18px;border-top:1px solid var(--line);font-family:var(--font-mono);font-size:12px;color:var(--ink-faint)}
.console-foot .live{width:7px;height:7px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 0 var(--brand-glow);animation:ping 1.8s infinite}
@keyframes ping{0%{box-shadow:0 0 0 0 var(--brand-glow)}70%{box-shadow:0 0 0 8px transparent}100%{box-shadow:0 0 0 0 transparent}}

/* Marquee Kundenleiste */
.ticker{border-block:1px solid var(--line);overflow:hidden;background:var(--bg-2)}
.ticker-track{display:flex;gap:0;width:max-content;animation:scrollX 38s linear infinite}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-item{display:inline-flex;align-items:center;gap:14px;padding:18px 34px;font-family:var(--font-mono);font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);white-space:nowrap}
.ticker-item::after{content:"✦";color:var(--brand);margin-left:34px;opacity:.6}
@keyframes scrollX{to{transform:translateX(-50%)}}

/* ============================ SERVICES (Bento) ============================ */
.svc-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
.svc-card{
  grid-column:span 3;background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(28px,3vw,42px);position:relative;overflow:hidden;
  transition:transform .5s var(--ease),border-color .5s,box-shadow .5s;display:flex;flex-direction:column;
}
.svc-card.feature{grid-column:span 3}
.svc-card::after{content:"";position:absolute;inset:0;background:radial-gradient(420px 200px at 100% 0%,var(--brand-tint),transparent 70%);opacity:0;transition:opacity .5s}
.svc-card:hover{transform:translateY(-6px);border-color:var(--brand-line);box-shadow:var(--shadow)}
.svc-card:hover::after{opacity:1}
.svc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px}
.svc-num{font-family:var(--font-mono);font-size:12px;color:var(--ink-faint);letter-spacing:.1em}
.svc-icon{width:54px;height:54px;border-radius:14px;background:var(--brand-tint);color:var(--brand);display:flex;align-items:center;justify-content:center;border:1px solid var(--brand-line)}
.svc-icon svg{width:26px;height:26px;stroke-width:1.7}
.svc-card h3{font-size:clamp(20px,2vw,25px);font-weight:700;margin-bottom:8px;letter-spacing:-.01em}
.svc-price{font-family:var(--font-mono);font-size:13px;color:var(--brand);margin-bottom:16px;font-weight:500}
.svc-card p{color:var(--ink-soft);font-size:15.5px;line-height:1.7;position:relative;z-index:1}
.svc-card p strong{color:var(--ink);font-weight:600}
.svc-foot{margin-top:auto;padding-top:22px}
.svc-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--brand)}
.svc-link svg{width:15px;height:15px;transition:transform .3s var(--ease)}
.svc-card:hover .svc-link svg{transform:translateX(4px)}
.svc-note{margin:34px auto 0;max-width:680px;text-align:center;font-size:14px;color:var(--ink-faint);line-height:1.6}

/* ============================ STATEMENT (Warum KI) ============================ */
.statement{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(36px,5vw,72px);align-items:start}
.statement-quote{font-family:var(--font-display);font-size:clamp(24px,3.2vw,38px);font-weight:600;line-height:1.28;letter-spacing:-.02em;color:var(--ink)}
.statement-quote em{font-style:normal;color:var(--brand)}
.statement-body{color:var(--ink-soft);font-size:16px;line-height:1.8}
.statement-body p+p{margin-top:18px}
.statement-body strong{color:var(--ink);font-weight:600}
.metrics{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.metric{padding:22px 0;border-bottom:1px solid var(--line)}
.metric b{font-family:var(--font-display);font-size:clamp(30px,3.4vw,42px);font-weight:700;color:var(--ink);letter-spacing:-.02em;display:block}
.metric span{font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint)}

/* ============================ PROCESS (Timeline) ============================ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative}
.steps::before{content:"";position:absolute;top:28px;left:6%;right:6%;height:1px;background:linear-gradient(90deg,transparent,var(--line-2),var(--line-2),transparent)}
.step{position:relative;z-index:1}
.step-num{width:56px;height:56px;border-radius:50%;border:1px solid var(--brand-line);background:var(--bg);color:var(--brand);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:18px;font-weight:500;margin-bottom:22px;transition:all .4s var(--ease)}
.step:hover .step-num{background:var(--brand);color:var(--brand-ink);transform:translateY(-3px);box-shadow:0 12px 26px -12px var(--brand-glow)}
.step h3{font-size:20px;font-weight:700;margin-bottom:10px}
.step p{color:var(--ink-soft);font-size:15px;line-height:1.65}

/* ============================ TESTIMONIALS ============================ */
.tm-wrap{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.tm-track{display:flex;gap:20px;width:max-content;animation:scrollX 64s linear infinite}
.tm-wrap:hover .tm-track{animation-play-state:paused}
.tm-card{
  width:392px;flex-shrink:0;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:32px 30px;display:flex;flex-direction:column;gap:20px;transition:border-color .4s,transform .4s;
}
.tm-card:hover{border-color:var(--brand-line)}
.tm-mark{font-family:var(--font-display);font-size:46px;line-height:.6;color:var(--brand);opacity:.5;height:24px}
.tm-quote{color:var(--ink-soft);font-size:15.5px;line-height:1.7;flex:1}
.tm-meta{display:flex;align-items:center;justify-content:space-between;gap:14px;border-top:1px solid var(--line);padding-top:18px}
.tm-meta .who b{display:block;color:var(--ink);font-weight:600;font-size:15px}
.tm-meta .who span{color:var(--brand);font-size:13px}
.tm-stars{display:flex;gap:2px;color:var(--accent);flex-shrink:0}
.tm-stars svg{width:15px;height:15px;fill:currentColor}

/* ============================ TEAM ============================ */
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:980px;margin:0 auto}
.team-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(28px,3vw,40px);display:flex;gap:26px;align-items:flex-start;transition:transform .5s var(--ease),border-color .5s,box-shadow .5s}
.team-card:hover{transform:translateY(-5px);border-color:var(--brand-line);box-shadow:var(--shadow)}
.team-card picture{flex:0 0 104px;display:block;width:104px;height:104px}
.team-photo{width:104px;height:104px;border-radius:20px;object-fit:cover;object-position:top center;border:1px solid var(--line-2);flex-shrink:0;filter:grayscale(.15);transition:filter .5s}
.team-card:hover .team-photo{filter:none}
.team-card h3{font-size:24px;font-weight:700;margin-bottom:3px}
.team-role{font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--brand);margin-bottom:14px}
.team-card p{color:var(--ink-soft);font-size:14.5px;line-height:1.7;margin-bottom:10px}
.team-tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}
.tag{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.04em;color:var(--ink-soft);background:var(--brand-tint);border:1px solid var(--brand-line);padding:5px 11px;border-radius:8px}

/* ============================ CTA-BANNER ============================ */
.cta-banner{position:relative;background:linear-gradient(135deg,var(--card) 0%,var(--card-2) 100%);border:1px solid var(--brand-line);border-radius:var(--radius-lg);padding:clamp(40px,6vw,72px);overflow:hidden;text-align:center}
.cta-banner::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 320px at 50% -10%,var(--brand-tint),transparent 70%)}
.cta-banner>*{position:relative;z-index:1}
.cta-banner h2{font-size:clamp(30px,4.4vw,52px);font-weight:800;letter-spacing:-.025em}
.cta-banner p{color:var(--ink-soft);max-width:54ch;margin:18px auto 0;font-size:17px}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:34px}

/* ============================ FAQ ============================ */
.faq{max-width:840px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;display:flex;align-items:center;gap:18px;padding:26px 0;font-family:var(--font-display);font-size:clamp(17px,2vw,20px);font-weight:600;color:var(--ink);transition:color .3s}
.faq-q .qn{font-family:var(--font-mono);font-size:13px;color:var(--ink-faint);font-weight:400;flex-shrink:0}
.faq-q .qt{flex:1}
.faq-q:hover{color:var(--brand)}
.faq-icon{flex-shrink:0;width:26px;height:26px;position:relative;transition:transform .4s var(--ease)}
.faq-icon::before,.faq-icon::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--brand)}
.faq-icon::before{width:14px;height:2px}
.faq-icon::after{width:2px;height:14px;transition:transform .4s var(--ease)}
.faq-item.open .faq-icon::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.faq-a-inner{padding:0 0 28px;color:var(--ink-soft);font-size:15.5px;line-height:1.75}
.faq-a-inner strong{color:var(--ink);font-weight:600}

/* ============================ CONTACT ============================ */
.contact-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(36px,5vw,64px);align-items:start}
.contact-info h3{font-size:clamp(24px,3vw,32px);font-weight:700;margin-bottom:12px}
.contact-info .lead{margin-top:8px;margin-bottom:36px}
.cinfo{display:block;padding:18px 0;border-top:1px solid var(--line)}
.cinfo .lbl{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:6px;display:block}
.cinfo a,.cinfo p{color:var(--ink);font-size:16px;line-height:1.5;transition:color .25s}
.cinfo a:hover{color:var(--brand)}

.form-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(28px,3.5vw,44px)}
.form-card h3{font-size:23px;font-weight:700;margin-bottom:6px}
.form-card .sub{color:var(--ink-faint);font-size:14px;margin-bottom:30px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--font-mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:8px}
.field input,.field textarea,.field select{
  width:100%;padding:14px 16px;background:var(--bg);border:1px solid var(--line-2);border-radius:var(--radius-sm);
  font-family:var(--font-text);font-size:15px;color:var(--ink);transition:border-color .25s,box-shadow .25s;
}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-faint)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-tint)}
.field textarea{resize:vertical;min-height:130px}
.field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237a8a82' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:42px}
.field select option{background:var(--card);color:var(--ink)}
.check{display:flex;gap:11px;align-items:flex-start;margin-bottom:22px}
.check input{width:19px;height:19px;margin-top:2px;accent-color:var(--brand);flex-shrink:0}
.check label{font-size:13.5px;color:var(--ink-soft);line-height:1.5}
.check a{color:var(--brand);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.form-status{margin-top:18px;padding:14px 18px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;display:none}
.form-status.success{display:block;background:var(--brand-tint);border:1px solid var(--brand-line);color:var(--brand)}
.form-status.error{display:block;background:rgba(240,138,138,.1);border:1px solid rgba(240,138,138,.3);color:var(--danger)}

/* ============================ FOOTER ============================ */
.site-footer{border-top:1px solid var(--line);background:var(--bg-2);padding-block:clamp(56px,7vw,84px) 34px;position:relative;overflow:hidden}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-brand .brand{font-size:26px;margin-bottom:16px}
.footer-brand p{color:var(--ink-soft);font-size:14.5px;max-width:34ch;line-height:1.7}
.footer-col .fch{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);font-weight:500;margin-bottom:18px}
.footer-col a,.footer-col p{display:block;color:var(--ink-soft);font-size:14.5px;padding:6px 0;transition:color .25s}
.footer-col a:hover{color:var(--brand)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:28px;border-top:1px solid var(--line)}
.footer-bottom p{font-size:13px;color:var(--ink-faint)}
.footer-watermark{position:absolute;bottom:-3.2vw;left:50%;transform:translateX(-50%);font-family:var(--font-display);font-weight:800;font-size:24vw;line-height:1;color:var(--ink);opacity:.025;pointer-events:none;white-space:nowrap;letter-spacing:-.04em}
.footer-watermark::after{content:"BRINGEFUL"}

/* ============================ COOKIE ============================ */
.cookie{
  position:fixed;left:var(--gutter);right:var(--gutter);bottom:20px;z-index:2000;max-width:520px;margin-inline:auto;
  background:var(--card);border:1px solid var(--line-2);border-radius:var(--radius);box-shadow:var(--shadow-lg);
  padding:22px 24px;transform:translateY(160%);opacity:0;transition:transform .6s var(--ease),opacity .4s;
}
.cookie.visible{transform:none;opacity:1}
.cookie .cookie-title{font-size:16px;font-weight:700;margin-bottom:7px;display:flex;align-items:center;gap:8px;color:var(--ink);font-family:var(--font-display)}
.cookie .cookie-title svg{width:17px;height:17px;color:var(--brand)}
.cookie p{font-size:13px;color:var(--ink-soft);line-height:1.6}
.cookie p a{color:var(--brand);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.cookie-btns{display:flex;gap:10px;margin-top:16px}
.cookie-btns .btn{flex:1;padding:11px 16px;font-size:13.5px}

/* ============================ CHAT WIDGET ============================ */
.chat-fab{position:fixed;bottom:26px;right:26px;width:58px;height:58px;border-radius:50%;background:var(--brand);color:var(--brand-ink);display:flex;align-items:center;justify-content:center;box-shadow:0 14px 34px -10px var(--brand-glow);z-index:9970;transition:transform .3s var(--ease)}
.chat-fab:hover{transform:scale(1.07)}
.chat-fab svg{width:25px;height:25px}
.chat-fab .icon-close{display:none}
.chat-fab.open .icon-chat{display:none}
.chat-fab.open .icon-close{display:block}
.chat-panel{position:fixed;bottom:96px;right:26px;width:382px;max-width:calc(100vw - 36px);height:560px;max-height:calc(100vh - 140px);background:var(--card);border:1px solid var(--line-2);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;z-index:9971;opacity:0;visibility:hidden;transform:translateY(16px) scale(.98);transition:opacity .3s,transform .3s,visibility .3s}
.chat-panel.open{opacity:1;visibility:visible;transform:none}
.chat-head{background:var(--brand);color:var(--brand-ink);padding:16px 20px;display:flex;align-items:center;gap:12px;flex-shrink:0}
.chat-head .av{width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.12);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.chat-head .av svg{width:20px;height:20px}
.chat-head .ct{font-weight:700;font-size:15px;line-height:1.2}
.chat-head .cs{font-size:11px;opacity:.75}
.chat-msgs{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:11px;background:var(--bg-2)}
.chat-msg{max-width:82%;padding:11px 14px;border-radius:14px;font-size:14px;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}
.chat-msg.bot{align-self:flex-start;background:var(--card);border:1px solid var(--line);color:var(--ink);border-bottom-left-radius:4px}
.chat-msg.user{align-self:flex-end;background:var(--brand);color:var(--brand-ink);border-bottom-right-radius:4px}
.chat-typing{align-self:flex-start;display:flex;gap:5px;padding:12px 14px}
.chat-typing span{width:7px;height:7px;border-radius:50%;background:var(--ink-faint);animation:blink 1.2s infinite both}
.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,80%,100%{opacity:.25}40%{opacity:1}}
.chat-inrow{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line);background:var(--card);flex-shrink:0}
.chat-inrow textarea{flex:1;resize:none;border:1px solid var(--line-2);background:var(--bg);color:var(--ink);border-radius:12px;padding:10px 12px;font-family:var(--font-text);font-size:14px;line-height:1.4;max-height:96px;outline:none}
.chat-inrow textarea:focus{border-color:var(--brand)}
.chat-send{flex-shrink:0;width:44px;border-radius:12px;background:var(--brand);color:var(--brand-ink);display:flex;align-items:center;justify-content:center;transition:opacity .2s}
.chat-send:disabled{opacity:.5}
.chat-send svg{width:20px;height:20px}
.chat-disc{font-size:10.5px;color:var(--ink-faint);text-align:center;padding:0 12px 10px;background:var(--card);flex-shrink:0}
.chat-disc strong{color:var(--brand);font-weight:600}

/* ============================ PROSE (Recht/Blog) ============================ */
.page-hero{padding-top:clamp(130px,16vh,180px);padding-bottom:clamp(30px,4vw,50px);position:relative;overflow:hidden}
.page-hero .hero-bg{z-index:0}
.page-hero-inner{position:relative;z-index:2}
.page-hero h1{font-size:clamp(40px,7vw,76px);font-weight:800;letter-spacing:-.03em}
.page-hero .lead{margin-top:18px}
.prose{max-width:760px;color:var(--ink-soft);font-size:16.5px;line-height:1.8}
.prose>*+*{margin-top:18px}
.prose h2{font-size:clamp(24px,3vw,34px);font-weight:700;color:var(--ink);margin-top:52px;margin-bottom:6px;letter-spacing:-.02em;padding-bottom:14px;border-bottom:1px solid var(--line)}
.prose h3{font-size:clamp(19px,2.2vw,23px);font-weight:700;color:var(--ink);margin-top:34px}
.prose h4{font-size:17px;font-weight:700;color:var(--ink);margin-top:24px}
.prose p,.prose li{color:var(--ink-soft)}
.prose strong{color:var(--ink);font-weight:600}
.prose a{color:var(--brand);text-decoration:underline;text-underline-offset:2px}
.prose ul,.prose ol{padding-left:24px}
.prose li{margin-top:8px}
.prose hr{border:0;height:1px;background:var(--line);margin:36px 0}
.prose table{width:100%;border-collapse:collapse;font-size:15px;margin-top:10px}
.prose th,.prose td{text-align:left;padding:12px 14px;border:1px solid var(--line)}
.prose th{font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);background:var(--bg-2)}
.callout{background:var(--card);border:1px solid var(--line-2);border-left:3px solid var(--brand);border-radius:var(--radius-sm);padding:20px 22px;margin-top:22px}
.callout h4,.callout .callout-h{margin-top:0;color:var(--ink);font-family:var(--font-display);font-weight:700;font-size:17px;margin-bottom:6px;letter-spacing:-.01em}
.callout.warn{border-left-color:var(--accent)}

/* Blog-Karten */
.post-grid{display:grid;grid-template-columns:1fr;gap:20px;max-width:880px;margin:0 auto}
.post-card{display:block;background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(26px,3vw,38px);transition:transform .5s var(--ease),border-color .5s,box-shadow .5s;position:relative;overflow:hidden}
.post-card:hover{transform:translateY(-4px);border-color:var(--brand-line);box-shadow:var(--shadow)}
.post-meta{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.post-cat{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--brand);background:var(--brand-tint);border:1px solid var(--brand-line);padding:5px 12px;border-radius:8px}
.post-date{font-family:var(--font-mono);font-size:12px;color:var(--ink-faint);letter-spacing:.04em}
.post-card h2,.post-card h3{font-size:clamp(21px,2.4vw,27px);font-weight:700;letter-spacing:-.01em;margin-bottom:12px}
.post-card p{color:var(--ink-soft);font-size:15.5px;line-height:1.7}
.post-card .read{display:inline-flex;align-items:center;gap:8px;margin-top:20px;font-family:var(--font-mono);font-size:12.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--brand)}
.post-card .read svg{width:15px;height:15px;transition:transform .3s var(--ease)}
.post-card:hover .read svg{transform:translateX(4px)}

/* ============================ PREISRECHNER ============================ */
.calc{display:grid;grid-template-columns:1.55fr 1fr;gap:26px;align-items:start}
.calc-panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(24px,3vw,40px)}
.calc-step{font-family:var(--font-mono);font-size:12.5px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--brand);display:flex;align-items:center;gap:11px;margin:34px 0 18px}
.calc-step:first-child{margin-top:0}
.calc-step .n{width:24px;height:24px;border-radius:7px;background:var(--brand-tint);border:1px solid var(--brand-line);display:inline-flex;align-items:center;justify-content:center;font-size:12px}
.pkg-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.package-card{position:relative;background:var(--bg);border:1px solid var(--line-2);border-radius:var(--radius);padding:22px 20px;cursor:pointer;transition:border-color .3s,background .3s,transform .3s var(--ease)}
.package-card:hover{transform:translateY(-3px);border-color:var(--brand-line)}
.package-card.selected{border-color:var(--brand);background:var(--brand-tint);box-shadow:0 0 0 1px var(--brand) inset,0 14px 34px -18px var(--brand-glow)}
.package-card h3{font-family:var(--font-display);font-size:16px;font-weight:700;letter-spacing:.01em;margin-bottom:8px}
.package-card strong{display:block;font-family:var(--font-display);font-size:30px;font-weight:800;color:var(--ink);letter-spacing:-.02em;margin-bottom:10px}
.package-card p{font-size:13.5px;color:var(--ink-soft);line-height:1.55}
.package-card .feature-badge{position:absolute;top:14px;right:14px;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-ink);background:var(--brand);padding:4px 9px;border-radius:7px}
.opt{padding:16px 0;border-bottom:1px solid var(--line)}
.opt.locked{opacity:.85}
.opt-label{display:flex;align-items:center;justify-content:space-between;gap:14px;cursor:pointer}
.opt-label .info{display:flex;align-items:center;gap:12px}
.opt-label input[type=checkbox]{width:20px;height:20px;accent-color:var(--brand);flex-shrink:0;cursor:pointer}
.opt-label .name{font-weight:600;font-size:15.5px;color:var(--ink)}
.opt-label .price{font-family:var(--font-mono);font-size:14px;color:var(--brand);font-weight:500;white-space:nowrap}
.opt .description{font-size:13px;color:var(--ink-faint);line-height:1.55;margin-top:8px;padding-left:32px}
.slider-group{padding:18px 0;border-bottom:1px solid var(--line)}
.slider-group>label{display:block;font-weight:600;font-size:15px;color:var(--ink);margin-bottom:14px}
.slider-control{display:flex;align-items:center;gap:14px}
.slider-control input[type=range]{flex:1;-webkit-appearance:none;appearance:none;height:5px;border-radius:5px;background:var(--line-2);outline:none}
.slider-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--brand);cursor:pointer;border:3px solid var(--card);box-shadow:0 2px 8px var(--brand-glow)}
.slider-control input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--brand);cursor:pointer;border:3px solid var(--card)}
.slider-value{font-family:var(--font-mono);font-size:18px;font-weight:500;color:var(--brand);min-width:26px;text-align:center}
.slider-group .description{font-size:13px;color:var(--ink-faint);margin-top:10px}
.calc-hint{padding:16px 0 0;font-size:13.5px;color:var(--ink-soft)}
.calc-hint b{color:var(--brand);font-weight:600}
.calc-summary{position:sticky;top:96px;background:linear-gradient(180deg,var(--card),var(--card-2));border:1px solid var(--line-2);border-radius:var(--radius-lg);padding:clamp(24px,3vw,34px);box-shadow:var(--shadow)}
.calc-summary>h2{font-family:var(--font-display);font-size:20px;font-weight:700;margin-bottom:22px;letter-spacing:-.01em}
.summary-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 0;border-bottom:1px solid var(--line);font-size:14.5px;color:var(--ink-soft)}
.summary-item strong{color:var(--ink);font-weight:600;font-family:var(--font-mono);font-size:14px}
.summary-item.option-onetime span,.summary-item.included-pro-feature span{color:var(--brand)}
.summary-total{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-top:18px;padding-top:18px;border-top:1px solid var(--line-2)}
.summary-total .label{font-size:13px;font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint)}
.summary-total .value{font-family:var(--font-display);font-size:clamp(34px,5vw,46px);font-weight:800;color:var(--ink);letter-spacing:-.02em}
.summary-monthly{font-size:12.5px;color:var(--ink-faint);text-align:right;margin-top:6px}
.calc-summary .btn{width:100%;margin-top:24px}
.legal-note{font-size:12px;color:var(--ink-faint);line-height:1.55;margin-top:18px;text-align:center}

/* ============================ REVEAL (IntersectionObserver) ============================ */
html.js .reveal{opacity:0;transform:translateY(34px) scale(.97);filter:blur(10px);transition:opacity .9s var(--expo),transform .9s var(--expo),filter .9s var(--expo)}
html.js .reveal.in{opacity:1;transform:none;filter:none}
html.js .reveal[data-d="1"]{transition-delay:.09s}
html.js .reveal[data-d="2"]{transition-delay:.18s}
html.js .reveal[data-d="3"]{transition-delay:.27s}
html.js .reveal[data-d="4"]{transition-delay:.36s}

/* ============================ KINETIC ============================ */
/* — View-Transition Theme-Reveal (Kreis-Wipe vom Toggle-Button) — */
::view-transition-old(root),::view-transition-new(root){animation:none;mix-blend-mode:normal}
::view-transition-old(root){z-index:1}
::view-transition-new(root){z-index:2147483646}
html.vt-active::view-transition-new(root){animation:vtReveal .62s var(--expo) forwards}
@keyframes vtReveal{from{clip-path:circle(0% at var(--vt-x,50%) var(--vt-y,0%))}to{clip-path:circle(150% at var(--vt-x,50%) var(--vt-y,0%))}}

/* — Rotierende Morph-Headline — */
.rotator{position:relative;display:inline-block;vertical-align:bottom;line-height:1;text-align:left}
.rotator>.rw{position:absolute;left:0;top:0;white-space:nowrap;background:var(--grad-anim);background-size:280% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:gradPan 7s linear infinite;
  opacity:0;transform:translateY(.42em);filter:blur(14px);transition:opacity .55s var(--expo),transform .6s var(--expo),filter .55s var(--expo);will-change:transform,filter,opacity}
.rotator>.rw.in{position:relative;opacity:1;transform:none;filter:none}
.rotator>.rw.out{opacity:0;transform:translateY(-.42em);filter:blur(14px)}
@keyframes gradPan{to{background-position:280% center}}

/* — Animierter Gradient-Text (Akzentworte) — */
.flow-text{background:var(--grad-anim);background-size:260% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:gradPan 8s linear infinite}

/* — Cursor-Glow (Desktop) — */
.cursor-glow{position:fixed;top:0;left:0;width:480px;height:480px;border-radius:50%;pointer-events:none;z-index:60;transform:translate3d(-50%,-50%,0);opacity:0;
  background:radial-gradient(circle,var(--brand-glow) 0%,transparent 60%);mix-blend-mode:screen;transition:opacity .4s;will-change:transform}
html[data-theme="light"] .cursor-glow{mix-blend-mode:multiply;background:radial-gradient(circle,rgba(28,122,91,.18) 0%,transparent 60%)}

/* — Buttons: ruhig, kein Versatz, kein Overlay (magnetisch deaktiviert) — */
.btn--primary{position:relative}

/* — Ink-Reveal Hero-Layer — */
.hero-spark{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;
  background:
    radial-gradient(40vw 40vw at 18% 30%,color-mix(in srgb,var(--brand) 46%,transparent),transparent 60%),
    radial-gradient(36vw 36vw at 82% 24%,color-mix(in srgb,var(--ion) 40%,transparent),transparent 62%),
    radial-gradient(42vw 42vw at 62% 88%,color-mix(in srgb,var(--spark) 42%,transparent),transparent 60%),
    radial-gradient(34vw 34vw at 30% 86%,color-mix(in srgb,var(--brand) 46%,transparent),transparent 62%);
  filter:saturate(1.1);animation:meshDrift 26s var(--ease) infinite alternate}
html[data-theme="light"] .hero-spark{filter:saturate(1.05) brightness(.98)}
@keyframes meshDrift{to{transform:scale(1.18) translate3d(2%,-2%,0)}}
.ink-canvas{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero.has-ink .hero-content,.hero.has-ink .wrap{position:relative;z-index:3}
.ink-hint{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);opacity:.85;pointer-events:none}
.ink-hint .blip{width:7px;height:7px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 0 var(--brand-glow);animation:ping 2s infinite}
@media (hover:none){.ink-hint{display:none}}

/* — TextReveal (Zeichen-Stagger beim Hover) — */
.tr{display:inline-flex;overflow:hidden;vertical-align:bottom;line-height:1}
.tr .trc{display:inline-block;will-change:transform;transition:transform .32s var(--ease);text-shadow:0 1em currentColor}
.tr:hover .trc,a:hover .tr .trc,.nav-menu a:hover .tr .trc{transform:translateY(-1em)}
.tr .trc[data-i]{transition-delay:calc(var(--i,0)*22ms)}

/* — Scroll-Cue — */
.scroll-cue{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:3;width:26px;height:42px;border:1.5px solid var(--line-2);border-radius:14px;display:flex;justify-content:center;padding-top:7px}
.scroll-cue i{width:4px;height:9px;border-radius:3px;background:var(--brand);animation:cueDrop 1.7s var(--ease) infinite}
@keyframes cueDrop{0%{opacity:0;transform:translateY(-3px)}40%{opacity:1}80%{opacity:0;transform:translateY(11px)}100%{opacity:0}}

/* — Skewed Stacked Cards (Branchen-Showcase) — */
.stack{display:grid;place-items:center;min-height:340px;perspective:1200px}
.stack-card{grid-area:1/1;width:min(360px,84vw);background:var(--card);border:1px solid var(--line-2);border-radius:var(--radius);padding:26px 28px;box-shadow:var(--shadow);
  transform:rotate(var(--rot,0deg)) translateY(var(--ty,0)) scale(var(--sc,1));transition:transform .6s var(--expo),box-shadow .6s;will-change:transform}
.stack:hover .stack-card{--rot:0deg}
.stack-card .si{width:42px;height:42px;border-radius:11px;background:var(--brand-tint);border:1px solid var(--brand-line);color:var(--brand);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.stack-card .si svg{width:22px;height:22px}
.stack-card h3{font-size:19px;font-weight:700;margin-bottom:6px}
.stack-card p{font-size:14px;color:var(--ink-soft);line-height:1.6}

@media (prefers-reduced-motion:reduce){
  .hero-spark{animation:none}
  .ink-canvas{display:none}
  .rotator>.rw{position:static;opacity:1;transform:none;filter:none}
  .rotator>.rw~.rw{display:none}
  .cursor-glow{display:none!important}
  html.vt-active::view-transition-new(root){animation:none}
}

.skip-link{position:absolute;left:-9999px;top:0;z-index:100000;background:var(--brand);color:var(--brand-ink);padding:12px 20px;border-radius:0 0 10px 0;font-weight:600}
.skip-link:focus{left:0}

/* ============================ RESPONSIVE ============================ */
@media (max-width:1040px){
  .svc-card,.svc-card.feature{grid-column:span 3}
  .statement{grid-template-columns:1fr;gap:36px}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .footer-brand{grid-column:1 / -1}
}
@media (max-width:920px){
  .nav-menu{display:none}
  .nav .btn--cta,.nav .icon-phone{display:none}
  .burger{display:flex}
  .hero-inner{grid-template-columns:1fr;gap:44px}
  .console{max-width:520px}
  .steps{grid-template-columns:1fr 1fr;gap:28px}
  .steps::before{display:none}
  .team-grid{grid-template-columns:1fr;max-width:560px}
}
@media (max-width:680px){
  body{font-size:16px}
  .hero h1{font-size:clamp(34px,8.4vw,62px)}
  .rotator,.rotator>.rw{max-width:92vw;overflow:hidden;text-overflow:ellipsis}
  .svc-grid{grid-template-columns:1fr}
  .svc-card,.svc-card.feature{grid-column:span 1}
  .steps{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .hero-actions .btn,.cta-actions .btn{flex:1;min-width:max-content}
  .team-card{flex-direction:column;align-items:flex-start}
  .tm-card{width:300px}
}

/* ============================ MOTION-REDUKTION ============================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  html.js .reveal{opacity:1!important;transform:none!important}
  .console-row{opacity:1;transform:none}
}

/* ============================ FUNNEL-KOMPONENTEN ============================ */
/* Feature-/Pain-/Trust-Kacheln */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(248px,1fr));gap:16px}
.feat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px 22px;transition:border-color .45s,transform .45s var(--expo),box-shadow .45s}
.feat:hover{border-color:var(--brand-line);transform:translateY(-4px);box-shadow:var(--shadow)}
.feat .fi{width:44px;height:44px;border-radius:11px;background:var(--brand-tint);border:1px solid var(--brand-line);color:var(--brand);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.feat .fi svg{width:22px;height:22px}
.feat h3{font-size:18px;font-weight:700;margin-bottom:7px;letter-spacing:-.01em}
.feat p{font-size:14.5px;color:var(--ink-soft);line-height:1.6}
.feat.muted .fi{background:color-mix(in srgb,var(--ink-faint) 16%,transparent);border-color:var(--line-2);color:var(--ink-faint)}
.feat--wide{grid-column:1/-1}

/* Mono-Band (Value-Stack / Hinweis) */
.band{display:flex;align-items:center;gap:10px 18px;flex-wrap:wrap;justify-content:center;text-align:center;background:var(--brand-tint);border:1px solid var(--brand-line);border-radius:var(--radius);padding:16px 24px;font-family:var(--font-mono);font-size:13px;letter-spacing:.02em;color:var(--ink)}
.band b{color:var(--brand)}
.band svg{width:16px;height:16px;color:var(--brand);vertical-align:-3px}

/* Loss-Aversion-Streifen */
.loss-line{margin-top:24px;border-left:3px solid var(--brand);background:var(--card);border-radius:var(--radius-sm);padding:20px 24px;font-family:var(--font-display);font-size:clamp(18px,2.3vw,25px);font-weight:600;color:var(--ink);line-height:1.35}

/* Ohne / Mit */
.vs-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.vs-col{border-radius:var(--radius-lg);padding:clamp(24px,3vw,38px);border:1px solid var(--line)}
.vs-col.neg{background:var(--bg-2)}
.vs-col.pos{background:linear-gradient(160deg,var(--card),var(--card-2));border-color:var(--brand-line);box-shadow:var(--shadow)}
.vs-col h3{font-size:19px;font-weight:700;margin-bottom:20px;display:flex;align-items:center;gap:10px}
.vs-col h3 .vh{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center}
.vs-col.neg .vh{background:color-mix(in srgb,var(--ink-faint) 16%,transparent);color:var(--ink-faint)}
.vs-col.pos .vh{background:var(--brand-tint);color:var(--brand);border:1px solid var(--brand-line)}
.vs-col ul{list-style:none;display:flex;flex-direction:column;gap:14px}
.vs-col li{display:flex;gap:11px;font-size:15px;line-height:1.5;color:var(--ink-soft)}
.vs-col li svg{width:19px;height:19px;flex-shrink:0;margin-top:1px}
.vs-col.neg li svg{color:var(--ink-faint)}
.vs-col.pos li{color:var(--ink)}.vs-col.pos li svg{color:var(--brand)}

/* Angebot: Für-wen-Zeile */
.svc-for{font-family:var(--font-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:10px}
.svc-card.anchor{position:relative}
.svc-badge{position:absolute;top:18px;right:18px;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-ink);background:var(--accent);padding:4px 9px;border-radius:7px}

/* Hero Kleingedrucktes */
.hero-fineprint{font-family:var(--font-mono);font-size:11px;letter-spacing:.03em;color:var(--ink-faint);margin-top:18px;line-height:1.5}
.hero-cred{font-family:var(--font-mono);font-size:13px;letter-spacing:.04em;color:var(--ink-soft);margin-top:32px;line-height:1.7}
.hero-cred strong{color:var(--brand);font-weight:500}

/* Proof statisch */
.proof-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px;margin-bottom:22px}
.proof-grid .tm-card{width:auto;flex-shrink:1;min-width:0}
.proof-note{text-align:center;font-size:12.5px;color:var(--ink-faint);max-width:760px;margin:0 auto 30px;line-height:1.55}

/* Mechanismus-Fluss */
.flow{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.flow .fl{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px 22px;position:relative}
.flow .fl .n{font-family:var(--font-mono);color:var(--brand);font-size:12.5px;letter-spacing:.06em;margin-bottom:12px;display:block}
.flow .fl h4{font-size:16.5px;font-weight:700;margin-bottom:7px;letter-spacing:-.01em}
.flow .fl p{font-size:14px;color:var(--ink-soft);line-height:1.55}
.flow .fl .fi{width:40px;height:40px;border-radius:10px;background:var(--brand-tint);border:1px solid var(--brand-line);color:var(--brand);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.flow .fl .fi svg{width:20px;height:20px}

@media (max-width:760px){.vs-grid{grid-template-columns:1fr}.flow{grid-template-columns:1fr}}
