/* ===================================================================
   VESPRO — Marketing Site
   Brand: Burgund #6E2032 · Porzellan #FCFAF7 · Anthrazit #26161C
   Type: Playfair Display (headlines) · Space Grotesk (labels) · Inter (body)
   =================================================================== */

:root{
  --ground:#FCFAF7;      /* porcelain bg */
  --canvas:#F6F0EB;      /* warm panel */
  --accent:#6E2032;      /* burgundy */
  --accent-dk:#561826;   /* burgundy hover */
  --anchor:#26161C;      /* anthracite text */
  --muted:#846C6E;       /* muted text */
  --line:rgba(38,22,28,.10);
  --line-2:rgba(110,32,50,.14);
  --dark:#1C1216;        /* dark sections */
  --dark-2:#241319;
  --shadow:0 18px 60px -24px rgba(38,22,28,.30);
  --shadow-sm:0 8px 30px -16px rgba(38,22,28,.28);
  --r:16px;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--ground);
  color:var(--anchor);
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  font-weight:400;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:'Playfair Display',serif;font-weight:500;line-height:1.08;letter-spacing:-.01em;color:var(--anchor)}
h1 em,h2 em,h3 em,h4 em{font-style:italic;color:var(--accent)}
h2{font-size:clamp(2rem,4vw,3.1rem)}
h3{font-size:clamp(1.5rem,3vw,2.1rem)}
.eyebrow{
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.72rem;
  text-transform:uppercase;letter-spacing:2px;color:var(--accent);
  display:inline-block;margin-bottom:18px;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:.95rem;
  padding:13px 26px;border-radius:999px;border:1px solid transparent;
  cursor:pointer;transition:all .35s var(--ease);white-space:nowrap;
}
.btn-lg{padding:16px 34px;font-size:1rem}
.btn-block{width:100%}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-dk);transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(110,32,50,.6)}
.btn-outline{background:transparent;border-color:var(--line-2);color:var(--anchor)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--anchor)}
.btn-ghost:hover{color:var(--accent)}
.btn-light{background:var(--ground);color:var(--anchor)}
.btn-light:hover{transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(0,0,0,.5)}
.btn-outline-light{background:transparent;border-color:rgba(252,250,247,.3);color:var(--ground)}
.btn-outline-light:hover{border-color:var(--ground);transform:translateY(-2px)}

/* ---------- Announcement ---------- */
.announce{
  background:var(--dark);color:var(--ground);
  font-size:.86rem;text-align:center;position:relative;
  display:flex;align-items:center;justify-content:center;
  padding:11px 44px;z-index:120;
}
.announce p{font-family:'Inter',sans-serif;font-weight:300}
.announce strong{font-weight:600}
.announce a{color:#fff;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:1px;margin-left:4px;transition:.3s}
.announce a:hover{border-color:#fff}
.announce-close{position:absolute;right:18px;background:none;border:none;color:rgba(252,250,247,.6);cursor:pointer;font-size:.85rem;transition:.3s}
.announce-close:hover{color:#fff}
.announce.hidden{display:none}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:100;transition:all .4s var(--ease)}
.header-inner{
  max-width:var(--maxw);margin:14px auto 0;padding:0 22px;
  height:66px;display:flex;align-items:center;justify-content:space-between;
  background:rgba(252,250,247,.0);border:1px solid transparent;border-radius:999px;
  transition:all .4s var(--ease);
}
.header.scrolled .header-inner{
  background:rgba(252,250,247,.82);backdrop-filter:blur(16px);
  border-color:var(--line);box-shadow:var(--shadow-sm);
}
.logo{display:flex;align-items:center;gap:10px;font-family:'Space Grotesk',sans-serif}
.logo-mark{
  width:34px;height:34px;border-radius:9px;background:var(--accent);color:#fff;
  display:grid;place-items:center;font-weight:700;font-size:1.15rem;
  font-family:'Playfair Display',serif;font-style:italic;
}
.logo-word{font-weight:700;font-size:1.15rem;letter-spacing:3px;color:var(--anchor)}
.logo-light .logo-word{color:var(--ground)}

.nav{display:flex;gap:34px}
.nav a{
  font-family:'Space Grotesk',sans-serif;font-size:.92rem;font-weight:500;color:var(--anchor);
  opacity:0;transform:translateY(-6px);transition:opacity .4s,transform .4s,color .25s;position:relative;
}
.header.scrolled .nav a{opacity:1;transform:none}
.nav a::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--accent);transition:width .3s}
.nav a:hover{color:var(--accent)}
.nav a:hover::after{width:100%}

