/* ==========================================================================
   Aktavo — Design 3-hell: "Bold Light"
   V3-Wucht (riesige Typo) auf hellem Grund · Corporate-Blau
   einzelne dunkle Kontrast-Bänder als Hingucker
   ========================================================================== */

:root {
  --bg: #FFFFFF;
  --surf: #F5F7FB;
  --surf2: #EEF3FA;
  --dark: #0E2034;        /* Kontrast-Band */
  --dark2: #14304D;
  --line: #E4EAF2;
  --line2: #D4DEEC;
  --ink: #122036;
  --txt: #1F2D40;
  --mute: #586577;
  --mute2: #8A97A8;
  --blue: #1657C8;
  --blue-d: #0E3F94;
  --blue-l: #EAF1FB;
  --blue-soft: rgba(22,87,200,.10);
  --ok: #1E7E4F;
  --no: #C0563A;

  --sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --display: "Archivo", "Inter", sans-serif;

  --maxw: 1200px;
  --radius: 16px;
  --radius-sm: 10px;
  --shadow-sm: 0 1px 3px rgba(18,32,54,.07);
  --shadow-md: 0 20px 44px -22px rgba(18,32,54,.28);
}

*, *::before, *::after { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { margin:0; background:var(--bg); color:var(--txt); font-family:var(--sans); font-size:16px; line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
h1,h2,h3 { font-family:var(--display); color:var(--ink); font-weight:800; line-height:1.03; margin:0; letter-spacing:-0.035em; }
p { margin:0; }

.visually-hidden { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0); }
.skip-link { position:absolute; left:16px; top:-48px; background:var(--blue); color:#fff; font-weight:700; padding:10px 16px; border-radius:var(--radius-sm); z-index:200; transition:top .15s; }
.skip-link:focus { top:16px; }

.container { width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:28px; }
.section { padding-block:116px; }
.section--tight { padding-block:72px; }

.kicker { display:inline-flex; align-items:center; gap:8px; font-size:12px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--blue); }
.kicker::before { content:""; width:8px; height:8px; background:var(--blue); border-radius:50%; }
.kicker.on-dark { color:#8FB3F2; }
.kicker.on-dark::before { background:#8FB3F2; box-shadow:0 0 12px #8FB3F2; }

.section-head { max-width:860px; margin-bottom:58px; }
.section-head.center { margin-inline:auto; text-align:center; }
.section-head .kicker { margin-bottom:22px; }
.section-head h2 { font-size:clamp(34px,6vw,66px); }
.section-head .lead { font-size:20px; color:var(--mute); margin-top:24px; max-width:620px; }
.section-head.center .lead { margin-inline:auto; }

.reveal { opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease; }
.reveal.is-visible { opacity:1; transform:none; }

/* Buttons */
.btn { display:inline-flex; align-items:center; gap:10px; font-family:var(--sans); font-size:16px; font-weight:700; padding:16px 30px; border-radius:var(--radius-sm); border:2px solid transparent; cursor:pointer; transition:background .18s, color .18s, border-color .18s, transform .18s, box-shadow .18s; }
.btn:active { transform:translateY(1px); }
.btn-primary { background:var(--blue); color:#fff; }
.btn-primary:hover { background:var(--blue-d); box-shadow:0 12px 28px -10px rgba(22,87,200,.55); }
.btn-dark { background:var(--ink); color:#fff; }
.btn-dark:hover { background:#0A1626; }
.btn-outline { background:#fff; color:var(--ink); border-color:var(--line2); }
.btn-outline:hover { border-color:var(--blue); color:var(--blue); }
.btn-light { background:#fff; color:var(--blue-d); }
.btn-light:hover { background:var(--blue-l); }
.btn-sm { padding:11px 20px; font-size:14px; border-width:1px; }
.btn .ti { font-size:19px; }

/* Header */
.site-header { position:sticky; top:0; z-index:100; background:rgba(255,255,255,.86); backdrop-filter:blur(12px); border-bottom:1px solid var(--line); }
.nav { display:flex; align-items:center; justify-content:space-between; height:74px; }
.brand { font-family:var(--display); font-size:25px; font-weight:800; letter-spacing:-0.04em; color:var(--ink); }
.brand span { color:var(--blue); }
.nav-links { display:flex; gap:32px; list-style:none; margin:0; padding:0; }
.nav-links a { font-size:14.5px; font-weight:500; color:var(--txt); transition:color .15s; }
.nav-links a:hover { color:var(--blue); }
.nav-actions { display:flex; align-items:center; gap:14px; }
.nav-toggle { display:none; width:46px; height:46px; align-items:center; justify-content:center; background:#fff; border:1px solid var(--line2); border-radius:var(--radius-sm); color:var(--ink); cursor:pointer; }
.nav-toggle .ti { font-size:23px; }
.mobile-menu { display:none; }

/* Hero (hell + Wucht) */
.hero { position:relative; overflow:hidden; border-bottom:1px solid var(--line); background:radial-gradient(800px 520px at 50% -25%, rgba(22,87,200,.12), transparent 62%), linear-gradient(180deg, var(--surf2), #fff); }
.hero::before { content:""; position:absolute; inset:0; background-image:linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px); background-size:62px 62px; mask-image:radial-gradient(circle at 50% 0%, #000 0%, transparent 68%); opacity:.7; pointer-events:none; }
.hero-inner { position:relative; padding-block:118px 102px; text-align:center; }
.hero .kicker { justify-content:center; margin-bottom:30px; }
.hero h1 { font-size:clamp(46px,9vw,104px); letter-spacing:-0.045em; }
.hero h1 .acc { color:var(--blue); }
.hero-lead { font-size:clamp(18px,2.2vw,23px); color:var(--mute); margin:30px auto 0; max-width:680px; }
.hero-actions { display:flex; flex-wrap:wrap; gap:16px; justify-content:center; margin-top:40px; }
.hero-trust { margin-top:46px; display:flex; flex-wrap:wrap; gap:12px 26px; justify-content:center; }
.hero-trust span { display:inline-flex; align-items:center; gap:8px; font-size:13.5px; color:var(--mute); }
.hero-trust .ti { color:var(--blue); font-size:18px; }

/* Stat-Band (dunkles Kontrast-Band) */
.statband { background:var(--dark); }
.statband .container { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; padding:0; }
.statband .s { padding:40px 28px; text-align:center; border-right:1px solid rgba(255,255,255,.1); }
.statband .s:last-child { border-right:0; }
.statband .num { font-family:var(--display); font-weight:800; font-size:clamp(30px,4vw,48px); color:#fff; line-height:1; letter-spacing:-0.04em; }
.statband .num span { color:#8FB3F2; }
.statband .lbl { font-size:13.5px; color:#A9BACE; margin-top:10px; }

/* Branchen */
.branches { background:var(--bg); }
.branch-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:16px; }
.branch { position:relative; background:var(--surf); border:1px solid var(--line); border-radius:var(--radius); padding:30px; transition:border-color .2s, transform .2s, box-shadow .2s; }
.branch:hover { border-color:var(--blue); transform:translateY(-4px); box-shadow:var(--shadow-md); }
.branch .num { font-family:var(--display); font-weight:800; font-size:13px; color:var(--blue); }
.branch .ti { font-size:30px; color:var(--ink); margin:18px 0 14px; display:block; }
.branch h3 { font-size:22px; margin-bottom:9px; }
.branch p { font-size:14.5px; color:var(--mute); }

/* Feature-Statements (große Reihen) */
.statements { background:var(--surf); border-block:1px solid var(--line); }
.statement { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; padding-block:64px; border-bottom:1px solid var(--line); }
.statement:last-child { border-bottom:0; }
.statement.flip .vis { order:-1; }
.statement h3 { font-size:clamp(28px,3.6vw,44px); }
.statement p { font-size:18px; color:var(--mute); margin-top:18px; max-width:480px; }
.statement .chips { display:flex; flex-wrap:wrap; gap:10px; margin-top:24px; }
.chip { font-size:13px; font-weight:600; color:var(--ink); border:1px solid var(--line2); border-radius:30px; padding:7px 14px; display:inline-flex; align-items:center; gap:7px; background:#fff; }
.chip .ti { font-size:16px; color:var(--blue); }
.vis { background:linear-gradient(150deg, #fff, var(--blue-l)); border:1px solid var(--line); border-radius:var(--radius); min-height:280px; display:flex; align-items:center; justify-content:center; padding:30px; box-shadow:var(--shadow-sm); }
.vis .big-ico { font-size:96px; color:var(--blue); }

/* Produkt-Fenster */
.window { width:100%; border:1px solid var(--line2); border-radius:12px; overflow:hidden; background:#fff; box-shadow:var(--shadow-md); }
.window-bar { background:var(--dark); padding:12px 15px; display:flex; align-items:center; justify-content:space-between; }
.window-bar .title { font-size:13px; color:#fff; }
.window-bar .title em { color:#8FB3F2; font-style:normal; }
.phase-pill { background:var(--blue-soft); color:#BFD6FF; font-size:11px; padding:4px 10px; border-radius:20px; }
.window-body { display:flex; }
.window-tree { width:140px; flex-shrink:0; background:var(--surf2); border-right:1px solid var(--line); padding:12px 10px; font-size:12px; }
.tree-item { display:flex; align-items:center; gap:7px; color:var(--mute); padding:6px 8px; border-radius:8px; }
.tree-item .ti { font-size:14px; }
.tree-item.active { color:var(--ink); background:#fff; box-shadow:var(--shadow-sm); }
.tree-item.active .ti { color:var(--blue); }
.window-list { flex:1; min-width:0; }
.row { display:flex; align-items:center; gap:10px; padding:11px 14px; font-size:12px; border-bottom:1px solid var(--line); }
.row:last-child { border-bottom:0; }
.row .doc { flex:2; display:flex; align-items:center; gap:8px; color:var(--txt); min-width:0; }
.row .doc .ti { font-size:14px; color:var(--mute); flex-shrink:0; }
.row .doc span { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.row .status { flex:1; text-align:right; }
.tag { font-size:10px; padding:3px 9px; border-radius:20px; white-space:nowrap; }
.tag-ok { background:#E3F4EB; color:var(--ok); }
.tag-acc { background:var(--blue-l); color:var(--blue); }

/* Sicherheit */
.security { background:var(--bg); }
.sec-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:16px; }
.sec-item { background:var(--surf); border:1px solid var(--line); border-radius:var(--radius); padding:28px; transition:border-color .2s; }
.sec-item:hover { border-color:var(--line2); }
.sec-item .ti { font-size:26px; color:var(--blue); }
.sec-item h3 { font-size:19px; margin:16px 0 9px; }
.sec-item p { font-size:14.5px; color:var(--mute); }

/* Zertifikate-Band */
.certs { background:var(--surf); border-block:1px solid var(--line); }
.certs .container { padding-block:30px; }
.cert-row { display:flex; flex-wrap:wrap; gap:12px; justify-content:center; }
.cert { display:inline-flex; align-items:center; gap:9px; border:1px solid var(--line2); border-radius:30px; padding:10px 16px; font-size:13.5px; color:var(--ink); background:#fff; }
.cert .ti { font-size:18px; color:var(--blue); }
.cert.pending { color:var(--mute); border-style:dashed; }
.cert.pending small { color:var(--blue); font-weight:600; }

/* Vergleich */
.compare { background:var(--surf); border-block:1px solid var(--line); }
.compare-table { width:100%; border-collapse:collapse; background:#fff; border:1px solid var(--line2); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); }
.compare-table th, .compare-table td { padding:18px 22px; text-align:left; border-bottom:1px solid var(--line); font-size:15px; }
.compare-table thead th { background:var(--dark); color:#fff; font-family:var(--display); font-weight:700; font-size:16px; }
.compare-table thead th.col-aktavo { background:var(--blue); }
.compare-table tbody th { color:var(--ink); font-weight:500; }
.compare-table td { color:var(--mute); }
.compare-table .col-aktavo { background:var(--blue-l); color:var(--txt); }
.compare-table .yes { color:var(--ok); font-weight:600; }
.compare-table .no { color:var(--no); }
.compare-table td .ti { font-size:18px; vertical-align:-3px; margin-right:6px; }
.compare-table tr:last-child td, .compare-table tr:last-child th { border-bottom:0; }

/* Social Proof */
.proof { background:var(--bg); }
.proof-note { display:inline-flex; align-items:center; gap:8px; font-size:12.5px; color:var(--blue); background:var(--blue-l); border:1px dashed var(--line2); border-radius:30px; padding:7px 14px; margin-bottom:28px; }
.logo-strip { display:grid; grid-template-columns:repeat(auto-fit,minmax(130px,1fr)); gap:14px; margin-bottom:44px; }
.logo-cell { height:70px; border:1px dashed var(--line2); border-radius:var(--radius-sm); display:flex; align-items:center; justify-content:center; gap:8px; color:var(--mute2); font-size:13px; background:var(--surf); }
.logo-cell .ti { font-size:19px; }
.quote-card { background:var(--surf); border:1px solid var(--line); border-radius:var(--radius); padding:48px; }
.quote-card .stars { color:var(--blue); font-size:17px; letter-spacing:3px; margin-bottom:16px; }
.quote-card blockquote { margin:0; font-family:var(--display); font-weight:700; font-size:clamp(24px,3.4vw,38px); line-height:1.25; color:var(--ink); letter-spacing:-0.02em; }
.quote-card .by { margin-top:24px; font-size:15px; color:var(--mute); }
.quote-card .by b { color:var(--ink); }

/* FAQ */
.faq { background:var(--surf); border-block:1px solid var(--line); }
.faq-list { max-width:880px; }
.faq-item { border-bottom:1px solid var(--line2); }
.faq-q { width:100%; text-align:left; background:transparent; border:0; cursor:pointer; padding:26px 0; display:flex; align-items:center; justify-content:space-between; gap:20px; font-family:var(--display); font-size:clamp(19px,2.2vw,24px); font-weight:700; color:var(--ink); letter-spacing:-0.02em; }
.faq-q .ti { font-size:24px; color:var(--blue); transition:transform .2s; flex-shrink:0; }
.faq-item.is-open .faq-q .ti { transform:rotate(45deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .3s ease; }
.faq-item.is-open .faq-a { max-height:320px; }
.faq-a p { padding:0 0 26px; color:var(--mute); font-size:16.5px; max-width:680px; }

/* Persönlich */
.personal { background:var(--bg); }
.personal-card { display:grid; grid-template-columns:auto 1fr; gap:28px; align-items:center; max-width:940px; background:var(--surf); border:1px solid var(--line); border-radius:var(--radius); padding:38px; }
.personal-card .por { width:88px; height:88px; border-radius:50%; background:var(--blue-l); border:1px solid var(--line2); display:inline-flex; align-items:center; justify-content:center; }
.personal-card .por .ti { font-size:42px; color:var(--blue); }
.personal-card h3 { font-size:clamp(26px,3.2vw,38px); }
.personal-card p { color:var(--mute); font-size:17px; margin-top:12px; }

/* CTA (dunkles Kontrast-Band) */
.cta { background:radial-gradient(700px 380px at 50% 130%, rgba(22,87,200,.4), transparent 60%), var(--dark); color:#fff; text-align:center; }
.cta h2 { color:#fff; font-size:clamp(40px,7vw,86px); letter-spacing:-0.045em; }
.cta p { color:#C3D2E4; font-size:20px; margin:22px auto 36px; max-width:540px; }

/* Demo-Formular (weiße Karte auf dem dunklen CTA-Band) */
.demo-form { max-width:620px; margin:0 auto; background:#fff; border:1px solid var(--line2); border-radius:var(--radius); padding:32px; text-align:left; box-shadow:0 30px 60px -28px rgba(0,0,0,.5); }
.df-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.df-field { display:flex; flex-direction:column; gap:7px; }
.df-field.df-full { grid-column:1 / -1; }
.df-field > span { font-size:13.5px; font-weight:600; color:var(--ink); }
.df-field > span em { color:var(--blue); font-style:normal; }
.df-field > span small { color:var(--mute); font-weight:500; }
.df-field input, .df-field select, .df-field textarea {
  font-family:var(--sans); font-size:15px; color:var(--ink);
  background:var(--surf); border:1px solid var(--line2); border-radius:var(--radius-sm);
  padding:11px 13px; width:100%; transition:border-color .15s, box-shadow .15s;
}
.df-field textarea { resize:vertical; min-height:84px; }
.df-field input:focus, .df-field select:focus, .df-field textarea:focus {
  outline:none; border-color:var(--blue); box-shadow:0 0 0 3px var(--blue-soft); background:#fff;
}
.df-hp { position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }
.df-consent { display:flex; gap:10px; align-items:flex-start; margin:18px 0 0; font-size:13.5px; color:var(--mute); line-height:1.5; }
.df-consent input { margin-top:3px; flex-shrink:0; width:17px; height:17px; accent-color:var(--blue); }
.df-consent a { color:var(--blue); }
.df-consent em { color:var(--blue); font-style:normal; }
.df-submit { margin-top:20px; width:100%; justify-content:center; }
.df-submit[disabled] { opacity:.7; cursor:default; }
.df-status { margin:16px 0 0; font-size:14.5px; border-radius:var(--radius-sm); padding:12px 14px; }
.df-status.ok { background:#E3F4EB; color:#176B45; border:1px solid #B6E0C8; }
.df-status.err { background:#FBEAE3; color:#9A4423; border:1px solid #F0CBBA; }
.df-status a { color:inherit; font-weight:600; text-decoration:underline; }
@media (max-width:560px) { .df-grid { grid-template-columns:1fr; } .demo-form { padding:22px; } }

/* Footer */
.site-footer { background:var(--dark); border-top:1px solid rgba(255,255,255,.08); color:#9FB0C4; }
.site-footer .container { padding-block:46px; }
.footer-top { display:flex; justify-content:space-between; flex-wrap:wrap; gap:24px; padding-bottom:30px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer-brand .brand { color:#fff; }
.footer-brand .brand span { color:#8FB3F2; }
.footer-brand p { font-size:14px; margin-top:12px; max-width:300px; }
.footer-links { display:flex; gap:48px; flex-wrap:wrap; }
.footer-col h4 { font-size:12px; letter-spacing:1.5px; text-transform:uppercase; color:#778AA0; margin:0 0 14px; font-family:var(--sans); }
.footer-col a { display:block; font-size:14.5px; color:#B5C4D6; padding:5px 0; }
.footer-col a:hover { color:#fff; }
.footer-bottom { padding-top:24px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; font-size:13px; }

/* Responsive */
@media (max-width:900px) {
  .statement, .statement.flip { grid-template-columns:1fr; gap:32px; }
  .statement.flip .vis { order:0; }
  .statband .container { grid-template-columns:repeat(2,1fr); }
  .statband .s:nth-child(2) { border-right:0; }
  .statband .s:nth-child(1), .statband .s:nth-child(2) { border-bottom:1px solid rgba(255,255,255,.1); }
}
@media (max-width:880px) {
  .nav-links, .nav-actions .btn { display:none; }
  .nav-toggle { display:inline-flex; }
  .mobile-menu.is-open { display:block; }
  .mobile-menu { background:var(--surf); border-top:1px solid var(--line); padding:14px 28px 24px; }
  .mobile-menu ul { list-style:none; margin:0; padding:0; }
  .mobile-menu a { display:block; font-size:16px; padding:13px 0; border-bottom:1px solid var(--line); color:var(--txt); }
  .mobile-menu .btn { margin-top:18px; width:100%; justify-content:center; }
  .section { padding-block:84px; }
  .personal-card { grid-template-columns:1fr; }
}
@media (max-width:560px) {
  .container { padding-inline:20px; }
  .statband .container { grid-template-columns:1fr; }
  .statband .s { border-right:0; border-bottom:1px solid rgba(255,255,255,.1); }
  .statband .s:last-child { border-bottom:0; }
  .window-tree { display:none; }
  .compare-table { font-size:13px; }
  .compare-table th, .compare-table td { padding:12px 13px; }
  .hero-actions .btn { width:100%; justify-content:center; }
}
/* Hinweis: Reduced-Motion-Reset bewusst entfernt — Effekte werden auf
   Kundenwunsch immer gezeigt (unabhängig von der OS-Einstellung). */

/* ==========================================================================
   Effekte (dezent, premium) — Bewegung via prefers-reduced-motion gekapselt
   ========================================================================== */

/* Scroll-Fortschrittsleiste (oben) */
.scroll-progress {
  position: fixed; top: 0; left: 0; right: 0; height: 3px;
  transform: scaleX(0); transform-origin: 0 50%;
  background: linear-gradient(90deg, var(--blue), #6f8cff);
  z-index: 200; pointer-events: none;
}

/* Header: feiner Schatten beim Scrollen */
.site-header { transition: box-shadow .25s ease, background .25s ease; }
.site-header.is-scrolled { box-shadow: 0 6px 24px -12px rgba(18,32,54,.28); }

/* Nav-Links: animierter Unterstrich */
.nav-links a { position: relative; }
.nav-links a::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -6px; height: 2px;
  background: var(--blue); border-radius: 2px;
  transform: scaleX(0); transform-origin: 0 50%; transition: transform .22s ease;
}
.nav-links a:hover::after { transform: scaleX(1); }

/* Buttons: Pfeil-Icon nudge auf Hover */
.btn .ti { transition: transform .18s ease; }
.btn:hover .ti { transform: translateX(3px); }

/* Branchen-Karten: Icon zoomt minimal */
.branch .ti { transition: transform .2s ease, color .2s ease; }
.branch:hover .ti { transform: scale(1.08); }

/* Sicherheits-Karten: sanftes Anheben */
.sec-item { transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease; }
.sec-item:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--line2); }

/* Gestaffeltes Einblenden von Grid-Kindern (Branchen, Sicherheit, Kennzahlen) */
[data-reveal-children] > * {
  opacity: 0; transform: translateY(16px);
  transition: opacity .55s ease, transform .55s ease;
}
[data-reveal-children].is-visible > * { opacity: 1; transform: none; }
[data-reveal-children].is-visible > *:nth-child(1) { transition-delay: .04s; }
[data-reveal-children].is-visible > *:nth-child(2) { transition-delay: .10s; }
[data-reveal-children].is-visible > *:nth-child(3) { transition-delay: .16s; }
[data-reveal-children].is-visible > *:nth-child(4) { transition-delay: .22s; }
[data-reveal-children].is-visible > *:nth-child(5) { transition-delay: .28s; }
[data-reveal-children].is-visible > *:nth-child(6) { transition-delay: .34s; }
[data-reveal-children].is-visible > *:nth-child(7) { transition-delay: .40s; }
[data-reveal-children].is-visible > *:nth-child(8) { transition-delay: .46s; }

/* Hero-Inhalt blendet beim Laden gestaffelt ein */
.hero-inner > * { opacity: 0; animation: aktavoHeroIn .7s ease forwards; }
.hero-inner > *:nth-child(1) { animation-delay: .05s; }
.hero-inner > *:nth-child(2) { animation-delay: .15s; }
.hero-inner > *:nth-child(3) { animation-delay: .25s; }
.hero-inner > *:nth-child(4) { animation-delay: .35s; }
.hero-inner > *:nth-child(5) { animation-delay: .45s; }

@keyframes aktavoHeroIn {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: none; }
}

/* Anker-Sprungziele nicht unter dem Sticky-Header verstecken */
main section[id], #top { scroll-margin-top: 90px; }

/* Scroll-Spy: aktiver Navigationspunkt */
.nav-links a.is-active { color: var(--blue); }
.nav-links a.is-active::after { transform: scaleX(1); }

/* Produkt-Fenster: weiche Tilt-Rückstellung */
[data-tilt] { transition: transform .25s ease; transform-style: preserve-3d; will-change: transform; }