.header-actions{display:flex;align-items:center;gap:12px}
.lang{display:flex;align-items:center;gap:5px;font-family:'Space Grotesk',sans-serif;font-size:.85rem;color:var(--muted);cursor:pointer;padding:6px 4px}
.lang:hover{color:var(--accent)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.burger span{width:22px;height:2px;background:var(--anchor);transition:.3s}

/* ---------- Mobile menu ---------- */
.mobile-menu{
  position:fixed;inset:0 0 0 auto;width:min(80vw,320px);background:var(--ground);
  z-index:99;transform:translateX(100%);transition:transform .4s var(--ease);
  display:flex;flex-direction:column;gap:8px;padding:120px 32px 32px;box-shadow:var(--shadow);
}
.mobile-menu.open{transform:none}
.mobile-menu a{font-family:'Space Grotesk',sans-serif;font-size:1.1rem;padding:12px 0;border-bottom:1px solid var(--line)}
.mobile-menu .btn{margin-top:16px}

/* ---------- Hero ---------- */
.hero{position:relative;padding:90px 0 0;text-align:center;overflow:hidden}
.hero-glow{
  position:absolute;top:-120px;left:50%;transform:translateX(-50%);
  width:900px;height:600px;border-radius:50%;
  background:radial-gradient(closest-side,rgba(110,32,50,.10),transparent 70%);
  filter:blur(20px);z-index:-1;
}
.hero-inner{display:flex;flex-direction:column;align-items:center}
.hero-title{font-size:clamp(2.6rem,6.2vw,5rem);max-width:14ch;margin-bottom:24px}
.hero-sub{font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--muted);max-width:46ch;font-weight:300;margin-bottom:36px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.hero-meta{margin-top:30px;font-family:'Space Grotesk',sans-serif;font-size:.8rem;letter-spacing:.5px;color:var(--muted)}

/* Interactive demo */
.demo{margin-top:64px;background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);overflow:hidden}
.demo-tabs{display:flex;border-bottom:1px solid var(--line);overflow-x:auto}
.demo-tab{
  flex:1;min-width:130px;display:flex;align-items:center;justify-content:center;gap:9px;
  font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:.92rem;color:var(--muted);
  background:transparent;border:none;padding:20px 14px;cursor:pointer;
  transition:.3s;border-bottom:2px solid transparent;white-space:nowrap;
}
.demo-tab-ico{color:var(--accent);font-size:.9rem}
.demo-tab:hover{color:var(--anchor)}
.demo-tab.active{color:var(--anchor);background:var(--anchor);color:#fff;border-radius:14px 14px 0 0;margin:0 4px}
.demo-tab.active .demo-tab-ico{color:#fff}
.demo-stage{display:grid;grid-template-columns:1fr 1fr;gap:28px;padding:38px;background:linear-gradient(180deg,#fbf6f2,#fff);align-items:center;min-height:330px}

.demo-scene{position:relative;height:260px;display:grid;place-items:center}
.scan-doc{position:relative;width:230px;height:230px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}
.scan-icon{font-size:3.4rem;color:var(--accent);opacity:.85}
.scan-title{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.5rem;color:var(--anchor)}
.scan-sub{color:var(--muted);font-size:.9rem}
.scan-line{
  position:absolute;left:0;right:0;height:2px;top:30%;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
  box-shadow:0 0 18px 2px rgba(110,32,50,.45);
  animation:scan 2.6s var(--ease) infinite;
}
@keyframes scan{0%,100%{top:18%;opacity:.2}50%{top:78%;opacity:1}}

.demo-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;box-shadow:var(--shadow-sm)}
.demo-card-head{display:flex;flex-direction:column;gap:4px;margin-bottom:18px}
.demo-card-status{font-family:'Space Grotesk',sans-serif;font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent)}
.demo-card-title{font-family:'Playfair Display',serif;font-size:1.3rem}
.demo-rows{list-style:none;display:flex;flex-direction:column;gap:14px}
.demo-rows li{display:flex;align-items:center;gap:12px;font-size:.96rem}
.demo-rows li em{margin-left:auto;font-style:normal}
.ico-file{width:30px;height:30px;border-radius:7px;background:#2b579a;color:#fff;display:grid;place-items:center;font-size:.8rem;font-weight:700;font-family:'Space Grotesk',sans-serif}
.ico-file.g{background:#1d6f42}.ico-file.r{background:#b7472a}
.gauge{position:relative;display:inline-flex;align-items:center;height:30px}
.gauge svg{flex-shrink:0}

/* ---------- Feature sections ---------- */
.feature{padding:clamp(70px,9vw,130px) 0}
.feature.alt{background:var(--canvas)}
.feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center}
.feature-grid.reverse .feature-visual{order:2}
.feature-text h2{margin:0 0 20px}
.feature-text p{color:var(--muted);font-weight:300;font-size:1.08rem;margin-bottom:28px;max-width:46ch}
.checklist{list-style:none;display:flex;flex-direction:column;gap:18px;margin-bottom:32px}
.checklist li{position:relative;padding-left:34px}
.checklist li::before{content:'✓';position:absolute;left:0;top:0;width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:.7rem}
.checklist strong{display:block;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.02rem}
.checklist span{color:var(--muted);font-size:.92rem;font-weight:300}

/* Visual mockups */
.feature-visual{position:relative}
.mock{position:relative;width:100%;aspect-ratio:1/.92;border-radius:22px;background:linear-gradient(150deg,#fff,var(--canvas));border:1px solid var(--line);box-shadow:var(--shadow);overflow:hidden}

/* mock-docs */
.mock-docs{display:grid;place-items:center}
.mock-core{font-size:3rem;color:var(--accent);position:absolute;top:42%;left:50%;transform:translate(-50%,-50%);opacity:.18}
.float-chip{position:absolute;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.72rem;padding:7px 12px;border-radius:8px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);color:var(--accent);animation:floaty 5s ease-in-out infinite}
.float-chip.c1{top:14%;left:12%}.float-chip.c2{top:24%;right:14%;animation-delay:.6s}
.float-chip.c3{top:50%;left:8%;animation-delay:1.2s}.float-chip.c4{top:62%;right:10%;animation-delay:1.8s}
.float-chip.c5{top:8%;left:46%;animation-delay:2.4s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.mock-table{position:absolute;bottom:18px;left:18px;right:18px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px;box-shadow:var(--shadow-sm)}
.mt-row{display:flex;justify-content:space-between;font-size:.82rem;padding:6px 0;border-bottom:1px solid var(--line)}
.mt-row:last-child{border:none}
.mt-row span{color:var(--muted)}.mt-row b{font-family:'Space Grotesk',sans-serif;font-weight:600}
.mt-row b.ok{color:#1d6f42}

/* mock-agents */
.mock-agents{padding:26px;display:flex;flex-direction:column;gap:12px;justify-content:center}
.agent-node{background:#fff;border:1px solid var(--line);border-radius:12px;padding:11px 16px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.9rem;box-shadow:var(--shadow-sm);position:relative;z-index:2;width:72%}
.agent-node:nth-child(2){align-self:flex-end}
.agent-node:nth-child(4){align-self:flex-end}
.agent-node small{display:block;font-weight:400;color:var(--muted);font-size:.72rem;margin-top:3px}
.agent-node.active{border-color:var(--accent);box-shadow:0 0 0 3px rgba(110,32,50,.12),var(--shadow-sm)}
.agent-lines{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.agent-lines path{stroke:var(--accent);stroke-width:1.4;fill:none;opacity:.3;stroke-dasharray:5 5}

/* mock-flow */
.mock-flow{display:flex;flex-direction:column;gap:18px;justify-content:center;align-items:center;padding:30px}
.wf{background:#fff;border:1px solid var(--line);border-radius:10px;padding:14px 22px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.92rem;box-shadow:var(--shadow-sm);position:relative}
.wf::after{content:'';position:absolute;bottom:-18px;left:50%;width:1px;height:18px;background:var(--line-2)}
.wf:last-child::after{display:none}
.wf.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 10px 24px -10px rgba(110,32,50,.6)}
.mock-flow .wf3,.mock-flow .wf4{display:inline-block}

/* mock-multi */
.mock-multi{display:grid;place-items:center}
.phone{width:120px;height:230px;border-radius:26px;background:linear-gradient(160deg,#fff,#f4ece7);border:1px solid var(--line);box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;position:relative;z-index:3}
.phone-core{font-size:2rem;color:var(--accent)}
.phone-label{font-family:'Space Grotesk',sans-serif;font-size:.74rem;color:var(--muted)}
.wave{display:flex;gap:3px;align-items:center;height:30px}
.wave i{width:3px;background:var(--accent);border-radius:2px;animation:wv 1s ease-in-out infinite}
.wave i:nth-child(1){animation-delay:0s}.wave i:nth-child(2){animation-delay:.1s}.wave i:nth-child(3){animation-delay:.2s}.wave i:nth-child(4){animation-delay:.3s}.wave i:nth-child(5){animation-delay:.4s}.wave i:nth-child(6){animation-delay:.5s}.wave i:nth-child(7){animation-delay:.6s}
@keyframes wv{0%,100%{height:6px}50%{height:26px}}
.orbit{position:absolute;width:46px;height:46px;border-radius:12px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;font-family:'Space Grotesk',sans-serif;font-weight:700;color:var(--accent);box-shadow:var(--shadow-sm);font-size:.85rem;z-index:2;animation:floaty 6s ease-in-out infinite}
.orbit.o1{top:10%;left:14%}.orbit.o2{top:8%;right:16%;animation-delay:.5s}
.orbit.o3{top:44%;left:6%;animation-delay:1s}.orbit.o4{top:46%;right:8%;animation-delay:1.5s}
.orbit.o5{bottom:12%;left:16%;animation-delay:2s}.orbit.o6{bottom:10%;right:18%;animation-delay:2.5s}

/* ---------- Center heads ---------- */
.center-head{text-align:center;max-width:760px;margin:0 auto 60px}
.center-head h2,.center-head h3{margin:0 auto 18px}
.center-head p{color:var(--muted);font-weight:300;font-size:1.1rem;max-width:54ch;margin:0 auto}
.center-head h2::after,.refs-title::after{content:'';display:block;width:120px;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);margin:22px auto 0}

/* ---------- VesproCORE cycle ---------- */
.core{padding:clamp(70px,9vw,130px) 0}
.cycle{position:relative;width:260px;height:260px;margin:0 auto 64px}
.cycle-ring{width:100%;height:100%;animation:spin 26s linear infinite}
.cycle-ring circle{fill:none;stroke:var(--accent);stroke-width:1.5;stroke-dasharray:6 10;opacity:.35}
@keyframes spin{to{transform:rotate(360deg)}}
.cycle-core{position:absolute;inset:0;margin:auto;width:120px;height:120px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;text-align:center;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.9rem;line-height:1.2;box-shadow:0 18px 40px -14px rgba(110,32,50,.55)}
.cycle-dot{position:absolute;width:38px;height:38px;border-radius:50%;background:#fff;border:1px solid var(--line-2);display:grid;place-items:center;font-family:'Space Grotesk',sans-serif;font-weight:700;color:var(--accent);box-shadow:var(--shadow-sm)}
.cycle-dot.d1{top:-8px;left:50%;transform:translateX(-50%)}
.cycle-dot.d2{right:-8px;top:50%;transform:translateY(-50%)}
.cycle-dot.d3{bottom:-8px;left:50%;transform:translateX(-50%)}
.cycle-dot.d4{left:-8px;top:50%;transform:translateY(-50%)}
.steps{display:grid;grid-template-columns:1fr 1fr;gap:30px 60px;max-width:840px;margin:0 auto}
.step{display:flex;gap:18px;align-items:flex-start}
.step-no{flex-shrink:0;width:40px;height:40px;border-radius:11px;background:var(--canvas);border:1px solid var(--line-2);display:grid;place-items:center;font-family:'Space Grotesk',sans-serif;font-weight:700;color:var(--accent)}
.step h4{font-size:1.18rem;margin-bottom:4px}
.step p{color:var(--muted);font-size:.95rem;font-weight:300}

/* ---------- Central layer ---------- */
.layer{padding:clamp(70px,9vw,130px) 0;background:var(--canvas)}
.layer-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.layer-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:38px;text-align:center;box-shadow:var(--shadow-sm);transition:transform .4s var(--ease),box-shadow .4s}
.layer-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.layer-card h4{font-size:1.35rem;margin:24px 0 10px}
.layer-card p{color:var(--muted);font-weight:300}
.layer-ill{height:120px;display:grid;place-items:center;position:relative}
.layer-ill.hub::before{content:'◉';font-size:3.4rem;color:var(--accent)}
.layer-ill.bricks::before{content:'◰◱◲';font-size:2.2rem;color:var(--accent);letter-spacing:4px}
.layer-ill.shield::before{content:'⛨';font-size:3.4rem;color:var(--accent)}
.layer-ill.models{gap:10px;display:flex;flex-wrap:wrap;justify-content:center;align-content:center}
.layer-ill.models span{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.8rem;padding:7px 14px;border-radius:999px;background:var(--canvas);border:1px solid var(--line-2);color:var(--accent)}

/* ---------- Integrations ---------- */
.integ{padding:clamp(70px,9vw,130px) 0}
.integ-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:44px;margin-bottom:64px}
.integ-ico{width:48px;height:48px;border-radius:13px;background:var(--canvas);border:1px solid var(--line-2);display:grid;place-items:center;font-size:1.3rem;color:var(--accent);margin-bottom:18px}
.integ-col h4{font-size:1.2rem;margin-bottom:10px}
.integ-col p{color:var(--muted);font-weight:300;font-size:.96rem}
.marquee{display:flex;flex-direction:column;gap:18px;padding:14px 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent)}
.marquee-row{overflow:hidden}
.marquee-track{display:flex;gap:18px;width:max-content;animation:march 48s linear infinite}
.marquee-row.rev .marquee-track{animation-direction:reverse}
.marquee:hover .marquee-track{animation-play-state:paused}
.logo-tile{flex-shrink:0;display:grid;place-items:center;width:176px;height:90px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s}
.logo-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.logo-tile img{max-height:30px;max-width:118px;width:auto;object-fit:contain}
@keyframes march{to{transform:translateX(-50%)}}

/* ---------- Modules ---------- */
.modules{padding:clamp(70px,9vw,130px) 0;background:var(--canvas)}
.module-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.module-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:34px;position:relative;overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s}
.module-card::before{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--accent);transition:width .4s}
.module-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.module-card:hover::before{width:100%}
.module-no{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:.85rem;color:var(--accent);opacity:.5}
.module-card h4{font-size:1.45rem;margin:12px 0 10px}
.module-card p{color:var(--muted);font-weight:300;margin-bottom:18px}
.module-rep{display:inline-block;font-family:'Space Grotesk',sans-serif;font-size:.74rem;letter-spacing:.5px;color:var(--muted);padding:6px 12px;border-radius:999px;background:var(--canvas);border:1px solid var(--line)}
.module-grid .module-card:nth-child(4),.module-grid .module-card:nth-child(5){grid-column:span 1}

/* ---------- Impact ---------- */
.impact{padding:clamp(70px,9vw,130px) 0}
.impact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:center}
.impact-metric{display:flex;align-items:flex-start;line-height:.9;margin:14px 0 22px}
.impact-metric .count{font-family:'Playfair Display',serif;font-weight:600;font-size:clamp(5rem,13vw,10rem);color:var(--accent)}
.impact-metric .pct{font-family:'Playfair Display',serif;font-size:clamp(2.5rem,6vw,4.5rem);color:var(--accent);margin-top:.3em}
.impact-claim{font-size:1.2rem;color:var(--anchor);font-weight:300;max-width:34ch;margin-bottom:26px}
.impact-logo{height:34px;width:auto;opacity:.85}
.comp-grid{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm)}
.comp-head{display:grid;grid-template-columns:1fr 1fr;background:var(--canvas);font-family:'Space Grotesk',sans-serif;font-size:.72rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted)}
.comp-head span{padding:14px 22px}
.comp-head span:last-child{color:var(--accent)}
.comp-row{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--line);align-items:center}
.comp-row span{padding:18px 22px;color:var(--muted);font-size:.95rem;text-decoration:line-through;text-decoration-color:var(--line-2)}
.comp-row b{padding:18px 22px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.05rem;color:var(--accent);border-left:1px solid var(--line)}

/* ---------- References ---------- */
.refs{padding:clamp(50px,7vw,90px) 0}
.refs-title{font-size:clamp(1.3rem,2.4vw,1.8rem)}
.ref-bar{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:34px 60px}
.ref-bar img{height:46px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.5;transition:filter .4s,opacity .4s,transform .4s}
.ref-bar img:hover{filter:grayscale(0);opacity:1;transform:scale(1.06)}

/* ---------- Security (dark) ---------- */
.security{background:var(--dark);color:var(--ground);padding:clamp(80px,10vw,140px) 0;position:relative}
.security .eyebrow,.security h2,.security h3{color:var(--ground)}
.security h2.light em{color:#d99fae}
.security .center-head p{color:rgba(252,250,247,.6)}
.security .center-head h2::after{background:linear-gradient(90deg,transparent,#d99fae,transparent)}
.pill{display:inline-flex;align-items:center;gap:8px;font-family:'Space Grotesk',sans-serif;font-size:.78rem;text-transform:uppercase;letter-spacing:1.5px;padding:9px 18px;border-radius:999px;border:1px solid rgba(252,250,247,.2);color:var(--ground);margin-bottom:22px}
.sec-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:64px}
.sec-card{background:var(--dark-2);border:1px solid rgba(252,250,247,.08);border-radius:var(--r);padding:30px;transition:border-color .4s,transform .4s}
.sec-card:hover{border-color:rgba(217,159,174,.4);transform:translateY(-5px)}
.sec-card h4{color:var(--ground);font-size:1.25rem;margin-bottom:12px}
.sec-card p{color:rgba(252,250,247,.6);font-weight:300;font-size:.94rem}
.cert-row{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin-top:54px}
.cert-row span{font-family:'Space Grotesk',sans-serif;font-size:.85rem;padding:10px 22px;border-radius:999px;border:1px solid rgba(252,250,247,.15);color:rgba(252,250,247,.8)}

/* ---------- Testimonials ---------- */
.testi{padding:clamp(70px,9vw,130px) 0}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.testi-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:34px;box-shadow:var(--shadow-sm);position:relative}
.testi-card::before{content:'\201C';position:absolute;top:8px;left:22px;font-family:'Playfair Display',serif;font-size:4rem;color:var(--accent);opacity:.18}
.testi-card p{font-family:'Playfair Display',serif;font-size:1.18rem;line-height:1.45;margin:18px 0 22px;font-style:italic}
.testi-card footer{font-family:'Space Grotesk',sans-serif;font-size:.82rem;color:var(--muted);letter-spacing:.3px}

/* ---------- CTA / Contact ---------- */
.cta{padding:clamp(70px,9vw,130px) 0}
.cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;background:var(--canvas);border:1px solid var(--line);border-radius:28px;padding:clamp(36px,5vw,70px)}
.cta-text h2{margin-bottom:18px}
.cta-text p{color:var(--muted);font-weight:300;font-size:1.08rem;margin-bottom:26px}
.cta-list{list-style:none;display:flex;flex-direction:column;gap:12px}
.cta-list li{font-family:'Space Grotesk',sans-serif;font-weight:500}
.cta-form{background:#fff;border:1px solid var(--line);border-radius:20px;padding:32px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:16px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cta-form label{display:flex;flex-direction:column;gap:7px;font-family:'Space Grotesk',sans-serif;font-size:.82rem;font-weight:500;color:var(--anchor)}
.cta-form input[type=text],.cta-form input[type=email],.cta-form input[type=tel]{
  padding:13px 15px;border:1px solid var(--line);border-radius:10px;font-family:'Inter',sans-serif;font-size:.95rem;background:var(--ground);transition:border-color .3s,box-shadow .3s;
}
.cta-form input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(110,32,50,.1)}
.check{flex-direction:row!important;align-items:flex-start;gap:10px!important;font-weight:300!important;color:var(--muted)!important;font-size:.78rem!important;line-height:1.4}
.check input{margin-top:2px;accent-color:var(--accent)}
.form-note{font-size:.85rem;color:var(--accent);font-weight:500}
.form-note a{text-decoration:underline}

/* ---------- Footer ---------- */
.footer{background:var(--dark);color:rgba(252,250,247,.7);padding:70px 0 34px}
.footer-top{display:flex;justify-content:space-between;gap:50px;flex-wrap:wrap;padding-bottom:48px}
.footer-brand{display:flex;flex-direction:column;gap:18px;align-items:flex-start}
.footer-login{width:fit-content;padding:10px 22px;font-size:.9rem;margin-top:2px}
.status{display:inline-flex;align-items:center;gap:9px;font-family:'Space Grotesk',sans-serif;font-size:.82rem;padding:8px 16px;border-radius:999px;border:1px solid rgba(252,250,247,.14);width:fit-content}
.status i{width:8px;height:8px;border-radius:50%;background:#5fc26b;box-shadow:0 0 0 3px rgba(95,194,107,.25);animation:pulse 2s infinite}
@keyframes pulse{50%{opacity:.5}}
.footer-cols{display:grid;grid-template-columns:repeat(4,auto);gap:40px 60px}
.footer-cols h5{font-family:'Space Grotesk',sans-serif;font-size:.78rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--ground);margin-bottom:16px}
.footer-cols a{display:block;font-size:.92rem;color:rgba(252,250,247,.6);padding:5px 0;transition:color .25s}
.footer-cols a:hover{color:var(--ground)}
.footer-badges{display:flex;flex-wrap:wrap;gap:12px;padding:30px 0;border-top:1px solid rgba(252,250,247,.1);border-bottom:1px solid rgba(252,250,247,.1)}
.footer-badges span{font-family:'Space Grotesk',sans-serif;font-size:.8rem;padding:8px 16px;border-radius:999px;border:1px solid rgba(252,250,247,.12)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;padding-top:28px;font-size:.85rem}
.footer-legal{display:flex;gap:22px}
.footer-legal a{color:rgba(252,250,247,.6);transition:color .25s}
.footer-legal a:hover{color:var(--ground)}

/* ---------- Reveal animations (base state) ---------- */
.reveal,.reveal-scale{opacity:0}
.reveal{transform:translateY(34px);filter:blur(6px)}
.reveal-scale{transform:scale(.96) translateY(20px)}

/* ===================================================================
   Sticky stacking feature cards
   =================================================================== */
.stack{padding:50px 0 90px;position:relative}
.stack-card{position:sticky;top:calc(94px + var(--i) * 14px);margin-bottom:30px}
.stack-card:last-child{margin-bottom:0}
.stack-inner{
  align-items:center;overflow:hidden;position:relative;
  padding:clamp(28px,4vw,60px);border:1px solid var(--line);border-radius:28px;
  background:linear-gradient(160deg,#ffffff,#fbf6f2);
  box-shadow:0 -6px 30px -22px rgba(38,22,28,.16), 0 40px 80px -42px rgba(38,22,28,.5);
  transform-origin:center top;min-height:min(70vh,600px);
}
.stack-card:nth-child(even) .stack-inner{background:linear-gradient(160deg,#ffffff,var(--canvas))}
.stack-card .feature-text h2{margin:0 0 18px}

/* shared scene panel */
.scene{position:relative;width:100%;aspect-ratio:1/.84;border-radius:20px;
  background:radial-gradient(120% 100% at 25% 15%,#ffffff,var(--canvas));
  border:1px solid var(--line);overflow:hidden;box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}

/* --- docs --- */
.scene-docs .paper{position:absolute;left:7%;top:13%;width:43%;background:#fff;border:1px solid var(--line);border-radius:12px;padding:15px;box-shadow:var(--shadow)}
.paper-head{display:flex;gap:5px;margin-bottom:12px}
.paper-head .dot{width:7px;height:7px;border-radius:50%;background:var(--line-2)}
.prow{height:8px;border-radius:4px;background:#ece3df;margin:9px 0}
.prow.hl{background:rgba(110,32,50,.24)}
.prow.w95{width:95%}.prow.w90{width:90%}.prow.w85{width:85%}.prow.w70{width:70%}.prow.w60{width:60%}.prow.w50{width:50%}
.beam{position:absolute;left:0;right:0;height:34px;top:6%;background:linear-gradient(180deg,rgba(110,32,50,.20),transparent);border-top:2px solid var(--accent);box-shadow:0 0 22px 3px rgba(110,32,50,.35)}
.scene-docs .out-card{position:absolute;right:6%;bottom:11%;width:52%;background:#fff;border:1px solid var(--line);border-radius:12px;padding:15px 17px;box-shadow:var(--shadow)}
.out-head{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.82rem;margin-bottom:10px;display:flex;justify-content:space-between}
.out-head .ok,.out-row b.ok{color:#1d6f42}
.out-row{display:flex;justify-content:space-between;font-size:.75rem;padding:6px 0;border-top:1px solid var(--line)}
.out-row span{color:var(--muted)}.out-row b{font-family:'Space Grotesk',sans-serif;font-weight:600}
.out-bar{height:6px;border-radius:3px;background:var(--canvas);margin-top:11px;overflow:hidden}
.out-bar i{display:block;height:100%;width:0;background:var(--accent);border-radius:3px;animation:fillbar 1.4s var(--ease) forwards}
@keyframes fillbar{to{width:var(--w)}}
.fchip{position:absolute;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.68rem;padding:6px 11px;border-radius:8px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);color:var(--accent);animation:floaty 5s ease-in-out infinite;z-index:3}
.fc1{top:7%;left:6%}.fc2{top:16%;right:9%;animation-delay:.6s}.fc3{top:66%;left:5%;animation-delay:1.2s}.fc4{top:5%;left:40%;animation-delay:1.8s}

/* --- agents pipeline --- */
.scene-agents{display:flex;flex-direction:column;justify-content:center;padding:7% 11%}
.pipe{display:flex;flex-direction:column;gap:16px;position:relative}
.pnode{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 15px;box-shadow:var(--shadow-sm);position:relative}
.pnode:not(:last-child)::after{content:'';position:absolute;left:28px;bottom:-16px;width:2px;height:16px;background:var(--line-2)}
.pnode i{width:27px;height:27px;border-radius:50%;display:grid;place-items:center;font-size:.72rem;flex-shrink:0;background:var(--canvas);color:var(--muted);border:1px solid var(--line);font-style:normal}
.pnode.done i{background:#1d6f42;color:#fff;border-color:#1d6f42}
.pnode.active{border-color:var(--accent);box-shadow:0 0 0 3px rgba(110,32,50,.12),var(--shadow-sm)}
.pnode.active i{background:var(--accent);color:#fff;border-color:var(--accent)}
.pn-t b{display:block;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.9rem}
.pn-t small{color:var(--muted);font-size:.74rem}
.spin{animation:spin 1.6s linear infinite}
.agent-reply{margin-top:18px;background:var(--accent);color:#fff;border-radius:14px 14px 14px 4px;padding:12px 16px;font-size:.85rem;line-height:1.45;box-shadow:var(--shadow-sm);align-self:flex-start;max-width:92%}

/* --- workflow svg --- */
.scene-flow{display:grid;place-items:center;padding:5%}
.flow-svg{width:100%;height:100%}
.flow-svg .wires path{fill:none;stroke:var(--accent);stroke-width:2;opacity:.45;stroke-linecap:round}
.flow-svg .wires path.alt{stroke:var(--muted);opacity:.32}
.flow-svg .fnode rect{fill:#fff;stroke:var(--line);stroke-width:1.2}
.flow-svg .fnode text{fill:var(--anchor);font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:600;text-anchor:middle}
.flow-svg .fhub rect{fill:var(--accent);filter:drop-shadow(0 10px 18px rgba(110,32,50,.4))}
.flow-svg .fhub text{fill:#fff;font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:700;text-anchor:middle}
.flow-svg .fhub text.sub{font-size:10px;font-weight:500;opacity:.85}

/* --- multimodal --- */
.scene-multi{display:grid;place-items:center}
.phone-img{width:84px;height:100px;border-radius:10px;background:linear-gradient(135deg,#ead, #f6f0eb);background:linear-gradient(135deg,#e8dcd7,#f6f0eb);border:1px solid var(--line);display:flex;align-items:flex-end;justify-content:center;padding-bottom:8px;position:relative;overflow:hidden}
.phone-img::before{content:'▦';position:absolute;top:16px;left:0;right:0;text-align:center;font-size:1.7rem;color:var(--accent);opacity:.55}
.phone-img span{font-family:'Space Grotesk',sans-serif;font-size:.58rem;background:#1d6f42;color:#fff;padding:3px 8px;border-radius:6px;position:relative;z-index:2}
.wave i:nth-child(8){animation-delay:.7s}.wave i:nth-child(9){animation-delay:.8s}

/* ===================================================================
   Central AI Layer — rich SVG illustrations
   =================================================================== */
.layer-ill{height:130px;display:grid;place-items:center}
.ill{width:100%;max-width:210px;height:130px;overflow:visible}
.ill-hub .spokes line{stroke:var(--line-2);stroke-width:1.5}
.ill-hub .sat{fill:#fff;stroke:var(--line-2);stroke-width:1.5;animation:floaty 5s ease-in-out infinite}
.ill-hub .sat:nth-child(3){animation-delay:.4s}.ill-hub .sat:nth-child(5){animation-delay:.8s}.ill-hub .sat:nth-child(7){animation-delay:1.2s}
.ill-hub .core{fill:rgba(110,32,50,.10);stroke:var(--accent);stroke-width:1.6}
.ill-hub .core-dot{fill:var(--accent)}
.ill-bricks .brick path{fill:#fff;stroke:var(--accent);stroke-width:1.4}
.ill-bricks .brick .side{fill:rgba(110,32,50,.09)}
.ill-bricks .brick .top{fill:rgba(110,32,50,.17)}
.ill-bricks .b2{opacity:.92}.ill-bricks .b3{opacity:.82}
.ill-models .mlink line{stroke:var(--line-2);stroke-width:1.5}
.ill-models .mcore{fill:var(--accent);filter:drop-shadow(0 6px 12px rgba(110,32,50,.4))}
.ill-models .mcore-t{fill:#fff;font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:700;text-anchor:middle}
.ill-models .mchip rect{fill:#fff;stroke:var(--line-2);stroke-width:1.2}
.ill-models .mchip text{fill:var(--accent);font-family:'Space Grotesk',sans-serif;font-size:12px;font-weight:600;text-anchor:middle}
.ill-shield .ring{fill:none;stroke:var(--line-2);stroke-width:1.5;stroke-dasharray:4 7;transform-origin:100px 70px;animation:spin 26s linear infinite}
.ill-shield .shield{fill:rgba(110,32,50,.08);stroke:var(--accent);stroke-width:1.6}
.ill-shield .check{fill:none;stroke:var(--accent);stroke-width:3.2;stroke-linecap:round;stroke-linejoin:round}
.ill-shield .rdot{fill:var(--accent)}

/* ===================================================================
   VesproCORE — animated process journey
   =================================================================== */
.journey{position:relative;margin-top:24px}
.journey-track{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.flowline{position:absolute;top:37px;left:12.5%;width:75%;height:3px;border-radius:3px;background:var(--line-2);opacity:.5;z-index:0}
.flowline::before{content:'';position:absolute;inset:-1px 0;border-radius:3px;background:linear-gradient(90deg,transparent,var(--accent),transparent);background-size:38% 100%;background-repeat:no-repeat;animation:flowmove 3.4s linear infinite}
@keyframes flowmove{0%{background-position:-38% 0}100%{background-position:138% 0}}
.packet{position:absolute;top:50%;left:0;width:12px;height:12px;border-radius:50%;background:var(--accent);transform:translate(-50%,-50%);box-shadow:0 0 0 5px rgba(110,32,50,.16),0 0 16px 2px rgba(110,32,50,.5);animation:packetmove 3.4s linear infinite}
@keyframes packetmove{0%{left:0;opacity:0}8%{opacity:1}92%{opacity:1}100%{left:100%;opacity:0}}
.jstep{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center}
.jnode{position:relative;width:76px;height:76px;border-radius:22px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;box-shadow:var(--shadow-sm);margin-bottom:22px;animation:nodepulse 4s ease-in-out infinite;animation-delay:calc(var(--d) * .85s)}
.jnode svg{width:32px;height:32px;fill:none;stroke:var(--accent);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.jnode svg rect{fill:rgba(110,32,50,.08)}
.jbadge{position:absolute;top:-9px;right:-9px;width:25px;height:25px;border-radius:50%;background:var(--accent);color:#fff;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:.78rem;display:grid;place-items:center;box-shadow:var(--shadow-sm)}
@keyframes nodepulse{0%,100%{box-shadow:var(--shadow-sm);transform:translateY(0)}50%{box-shadow:0 0 0 8px rgba(110,32,50,.10),var(--shadow-sm);transform:translateY(-6px)}}
.jstep h4{font-size:1.2rem;margin-bottom:8px}
.jstep p{color:var(--muted);font-size:.92rem;font-weight:300;max-width:24ch;margin:0 auto}
.journey-loop{position:relative;margin-top:20px;height:70px}
.journey-loop svg{width:100%;height:70px;overflow:visible}
.journey-loop path{fill:none;stroke:var(--accent);stroke-width:2;opacity:.55;stroke-dasharray:7 9;animation:dashflow 1.5s linear infinite}
@keyframes dashflow{to{stroke-dashoffset:-32}}
.journey-loop-label{position:absolute;bottom:2px;left:50%;transform:translateX(-50%);font-family:'Space Grotesk',sans-serif;font-size:.84rem;font-weight:500;color:var(--accent);background:var(--ground);padding:0 16px;white-space:nowrap}

/* ===================================================================
   Module — Bento grid
   =================================================================== */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:208px;gap:18px}
.bento-cell{position:relative;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:transform .4s var(--ease),box-shadow .4s,border-color .4s}
.bento-cell::before{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--accent);transition:width .45s var(--ease)}
.bento-cell:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line-2)}
.bento-cell:hover::before{width:100%}
.bento-cell.big{grid-column:span 2;grid-row:span 2}
.bento-cell.wide{grid-column:span 2}
.bento-top{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.bento-no{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:.76rem;color:var(--accent);opacity:.5}
.bento-tag{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.96rem}
.bento-cell.big .bento-tag{font-size:1.1rem}
.bento-cell.big h4{font-family:'Playfair Display',serif;font-weight:500;font-size:1.7rem;max-width:16ch;margin-bottom:18px}
.bento-cell.big .viz-chart{flex:1;margin:0 0 4px}
.bento-cell.big .viz-chart .bars{flex:1;height:auto;min-height:120px}
.bento-rep{font-family:'Space Grotesk',sans-serif;font-size:.7rem;letter-spacing:.4px;color:var(--muted);margin-top:14px}

/* CRM — bar chart */
.viz-chart{margin:16px 0;display:flex;flex-direction:column;gap:12px}
.viz-chart .bars{display:flex;align-items:flex-end;gap:11px;height:130px}
.viz-chart .bars i{flex:1;height:8px;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--accent),#a8506480);transition:height 1.1s var(--ease)}
.bento.in .viz-chart .bars i{height:var(--h)}
.chart-tag{font-family:'Space Grotesk',sans-serif;font-size:.82rem;font-weight:600;color:#1d6f42}

/* Recruiting — match bars */
.viz-match{margin:auto 0;display:flex;flex-direction:column;gap:11px}
.mrow{display:flex;align-items:center;gap:9px}
.mrow .av{width:22px;height:22px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--canvas),#e6d9d5);border:1px solid var(--line-2)}
.mrow .mbar{flex:1;height:7px;border-radius:4px;background:var(--canvas);overflow:hidden}
.mrow .mbar i{display:block;height:100%;width:0;border-radius:4px;background:var(--accent);transition:width 1.1s var(--ease)}
.bento.in .mrow .mbar i{width:var(--w)}
.mrow .pct{font-family:'Space Grotesk',sans-serif;font-size:.72rem;font-weight:600;color:var(--accent);width:32px;text-align:right}

/* Buchhaltung — invoice */
.viz-invoice{margin:auto 0;background:var(--canvas);border:1px solid var(--line);border-radius:11px;padding:10px 13px}
.viz-invoice .il{display:flex;justify-content:space-between;font-size:.73rem;color:var(--muted);padding:2.5px 0}
.viz-invoice .tot{display:flex;justify-content:space-between;border-top:1px solid var(--line);margin-top:4px;padding-top:6px;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:.8rem}
.viz-invoice .tot b{color:var(--accent)}

/* Operations — pins */
.viz-ops{position:relative;flex:1;margin:8px 0 0;border-radius:13px;border:1px solid var(--line);background:radial-gradient(120% 110% at 50% 0%,#fff,var(--canvas));overflow:hidden;min-height:0}
.viz-ops .pins{position:absolute;inset:0}
.viz-ops .pin{position:absolute;left:var(--x);top:var(--y);width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px rgba(110,32,50,.5)}
.viz-ops .pin::after{content:'';position:absolute;left:50%;top:50%;width:8px;height:8px;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 1px var(--accent);opacity:.6;animation:ping 2.6s ease-out infinite;animation-delay:var(--t)}
@keyframes ping{0%{transform:translate(-50%,-50%) scale(1);opacity:.6}100%{transform:translate(-50%,-50%) scale(4.5);opacity:0}}
.ops-meta{display:flex;align-items:baseline;gap:9px;margin-top:10px}
.ops-meta b{font-family:'Playfair Display',serif;font-weight:600;font-size:1.8rem;color:var(--accent);line-height:1}
.ops-meta span{font-size:.78rem;color:var(--muted)}

/* Wissen — search */
.viz-search{margin:auto 0;display:flex;flex-direction:column;gap:9px}
.viz-search .sbar{display:flex;align-items:center;gap:8px;background:var(--canvas);border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:.76rem;color:var(--muted)}
.viz-search .sbar svg{width:15px;height:15px;fill:none;stroke:var(--accent);stroke-width:2;flex-shrink:0}
.viz-search .cur{display:inline-block;width:1.5px;height:.95em;background:var(--accent);margin-left:1px;vertical-align:middle;animation:blink 1s step-end infinite}
@keyframes blink{50%{opacity:0}}
.viz-search .sres{height:7px;border-radius:4px;background:var(--canvas);opacity:0;width:60%}
.bento.in .viz-search .sres{animation:resin .55s var(--ease) forwards}
.bento.in .viz-search .sres.r1{width:92%;animation-delay:.3s}
.bento.in .viz-search .sres.r2{width:78%;animation-delay:.48s}
.bento.in .viz-search .sres.r3{width:64%;animation-delay:.66s}
@keyframes resin{from{opacity:0;transform:translateX(-6px)}to{opacity:1;transform:none}}

/* --- Tool-Stack ersetzt (scene-replace) --- */
.scene-replace{display:flex;align-items:center;justify-content:center;gap:0;padding:8% 7%}
.rep-tools{display:grid;grid-template-columns:1fr 1fr;gap:12px;flex:1;max-width:58%}
.rep-tool{position:relative;height:56px;background:#fff;border:1px solid var(--line);border-radius:11px;display:grid;place-items:center;box-shadow:var(--shadow-sm);filter:grayscale(1);opacity:.5;overflow:hidden;transition:opacity .4s}
.rep-tool img{max-height:20px;max-width:78%;width:auto}
.rep-tool::after{content:'';position:absolute;left:8%;right:8%;top:50%;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;opacity:.75}
.scene-replace.in .rep-tool::after{animation:strike .5s var(--ease) forwards}
.scene-replace.in .rep-tool:nth-child(1)::after{animation-delay:.15s}
.scene-replace.in .rep-tool:nth-child(2)::after{animation-delay:.28s}
.scene-replace.in .rep-tool:nth-child(3)::after{animation-delay:.41s}
.scene-replace.in .rep-tool:nth-child(4)::after{animation-delay:.54s}
.scene-replace.in .rep-tool:nth-child(5)::after{animation-delay:.67s}
.scene-replace.in .rep-tool:nth-child(6)::after{animation-delay:.8s}
@keyframes strike{to{transform:scaleX(1)}}
.rep-flow{display:flex;flex-direction:column;gap:7px;align-items:center;padding:0 16px}
.rep-flow .rep-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);opacity:.3;animation:repflow 1.5s ease-in-out infinite}
.rep-flow .rep-dot:nth-child(2){animation-delay:.22s}.rep-flow .rep-dot:nth-child(3){animation-delay:.44s}
@keyframes repflow{0%,100%{opacity:.25;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}
.rep-core{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:9px;background:#fff;border:1px solid var(--line-2);border-radius:18px;padding:24px 22px;box-shadow:0 22px 50px -22px rgba(110,32,50,.5)}
.rep-mark{width:56px;height:56px;border-radius:15px;background:var(--accent);color:#fff;display:grid;place-items:center;font-family:'Playfair Display',serif;font-style:italic;font-weight:600;font-size:1.9rem;animation:coreglow 2.6s ease-in-out infinite}
@keyframes coreglow{0%,100%{box-shadow:0 0 0 0 rgba(110,32,50,.4)}50%{box-shadow:0 0 0 12px rgba(110,32,50,0)}}
.rep-core b{font-family:'Space Grotesk',sans-serif;font-size:.92rem;color:var(--anchor)}
.rep-core small{font-family:'Space Grotesk',sans-serif;font-size:.72rem;color:var(--accent);font-weight:600}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .nav{display:none}
  .burger{display:flex}
  .hide-sm{display:none}
  .feature-grid,.feature-grid.reverse{grid-template-columns:1fr;gap:44px}
  .feature-grid.reverse .feature-visual{order:0}
  .layer-grid,.integ-cols,.module-grid,.sec-grid,.testi-grid,.impact-grid,.cta-grid,.steps{grid-template-columns:1fr!important}
  .demo-stage{grid-template-columns:1fr;gap:20px}
  .journey-track{grid-template-columns:1fr;gap:8px}
  .flowline,.packet,.journey-loop{display:none}
  .jstep{flex-direction:row;text-align:left;gap:16px;align-items:flex-start;padding:6px 0}
  .jnode{margin-bottom:0;flex-shrink:0;width:60px;height:60px}
  .jstep p{margin:0;max-width:none}
  .bento{grid-template-columns:1fr 1fr;grid-auto-rows:150px}
  .bento-cell.big{grid-column:span 2;grid-row:span 1}
  .bento-cell.big h4{font-size:1.35rem}
  .bento-cell.wide{grid-column:span 2}
  .scene-replace{flex-direction:column;gap:18px;padding:30px}
  .rep-tools{max-width:none;width:100%}
  .rep-flow{flex-direction:row;padding:0}
  .footer-cols{grid-template-columns:1fr 1fr}
  .footer-top{flex-direction:column}
}
@media(max-width:560px){
  .field-row{grid-template-columns:1fr}
  .comp-row span,.comp-row b{padding:14px}
  .module-grid{grid-template-columns:1fr}
  .header-inner{height:58px}
  .footer-cols{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal,.reveal-scale{opacity:1;transform:none;filter:none}
}
