:root {
  --paper: #f4efe7;
  --paper-soft: #fbf7ef;
  --paper-deep: #e7ded1;
  --ink: #171412;
  --muted: #6f675e;
  --quiet: #9a8f82;
  --line: rgba(23, 20, 18, 0.12);
  --line-strong: rgba(23, 20, 18, 0.2);
  --accent: #574bc8;
  --accent-dark: #2d2678;
  --violet-wash: rgba(87, 75, 200, 0.08);
  --green: #197557;
  --shadow-soft: 0 26px 88px rgba(43, 34, 24, 0.12);
  --shadow-strong: 0 44px 120px rgba(43, 34, 24, 0.18);
  --serif: "Instrument Serif", Georgia, serif;
  --sans: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono: "JetBrains Mono", "IBM Plex Mono", ui-monospace, monospace;
  --ease: cubic-bezier(0.2, 0.7, 0.2, 1);
  --ease-architecture: cubic-bezier(0.16, 1, 0.3, 1);
  --max: 1320px;
  --header-height: 52px;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--header-height) + 6px);
  overflow-x: clip;
}

html:focus-within {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  overflow-x: clip;
  color: var(--ink);
  background:
    linear-gradient(90deg, rgba(23, 20, 18, 0.032) 1px, transparent 1px),
    linear-gradient(180deg, rgba(23, 20, 18, 0.028) 1px, transparent 1px),
    var(--paper);
  background-size: 96px 96px;
  font-family: var(--sans);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    linear-gradient(115deg, rgba(255, 255, 255, 0.72), transparent 36%),
    linear-gradient(180deg, rgba(244, 239, 231, 0), rgba(232, 222, 210, 0.42));
}

::selection {
  color: #fff;
  background: var(--accent);
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  display: block;
  max-width: 100%;
}

button,
input,
select,
textarea {
  font: inherit;
}

.page-shell {
  width: min(calc(100% - 48px), var(--max));
  margin-inline: auto;
}

.skip-link {
  position: fixed;
  left: 16px;
  top: 14px;
  z-index: 100;
  padding: 10px 14px;
  color: #fff;
  background: var(--ink);
  transform: translateY(-140%);
  transition: transform 180ms var(--ease);
}

.skip-link:focus {
  transform: translateY(0);
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible {
  outline: 3px solid rgba(87, 75, 200, 0.5);
  outline-offset: 3px;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 30;
  border-bottom: 1px solid transparent;
  transition: background 220ms var(--ease), border-color 220ms var(--ease), box-shadow 220ms var(--ease);
}

.site-header.is-scrolled {
  border-color: rgba(23, 20, 18, 0.08);
  background: rgba(244, 239, 231, 0.84);
  box-shadow: 0 16px 50px rgba(23, 20, 18, 0.08);
  backdrop-filter: blur(18px);
}

.header-inner {
  min-height: var(--header-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.brand {
  width: 188px;
  height: 42px;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.brand img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 34px;
  color: #5c554e;
  font-size: 14px;
  font-weight: 500;
}

.nav-links a {
  position: relative;
  padding: 4px 0;
}

.nav-links a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 2px;
  height: 1px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 180ms var(--ease);
}

.nav-links a:hover::after {
  transform: scaleX(1);
}

.button,
.header-cta,
.mobile-sticky-cta {
  display: inline-flex;
  min-height: 48px;
  align-items: center;
  justify-content: center;
  border: 1px solid transparent;
  border-radius: 999px;
  padding: 0 22px;
  font-weight: 700;
  font-size: 14px;
  cursor: pointer;
  transition: transform 180ms var(--ease), box-shadow 180ms var(--ease), background 180ms var(--ease), color 180ms var(--ease);
}

.button:hover,
.header-cta:hover,
.mobile-sticky-cta:hover {
  transform: translateY(-1px);
}

.button-primary,
.header-cta,
.mobile-sticky-cta {
  color: #fff;
  background: var(--ink);
  box-shadow: 0 14px 34px rgba(23, 20, 18, 0.16);
}

.button-primary:hover,
.header-cta:hover,
.mobile-sticky-cta:hover {
  background: var(--accent-dark);
}

.button-secondary {
  color: var(--ink);
  background: rgba(255, 255, 255, 0.52);
  border-color: var(--line);
}

.header-cta {
  min-height: 42px;
  padding: 0 20px;
}

.mobile-sticky-cta {
  display: none;
}

#sistemas,
#proyectos,
#casos,
#proceso {
  scroll-margin-top: calc(var(--header-height) + 6px);
}

.to-top {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 38;
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(23, 20, 18, 0.12);
  border-radius: 50%;
  color: var(--ink);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 14px 34px rgba(23, 20, 18, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.86);
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transform: translateY(16px) scale(0.92);
  backdrop-filter: blur(12px);
  transition:
    opacity 220ms var(--ease),
    transform 220ms var(--ease),
    border-color 220ms var(--ease),
    box-shadow 220ms var(--ease),
    background-color 220ms var(--ease);
}

.to-top::before {
  content: "";
  position: absolute;
  inset: -1px;
  border: 1px solid rgba(23, 20, 18, 0.07);
  border-radius: 50%;
  transition: transform 260ms var(--ease-architecture), border-color 260ms var(--ease), opacity 260ms var(--ease);
}

.to-top::after {
  content: "";
  position: absolute;
  inset: -5px;
  border-radius: 50%;
  border: 1px solid rgba(87, 75, 200, 0.22);
  opacity: 0;
  transform: scale(0.74);
}

.to-top span {
  position: relative;
  z-index: 1;
  width: 15px;
  height: 18px;
  display: block;
}

.to-top span::before,
.to-top span::after {
  content: "";
  position: absolute;
  left: 50%;
  background: currentColor;
  transform: translateX(-50%);
}

.to-top span::before {
  bottom: 0;
  width: 2px;
  height: 17px;
  border-radius: 999px;
  transform-origin: bottom;
}

.to-top span::after {
  top: 0;
  width: 10px;
  height: 10px;
  border-top: 2px solid currentColor;
  border-left: 2px solid currentColor;
  background: transparent;
  transform: translateX(-50%) rotate(45deg);
}

body.show-to-top .to-top {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

.to-top:hover,
.to-top:focus-visible {
  transform: translateY(-3px) scale(1.03);
  border-color: rgba(23, 20, 18, 0.2);
  background-color: rgba(255, 255, 255, 0.98);
  box-shadow: 0 18px 40px rgba(23, 20, 18, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.to-top:hover::before,
.to-top:focus-visible::before {
  border-color: rgba(87, 75, 200, 0.32);
  transform: scale(1.08);
}

.to-top.is-launching {
  animation: topButtonLaunch 760ms var(--ease-architecture) both;
}

.to-top.is-launching::after {
  animation: returnPulse 760ms var(--ease-architecture) both;
}

.to-top.is-launching span::before {
  animation: arrowLift 760ms var(--ease-architecture) both;
}

.hero {
  min-height: calc(100vh - var(--header-height));
  display: grid;
  grid-template-columns: minmax(390px, 0.92fr) minmax(520px, 1fr);
  gap: 68px;
  align-items: center;
  padding: 24px 0 70px;
}

.hero h1,
.section-intro h2,
.cases-heading h2,
.case-narrative h3,
.build-copy h2 {
  margin: 0;
  font-family: var(--serif);
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 0.92;
  text-wrap: balance;
}

.hero h1 {
  max-width: 660px;
  font-size: clamp(4.3rem, 6.2vw, 6.85rem);
}

.hero h1 em {
  color: var(--accent);
  font-style: italic;
}

.hero-lede {
  max-width: 610px;
  margin: 28px 0 0;
  color: #4d453e;
  font-size: clamp(1.08rem, 1.55vw, 1.28rem);
  line-height: 1.5;
  text-wrap: pretty;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 32px;
}

.hero-actions .button-primary::after {
  content: "→";
  margin-left: 10px;
  font-weight: 800;
  transition: transform 180ms var(--ease);
}

.hero-actions .button-primary:hover::after {
  transform: translateX(3px);
}

.hero-proof {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin: 48px 0 0;
  padding: 24px 0 0;
  border-top: 1px solid var(--line-strong);
}

.hero-proof div {
  min-width: 0;
}

.hero-proof dt {
  color: var(--ink);
  font-family: var(--serif);
  font-size: clamp(2.1rem, 3.2vw, 3.25rem);
  font-weight: 400;
  line-height: 0.9;
}

.hero-proof dd {
  margin: 8px 0 0;
  color: var(--quiet);
  font-size: 14px;
  line-height: 1.3;
}

.product-system {
  position: relative;
  min-height: 468px;
}

.system-canvas {
  position: relative;
  min-height: 420px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 26px;
  background:
    linear-gradient(90deg, rgba(87, 75, 200, 0.075) 1px, transparent 1px),
    linear-gradient(180deg, rgba(23, 20, 18, 0.05) 1px, transparent 1px),
    linear-gradient(135deg, rgba(251, 247, 239, 0.98), rgba(231, 222, 209, 0.76));
  background-size: 34px 34px, 34px 34px, auto;
  box-shadow: var(--shadow-strong);
  isolation: isolate;
  animation: blueprintDrift 18s linear infinite;
}

.system-canvas::after {
  content: "";
  position: absolute;
  inset: 26px;
  z-index: 0;
  border: 1px solid rgba(87, 75, 200, 0.24);
  border-radius: 20px;
  pointer-events: none;
}

.app-window {
  position: absolute;
  z-index: 2;
  border: 1px solid rgba(23, 20, 18, 0.14);
  border-radius: 14px;
  background: rgba(251, 247, 239, 0.94);
  box-shadow: 0 24px 70px rgba(43, 34, 24, 0.12);
  opacity: 0;
  transform: translate(var(--x, 0), var(--y, 18px));
  animation: assemble 760ms var(--ease-architecture) forwards;
}

.main-app {
  left: 48px;
  top: 54px;
  width: min(76%, 530px);
  min-height: 286px;
  --x: -22px;
  animation-delay: 140ms;
}

.automation-app {
  right: 30px;
  top: 86px;
  width: 310px;
  min-height: 116px;
  --x: 24px;
  animation-delay: 460ms;
}

.insight-app {
  left: 18px;
  right: auto;
  top: 250px;
  width: 230px;
  min-height: 132px;
  --x: 18px;
  animation-delay: 620ms;
}

.window-bar,
.product-chrome {
  min-height: 42px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 14px;
  border-bottom: 1px solid var(--line);
  color: var(--muted);
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.03em;
}

.window-bar span,
.product-chrome span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--line-strong);
}

.window-bar strong,
.product-chrome strong {
  margin-left: auto;
  color: var(--ink);
  font-weight: 600;
}

.window-bar.compact strong {
  margin-left: 0;
}

.app-layout {
  display: grid;
  grid-template-columns: 78px 1fr;
  min-height: 244px;
}

.product-grid {
  display: grid;
  grid-template-columns: 96px 1fr;
  min-height: 338px;
}

.app-sidebar,
.side-nav {
  display: grid;
  align-content: start;
  gap: 14px;
  padding: 22px;
  border-right: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.34);
}

.app-sidebar {
  gap: 12px;
  padding: 18px;
}

.app-sidebar span,
.side-nav i {
  display: block;
  height: 11px;
  background: var(--line);
}

.app-sidebar .active,
.side-nav .on {
  background: var(--accent);
}

.app-content,
.workspace {
  padding: 24px;
}

.app-content {
  padding: 20px;
}

.app-title,
.workspace-head {
  width: 46%;
  height: 28px;
  margin-bottom: 28px;
  background: var(--ink);
}

.metric-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 24px;
}

.metric-row span {
  min-height: 58px;
  border: 1px solid var(--line);
  background: #fff;
}

.data-table {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 9px;
}

.data-table i {
  height: 32px;
  background: rgba(23, 20, 18, 0.1);
}

.automation-flow,
.automation-map {
  display: grid;
  grid-template-columns: 1fr 0.35fr 1fr 0.35fr 1fr;
  gap: 9px;
  align-items: center;
  padding: 26px;
}

.automation-flow {
  padding: 18px;
}

.automation-flow span,
.automation-map span {
  min-height: 48px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(87, 75, 200, 0.26);
  background: rgba(255, 255, 255, 0.62);
  color: var(--accent-dark);
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
}

.automation-flow span {
  min-height: 42px;
}

.automation-flow i,
.automation-map i,
.timeline i {
  height: 2px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left;
  animation: lineDraw 680ms var(--ease-architecture) forwards;
}

.automation-flow i:nth-of-type(1),
.automation-map i:nth-of-type(1) {
  animation-delay: 760ms;
}

.automation-flow i:nth-of-type(2),
.automation-map i:nth-of-type(2) {
  animation-delay: 900ms;
}

.result-graph {
  height: 92px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  align-items: end;
  padding: 18px;
}

.result-graph span {
  display: block;
  background: var(--accent);
  transform-origin: bottom;
  animation: barRise 680ms var(--ease-architecture) forwards;
  transform: scaleY(0);
}

.result-graph span:nth-child(1) { height: 34%; animation-delay: 760ms; }
.result-graph span:nth-child(2) { height: 58%; animation-delay: 840ms; }
.result-graph span:nth-child(3) { height: 78%; animation-delay: 920ms; }
.result-graph span:nth-child(4) { height: 100%; animation-delay: 1000ms; }

.system-lines {
  position: absolute;
  inset: 52px 36px 42px;
  z-index: 1;
  width: calc(100% - 72px);
  height: calc(100% - 94px);
  pointer-events: none;
}

.system-lines path,
.system-lines circle {
  fill: none;
  stroke: var(--accent);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.system-lines path {
  opacity: 0.52;
  stroke-dasharray: 1;
  stroke-dashoffset: 1;
  animation:
    pathDraw 1000ms var(--ease-architecture) forwards,
    circuitPulse 4200ms ease-in-out 1200ms infinite;
}

.line-main { animation-delay: 360ms; }
.line-secondary { animation-delay: 680ms; }
.line-branch { animation-delay: 840ms; }

.system-lines circle {
  fill: var(--paper-soft);
  opacity: 0;
  transform: scale(0.6);
  transform-box: fill-box;
  transform-origin: center;
  animation: nodePlot 420ms var(--ease-architecture) forwards;
}

.system-lines circle:nth-of-type(1) { animation-delay: 520ms; }
.system-lines circle:nth-of-type(2) { animation-delay: 820ms; }
.system-lines circle:nth-of-type(3) { animation-delay: 1040ms; }

.hero-copy h1,
.hero-lede,
.hero-actions,
.hero-proof,
.product-system {
  opacity: 0;
  transform: translateY(22px);
  animation: reveal-up 760ms var(--ease-architecture) forwards;
}

.hero-copy h1 { animation-delay: 80ms; }
.hero-lede { animation-delay: 220ms; }
.hero-actions { animation-delay: 360ms; }
.hero-proof { animation-delay: 500ms; }

.product-system {
  min-height: 500px;
  display: grid;
  align-items: center;
  animation-delay: 620ms;
}

.ops-ecosystem {
  --system-scale: 1;
  --parallax-soft-x: 0px;
  --parallax-soft-y: 0px;
  --parallax-mid-x: 0px;
  --parallax-mid-y: 0px;
  --parallax-deep-x: 0px;
  --parallax-deep-y: 0px;
  position: relative;
  min-height: 500px;
  overflow: visible;
  isolation: isolate;
}

.ops-ecosystem::before,
.ops-ecosystem::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.ops-ecosystem::before {
  inset: 6% 3% 4%;
  z-index: -1;
  opacity: 0.22;
  background:
    radial-gradient(circle at 68% 34%, rgba(87, 75, 200, 0.12), transparent 26%),
    radial-gradient(circle at 42% 68%, rgba(255, 255, 255, 0.7), transparent 28%);
  filter: blur(10px);
}

.ops-ecosystem::after {
  inset: 0;
  z-index: 6;
  opacity: 0.06;
  background-image: radial-gradient(rgba(23, 20, 18, 0.34) 0.45px, transparent 0.6px);
  background-size: 5px 5px;
  mix-blend-mode: multiply;
}

.ops-field {
  position: absolute;
  left: 50%;
  top: 0;
  width: 640px;
  height: 500px;
  transform: translateX(-50%) scale(var(--system-scale));
  transform-origin: top center;
}

.ops-plane {
  position: absolute;
  inset: 48px 24px 34px;
  border: 1px solid rgba(87, 75, 200, 0.18);
  border-radius: 34px;
  background:
    radial-gradient(circle at 32% 28%, rgba(255, 255, 255, 0.72), transparent 28%),
    linear-gradient(90deg, rgba(87, 75, 200, 0.065) 1px, transparent 1px),
    linear-gradient(180deg, rgba(23, 20, 18, 0.048) 1px, transparent 1px),
    rgba(251, 247, 239, 0.72);
  background-size: auto, 28px 28px, 28px 28px, auto;
  box-shadow: 0 38px 120px rgba(43, 34, 24, 0.14);
  transform: translate3d(var(--parallax-soft-x), var(--parallax-soft-y), 0) skewY(-2deg);
}

.ops-plane::before,
.ops-plane::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.ops-plane::before {
  inset: 20px;
  border: 1px solid rgba(87, 75, 200, 0.16);
  border-radius: 24px;
}

.ops-plane::after {
  inset: 0;
  opacity: 0.16;
  background-image: radial-gradient(rgba(23, 20, 18, 0.22) 0.55px, transparent 0.65px);
  background-size: 6px 6px;
  mix-blend-mode: multiply;
}

.ops-links {
  position: absolute;
  inset: 0;
  z-index: 2;
  color: var(--accent);
  opacity: 0;
  transform: translateY(10px);
  animation: reveal-up 700ms var(--ease-architecture) 980ms forwards;
  pointer-events: none;
}

.route,
.route-pulse {
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.route {
  stroke: rgba(87, 75, 200, 0.38);
  stroke-width: 1.7;
  stroke-dasharray: 1;
  stroke-dashoffset: 1;
  animation: connection-draw 760ms var(--ease-architecture) forwards;
  animation-delay: var(--route-delay, 1240ms);
  transition: stroke 240ms var(--ease), stroke-width 240ms var(--ease), opacity 240ms var(--ease);
}

.route-pulse {
  stroke: rgba(87, 75, 200, 0.9);
  stroke-width: 2.65;
  stroke-dasharray: 0.052 0.948;
  stroke-dashoffset: 1;
  opacity: 0.72;
  filter: drop-shadow(0 0 9px rgba(87, 75, 200, 0.42));
  animation: pulse-line var(--pulse-speed, 4.4s) linear infinite;
  animation-delay: calc(1850ms + var(--pulse-delay, 0ms));
}

.route-crm { --route-delay: 1160ms; }
.route-automation { --route-delay: 1260ms; }
.route-erp { --route-delay: 1360ms; }
.route-db { --route-delay: 1460ms; }
.route-mobile { --route-delay: 1560ms; }
.route-analytics { --route-delay: 1660ms; }
.route-api { --route-delay: 1760ms; }

.pulse-automation { --pulse-delay: 420ms; --pulse-speed: 4.8s; }
.pulse-erp { --pulse-delay: 860ms; --pulse-speed: 4.1s; }
.pulse-db { --pulse-delay: 1220ms; --pulse-speed: 3.8s; }
.pulse-mobile { --pulse-delay: 1500ms; --pulse-speed: 4.7s; }
.pulse-analytics { --pulse-delay: 1900ms; --pulse-speed: 4.3s; }
.pulse-api { --pulse-delay: 2300ms; --pulse-speed: 3.9s; }

.ops-node {
  position: absolute;
  z-index: 3;
  opacity: 0;
  animation: nodeReveal 680ms var(--ease-architecture) var(--node-delay, 900ms) forwards;
}

.depth-soft { transform: translate3d(var(--parallax-soft-x), var(--parallax-soft-y), 0); }
.depth-mid { transform: translate3d(var(--parallax-mid-x), var(--parallax-mid-y), 0); }
.depth-deep { transform: translate3d(var(--parallax-deep-x), var(--parallax-deep-y), 0); }

.node-float {
  position: relative;
  animation: float-slow var(--float-speed, 6.6s) ease-in-out infinite;
  animation-delay: var(--float-delay, 0ms);
}

.node-panel,
.phone-panel {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(23, 20, 18, 0.12);
  border-radius: 18px;
  background: rgba(251, 247, 239, 0.94);
  box-shadow: 0 18px 48px rgba(43, 34, 24, 0.12);
  transition:
    transform 240ms var(--ease),
    box-shadow 240ms var(--ease),
    border-color 240ms var(--ease);
}

.node-panel::before,
.phone-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.72), transparent 42%);
}

.node-panel::after {
  content: "";
  position: absolute;
  inset: -1px;
  pointer-events: none;
  border-radius: inherit;
  opacity: 0;
  box-shadow: inset 0 0 0 1px rgba(87, 75, 200, 0.32), 0 0 34px rgba(87, 75, 200, 0.18);
  animation: glow-breathe 5.8s ease-in-out infinite;
}

.ai-node .node-panel::after,
.automation-node .node-panel::after,
.db-node .node-panel::after {
  opacity: 1;
}

.ops-node:hover .node-panel,
.ops-node:hover .phone-panel {
  border-color: rgba(87, 75, 200, 0.38);
  box-shadow: 0 24px 64px rgba(43, 34, 24, 0.16), 0 0 0 1px rgba(87, 75, 200, 0.08);
  transform: translateY(-4px);
}

.node-kicker {
  display: block;
  color: var(--accent);
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.node-panel strong,
.phone-panel strong {
  position: relative;
  z-index: 1;
  display: block;
  margin-top: 6px;
  color: var(--ink);
  font-size: 14px;
  font-weight: 750;
  letter-spacing: -0.02em;
}

.node-note {
  position: absolute;
  left: 12px;
  top: calc(100% + 8px);
  z-index: 4;
  width: max-content;
  max-width: 210px;
  padding: 7px 10px;
  border: 1px solid rgba(87, 75, 200, 0.18);
  border-radius: 999px;
  color: var(--accent-dark);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 12px 32px rgba(43, 34, 24, 0.1);
  font-size: 11px;
  font-weight: 650;
  opacity: 0;
  transform: translateY(5px);
  transition: opacity 180ms var(--ease), transform 180ms var(--ease);
  pointer-events: none;
}

.ops-node:hover .node-note {
  opacity: 1;
  transform: translateY(0);
}

.crm-node {
  left: 50px;
  top: 82px;
  width: 158px;
  --node-delay: 940ms;
  --float-speed: 6.4s;
}

.automation-node {
  left: 256px;
  top: 66px;
  width: 184px;
  --node-delay: 1040ms;
  --float-speed: 7.1s;
  --float-delay: -900ms;
}

.ai-node {
  left: 292px;
  top: 194px;
  z-index: 5;
  width: 176px;
  --node-delay: 1380ms;
  --float-speed: 6.1s;
  --float-delay: -520ms;
}

.erp-node {
  left: 58px;
  top: 292px;
  width: 160px;
  --node-delay: 1240ms;
  --float-speed: 7.4s;
  --float-delay: -1300ms;
}

.db-node {
  left: 198px;
  top: 205px;
  width: 118px;
  --node-delay: 1320ms;
  --float-speed: 6.8s;
  --float-delay: -1700ms;
}

.mobile-node {
  left: 520px;
  top: 98px;
  width: 88px;
  --node-delay: 1400ms;
  --float-speed: 7.8s;
  --float-delay: -2200ms;
}

.analytics-node {
  left: 490px;
  top: 330px;
  width: 150px;
  --node-delay: 1480ms;
  --float-speed: 6.9s;
  --float-delay: -2600ms;
}

.api-node {
  left: 274px;
  top: 374px;
  width: 156px;
  --node-delay: 1560ms;
  --float-speed: 7.3s;
  --float-delay: -3100ms;
}

.crm-node .node-panel,
.erp-node .node-panel,
.analytics-node .node-panel,
.api-node .node-panel,
.automation-node .node-panel,
.db-node .node-panel {
  padding: 16px;
}

.ai-node .node-panel {
  min-height: 152px;
  padding: 18px;
  border-color: rgba(87, 75, 200, 0.28);
  box-shadow: 0 26px 78px rgba(43, 34, 24, 0.16), 0 0 44px rgba(87, 75, 200, 0.1);
  animation: ai-panel-breathe 6s ease-in-out 1900ms infinite;
}

.crm-visual {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 26px 1fr;
  gap: 8px 10px;
  margin-top: 18px;
}

.crm-visual::before,
.crm-visual::after {
  content: "";
  position: absolute;
  z-index: 2;
  border-radius: 50%;
}

.crm-visual::before {
  left: 18px;
  top: -9px;
  width: 8px;
  height: 8px;
  background: #35a370;
  box-shadow: 0 0 0 5px rgba(53, 163, 112, 0.11);
  animation: online-dot 4.6s ease-in-out 2100ms infinite;
}

.crm-visual::after {
  right: 12px;
  top: 9px;
  width: 7px;
  height: 7px;
  background: var(--accent);
  box-shadow: 0 0 0 0 rgba(87, 75, 200, 0.24);
  animation: crm-task 5.4s ease-in-out 2600ms infinite;
}

.crm-visual i {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: rgba(87, 75, 200, 0.14);
  animation: contact-update 5.8s ease-in-out 2300ms infinite;
}

.crm-visual i:nth-child(2) { background: rgba(23, 20, 18, 0.12); }
.crm-visual i:nth-child(3) { background: rgba(87, 75, 200, 0.26); animation-delay: 3300ms; }

.crm-visual span {
  height: 8px;
  align-self: center;
  border-radius: 999px;
  background: rgba(23, 20, 18, 0.12);
  transform-origin: left;
  animation: crm-line-update 6.2s ease-in-out 2900ms infinite;
}

.crm-visual span:nth-of-type(2) { animation-delay: 3600ms; }

.flow-visual {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 18px 1fr 18px 1fr;
  gap: 6px;
  align-items: center;
  margin-top: 16px;
}

.flow-visual::after {
  content: "";
  position: absolute;
  left: 10px;
  top: -7px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 5px rgba(87, 75, 200, 0.08);
  animation: workflow-event 4.8s ease-in-out 2400ms infinite;
}

.flow-visual span {
  min-height: 28px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(87, 75, 200, 0.18);
  border-radius: 8px;
  color: var(--accent-dark);
  background: rgba(255, 255, 255, 0.62);
  font-family: var(--mono);
  font-size: 7px;
  font-weight: 700;
  text-transform: uppercase;
  animation: workflow-step 4.8s ease-in-out 2400ms infinite;
}

.flow-visual span:nth-of-type(2) { animation-delay: 2640ms; }
.flow-visual span:nth-of-type(3) { animation-delay: 2880ms; }

.flow-visual i {
  height: 1px;
  background: rgba(87, 75, 200, 0.72);
  transform-origin: left;
  animation: workflow-link 4.8s ease-in-out 2520ms infinite;
}

.flow-visual i:nth-of-type(2) { animation-delay: 2760ms; }

.ai-core {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  min-height: 68px;
  margin-top: 14px;
}

.ai-core::before,
.ai-core::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.ai-core::before {
  width: 98px;
  height: 98px;
  background: radial-gradient(circle, rgba(87, 75, 200, 0.2), transparent 64%);
  opacity: 0.78;
  animation: ai-glow-breathe 6s ease-in-out 1900ms infinite;
}

.ai-core::after {
  width: 70px;
  height: 70px;
  border: 1px solid rgba(87, 75, 200, 0.15);
  transform: rotate(12deg);
  animation: ai-orbit 14s linear 1900ms infinite;
}

.ai-core span {
  position: relative;
  z-index: 2;
  width: 44px;
  height: 44px;
  border: 1px solid rgba(87, 75, 200, 0.32);
  border-radius: 16px;
  background:
    radial-gradient(circle at 50% 50%, rgba(87, 75, 200, 0.34), transparent 56%),
    rgba(255, 255, 255, 0.72);
  box-shadow: 0 0 34px rgba(87, 75, 200, 0.28);
  animation: ai-core-pulse 6s ease-in-out 1900ms infinite;
}

.ai-core i {
  position: absolute;
  border: 1px solid rgba(87, 75, 200, 0.18);
  border-radius: 22px;
  transform-origin: center;
  animation: ai-orbit 12s linear 1900ms infinite, glow-breathe 6s ease-in-out 1900ms infinite;
}

.ai-core i:nth-of-type(1) { width: 64px; height: 64px; }
.ai-core i:nth-of-type(2) { width: 84px; height: 42px; animation-duration: 16s, 6s; animation-delay: 1700ms, 1700ms; }
.ai-core i:nth-of-type(3) { width: 42px; height: 84px; animation-duration: 18s, 6s; animation-delay: 1500ms, 1500ms; }

.stack-visual {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 8px;
  margin-top: 16px;
}

.stack-visual span {
  height: 30px;
  border: 1px solid rgba(23, 20, 18, 0.08);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.58);
  transform-origin: left;
  animation: erp-process 5.6s ease-in-out 2600ms infinite;
}

.stack-visual span:nth-child(2) { margin-left: 14px; animation-delay: 2860ms; }
.stack-visual span:nth-child(3) { margin-left: 28px; background: rgba(87, 75, 200, 0.12); animation-delay: 3120ms; }

.database-visual {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 4px;
  margin-top: 14px;
}

.database-visual span {
  height: 20px;
  border: 1px solid rgba(87, 75, 200, 0.18);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.62);
  box-shadow: inset 0 -8px 0 rgba(87, 75, 200, 0.08);
  animation: db-sync 5.2s ease-in-out 2600ms infinite;
}

.database-visual span:nth-child(2) { animation-delay: 2840ms; }
.database-visual span:nth-child(3) { animation-delay: 3080ms; }

.phone-panel {
  min-height: 176px;
  padding: 18px 12px;
  border-radius: 24px;
}

.phone-panel::after {
  content: "";
  position: absolute;
  right: 15px;
  top: 18px;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 0 rgba(87, 75, 200, 0.24);
  opacity: 0;
  animation: phone-notification 5.8s ease-in-out 3100ms infinite;
}

.phone-panel > span {
  display: block;
  width: 28px;
  height: 4px;
  margin: 0 auto 20px;
  border-radius: 999px;
  background: rgba(23, 20, 18, 0.16);
}

.phone-panel strong {
  text-align: center;
  font-size: 12px;
}

.phone-panel i {
  display: block;
  height: 24px;
  margin-top: 12px;
  border-radius: 10px;
  background: rgba(87, 75, 200, 0.1);
  transform-origin: left;
  animation: phone-sync 5.8s ease-in-out 3200ms infinite;
}

.phone-panel i:nth-of-type(2) { background: rgba(23, 20, 18, 0.08); }
.phone-panel i:nth-of-type(2) { animation-delay: 3480ms; }
.phone-panel i:nth-of-type(3) { background: rgba(87, 75, 200, 0.2); animation-delay: 3760ms; }

.signal-visual {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  margin-top: 14px;
}

.signal-visual path {
  fill: none;
  stroke: rgba(87, 75, 200, 0.72);
  stroke-width: 3;
  stroke-linecap: round;
}

.signal-path {
  stroke-dasharray: 1;
  stroke-dashoffset: 0;
  animation: analytics-curve 5.2s ease-in-out 2800ms infinite;
}

.signal-visual circle {
  fill: var(--paper-soft);
  stroke: rgba(87, 75, 200, 0.72);
  stroke-width: 2;
}

.signal-runner {
  fill: var(--accent) !important;
  stroke: var(--paper-soft) !important;
  stroke-width: 2.4 !important;
  filter: drop-shadow(0 0 6px rgba(87, 75, 200, 0.36));
  animation: signal-runner 5.2s ease-in-out 2800ms infinite;
}

.api-visual {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 8px;
  margin-top: 14px;
}

.api-visual span {
  padding: 6px 8px;
  border: 1px solid rgba(23, 20, 18, 0.08);
  border-radius: 999px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.58);
  font-family: var(--mono);
  font-size: 10px;
}

.ops-ecosystem:has(.ai-node:hover) .route-ai,
.ops-ecosystem:has(.crm-node:hover) .route-crm,
.ops-ecosystem:has(.automation-node:hover) .route-automation,
.ops-ecosystem:has(.erp-node:hover) .route-erp,
.ops-ecosystem:has(.db-node:hover) .route-db,
.ops-ecosystem:has(.mobile-node:hover) .route-mobile,
.ops-ecosystem:has(.analytics-node:hover) .route-analytics,
.ops-ecosystem:has(.api-node:hover) .route-api {
  opacity: 1;
  stroke: rgba(87, 75, 200, 0.58);
  stroke-width: 2.2;
}

.ops-ecosystem:has(.ai-node:hover) .pulse-ai,
.ops-ecosystem:has(.crm-node:hover) .pulse-crm,
.ops-ecosystem:has(.automation-node:hover) .pulse-automation,
.ops-ecosystem:has(.erp-node:hover) .pulse-erp,
.ops-ecosystem:has(.db-node:hover) .pulse-db,
.ops-ecosystem:has(.mobile-node:hover) .pulse-mobile,
.ops-ecosystem:has(.analytics-node:hover) .pulse-analytics,
.ops-ecosystem:has(.api-node:hover) .pulse-api {
  opacity: 1;
  stroke-width: 2.8;
  animation-duration: 2.6s;
}

.operation-live {
  --system-scale: 1;
  --parallax-soft-x: 0px;
  --parallax-soft-y: 0px;
  --parallax-mid-x: 0px;
  --parallax-mid-y: 0px;
  --parallax-deep-x: 0px;
  --parallax-deep-y: 0px;
  position: relative;
  min-height: 500px;
  isolation: isolate;
}

.operation-live::before,
.operation-live::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.operation-live::before {
  inset: 5% 2% 3%;
  z-index: -1;
  opacity: 0.24;
  background:
    radial-gradient(circle at 58% 44%, rgba(87, 75, 200, 0.13), transparent 28%),
    radial-gradient(circle at 26% 72%, rgba(255, 255, 255, 0.74), transparent 24%);
  filter: blur(12px);
}

.operation-live::after {
  inset: 0;
  z-index: 6;
  opacity: 0.055;
  background-image: radial-gradient(rgba(23, 20, 18, 0.34) 0.45px, transparent 0.6px);
  background-size: 5px 5px;
  mix-blend-mode: multiply;
}

.operation-board {
  position: absolute;
  left: 50%;
  top: 40px;
  width: 650px;
  min-height: 420px;
  overflow: hidden;
  border: 1px solid rgba(23, 20, 18, 0.13);
  border-radius: 30px;
  background:
    linear-gradient(90deg, rgba(87, 75, 200, 0.055) 1px, transparent 1px),
    linear-gradient(180deg, rgba(23, 20, 18, 0.04) 1px, transparent 1px),
    rgba(251, 247, 239, 0.88);
  background-size: 30px 30px;
  box-shadow: 0 40px 120px rgba(43, 34, 24, 0.15);
  transform: translateX(-50%) translate3d(var(--parallax-mid-x), var(--parallax-mid-y), 0) scale(var(--system-scale));
  transform-origin: top center;
  animation: operationWake 760ms var(--ease-architecture) 660ms both;
}

.operation-board::before {
  content: "";
  position: absolute;
  inset: 26px;
  border: 1px solid rgba(87, 75, 200, 0.18);
  border-radius: 22px;
  pointer-events: none;
}

.operation-chrome {
  min-height: 50px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 20px;
  border-bottom: 1px solid rgba(23, 20, 18, 0.1);
  color: var(--muted);
  background: rgba(251, 247, 239, 0.72);
  font-family: var(--mono);
  font-size: 11px;
}

.operation-chrome span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(23, 20, 18, 0.16);
}

.operation-chrome strong {
  margin-left: auto;
  color: var(--ink);
  font-weight: 650;
}

.operation-layout {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 150px 1fr 152px;
  gap: 16px;
  padding: 24px;
}

.operation-inbox,
.operation-main,
.operation-side {
  border: 1px solid rgba(23, 20, 18, 0.1);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.48);
  box-shadow: 0 18px 44px rgba(43, 34, 24, 0.08);
}

.operation-inbox,
.operation-side {
  padding: 14px;
}

.operation-main {
  min-height: 318px;
  padding: 18px;
  background: rgba(251, 247, 239, 0.82);
}

.panel-label,
.operation-title span,
.live-kpi span {
  display: block;
  color: rgba(87, 75, 200, 0.78);
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.incoming-request {
  position: relative;
  margin-top: 16px;
  padding: 13px;
  border: 1px solid rgba(87, 75, 200, 0.18);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
  animation: requestArrive 6.4s var(--ease-architecture) 1600ms infinite;
}

.incoming-request i {
  position: absolute;
  right: 12px;
  top: 13px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 0 rgba(87, 75, 200, 0.24);
  animation: requestPulse 4.2s ease-in-out 1800ms infinite;
}

.incoming-request strong {
  display: block;
  max-width: 90px;
  color: var(--ink);
  font-size: 13px;
  line-height: 1.1;
}

.incoming-request span {
  display: block;
  margin-top: 9px;
  color: var(--quiet);
  font-family: var(--mono);
  font-size: 10px;
}

.inbox-line {
  height: 11px;
  margin-top: 16px;
  border-radius: 999px;
  background: rgba(23, 20, 18, 0.09);
}

.inbox-line.short {
  width: 68%;
  margin-top: 9px;
}

.operation-title {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 18px;
}

.operation-title strong {
  display: block;
  margin-top: 6px;
  color: var(--ink);
  font-size: 20px;
  line-height: 1;
}

.operation-title em {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 10px;
  border: 1px solid rgba(87, 75, 200, 0.16);
  border-radius: 999px;
  color: var(--accent-dark);
  background: rgba(87, 75, 200, 0.07);
  font-size: 11px;
  font-style: normal;
  font-weight: 700;
}

.operation-title em i {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #35a370;
  box-shadow: 0 0 0 5px rgba(53, 163, 112, 0.1);
  animation: requestPulse 4.2s ease-in-out infinite;
}

.operation-flow {
  position: relative;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  margin-top: 30px;
  padding-top: 18px;
}

.operation-flow::before {
  content: "";
  position: absolute;
  left: 9%;
  right: 9%;
  top: 30px;
  height: 2px;
  border-radius: 999px;
  background: rgba(87, 75, 200, 0.18);
}

.operation-flow::after {
  content: "";
  position: absolute;
  left: 9%;
  top: 27px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 10px rgba(87, 75, 200, 0.36);
  animation: flowRunner 6.4s ease-in-out 1800ms infinite;
}

.flow-step {
  position: relative;
  z-index: 1;
  display: grid;
  justify-items: center;
  gap: 10px;
  min-width: 0;
}

.flow-step span {
  position: relative;
  width: 24px;
  height: 24px;
  border: 1px solid rgba(87, 75, 200, 0.28);
  border-radius: 50%;
  background: rgba(251, 247, 239, 0.96);
  box-shadow: 0 0 0 6px rgba(251, 247, 239, 0.78);
  animation: stepState 6.4s ease-in-out infinite;
  animation-delay: var(--step-delay, 1800ms);
}

.flow-step span::after {
  content: "";
  position: absolute;
  left: 7px;
  top: 5px;
  width: 8px;
  height: 11px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  opacity: 0;
  transform: rotate(40deg) scale(0.7);
  animation: checkAppear 6.4s ease-in-out infinite;
  animation-delay: var(--step-delay, 1800ms);
}

.flow-step strong {
  max-width: 72px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 700;
  line-height: 1.15;
  text-align: center;
}

.is-new { --step-delay: 1800ms; }
.is-assigned { --step-delay: 2200ms; }
.is-approved { --step-delay: 2600ms; }
.is-billed { --step-delay: 3000ms; }
.is-delivered { --step-delay: 3400ms; }

.operation-table {
  display: grid;
  gap: 10px;
  margin-top: 30px;
}

.operation-table div {
  position: relative;
  display: grid;
  grid-template-columns: 90px 1fr 48px;
  align-items: center;
  gap: 12px;
  min-height: 38px;
  padding: 9px 10px;
  border: 1px solid rgba(23, 20, 18, 0.08);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.54);
}

.operation-table span {
  color: var(--quiet);
  font-size: 11px;
  font-weight: 650;
}

.operation-table strong {
  color: var(--ink);
  font-size: 12px;
}

.operation-table i {
  height: 8px;
  border-radius: 999px;
  background: rgba(87, 75, 200, 0.16);
  transform-origin: left;
  animation: progressFill 6.4s ease-in-out infinite;
  animation-delay: var(--row-delay, 2300ms);
}

.operation-table div:nth-child(2) { --row-delay: 2700ms; }
.operation-table div:nth-child(3) { --row-delay: 3100ms; }

.live-kpi {
  padding: 13px;
  border: 1px solid rgba(23, 20, 18, 0.08);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.58);
}

.live-kpi + .live-kpi {
  margin-top: 10px;
}

.live-kpi strong {
  display: block;
  margin-top: 8px;
  color: var(--ink);
  font-family: var(--serif);
  font-size: 34px;
  font-weight: 400;
  line-height: 0.95;
  animation: kpiLift 6.4s ease-in-out 3200ms infinite;
}

.live-kpi i {
  display: block;
  height: 7px;
  margin-top: 11px;
  border-radius: 999px;
  background: rgba(87, 75, 200, 0.18);
  transform-origin: left;
  animation: kpiBar 6.4s ease-in-out 3200ms infinite;
}

.live-kpi.secondary strong {
  font-size: 28px;
  animation-delay: 3500ms;
}

.live-kpi.secondary i {
  animation-delay: 3500ms;
}

.activity-feed {
  display: grid;
  gap: 8px;
  margin-top: 14px;
}

.activity-feed span {
  display: block;
  padding: 8px 9px;
  border: 1px solid rgba(87, 75, 200, 0.12);
  border-radius: 999px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.5);
  font-size: 11px;
  font-weight: 700;
  opacity: 0.56;
  animation: feedItem 6.4s ease-in-out infinite;
  animation-delay: var(--feed-delay, 2400ms);
}

.activity-feed span:nth-child(2) { --feed-delay: 2900ms; }
.activity-feed span:nth-child(3) { --feed-delay: 3400ms; }

.operation-toast {
  position: absolute;
  left: calc(50% - 248px);
  top: 20px;
  z-index: 4;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid rgba(87, 75, 200, 0.18);
  border-radius: 999px;
  color: var(--ink);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 18px 44px rgba(43, 34, 24, 0.12);
  font-size: 12px;
  opacity: 0;
  transform: translateY(10px);
  animation: toastIn 6.4s var(--ease-architecture) 1600ms infinite;
}

.operation-toast i {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
}

.operation-toast strong {
  font-weight: 750;
}

.business-live {
  --business-bg: #f7f7f7;
  --business-surface: #ffffff;
  --business-border: #e7e7ea;
  --business-text: #111111;
  --business-muted: #6b7280;
  --business-success: #16a34a;
  --business-warning: #f59e0b;
  --business-danger: #ef4444;
  --business-scale: 0.94;
  --parallax-soft-x: 0px;
  --parallax-soft-y: 0px;
  --parallax-mid-x: 0px;
  --parallax-mid-y: 0px;
  --parallax-deep-x: 0px;
  --parallax-deep-y: 0px;
  position: relative;
  display: grid;
  place-items: center;
  min-height: 500px;
  overflow: visible;
  color: var(--business-text);
  isolation: isolate;
}

.business-live::after {
  content: "";
  position: absolute;
  inset: 8% -2% 4%;
  z-index: -1;
  pointer-events: none;
  opacity: 0.045;
  background-image: radial-gradient(rgba(17, 17, 17, 0.45) 0.5px, transparent 0.7px);
  background-size: 5px 5px;
  mix-blend-mode: multiply;
}

.business-board {
  --business-offset-x: 0px;
  position: relative;
  width: min(780px, 106%);
  padding: 14px;
  border: 1px solid var(--business-border);
  border-radius: 12px;
  background: var(--business-bg);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.04);
  transform: translateX(var(--business-offset-x)) translate3d(var(--parallax-mid-x), var(--parallax-mid-y), 0) scale(var(--business-scale));
  transform-origin: center;
  animation: businessBoot 760ms var(--ease-architecture) 760ms both;
}

.business-board::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.92), transparent 38%),
    linear-gradient(180deg, transparent 68%, rgba(17, 17, 17, 0.018));
}

.business-header,
.business-grid,
.business-metrics {
  position: relative;
  z-index: 1;
}

.business-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  min-height: 46px;
  margin-bottom: 10px;
}

.business-header strong {
  display: block;
  color: var(--business-text);
  font-size: 19px;
  font-weight: 800;
  line-height: 1.1;
}

.business-header span {
  display: block;
  margin-top: 4px;
  color: var(--business-muted);
  font-size: 11px;
  line-height: 1.25;
}

.business-status {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #374151;
  white-space: nowrap;
}

.business-status > i,
.business-panel-head > i,
.order-freshness i {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--business-success);
  animation: businessStatus 3.8s ease-in-out infinite;
}

.business-status em {
  padding-left: 14px;
  border-left: 1px solid var(--business-border);
  color: #1f2937;
  font-style: normal;
  font-size: 12px;
  font-weight: 500;
}

.business-status b {
  display: inline-grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 1px solid var(--business-border);
  border-radius: 50%;
  background: var(--business-surface);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.04);
}

.business-status svg,
.entry-icon svg,
.task-icon svg {
  width: 18px;
  height: 18px;
  overflow: visible;
}

.business-status path,
.entry-icon svg path,
.entry-icon svg circle,
.task-icon svg path,
.task-icon svg circle {
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.business-grid {
  display: grid;
  grid-template-columns: 0.9fr 2fr 1fr;
  gap: 10px;
  align-items: stretch;
}

.business-panel {
  border: 1px solid var(--business-border);
  border-radius: 12px;
  background: var(--business-surface);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.04);
}

.business-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 12px 8px;
}

.business-panel-head strong {
  color: var(--business-text);
  font-size: 12px;
  font-weight: 800;
}

.business-panel-head span {
  padding: 5px 9px;
  border: 1px solid var(--business-border);
  border-radius: 8px;
  color: #111827;
  background: #fff;
  font-size: 11px;
  font-weight: 700;
}

.entry-stack {
  display: grid;
  gap: 7px;
  padding: 0 9px 9px;
}

.entry-card {
  position: relative;
  display: grid;
  grid-template-columns: 32px 1fr auto 6px;
  align-items: center;
  gap: 8px;
  min-height: 52px;
  padding: 8px;
  border: 1px solid var(--business-border);
  border-radius: 8px;
  background: #fff;
  transform-origin: top;
  animation: entryArrive 7.2s var(--ease-architecture) infinite;
  animation-delay: var(--entry-delay, 1400ms);
}

.entry-card:nth-child(2) { --entry-delay: 1900ms; }
.entry-card:nth-child(3) { --entry-delay: 2400ms; }
.entry-card:nth-child(4) { --entry-delay: 2900ms; }
.entry-card:nth-child(5) { --entry-delay: 3400ms; }

.entry-card strong,
.task-row strong,
.activity-row strong {
  display: block;
  color: var(--business-text);
  font-size: 10px;
  font-weight: 800;
  line-height: 1.15;
}

.entry-card span,
.task-row span,
.activity-row em,
.order-meta span,
.order-freshness span {
  color: var(--business-muted);
  font-size: 10px;
  font-style: normal;
  line-height: 1.3;
}

.entry-card time,
.task-row time,
.activity-row time {
  color: #4b5563;
  font-size: 10px;
  font-weight: 500;
}

.entry-icon,
.task-icon {
  display: inline-grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  color: #111827;
  background: #f3f4f6;
}

.entry-icon-whatsapp {
  color: #fff;
  background: #25d366;
}

.entry-icon-whatsapp svg path:first-child {
  fill: currentColor;
  stroke: currentColor;
}

.entry-icon-whatsapp svg path:last-child {
  color: #25d366;
  fill: #25d366;
  stroke: #fff;
  stroke-width: 0.9;
}

.entry-icon-excel {
  color: #fff;
  background: #16834a;
}

.entry-icon-excel svg path:first-child,
.entry-icon-excel svg path:nth-child(2) {
  fill: currentColor;
  stroke: currentColor;
}

.entry-icon-alert {
  color: var(--business-danger);
  background: rgba(239, 68, 68, 0.1);
}

.entry-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
}

.entry-dot.success { background: var(--business-success); }
.entry-dot.warning { background: var(--business-warning); }
.entry-dot.danger { background: var(--business-danger); }

.business-action {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 32px;
  margin: 7px 9px 9px;
  padding: 0 11px;
  border: 1px solid var(--business-border);
  border-radius: 8px;
  color: var(--business-text);
  background: #fff;
  font-size: 11px;
  font-weight: 800;
}

.active-order {
  display: flex;
  flex-direction: column;
  min-width: 0;
  padding: 14px;
}

.order-summary {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 14px;
}

.order-summary span {
  color: #4b5563;
  font-size: 13px;
  font-weight: 700;
}

.order-summary strong {
  display: block;
  margin-top: 8px;
  color: var(--business-text);
  font-size: 20px;
  font-weight: 800;
  line-height: 1;
}

.order-summary em {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 11px;
  border-radius: 999px;
  color: #065f46;
  background: rgba(22, 163, 74, 0.12);
  font-size: 11px;
  font-style: normal;
  font-weight: 800;
  white-space: nowrap;
}

.order-summary em i {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--business-success);
}

.order-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
  margin-top: 10px;
}

.order-meta strong {
  margin-left: 4px;
  color: var(--business-text);
  font-weight: 800;
}

.order-progress {
  position: relative;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  margin: 20px 0 14px;
}

.progress-track {
  position: absolute;
  left: 8%;
  right: 8%;
  top: 14px;
  height: 3px;
  border-radius: 999px;
  background: rgba(22, 163, 74, 0.18);
  overflow: hidden;
}

.progress-track::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  background: var(--business-success);
  transform-origin: left;
  animation: businessProgress 7.2s ease-in-out infinite;
}

.order-step {
  position: relative;
  z-index: 1;
  display: grid;
  justify-items: center;
  gap: 8px;
  min-width: 0;
}

.order-step span {
  position: relative;
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--business-success);
  box-shadow: 0 0 0 5px #fff;
}

.order-step span::after {
  content: "";
  width: 8px;
  height: 13px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(40deg);
  animation: businessCheck 7.2s ease-in-out infinite;
}

.order-step.is-active span {
  border: 4px solid #fff;
  background: var(--business-success);
  box-shadow: 0 0 0 3px var(--business-success), 0 4px 14px rgba(22, 163, 74, 0.2);
  animation: activeStep 4.8s ease-in-out infinite;
}

.order-step.is-active span::after {
  opacity: 0;
}

.order-step strong {
  max-width: 76px;
  color: #1f2937;
  font-size: 10px;
  font-weight: 650;
  line-height: 1.15;
  text-align: center;
}

.task-list {
  display: grid;
  gap: 7px;
  margin-top: auto;
}

.task-row {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr) auto 24px;
  align-items: center;
  gap: 8px;
  min-height: 50px;
  padding: 7px 9px;
  border: 1px solid var(--business-border);
  border-radius: 8px;
  background: #fff;
}

.task-icon {
  color: var(--business-success);
  background: rgba(22, 163, 74, 0.1);
}

.task-row b {
  color: var(--business-text);
  font-weight: 750;
}

.task-row > i {
  position: relative;
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border: 1px solid var(--business-success);
  border-radius: 6px;
}

.task-row > i::after {
  content: "";
  width: 7px;
  height: 11px;
  border-right: 2px solid var(--business-success);
  border-bottom: 2px solid var(--business-success);
  opacity: 0;
  transform: rotate(40deg) scale(0.72);
  animation: taskCheck 7.2s ease-in-out infinite;
  animation-delay: var(--task-delay, 2200ms);
}

.task-row:nth-child(2) > i::after { --task-delay: 2700ms; }
.task-row:nth-child(3) > i::after { --task-delay: 3200ms; }
.task-row:nth-child(4) > i::after { --task-delay: 3700ms; }

.order-freshness {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 10px;
}

.results-column {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.kpi-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--business-border);
}

.kpi-card {
  min-height: 72px;
  padding: 10px 12px;
  border-right: 1px solid var(--business-border);
  border-bottom: 1px solid var(--business-border);
}

.kpi-card:nth-child(2n) {
  border-right: 0;
}

.kpi-card:nth-child(n + 3) {
  border-bottom: 0;
}

.kpi-card span,
.business-metrics span {
  display: block;
  color: #374151;
  font-size: 10px;
  font-weight: 600;
  line-height: 1.25;
}

.kpi-card strong,
.business-metrics strong {
  display: block;
  margin-top: 7px;
  color: var(--business-text);
  font-size: 24px;
  font-weight: 800;
  line-height: 0.95;
  animation: kpiRefresh 7.2s ease-in-out infinite;
}

.kpi-card em,
.business-metrics em {
  display: block;
  margin-top: 7px;
  color: #02833f;
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
}

.activity-panel {
  padding-bottom: 1px;
}

.activity-list {
  display: grid;
  gap: 4px;
  padding: 0 10px;
}

.activity-row {
  display: grid;
  grid-template-columns: 28px 1fr auto;
  align-items: center;
  gap: 9px;
  min-height: 36px;
  animation: activityRefresh 7.2s var(--ease-architecture) infinite;
  animation-delay: var(--activity-delay, 1600ms);
}

.activity-row:nth-child(2) { --activity-delay: 2200ms; }
.activity-row:nth-child(3) { --activity-delay: 2800ms; }
.activity-row:nth-child(4) { --activity-delay: 3400ms; }

.activity-row > span {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  color: #111827;
  background: #f3f4f6;
  font-size: 9px;
  font-weight: 800;
}

.business-metrics {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  margin-top: 10px;
  border: 1px solid var(--business-border);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.035);
  overflow: hidden;
}

.business-metrics div {
  position: relative;
  min-height: 72px;
  padding: 11px 16px;
  border-right: 1px solid var(--business-border);
}

.business-metrics div:last-child {
  border-right: 0;
}

.business-metrics strong {
  font-size: 24px;
}

.business-metrics svg {
  position: absolute;
  right: 14px;
  bottom: 17px;
  width: 52px;
  height: 18px;
  overflow: visible;
}

.business-metrics path {
  fill: none;
  stroke: var(--business-success);
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 104;
  stroke-dashoffset: 104;
  animation: sparkDraw 7.2s ease-in-out infinite;
}

.business-metrics div:nth-child(2) path { animation-delay: 240ms; }
.business-metrics div:nth-child(3) path { animation-delay: 480ms; }
.business-metrics div:nth-child(4) path { animation-delay: 720ms; }

.business-live {
  --business-bg: #f7f4ee;
  --business-surface: #fcfbf8;
  --business-border: #e6e1d8;
  --business-text: #111111;
  --business-muted: #6e6a64;
  --business-accent: #5b4fe8;
  --business-success: #16a34a;
  --business-warning: #f59e0b;
  --business-danger: #ef4444;
  --business-scale: 1;
  min-height: 520px;
}

.business-live::after {
  inset: 10% -4% 2%;
  opacity: 0.032;
}

.business-board {
  --business-offset-x: 0%;
  width: min(740px, 106%);
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.business-board::before {
  display: none;
}

.operation-surface {
  position: relative;
  overflow: hidden;
  padding: 22px;
  border: 1px solid rgba(230, 225, 216, 0.82);
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.82), transparent 42%),
    var(--business-bg);
  box-shadow: 0 3px 18px rgba(17, 17, 17, 0.035);
}

.operation-surface::before {
  content: "";
  position: absolute;
  inset: -18% 48% 54% -18%;
  pointer-events: none;
  background: radial-gradient(circle, rgba(91, 79, 232, 0.07), transparent 64%);
}

.operation-topline,
.operation-story {
  position: relative;
  z-index: 1;
}

.operation-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 28px;
  color: var(--business-muted);
  font-size: 12px;
  font-weight: 650;
}

.operation-topline span {
  display: inline-flex;
  align-items: center;
  gap: 9px;
}

.operation-topline i {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--business-success);
  animation: businessStatus 3.8s ease-in-out infinite;
}

.operation-topline time {
  color: var(--business-text);
  font-size: 13px;
  font-weight: 750;
}

.operation-story {
  display: grid;
  grid-template-columns: 142px minmax(342px, 2fr) 122px;
  gap: 22px;
  align-items: center;
}

.operation-inputs {
  position: relative;
  min-height: 252px;
  display: grid;
  align-content: center;
}

.operation-inputs::after {
  content: "";
  position: absolute;
  left: calc(100% + 10px);
  top: 50%;
  width: 34px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(91, 79, 232, 0), rgba(91, 79, 232, 0.78));
  transform: translateY(-50%);
  animation: intakePulse 5.8s ease-in-out infinite;
}

.whatsapp-entry {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  align-items: center;
  gap: 13px;
  min-height: 82px;
  padding: 15px;
  border: 1px solid rgba(230, 225, 216, 0.9);
  border-radius: 14px;
  background: var(--business-surface);
  box-shadow: 0 2px 10px rgba(17, 17, 17, 0.035);
  animation: workArrives 6.8s var(--ease-architecture) infinite;
}

.whatsapp-entry .entry-icon {
  width: 46px;
  height: 46px;
  border-radius: 13px;
}

.whatsapp-entry strong {
  display: block;
  color: var(--business-text);
  font-size: 14px;
  font-weight: 850;
  line-height: 1.05;
}

.whatsapp-entry span:not(.entry-icon) {
  display: block;
  margin-top: 6px;
  color: var(--business-muted);
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
}

.whatsapp-entry time {
  position: static;
  grid-column: 2;
  margin-top: -8px;
  color: var(--business-text);
  font-size: 11px;
  font-weight: 800;
}

.manual-stack {
  position: relative;
  height: 118px;
  margin: 18px 14px 0;
}

.manual-slip {
  position: absolute;
  left: 0;
  right: 0;
  height: 50px;
  border: 1px solid rgba(230, 225, 216, 0.82);
  border-radius: 12px;
  background: rgba(252, 251, 248, 0.78);
  box-shadow: 0 2px 10px rgba(17, 17, 17, 0.025);
}

.manual-slip b,
.manual-slip i {
  position: absolute;
  left: 16px;
  right: 18px;
  height: 6px;
  border-radius: 999px;
  background: rgba(17, 17, 17, 0.12);
}

.manual-slip b {
  top: 15px;
  width: 42%;
}

.manual-slip i {
  top: 29px;
  width: 68%;
}

.slip-mail {
  top: 0;
  transform: rotate(-4deg) translateX(-6px);
}

.slip-sheet {
  top: 32px;
  transform: rotate(3deg) translateX(10px);
}

.slip-alert {
  top: 66px;
  transform: rotate(-2deg) translateX(1px);
}

.slip-alert::after {
  content: "";
  position: absolute;
  right: 15px;
  top: 17px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--business-warning);
}

.operation-core {
  min-width: 0;
  padding: 10px 0 8px;
}

.order-heading {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 34px;
}

.order-heading span {
  display: block;
  color: var(--business-muted);
  font-size: 13px;
  font-weight: 760;
}

.order-heading strong {
  display: block;
  margin-top: 8px;
  color: var(--business-text);
  font-size: 32px;
  font-weight: 850;
  letter-spacing: -0.04em;
  line-height: 0.92;
}

.order-heading em {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  color: var(--business-accent);
  background: rgba(91, 79, 232, 0.09);
  font-size: 12px;
  font-style: normal;
  font-weight: 850;
  white-space: nowrap;
}

.operation-flow-large {
  position: relative;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
  min-height: 126px;
}

.flow-rail {
  position: absolute;
  left: 6%;
  right: 6%;
  top: 26px;
  height: 4px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(91, 79, 232, 0.14);
}

.flow-rail::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  background: var(--business-accent);
  transform-origin: left;
  animation: flowPrimary 6.8s ease-in-out infinite;
}

.flow-node {
  position: relative;
  z-index: 1;
  display: grid;
  justify-items: center;
  align-content: start;
  gap: 13px;
  min-width: 0;
}

.flow-node span {
  position: relative;
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  color: var(--business-muted);
  background: var(--business-surface);
  box-shadow: inset 0 0 0 1px var(--business-border), 0 0 0 8px var(--business-bg);
}

.flow-node.is-complete span {
  color: #fff;
  background: var(--business-success);
  box-shadow: 0 0 0 8px var(--business-bg);
}

.flow-node.is-current span {
  color: #fff;
  background: var(--business-accent);
  box-shadow: 0 0 0 8px var(--business-bg);
  animation: currentNode 4.8s ease-in-out infinite;
}

.flow-node.is-next span {
  border: 2px solid rgba(91, 79, 232, 0.36);
}

.flow-node.is-complete span::after,
.completion-list i::after {
  content: "";
  width: 10px;
  height: 16px;
  border-right: 2.5px solid currentColor;
  border-bottom: 2.5px solid currentColor;
  transform: rotate(40deg);
  animation: bigCheck 6.8s ease-in-out infinite;
}

.flow-node.is-current span::after {
  content: "";
  width: 14px;
  height: 14px;
  border-radius: 4px;
  background: currentColor;
  box-shadow:
    0 0 0 8px rgba(255, 255, 255, 0.1),
    0 0 0 14px rgba(255, 255, 255, 0.06);
}

.flow-node.is-next span::after {
  content: "";
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: rgba(91, 79, 232, 0.34);
}

.flow-node strong {
  max-width: 78px;
  color: var(--business-text);
  font-size: 11px;
  font-weight: 760;
  line-height: 1.15;
  text-align: center;
}

.completion-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 28px;
}

.completion-list div {
  display: flex;
  align-items: center;
  gap: 9px;
  min-width: 0;
  padding-top: 14px;
  border-top: 1px solid rgba(230, 225, 216, 0.9);
}

.completion-list i {
  display: grid;
  flex: 0 0 auto;
  place-items: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  color: #fff;
  background: var(--business-success);
}

.completion-list i::after {
  width: 6px;
  height: 10px;
  border-width: 2px;
}

.completion-list span {
  color: var(--business-muted);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.25;
}

.operation-results {
  display: grid;
  align-content: center;
  gap: 18px;
  min-height: 252px;
  padding-left: 8px;
}

.result-metric {
  padding-bottom: 15px;
  border-bottom: 1px solid rgba(230, 225, 216, 0.95);
}

.result-metric span {
  display: block;
  color: var(--business-muted);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.18;
}

.result-metric strong {
  display: block;
  margin-top: 7px;
  color: var(--business-text);
  font-size: 34px;
  font-weight: 850;
  letter-spacing: -0.045em;
  line-height: 0.92;
  animation: kpiRefresh 6.8s ease-in-out infinite;
}

.delivery-note {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  color: var(--business-text);
  font-size: 12px;
  font-weight: 850;
}

.delivery-note i {
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  color: #fff;
  background: var(--business-success);
}

.delivery-note i::after {
  content: "";
  width: 7px;
  height: 11px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(40deg);
}

.business-live {
  --eco-scale: 1;
  --eco-surface: rgba(252, 251, 248, 0.9);
  --eco-border: rgba(87, 75, 200, 0.18);
  --eco-muted: #756f66;
  min-height: 520px;
  overflow: visible;
}

.brand-ecosystem {
  position: relative;
  width: min(780px, 112%);
  height: 500px;
  isolation: isolate;
  transform: translate3d(var(--parallax-mid-x), var(--parallax-mid-y), 0) scale(var(--eco-scale));
  transform-origin: center;
  animation: ecosystemEnter 780ms var(--ease-architecture) 720ms both;
}

.brand-ecosystem::before {
  content: "";
  position: absolute;
  inset: 42px 28px 36px;
  z-index: 0;
  border: 1px solid rgba(87, 75, 200, 0.16);
  border-radius: 30px;
  background:
    linear-gradient(90deg, rgba(87, 75, 200, 0.055) 1px, transparent 1px),
    linear-gradient(180deg, rgba(23, 20, 18, 0.045) 1px, transparent 1px),
    linear-gradient(135deg, rgba(252, 251, 248, 0.88), rgba(244, 239, 231, 0.68));
  background-size: 32px 32px, 32px 32px, auto;
  box-shadow: 0 34px 90px rgba(43, 34, 24, 0.12);
}

.brand-ecosystem::after {
  content: "";
  position: absolute;
  inset: 15% 8% 9%;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% 42%, rgba(87, 75, 200, 0.14), transparent 31%),
    radial-gradient(circle at 20% 78%, rgba(255, 255, 255, 0.72), transparent 24%);
  filter: blur(24px);
  opacity: 0.78;
}

.ecosystem-depth {
  position: absolute;
  z-index: 1;
  pointer-events: none;
  border: 1px solid rgba(23, 20, 18, 0.075);
  border-radius: 22px;
  background: rgba(252, 251, 248, 0.45);
}

.depth-one {
  left: 86px;
  top: 64px;
  width: 540px;
  height: 300px;
  transform: translate3d(var(--parallax-soft-x), var(--parallax-soft-y), 0) rotate(-2deg);
}

.depth-two {
  right: 52px;
  bottom: 58px;
  width: 460px;
  height: 230px;
  transform: translate3d(var(--parallax-deep-x), var(--parallax-deep-y), 0) rotate(2deg);
}

.ecosystem-lines {
  position: absolute;
  inset: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  overflow: visible;
}

.route {
  fill: none;
  stroke: rgba(87, 75, 200, 0.28);
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-dasharray: 9 14;
  animation: dataRoute 5.8s linear infinite;
}

.route-auto,
.route-results {
  animation-delay: 800ms;
}

.route-app {
  animation-delay: 1400ms;
}

.route-dot {
  fill: var(--paper-soft);
  stroke: rgba(87, 75, 200, 0.62);
  stroke-width: 1.6;
  transform-box: fill-box;
  transform-origin: center;
  animation: dotPulse 4.8s ease-in-out infinite;
}

.dot-two,
.dot-four {
  animation-delay: 900ms;
}

.dot-three {
  animation-delay: 1600ms;
}

.eco-module {
  position: absolute;
  z-index: 3;
  overflow: hidden;
  border: 1px solid rgba(23, 20, 18, 0.11);
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.82), transparent 56%),
    var(--eco-surface);
  box-shadow: 0 24px 70px rgba(43, 34, 24, 0.12);
  transform: translate3d(var(--module-x, 0), var(--module-y, 0), 0);
  animation: moduleFloat 7.2s ease-in-out infinite;
  animation-delay: var(--float-delay, 0ms);
}

.eco-module::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.eco-module span {
  display: block;
  color: var(--accent);
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.eco-module strong {
  display: block;
  margin-top: 8px;
  color: var(--ink);
  font-size: 16px;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.05;
}

.eco-module em {
  display: block;
  color: var(--quiet);
  font-style: normal;
  font-weight: 750;
}

.module-orders {
  left: 58px;
  top: 88px;
  width: 190px;
  min-height: 134px;
  padding: 18px;
  --module-y: -2px;
}

.module-clients {
  left: 42px;
  top: 286px;
  width: 210px;
  min-height: 132px;
  padding: 18px;
  --float-delay: 700ms;
}

.module-core {
  left: 280px;
  top: 154px;
  width: 270px;
  min-height: 206px;
  padding: 22px;
  border-color: rgba(87, 75, 200, 0.24);
  box-shadow: 0 36px 96px rgba(43, 34, 24, 0.16);
  --module-y: 2px;
  --float-delay: 300ms;
}

.module-automation {
  right: 42px;
  top: 78px;
  width: 210px;
  min-height: 142px;
  padding: 18px;
  --float-delay: 1100ms;
}

.module-results {
  right: 30px;
  top: 300px;
  width: 176px;
  min-height: 154px;
  padding: 18px;
  --float-delay: 1500ms;
}

.module-app {
  left: 390px;
  bottom: 30px;
  width: 178px;
  min-height: 124px;
  padding: 18px;
  --float-delay: 1900ms;
}

.module-lines {
  display: grid;
  gap: 8px;
  margin-top: 18px;
}

.module-lines i {
  display: block;
  height: 8px;
  border-radius: 999px;
  background: rgba(23, 20, 18, 0.1);
  transform-origin: left;
  animation: lineFill 5.8s ease-in-out infinite;
}

.module-lines i:nth-child(1) {
  width: 82%;
}

.module-lines i:nth-child(2) {
  width: 58%;
  animation-delay: 420ms;
}

.module-lines i:nth-child(3) {
  width: 70%;
  animation-delay: 760ms;
}

.module-orders em {
  margin-top: 14px;
  color: var(--accent-dark);
  font-family: var(--mono);
  font-size: 12px;
}

.client-source {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 18px;
}

.client-source svg {
  width: 42px;
  height: 42px;
  padding: 10px;
  border-radius: 12px;
  background: #25d366;
}

.client-source path:first-child {
  fill: #fff;
  stroke: #fff;
}

.client-source path:last-child {
  fill: #25d366;
  stroke: #fff;
  stroke-width: 0.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.client-source b {
  color: var(--ink);
  font-family: var(--mono);
  font-size: 12px;
}

.core-flow {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-top: 28px;
}

.core-flow::before {
  content: "";
  position: absolute;
  left: 10%;
  right: 10%;
  top: 15px;
  height: 2px;
  border-radius: 999px;
  background: rgba(87, 75, 200, 0.18);
}

.core-flow::after {
  content: "";
  position: absolute;
  left: 10%;
  top: 12px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 14px rgba(87, 75, 200, 0.32);
  animation: coreRunner 5.8s ease-in-out infinite;
}

.core-flow i {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 7px rgba(251, 247, 239, 0.9);
}

.core-flow i::after {
  content: "";
  width: 7px;
  height: 11px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(40deg);
}

.core-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 26px;
}

.core-actions b {
  padding: 8px 10px;
  border: 1px solid rgba(87, 75, 200, 0.14);
  border-radius: 999px;
  color: var(--ink);
  background: rgba(87, 75, 200, 0.055);
  font-size: 11px;
  font-weight: 750;
}

.automation-pipeline {
  position: relative;
  display: flex;
  gap: 18px;
  margin-top: 24px;
}

.automation-pipeline::before {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  top: 17px;
  height: 2px;
  background: rgba(87, 75, 200, 0.18);
}

.automation-pipeline i {
  position: relative;
  z-index: 1;
  width: 34px;
  height: 34px;
  border: 1px solid rgba(87, 75, 200, 0.2);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.78);
  animation: stepBlink 5.8s ease-in-out infinite;
}

.automation-pipeline i:nth-child(2) {
  animation-delay: 480ms;
}

.automation-pipeline i:nth-child(3) {
  animation-delay: 960ms;
}

.module-results strong {
  margin-top: 10px;
  color: var(--ink);
  font-family: var(--serif);
  font-size: 58px;
  font-weight: 400;
  letter-spacing: -0.04em;
  line-height: 0.86;
}

.module-results em {
  margin-top: 8px;
  font-size: 12px;
}

.result-wave {
  display: flex;
  align-items: end;
  gap: 8px;
  height: 36px;
  margin-top: 18px;
}

.result-wave i {
  width: 18px;
  border-radius: 6px 6px 0 0;
  background: var(--accent);
  transform-origin: bottom;
  animation: resultRise 5.8s ease-in-out infinite;
}

.result-wave i:nth-child(1) { height: 14px; opacity: 0.4; }
.result-wave i:nth-child(2) { height: 22px; opacity: 0.58; animation-delay: 280ms; }
.result-wave i:nth-child(3) { height: 28px; opacity: 0.78; animation-delay: 560ms; }
.result-wave i:nth-child(4) { height: 36px; animation-delay: 840ms; }

.app-surface {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 10px;
  margin-top: 18px;
}

.app-surface i {
  display: block;
  height: 12px;
  border-radius: 999px;
  background: rgba(23, 20, 18, 0.1);
}

.app-surface i:first-child {
  grid-row: span 3;
  width: 40px;
  height: 52px;
  border-radius: 14px;
  background:
    linear-gradient(180deg, rgba(87, 75, 200, 0.18), rgba(87, 75, 200, 0.05)),
    rgba(255, 255, 255, 0.7);
  animation: appNotify 5.8s ease-in-out infinite;
}

.app-surface i:nth-child(2) { width: 72%; }
.app-surface i:nth-child(3) { width: 58%; }

.business-live {
  --live-bg: #f7f4ee;
  --live-card: #fcfbf8;
  --live-border: #e7e1d8;
  --live-text: #111111;
  --live-muted: #6e6a64;
  --live-accent: #5b4fe8;
  --live-success: #16a34a;
  --live-warning: #f59e0b;
  --live-danger: #ef4444;
  --live-scale: 1;
  min-height: 520px;
  overflow: visible;
}

.live-operation-panel {
  --live-offset-x: clamp(-48px, -3vw, -26px);
  position: relative;
  width: min(830px, 116%);
  padding: 22px;
  border: 1px solid rgba(231, 225, 216, 0.82);
  border-radius: 24px;
  background:
    radial-gradient(circle at 18% 10%, rgba(91, 79, 232, 0.055), transparent 24%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.82), transparent 48%),
    var(--live-bg);
  box-shadow: 0 32px 90px rgba(43, 34, 24, 0.1);
  transform: translateX(var(--live-offset-x)) translate3d(var(--parallax-mid-x), var(--parallax-mid-y), 0) scale(var(--live-scale));
  transform-origin: center;
  animation: livePanelIn 760ms var(--ease-architecture) 680ms both;
}

.live-operation-panel::before {
  content: "";
  position: absolute;
  inset: 20px;
  pointer-events: none;
  border-radius: 18px;
  background:
    linear-gradient(90deg, rgba(23, 20, 18, 0.026) 1px, transparent 1px),
    linear-gradient(180deg, rgba(23, 20, 18, 0.022) 1px, transparent 1px);
  background-size: 54px 54px;
  mask-image: linear-gradient(90deg, transparent, #000 18%, #000 82%, transparent);
}

.live-panel-top,
.operation-connectors,
.live-panel-grid {
  position: relative;
  z-index: 1;
}

.live-panel-top {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 16px;
}

.live-panel-top span {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  color: var(--live-text);
  font-size: 13.5px;
  font-weight: 850;
}

.live-panel-top i,
.updated-line i {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--live-success);
  animation: systemBreathing 2s ease-in-out infinite;
}

.live-panel-top em {
  display: block;
  margin-top: 5px;
  color: var(--live-muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 550;
}

.operation-connectors {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  pointer-events: none;
  overflow: visible;
}

.connector-base,
.connector-pulse {
  fill: none;
  stroke-linecap: round;
}

.connector-base {
  stroke: rgba(91, 79, 232, 0.13);
  stroke-width: 1.4;
}

.connector-pulse {
  stroke: rgba(91, 79, 232, 0.72);
  stroke-width: 1.8;
  stroke-dasharray: 1 180;
  stroke-dashoffset: 0;
  animation: connectorTravel 4.8s ease-in-out infinite;
}

.pulse-two {
  animation-delay: 600ms;
}

.pulse-three {
  animation-delay: 1200ms;
}

.time-cycle,
.kpi-cycle {
  position: relative;
  display: inline-block;
}

.time-cycle {
  min-width: 42px;
  min-height: 20px;
  color: var(--live-text);
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 750;
}

.time-cycle b,
.kpi-cycle b {
  position: absolute;
  inset: 0;
  opacity: 0;
  animation: valueCycle 6s ease-in-out infinite;
}

.time-cycle b:nth-child(2),
.kpi-cycle b:nth-child(2) {
  animation-delay: 2s;
}

.time-cycle b:nth-child(3),
.kpi-cycle b:nth-child(3) {
  animation-delay: 4s;
}

.live-panel-grid {
  display: grid;
  grid-template-columns: minmax(230px, 1.15fr) minmax(338px, 1.58fr) minmax(198px, 0.95fr);
  gap: 14px;
  align-items: stretch;
}

.live-card {
  border: 1px solid var(--live-border);
  border-radius: 14px;
  background: rgba(252, 251, 248, 0.88);
  box-shadow: 0 12px 38px rgba(43, 34, 24, 0.055);
  backdrop-filter: blur(12px);
  transition: transform 300ms var(--ease-architecture), border-color 300ms var(--ease-architecture), box-shadow 300ms var(--ease-architecture);
}

.live-card-title {
  display: block;
  margin: 0;
  color: var(--live-text);
  font-size: 13px;
  font-weight: 850;
  letter-spacing: -0.01em;
}

.entries-card {
  padding: 22px 20px;
}

.entry-feed {
  display: grid;
  margin-top: 18px;
}

.entry-row {
  position: relative;
  display: grid;
  grid-template-columns: 44px minmax(154px, 1fr);
  align-items: center;
  gap: 15px;
  min-height: 74px;
  border-top: 1px solid rgba(231, 225, 216, 0.9);
  animation: entryFeedCycle 6s var(--ease-architecture) infinite;
  animation-delay: var(--entry-cycle-delay, 0ms);
}

.entry-row:first-child {
  border-top: 0;
}

.entry-row > div {
  min-width: 0;
}

.entry-row:nth-child(2) { --entry-cycle-delay: 900ms; }
.entry-row:nth-child(3) { --entry-cycle-delay: 1800ms; }
.entry-row:nth-child(4) { --entry-cycle-delay: 2700ms; }

.entry-row strong,
.task-item strong,
.activity-feed-live span {
  display: block;
  max-width: 100%;
  color: var(--live-text);
  font-size: 12px;
  font-weight: 850;
  line-height: 1.15;
  overflow-wrap: normal;
}

.entry-row span,
.task-item span {
  display: block;
  max-width: 100%;
  color: var(--live-muted);
  font-size: 10.5px;
  font-weight: 560;
  line-height: 1.3;
  overflow-wrap: anywhere;
}

.entry-row time,
.task-item time,
.activity-feed-live time {
  color: var(--live-muted);
  font-family: var(--mono);
  font-size: 9px;
  font-weight: 650;
}

.entry-symbol {
  position: relative;
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 11px;
  color: var(--live-muted);
  background: rgba(91, 79, 232, 0.07);
  overflow: hidden;
  flex: 0 0 auto;
}

.entry-symbol svg,
.entry-symbol img {
  display: block;
  width: 19px;
  height: 19px;
}

.entry-symbol img {
  width: var(--entry-logo-size, 30px);
  height: var(--entry-logo-size, 30px);
  object-fit: contain;
}

.brand-symbol {
  border: 1px solid rgba(231, 225, 216, 0.92);
  background: #fff;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.42),
    0 6px 16px rgba(43, 34, 24, 0.035);
}

.whatsapp-symbol,
.slack-symbol,
.excel-symbol,
.stock-symbol {
  border-color: transparent;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.whatsapp-symbol {
  --entry-logo-size: 36px;
}

.slack-symbol {
  --entry-logo-size: 34px;
}

.stock-symbol {
  --entry-logo-size: 28px;
}

.slack-symbol svg {
  width: 30px;
  height: 30px;
}

.excel-symbol svg {
  width: 29px;
  height: 29px;
}

.excel-sheet {
  fill: #21a366;
}

.excel-grid {
  fill: none;
  stroke: rgba(255, 255, 255, 0.52);
  stroke-width: 1.1;
  stroke-linecap: round;
}

.excel-cover {
  fill: #107c41;
}

.excel-x {
  fill: none;
  stroke: #fff;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.mail-symbol::before,
.sheet-symbol::before,
.warning-symbol::before {
  content: "";
  width: 16px;
  height: 12px;
  border: 1.8px solid currentColor;
  border-radius: 3px;
}

.entry-slack path {
  stroke: none;
}

.slack-red { fill: #e01e5a; }
.slack-blue { fill: #36c5f0; }
.slack-green { fill: #2eb67d; }
.slack-yellow { fill: #ecb22e; }

.mail-symbol::after {
  content: "";
  position: absolute;
  width: 13px;
  height: 8px;
  border-left: 1.8px solid currentColor;
  border-bottom: 1.8px solid currentColor;
  transform: translateY(-2px) rotate(-45deg);
}

.sheet-symbol {
  color: #16834a;
  background: rgba(22, 131, 74, 0.1);
}

.sheet-symbol::before {
  width: 13px;
  height: 16px;
  border-radius: 2px;
}

.warning-symbol {
  color: #6e6a64;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.warning-symbol::before {
  width: 0;
  height: 0;
  border: 0;
  border-left: 11px solid transparent;
  border-right: 11px solid transparent;
  border-bottom: 19px solid currentColor;
  border-radius: 0;
}

.operation-card {
  padding: 24px 22px 20px;
}

.operation-card-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 16px;
}

.operation-card-head span {
  color: var(--live-accent);
  font-size: 11.5px;
  font-weight: 850;
}

.operation-card-head strong {
  display: block;
  margin-top: 8px;
  color: var(--live-text);
  font-size: 21px;
  font-weight: 850;
  letter-spacing: -0.035em;
  line-height: 1;
}

.operation-card-head em {
  padding: 7px 12px;
  border-radius: 999px;
  color: var(--live-accent);
  background: rgba(91, 79, 232, 0.09);
  font-size: 10px;
  font-style: normal;
  font-weight: 850;
  white-space: nowrap;
}

.operation-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  margin-top: 10px;
  color: var(--live-muted);
  font-size: 10.5px;
}

.operation-meta b {
  color: var(--live-text);
}

.live-flow {
  position: relative;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 9px;
  margin: 34px 0 24px;
}

.live-flow::before {
  content: "";
  position: absolute;
  left: 8%;
  right: 8%;
  top: 16px;
  height: 3px;
  border-radius: 999px;
  background: rgba(91, 79, 232, 0.18);
}

.flow-light {
  position: absolute;
  left: 8%;
  top: 13px;
  z-index: 2;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 0 3px rgba(91, 79, 232, 0.18), 0 0 18px rgba(91, 79, 232, 0.52);
  animation: flowLight 4s ease-in-out infinite;
}

.live-step {
  position: relative;
  z-index: 3;
  display: grid;
  justify-items: center;
  gap: 10px;
  min-width: 0;
}

.live-step i {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--live-accent);
  box-shadow: 0 0 0 6px var(--live-card);
  animation: sequentialCheck 5s ease-in-out infinite;
  animation-delay: var(--step-delay, 0ms);
}

.live-step i::after {
  content: "";
  width: 8px;
  height: 13px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(40deg);
}

.live-step:nth-of-type(2) { --step-delay: 500ms; }
.live-step:nth-of-type(3) { --step-delay: 1000ms; }
.live-step:nth-of-type(4) { --step-delay: 1500ms; }
.live-step:nth-of-type(5) { --step-delay: 2000ms; }
.live-step:nth-of-type(6) { --step-delay: 2500ms; }

.live-step.is-pending i {
  position: relative;
  border: 2px solid var(--live-accent);
  background: var(--live-card);
  animation: finalStepComplete 5s ease-in-out infinite;
}

.live-step.is-pending i::after {
  content: "";
  width: 9px;
  height: 9px;
  border: 0;
  border-radius: 50%;
  background: rgba(91, 79, 232, 0.42);
  animation: finalDotFade 5s ease-in-out infinite;
}

.live-step.is-pending i::before {
  content: "";
  position: absolute;
  width: 8px;
  height: 13px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  opacity: 0;
  transform: rotate(40deg) scale(0.72);
  animation: finalCheckAppear 5s ease-in-out infinite;
}

.live-step span {
  color: var(--live-text);
  font-size: 10.5px;
  font-weight: 750;
  line-height: 1.12;
  text-align: center;
}

.task-feed {
  display: grid;
  gap: 0;
}

.task-item {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr);
  gap: 11px;
  align-items: center;
  min-height: 50px;
  border-top: 1px solid rgba(231, 225, 216, 0.9);
}

.task-item > i {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 9px;
  background: rgba(91, 79, 232, 0.07);
}

.task-item > i::after {
  content: "";
  width: 7px;
  height: 11px;
  border-right: 2px solid var(--live-success);
  border-bottom: 2px solid var(--live-success);
  transform: rotate(40deg);
}

.task-item.is-muted {
  opacity: 0.62;
}

.updated-line {
  display: flex;
  align-items: center;
  gap: 9px;
  margin: 16px 0 0;
  color: var(--live-muted);
  font-size: 10px;
}

.korve-preview-card {
  position: relative;
  display: grid;
  gap: 14px;
  min-height: 368px;
  padding: 18px;
  overflow: hidden;
  isolation: isolate;
  cursor: pointer;
}

.korve-preview-card::before {
  content: "";
  position: absolute;
  inset: -18% -16% auto auto;
  z-index: -1;
  width: 230px;
  height: 230px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(91, 79, 232, 0.12), transparent 66%);
  opacity: 0.62;
  filter: blur(16px);
  transition: opacity 300ms var(--ease-architecture), transform 300ms var(--ease-architecture);
}

.korve-preview-head,
.korve-preview-meta {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 16px;
}

.korve-preview-head span {
  color: var(--live-accent);
  font-size: 11px;
  font-weight: 850;
  letter-spacing: 0.01em;
}

.korve-preview-head strong {
  display: block;
  margin-top: 6px;
  color: var(--live-text);
  font-size: 25px;
  font-weight: 850;
  letter-spacing: -0.045em;
  line-height: 0.95;
}

.korve-preview-head em,
.korve-preview-meta span {
  font-style: normal;
  white-space: nowrap;
}

.korve-preview-head em {
  padding: 7px 12px;
  border: 1px solid rgba(91, 79, 232, 0.18);
  border-radius: 999px;
  color: var(--live-accent);
  background: rgba(91, 79, 232, 0.075);
  font-size: 10px;
  font-weight: 850;
}

.korve-preview-browser {
  position: relative;
  min-height: 218px;
  border: 1px solid rgba(17, 17, 17, 0.1);
  border-radius: 16px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(247, 244, 238, 0.58)),
    #111;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72), 0 18px 42px rgba(43, 34, 24, 0.08);
}

.korve-preview-browser::before {
  content: "";
  position: absolute;
  left: 13px;
  top: 12px;
  z-index: 3;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #ef665f;
  box-shadow: 13px 0 0 #e1c76a, 26px 0 0 #75c886;
}

.korve-preview-browser::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  z-index: 2;
  height: 86px;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(252, 251, 248, 0), rgba(252, 251, 248, 0.98) 72%);
}

.korve-preview-browser iframe {
  position: absolute;
  z-index: 1;
  left: 0;
  top: -30px;
  width: 1280px;
  height: 650px;
  border: 0;
  pointer-events: none;
  transform: scale(0.4);
  transform-origin: 0 0;
  opacity: 0.98;
}

.korve-preview-meta {
  align-items: center;
  color: var(--live-muted);
  font-size: 10.5px;
  font-weight: 700;
}

.korve-preview-meta span:first-child {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--live-text);
}

.korve-preview-meta i {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--live-success);
  animation: systemBreathing 2s ease-in-out infinite;
}

.korve-preview-link {
  position: absolute;
  inset: 0;
  z-index: 5;
  border-radius: inherit;
}

.korve-preview-link:focus-visible {
  outline: 3px solid rgba(91, 79, 232, 0.38);
  outline-offset: -5px;
}

.portfolio-products {
  --live-offset-x: 0px;
  width: min(1180px, 172%);
  height: 540px;
  display: grid;
  grid-template-rows: 1fr 1fr 1fr;
  gap: 0;
  padding: 0;
  overflow: hidden;
  isolation: isolate;
  border-color: transparent;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.portfolio-products::before {
  inset: -24px;
  border-radius: 0;
  background:
    linear-gradient(90deg, rgba(23, 20, 18, 0.024) 1px, transparent 1px),
    linear-gradient(180deg, rgba(23, 20, 18, 0.02) 1px, transparent 1px);
  background-size: 52px 52px;
  mask-image: linear-gradient(90deg, transparent, #000 14%, #000 88%, transparent);
  opacity: 0.38;
}

.portfolio-product {
  --preview-scale: 0.46 !important;
  --preview-hover-scale: 0.485 !important;
  position: relative;
  min-height: 0;
  overflow: hidden;
  border: 0;
  background: transparent;
  box-shadow: inset 0 1px 0 rgba(17, 17, 17, 0.055);
  transform: translate3d(0, 0, 0);
  transition:
    transform 420ms var(--ease-architecture),
    border-color 420ms var(--ease-architecture),
    box-shadow 420ms var(--ease-architecture);
  animation: portfolioPanelIn 860ms var(--ease-architecture) both;
}

.portfolio-product:nth-child(2) {
  animation-delay: 130ms;
}

.portfolio-product:nth-child(3) {
  animation-delay: 260ms;
}

.portfolio-product-korve {
  clip-path: none;
}

.portfolio-product-scribblit {
  clip-path: none;
}

.portfolio-product-irondistrict {
  clip-path: none;
}

.portfolio-product::before {
  content: "";
  position: absolute;
  inset: 0 0 0 0;
  z-index: 8;
  pointer-events: none;
  background:
    linear-gradient(90deg, #574bc8, #574bc8) left top / 0 3px no-repeat,
    linear-gradient(180deg, #574bc8, #574bc8) right top / 3px 0 no-repeat,
    linear-gradient(90deg, #574bc8, #574bc8) right bottom / 0 3px no-repeat,
    linear-gradient(180deg, #574bc8, #574bc8) left bottom / 3px 0 no-repeat;
  box-shadow: inset 0 0 0 1px rgba(17, 17, 17, 0.055);
  opacity: 0.66;
  filter: drop-shadow(0 0 0 rgba(87, 75, 200, 0));
  transition:
    background-size 720ms var(--ease-architecture),
    box-shadow 420ms var(--ease-architecture),
    filter 520ms var(--ease-architecture),
    opacity 320ms var(--ease-architecture);
}

.portfolio-product::after {
  content: "";
  position: absolute;
  z-index: 4;
  top: -40px;
  width: 28px;
  height: calc(100% + 80px);
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 44%, transparent);
  opacity: 0.14;
  transform: rotate(var(--line-angle));
  pointer-events: none;
  transition:
    opacity 420ms var(--ease-architecture),
    background 420ms var(--ease-architecture),
    transform 420ms var(--ease-architecture);
}

.portfolio-product-korve::after,
.portfolio-product-irondistrict::after {
  right: 4.2%;
}

.portfolio-product-scribblit::after {
  left: 3.1%;
}

.portfolio-product-copy {
  position: absolute;
  left: 24px;
  right: auto;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  width: clamp(210px, 21vw, 268px);
  height: auto;
  padding: 16px 18px 17px;
  text-align: left;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(247, 244, 238, 0.94), rgba(247, 244, 238, 0.72) 78%, transparent);
  text-shadow: 0 1px 16px rgba(244, 239, 231, 0.82);
}

.portfolio-product-scribblit .portfolio-product-copy {
  padding-left: 0;
}

.portfolio-product-copy span {
  display: inline-flex;
  width: max-content;
  margin-bottom: 6px;
  color: color-mix(in srgb, var(--accent) 82%, #111);
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 780;
  letter-spacing: 0.08em;
}

.portfolio-product-copy h3 {
  margin: 0;
  color: var(--live-text);
  font-size: clamp(2.22rem, 4.12vw, 3.5rem);
  font-weight: 900;
  letter-spacing: -0.075em;
  line-height: 0.78;
}

.portfolio-product-irondistrict .portfolio-product-copy h3 {
  font-size: clamp(1.72rem, 2.9vw, 2.32rem);
  letter-spacing: -0.08em;
}

.portfolio-product-copy p {
  max-width: 202px;
  margin: 11px 0 0;
  color: rgba(17, 17, 17, 0.62);
  font-size: 10.5px;
  font-weight: 750;
  line-height: 1.34;
}

.portfolio-product-irondistrict .portfolio-product-copy span,
.portfolio-product-irondistrict .portfolio-product-copy h3,
.portfolio-product-irondistrict .portfolio-product-copy p {
  color: var(--live-text);
  text-shadow: 0 1px 16px rgba(244, 239, 231, 0.82);
}

.portfolio-product-preview {
  position: absolute;
  z-index: 1;
  inset: 0;
  overflow: hidden;
  border-left: 0;
  background: transparent;
  filter: grayscale(1) contrast(1.12) brightness(0.97);
  transform:
    translate3d(
      calc(var(--parallax-soft-x, 0px) * 0.45),
      calc(var(--parallax-soft-y, 0px) * 0.35),
      0
    );
  transition:
    filter 520ms var(--ease-architecture),
    transform 520ms var(--ease-architecture),
    opacity 520ms var(--ease-architecture);
}

.portfolio-product-preview::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: var(--preview-image);
  background-position: center top;
  background-size: cover;
  opacity: 0.98;
  transform: scale(1.01);
  transition:
    opacity 520ms var(--ease-architecture),
    transform 700ms var(--ease-architecture);
}

.portfolio-product-scribblit .portfolio-product-preview {
  inset: 0;
  border-left: 0;
  border-right: 0;
}

.portfolio-product-preview::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(247, 244, 238, 0.18), rgba(247, 244, 238, 0.03) 34%, transparent 62%),
    linear-gradient(270deg, rgba(247, 244, 238, 0.7), rgba(247, 244, 238, 0.2) 24%, transparent 48%),
    linear-gradient(180deg, rgba(247, 244, 238, 0.04), rgba(247, 244, 238, 0.18));
  transition: opacity 420ms var(--ease-architecture);
}

.portfolio-product-scribblit .portfolio-product-preview::before {
  background:
    linear-gradient(270deg, rgba(247, 244, 238, 0.64), rgba(247, 244, 238, 0.18) 24%, transparent 48%),
    linear-gradient(180deg, rgba(247, 244, 238, 0.03), rgba(247, 244, 238, 0.16));
}

.portfolio-product-preview iframe {
  position: absolute;
  z-index: 1;
  left: -18px;
  top: 0;
  width: 2400px;
  height: 920px;
  border: 0;
  pointer-events: none;
  transform: translate3d(0, var(--preview-y), 0) scale(var(--preview-scale));
  transform-origin: 0 0;
  opacity: 0.96;
  transition:
    transform 700ms var(--ease-architecture),
    opacity 500ms var(--ease-architecture);
}

.portfolio-product-preview iframe:not([src]) {
  display: none;
}

.portfolio-product-scribblit .portfolio-product-preview iframe {
  left: -28px;
}

.portfolio-product-irondistrict .portfolio-product-preview iframe {
  left: 0;
  width: 2700px;
}

.portfolio-product-irondistrict .portfolio-product-preview {
  inset-inline-start: 0;
  background: #151515;
}

.portfolio-product-irondistrict .portfolio-product-copy {
  padding-left: 0;
  background: linear-gradient(90deg, rgba(247, 244, 238, 0.98), rgba(247, 244, 238, 0.84) 82%, rgba(247, 244, 238, 0.08));
}

.portfolio-product-link {
  position: absolute;
  inset: 0;
  z-index: 10;
  color: inherit;
  text-decoration: none;
}

.portfolio-product-link:focus-visible {
  outline: 3px solid rgba(91, 79, 232, 0.42);
  outline-offset: -7px;
}

@media (hover: hover) and (pointer: fine) {
  .portfolio-product:hover {
    border-color: color-mix(in srgb, var(--accent) 28%, var(--live-border));
    box-shadow: 0 24px 70px rgba(43, 34, 24, 0.11);
    transform: translate3d(0, -3px, 0);
  }

  .portfolio-product:hover::before {
    background-size: 100% 3px, 3px 100%, 100% 3px, 3px 100%;
    box-shadow:
      inset 0 0 0 2px rgba(87, 75, 200, 0.5),
      inset 0 0 0 999px rgba(87, 75, 200, 0.018);
    filter: drop-shadow(0 0 14px rgba(87, 75, 200, 0.22));
    opacity: 1;
  }

  .portfolio-product:hover::after {
    left: -22%;
    right: auto;
    width: 120px;
    opacity: 0.42;
    background: linear-gradient(90deg, transparent, rgba(87, 75, 200, 0.26), transparent);
    transform: translateX(0) rotate(10deg) scaleY(1.18);
    animation: portfolioTraceSweep 980ms var(--ease-architecture) both;
  }

  .portfolio-product:hover .portfolio-product-preview {
    filter: grayscale(0) contrast(1) brightness(1);
    transform:
      translate3d(
        calc(var(--parallax-mid-x, 0px) * 0.38),
        calc(var(--parallax-mid-y, 0px) * 0.3),
        0
      );
  }

  .portfolio-product:hover .portfolio-product-preview::before {
    opacity: 0.34;
  }

  .portfolio-product:hover .portfolio-product-preview::after {
    transform: scale(1.035);
  }

  .portfolio-product:hover .portfolio-product-preview iframe[src] {
    opacity: 1;
    transform: translate3d(0, calc(var(--preview-y) - 4px), 0) scale(var(--preview-hover-scale));
  }
}

@keyframes portfolioPanelIn {
  from {
    opacity: 0;
    transform: translate3d(46%, 0, 0) scale(0.99);
    filter: blur(12px);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
    filter: blur(0);
  }
}

@keyframes portfolioTraceSweep {
  from {
    transform: translateX(-40%) rotate(10deg) scaleY(1.18);
  }

  to {
    transform: translateX(920%) rotate(10deg) scaleY(1.18);
  }
}

@media (min-width: 1451px) {
  .business-live:has(.portfolio-products) {
    justify-items: end;
  }

  .live-operation-panel.portfolio-products {
    position: absolute;
    right: -420px;
    width: 1120px;
    animation: none;
  }
}

@media (min-width: 1376px) and (max-width: 1450px) {
  .business-live:has(.portfolio-products) {
    justify-items: end;
  }

  .live-operation-panel.portfolio-products {
    position: absolute;
    right: -360px;
    width: 980px;
    animation: none;
  }
}

@media (min-width: 1181px) and (max-width: 1375px) {
  .business-live:has(.portfolio-products) {
    justify-items: end;
  }

  .live-operation-panel.portfolio-products {
    position: absolute;
    right: -330px;
    width: 900px;
    animation: none;
  }
}

@media (max-width: 1180px) {
  .live-operation-panel.portfolio-products {
    --live-offset-x: 0px;
  }
}

@media (max-width: 760px) {
  .live-operation-panel.portfolio-products {
    --live-offset-x: -50%;
  }
}

.live-side {
  display: grid;
  gap: 16px;
}

.summary-card,
.activity-card {
  padding: 20px 17px;
}

.summary-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.summary-head span {
  padding: 5px 9px;
  border: 1px solid var(--live-border);
  border-radius: 999px;
  color: var(--live-text);
  font-size: 10px;
  font-weight: 800;
}

.summary-metrics {
  display: grid;
  gap: 0;
  margin-top: 18px;
}

.summary-metric {
  padding: 14px 0;
  border-top: 1px solid rgba(231, 225, 216, 0.9);
}

.summary-metric:first-child {
  border-top: 0;
  padding-top: 0;
}

.summary-metric span {
  color: var(--live-muted);
  font-size: 10.5px;
  font-weight: 650;
}

.summary-metric strong {
  display: block;
  min-height: 30px;
  margin-top: 6px;
  color: var(--live-text);
  font-size: 30px;
  font-weight: 850;
  letter-spacing: -0.045em;
  line-height: 1;
}

.summary-metric em {
  display: block;
  margin-top: 4px;
  color: var(--live-accent);
  font-size: 10px;
  font-style: normal;
  font-weight: 850;
}

.activity-feed-live {
  display: grid;
  gap: 0;
  margin-top: 16px;
}

.activity-feed-live div {
  position: relative;
  display: grid;
  grid-template-columns: 26px minmax(0, 1fr);
  gap: 11px;
  align-items: center;
  min-height: 48px;
  padding: 4px 0;
  border-top: 1px solid rgba(231, 225, 216, 0.9);
  animation: activityLiveCycle 6s ease-in-out infinite;
  animation-delay: var(--activity-delay, 0ms);
}

.activity-feed-live div:first-child {
  border-top: 0;
}

.activity-feed-live div:nth-child(2) { --activity-delay: 1000ms; }
.activity-feed-live div:nth-child(3) { --activity-delay: 2000ms; }

.activity-feed-live i {
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 8px;
  background: rgba(91, 79, 232, 0.07);
  animation: activityCheckSurface 6s ease-in-out infinite;
  animation-delay: var(--activity-delay, 0ms);
}

.activity-feed-live i::after {
  content: "";
  width: 7px;
  height: 11px;
  border-right: 2px solid var(--live-success);
  border-bottom: 2px solid var(--live-success);
  opacity: 0;
  transform: rotate(40deg) scale(0.68);
  animation: activityCheckAppear 6s ease-in-out infinite;
  animation-delay: var(--activity-delay, 0ms);
}

@media (hover: hover) and (pointer: fine) {
  .live-card:hover {
    border-color: rgba(91, 79, 232, 0.28);
    box-shadow: 0 18px 48px rgba(43, 34, 24, 0.09);
    transform: translateY(-4px);
  }

  .korve-preview-card:hover {
    border-color: rgba(91, 79, 232, 0.34);
    box-shadow: 0 24px 58px rgba(43, 34, 24, 0.12);
    transform: translateY(-6px) scale(1.025);
  }

  .korve-preview-card:hover::before {
    opacity: 0.86;
    transform: translate(-8px, 8px) scale(1.08);
  }
}

.systems-section,
.build-section {
  padding: 88px 0;
}

.section-intro {
  max-width: 1060px;
}

.section-intro h2,
.cases-heading h2,
.build-copy h2 {
  font-size: clamp(3.45rem, 6vw, 5.95rem);
}

.section-intro > p {
  max-width: 720px;
  margin: 28px 0 0;
  color: var(--muted);
  font-size: clamp(1.08rem, 1.35vw, 1.32rem);
  line-height: 1.58;
  text-wrap: pretty;
}

.marker-no {
  position: relative;
  display: inline-block;
  margin: 0 0.04em 0 0.06em;
  color: #d83b32;
  font-family: var(--mono);
  font-size: 0.58em;
  font-weight: 800;
  letter-spacing: -0.06em;
  line-height: 1;
  text-transform: uppercase;
  text-shadow:
    0.018em 0.018em 0 rgba(216, 59, 50, 0.22),
    -0.012em 0.016em 0 rgba(216, 59, 50, 0.16);
  transform: translateY(-0.16em) rotate(-11deg) skewX(-5deg);
  transform-origin: center;
}

.systems-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 36px;
  margin-top: 48px;
  border-top: 1px solid var(--line-strong);
}

.systems-list article {
  padding-top: 24px;
}

.systems-list span {
  color: var(--accent);
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.systems-list h3 {
  margin: 18px 0 12px;
  font-size: clamp(1.55rem, 2.2vw, 2.3rem);
  line-height: 1.05;
}

.systems-list p,
.case-narrative p,
.build-copy p {
  margin: 0;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.58;
  text-wrap: pretty;
}

.systems-list article p + p {
  margin-top: 12px;
}

.systems-list article p strong {
  color: var(--ink);
  font-size: 18px;
  font-weight: 700;
  line-height: 1.34;
}

.cases-section {
  padding: 76px 0 88px;
  background: rgba(251, 247, 239, 0.42);
  border-block: 1px solid rgba(23, 20, 18, 0.08);
}

.cases-heading {
  max-width: 1080px;
  margin-bottom: 44px;
}

.case-showcase {
  position: relative;
}

.case-primary {
  margin-bottom: 36px;
}

.case-layout {
  display: grid;
  grid-template-columns: minmax(360px, 0.72fr) minmax(620px, 1.28fr);
  gap: 52px;
  align-items: start;
}

.case-narrative h3 {
  margin-top: 0;
  font-size: clamp(3.05rem, 5.1vw, 5.25rem);
}

.case-narrative p {
  max-width: 540px;
  margin-top: 18px;
}

.case-outcomes {
  display: grid;
  gap: 14px;
  margin: 30px 0 0;
  padding: 0;
  list-style: none;
}

.case-outcomes li {
  padding-top: 14px;
  border-top: 1px solid var(--line);
  color: var(--ink);
  font-weight: 600;
}

.case-product {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  background:
    linear-gradient(90deg, rgba(87, 75, 200, 0.06) 1px, transparent 1px),
    linear-gradient(180deg, rgba(23, 20, 18, 0.045) 1px, transparent 1px),
    rgba(231, 222, 209, 0.62);
  background-size: 28px 28px;
  box-shadow: var(--shadow-soft);
}

.case-product-large {
  min-height: 500px;
}

.kanban {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.kanban div {
  min-height: 220px;
  padding: 14px;
  background: rgba(255, 255, 255, 0.66);
  border: 1px solid var(--line);
}

.kanban strong,
.kanban span,
.rule-stack b {
  display: block;
  background: rgba(23, 20, 18, 0.14);
}

.kanban strong {
  width: 64%;
  height: 18px;
  margin-bottom: 22px;
  background: var(--ink);
}

.kanban span {
  height: 38px;
  margin-top: 12px;
}

.timeline {
  display: grid;
  grid-template-columns: 1fr 0.4fr 1fr 0.4fr 1fr;
  gap: 10px;
  align-items: center;
  margin-top: 22px;
}

.timeline span {
  height: 54px;
  border: 1px solid var(--line);
  background: #fff;
}

.case-pair {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}

.case-compact {
  display: grid;
  grid-template-columns: minmax(280px, 0.92fr) minmax(260px, 0.78fr);
  gap: 24px;
  align-items: center;
}

.case-compact .case-product {
  min-height: 292px;
}

.case-compact .case-narrative h3 {
  font-size: clamp(2.4rem, 3.8vw, 4rem);
}

.automation-map {
  padding-top: 42px;
}

.rule-stack {
  display: grid;
  gap: 12px;
  padding: 0 28px 28px;
}

.rule-stack b {
  height: 18px;
}

.rule-stack b:nth-child(2) {
  width: 78%;
}

.rule-stack b:nth-child(3) {
  width: 54%;
}

.funnel-ui {
  display: grid;
  place-items: center;
  gap: 18px;
  min-height: 222px;
  padding: 32px;
}

.funnel-ui span {
  display: block;
  height: 54px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.74);
}

.funnel-ui span:nth-child(1) { width: 92%; }
.funnel-ui span:nth-child(2) { width: 72%; }
.funnel-ui span:nth-child(3) { width: 52%; background: rgba(87, 75, 200, 0.18); }

.funnel-ui i {
  width: 34%;
  height: 2px;
  background: var(--accent);
}

.legacy-cases-section {
  display: none;
}

.projects-section {
  position: relative;
  overflow: hidden;
  padding: clamp(72px, 8vw, 126px) 0 clamp(78px, 8vw, 132px);
  background:
    linear-gradient(90deg, rgba(23, 20, 18, 0.024) 1px, transparent 1px),
    linear-gradient(180deg, rgba(23, 20, 18, 0.022) 1px, transparent 1px),
    rgba(247, 244, 238, 0.74);
  background-size: 96px 96px;
  border-block: 1px solid rgba(23, 20, 18, 0.08);
}

.projects-section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.035;
  background-image: radial-gradient(rgba(17, 17, 17, 0.42) 0.5px, transparent 0.7px);
  background-size: 5px 5px;
  mix-blend-mode: multiply;
}

.project-showcase {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(360px, 0.8fr) minmax(0, 1.2fr);
  gap: clamp(34px, 5vw, 72px);
  align-items: center;
  min-height: min(760px, calc(100vh - var(--header-height) - 80px));
}

.project-showcase::before {
  content: "";
  position: absolute;
  right: -12%;
  top: 50%;
  width: min(52vw, 760px);
  height: min(52vw, 760px);
  border-radius: 999px;
  pointer-events: none;
  background: radial-gradient(circle, color-mix(in srgb, var(--project-accent) 18%, transparent), transparent 62%);
  opacity: 0.72;
  filter: blur(34px);
  transform: translateY(-50%);
  transition: background 700ms cubic-bezier(0.22, 1, 0.36, 1);
}

.project-copy {
  position: relative;
  z-index: 2;
  display: flex;
  min-height: 620px;
  flex-direction: column;
  justify-content: center;
  padding: 18px 0;
}

.project-text-stack {
  display: grid;
  align-content: start;
  min-height: 290px;
}

.project-category {
  margin: 0 0 18px;
  color: var(--project-accent);
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: color 700ms cubic-bezier(0.22, 1, 0.36, 1);
}

.project-copy h2 {
  margin: 0;
  font-family: var(--sans);
  min-height: 0.95em;
  font-size: clamp(4.05rem, 6.7vw, 6.65rem);
  font-weight: 800;
  letter-spacing: -0.07em;
  line-height: 0.92;
  white-space: nowrap;
}

.project-description {
  max-width: 520px;
  min-height: 94px;
  margin: 26px 0 0;
  color: #5f5850;
  font-size: clamp(1.06rem, 1.35vw, 1.28rem);
  line-height: 1.52;
  text-wrap: pretty;
}

.project-features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 20px;
  max-width: 560px;
  margin: 36px 0 0;
  padding: 0;
  list-style: none;
}

.project-features li {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #474039;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.25;
}

.project-features li::before {
  content: "";
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  border: 1px solid color-mix(in srgb, var(--project-accent) 64%, rgba(23, 20, 18, 0.12));
  border-radius: 999px;
  background:
    linear-gradient(135deg, transparent 47%, currentColor 48% 54%, transparent 55%) 5px 8px / 7px 5px no-repeat,
    color-mix(in srgb, var(--project-accent) 11%, #fff);
  color: var(--project-accent);
  box-shadow: inset 0 0 0 4px rgba(255, 255, 255, 0.62);
}

.project-controls {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 22px;
  width: min(100%, 560px);
  margin-top: 48px;
  padding-top: 26px;
  border-top: 1px solid var(--line-strong);
}

.project-counter {
  display: flex;
  align-items: baseline;
  gap: 8px;
  color: var(--ink);
  font-family: var(--mono);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.project-counter span:last-child {
  color: var(--quiet);
}

.project-dots {
  display: flex;
  align-items: center;
  gap: 9px;
}

.project-dots button {
  width: 8px;
  height: 8px;
  border: 0;
  border-radius: 999px;
  padding: 0;
  background: rgba(23, 20, 18, 0.18);
  cursor: pointer;
  transition:
    width 260ms var(--ease),
    background 260ms var(--ease),
    transform 260ms var(--ease);
}

.project-dots button.is-active {
  width: 28px;
  background: var(--project-accent);
}

.project-dots button:hover {
  transform: scale(1.2);
}

.project-arrows {
  display: flex;
  gap: 12px;
}

.project-arrows button {
  position: relative;
  display: grid;
  width: 48px;
  height: 48px;
  place-items: center;
  border: 1px solid rgba(23, 20, 18, 0.12);
  border-radius: 999px;
  color: var(--ink);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 12px 34px rgba(43, 34, 24, 0.08);
  cursor: pointer;
  transition:
    transform 240ms var(--ease),
    box-shadow 240ms var(--ease),
    background 240ms var(--ease),
    border-color 240ms var(--ease),
    color 240ms var(--ease);
}

.project-arrows button:hover {
  border-color: color-mix(in srgb, var(--project-accent) 54%, rgba(23, 20, 18, 0.12));
  color: #111;
  background: var(--project-accent);
  box-shadow: 0 16px 42px color-mix(in srgb, var(--project-accent) 20%, rgba(43, 34, 24, 0.1));
  transform: scale(1.05);
}

.project-arrows span {
  width: 13px;
  height: 13px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
}

.project-arrows [data-project-prev] span {
  transform: translateX(2px) rotate(-135deg);
}

.project-arrows [data-project-next] span {
  transform: translateX(-2px) rotate(45deg);
}

.project-media {
  position: relative;
  z-index: 1;
  display: grid;
  min-height: 620px;
  align-items: center;
  justify-items: end;
}

.project-image-shell {
  position: relative;
  display: grid;
  width: var(--project-image-width, min(104%, 960px));
  min-height: 580px;
  place-items: center;
  margin-left: auto;
  isolation: isolate;
  overflow: visible;
  transition: width 700ms cubic-bezier(0.22, 1, 0.36, 1);
}

.project-image-shell::before {
  content: "";
  position: absolute;
  inset: 4% -12% -4%;
  z-index: -1;
  border-radius: 999px;
  background:
    radial-gradient(circle at 50% 48%, color-mix(in srgb, var(--project-accent) 16%, transparent), transparent 62%);
  opacity: 0.7;
  filter: blur(34px);
  transition: background 700ms cubic-bezier(0.22, 1, 0.36, 1);
}

.project-image-shell img,
.project-image-ghost {
  width: 100%;
  max-height: var(--project-image-max-height, 670px);
  object-fit: contain;
  object-position: center;
  filter: drop-shadow(0 34px 58px rgba(43, 34, 24, 0.16));
  transform: translateX(0);
  transition:
    opacity 360ms cubic-bezier(0.22, 1, 0.36, 1),
    filter 700ms cubic-bezier(0.22, 1, 0.36, 1),
    transform 700ms cubic-bezier(0.22, 1, 0.36, 1);
}

.project-image-ghost {
  position: absolute;
  inset: 0;
  z-index: 2;
  margin: auto;
  pointer-events: none;
  animation: projectImageOutRight 860ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

.project-image-fallback {
  position: absolute;
  inset: 10%;
  display: none;
  place-items: center;
  align-content: center;
  gap: 10px;
  border: 1px dashed color-mix(in srgb, var(--project-accent) 46%, rgba(23, 20, 18, 0.2));
  border-radius: 32px;
  color: var(--muted);
  background: rgba(252, 251, 248, 0.74);
  text-align: center;
}

.project-image-fallback strong {
  color: var(--ink);
  font-size: 18px;
}

.project-image-fallback span {
  font-family: var(--mono);
  font-size: 12px;
}

.project-image-shell.is-missing img {
  display: none;
}

.project-image-shell.is-missing .project-image-fallback {
  display: grid;
}

[data-project-carousel].is-exiting [data-project-category],
[data-project-carousel].is-exiting [data-project-title],
[data-project-carousel].is-exiting [data-project-description],
[data-project-carousel].is-exiting [data-project-features] {
  opacity: 0;
  filter: blur(8px);
  transform: translateY(20px);
}

[data-project-carousel].is-exiting [data-project-image] {
  opacity: 0;
  filter: blur(10px) drop-shadow(0 20px 40px rgba(43, 34, 24, 0.08));
  transform: translateX(76px) scale(0.985);
}

[data-project-category],
[data-project-title],
[data-project-description],
[data-project-features] {
  transition:
    opacity 320ms cubic-bezier(0.22, 1, 0.36, 1),
    filter 320ms cubic-bezier(0.22, 1, 0.36, 1),
    transform 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

[data-project-carousel].is-entering [data-project-title] {
  animation: projectTextIn 500ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

[data-project-carousel].is-entering [data-project-description] {
  animation: projectTextIn 500ms cubic-bezier(0.22, 1, 0.36, 1) 100ms both;
}

[data-project-carousel].is-entering [data-project-features] {
  animation: projectTextIn 500ms cubic-bezier(0.22, 1, 0.36, 1) 200ms both;
}

[data-project-carousel].is-entering [data-project-category] {
  animation: projectTextIn 500ms cubic-bezier(0.22, 1, 0.36, 1) 40ms both;
}

[data-project-carousel].is-entering [data-project-image] {
  animation: projectImageIn 700ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

@keyframes projectTextIn {
  from {
    opacity: 0;
    filter: blur(8px);
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    filter: blur(0);
    transform: translateY(0);
  }
}

@keyframes projectImageIn {
  from {
    opacity: 0;
    filter: blur(12px) drop-shadow(0 20px 40px rgba(43, 34, 24, 0.08));
    transform: translateX(92px) scale(0.985);
  }
  to {
    opacity: 1;
    filter: blur(0) drop-shadow(0 34px 58px rgba(43, 34, 24, 0.16));
    transform: translateX(0) scale(1);
  }
}

@keyframes projectImageOutRight {
  0% {
    opacity: 1;
    filter: blur(0) drop-shadow(0 34px 58px rgba(43, 34, 24, 0.16));
    transform: translateX(0) scale(1);
  }
  42% {
    opacity: 0.94;
    filter: blur(2px) drop-shadow(0 28px 52px rgba(43, 34, 24, 0.12));
  }
  100% {
    opacity: 0;
    filter: blur(14px) drop-shadow(0 14px 28px rgba(43, 34, 24, 0.04));
    transform: translateX(118px) scale(0.974);
  }
}

.operations-section {
  position: relative;
  padding: 96px 0 108px;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(23, 20, 18, 0.024) 1px, transparent 1px),
    linear-gradient(180deg, rgba(23, 20, 18, 0.022) 1px, transparent 1px),
    rgba(247, 244, 238, 0.72);
  background-size: 96px 96px;
  border-block: 1px solid rgba(23, 20, 18, 0.08);
}

.operations-section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.03;
  background-image: radial-gradient(rgba(17, 17, 17, 0.46) 0.5px, transparent 0.7px);
  background-size: 5px 5px;
  mix-blend-mode: multiply;
}

.operations-layout {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(320px, 0.82fr) minmax(640px, 1.18fr);
  gap: clamp(54px, 7vw, 104px);
  align-items: center;
}

.operations-copy h2 {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(4.7rem, 7.1vw, 7.7rem);
  font-weight: 400;
  letter-spacing: -0.045em;
  line-height: 0.78;
}

.operations-copy p {
  max-width: 540px;
  margin: 34px 0 0;
  color: #4d453e;
  font-size: clamp(1.05rem, 1.35vw, 1.24rem);
  line-height: 1.55;
  text-wrap: pretty;
}

.operation-mode-list {
  display: grid;
  gap: 13px;
  margin-top: 42px;
  padding: 0;
  list-style: none;
}

.operation-mode-list li {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  width: fit-content;
  color: var(--muted);
  font-size: 14px;
  font-weight: 700;
  opacity: 0.54;
  transition: color 700ms var(--ease-architecture), opacity 700ms var(--ease-architecture);
  animation: operationModeActive 32s var(--ease-architecture) infinite;
}

.operation-mode-list li:nth-child(1) { animation-delay: 0s; }
.operation-mode-list li:nth-child(2) { animation-delay: 8s; }
.operation-mode-list li:nth-child(3) { animation-delay: 16s; }
.operation-mode-list li:nth-child(4) { animation-delay: 24s; }

.operation-mode-list i {
  width: 9px;
  height: 9px;
  border: 1px solid rgba(23, 20, 18, 0.22);
  border-radius: 50%;
  background: transparent;
  box-shadow: 0 0 0 0 rgba(91, 79, 232, 0);
  animation: operationModeDot 32s ease-in-out infinite;
}

.operation-mode-list li:nth-child(1) i { animation-delay: 0s; }
.operation-mode-list li:nth-child(2) i { animation-delay: 8s; }
.operation-mode-list li:nth-child(3) i { animation-delay: 16s; }
.operation-mode-list li:nth-child(4) i { animation-delay: 24s; }

.operations-visual {
  position: relative;
  min-height: 650px;
  padding: 42px;
  border: 1px solid rgba(230, 225, 216, 0.9);
  border-radius: 30px;
  background:
    radial-gradient(circle at 18% 12%, rgba(91, 79, 232, 0.055), transparent 24%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.82), transparent 54%),
    #f7f4ee;
  box-shadow: 0 32px 90px rgba(43, 34, 24, 0.1);
  isolation: isolate;
}

.operations-visual::before {
  content: "";
  position: absolute;
  inset: 26px;
  z-index: 0;
  border-radius: 22px;
  background:
    linear-gradient(90deg, rgba(23, 20, 18, 0.024) 1px, transparent 1px),
    linear-gradient(180deg, rgba(23, 20, 18, 0.02) 1px, transparent 1px);
  background-size: 46px 46px;
  mask-image: linear-gradient(90deg, transparent, #000 18%, #000 82%, transparent);
}

.operations-scenario {
  position: absolute;
  inset: 42px;
  z-index: 1;
  display: grid;
  grid-template-rows: 1fr auto;
  gap: 24px;
  color: var(--ink);
  opacity: 0;
  transform: translateY(18px) scale(0.985);
  pointer-events: none;
  animation: operationScenario 32s var(--ease-architecture) infinite;
  animation-delay: var(--scenario-delay);
}

.operation-flow-map {
  position: relative;
  display: grid;
  align-content: center;
  gap: 8px;
  max-width: 660px;
  margin-left: auto;
}

.operation-flow-map::before {
  content: "";
  position: absolute;
  left: 28px;
  top: 42px;
  bottom: 42px;
  width: 2px;
  border-radius: 999px;
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--scenario-color) 54%, transparent), transparent);
}

.flow-runner {
  position: absolute;
  left: 22px;
  top: 42px;
  z-index: 3;
  width: 14px;
  height: 14px;
  border: 2px solid #fcfbf8;
  border-radius: 50%;
  background: var(--scenario-color);
  box-shadow: 0 0 0 7px color-mix(in srgb, var(--scenario-color) 16%, transparent), 0 0 22px color-mix(in srgb, var(--scenario-color) 36%, transparent);
  animation: operationRunner 4s ease-in-out infinite;
}

.operation-node {
  --node-step: 0;
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr) auto;
  gap: 15px;
  align-items: center;
  min-height: 66px;
  padding: 11px 16px 11px 12px;
  border: 1px solid rgba(230, 225, 216, 0.92);
  border-radius: 18px;
  background: rgba(252, 251, 248, 0.9);
  box-shadow: 0 14px 40px rgba(43, 34, 24, 0.055);
  backdrop-filter: blur(12px);
  animation:
    operationNodeFloat 6s ease-in-out infinite,
    operationNodeActive 4s ease-in-out infinite;
  animation-delay: calc(var(--node-step) * 180ms), calc(var(--node-step) * 520ms);
}

.operation-node:nth-of-type(1) { --node-step: 0; }
.operation-node:nth-of-type(2) { --node-step: 1; }
.operation-node:nth-of-type(3) { --node-step: 2; }
.operation-node:nth-of-type(4) { --node-step: 3; }
.operation-node:nth-of-type(5) { --node-step: 4; }
.operation-node:nth-of-type(6) { --node-step: 5; }

.operation-node i {
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  border-radius: 14px;
  color: var(--scenario-color);
  background: color-mix(in srgb, var(--scenario-color) 9%, #fcfbf8);
  font-family: var(--mono);
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.operation-node strong {
  display: block;
  color: var(--ink);
  font-size: 16px;
  font-weight: 850;
  letter-spacing: -0.02em;
  line-height: 1.05;
}

.operation-node p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 560;
  line-height: 1.28;
}

.operation-node em {
  display: inline-grid;
  place-items: center;
  min-width: 64px;
  min-height: 24px;
  padding: 0 10px;
  border-radius: 999px;
  color: var(--scenario-color);
  background: color-mix(in srgb, var(--scenario-color) 9%, transparent);
  font-size: 10px;
  font-style: normal;
  font-weight: 850;
}

.operation-node::after {
  content: "";
  position: absolute;
  right: 16px;
  bottom: 11px;
  width: 7px;
  height: 11px;
  border-right: 2px solid var(--scenario-color);
  border-bottom: 2px solid var(--scenario-color);
  opacity: 0;
  transform: rotate(40deg) scale(0.74);
  animation: operationCheck 4s ease-in-out infinite;
  animation-delay: calc(var(--node-step) * 520ms);
}

.operation-live-events {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 14px;
  max-width: 660px;
  margin-left: auto;
}

.operation-live-events span {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  padding: 10px 12px;
  border: 1px solid rgba(230, 225, 216, 0.9);
  border-radius: 14px;
  color: var(--ink);
  background: rgba(252, 251, 248, 0.76);
  font-size: 12px;
  font-weight: 750;
  opacity: 0.72;
  animation: operationEvent 4.6s ease-in-out infinite;
}

.operation-live-events span:nth-child(2) { animation-delay: 420ms; }
.operation-live-events span:nth-child(3) { animation-delay: 840ms; }
.operation-live-events span:nth-child(4) { animation-delay: 1260ms; }

.operation-live-events span::before {
  content: "";
  width: 6px;
  height: 10px;
  border-right: 2px solid var(--scenario-color);
  border-bottom: 2px solid var(--scenario-color);
  transform: rotate(40deg);
}

.build-section {
  display: grid;
  grid-template-columns: minmax(360px, 0.82fr) minmax(560px, 1fr);
  gap: 86px;
  align-items: center;
}

.build-copy p {
  max-width: 610px;
  margin-top: 20px;
}

.build-visual {
  position: relative;
  display: grid;
  gap: 22px;
  padding-left: 34px;
}

.build-visual::before {
  content: "";
  position: absolute;
  left: 73px;
  top: 46px;
  bottom: 46px;
  width: 2px;
  background: linear-gradient(180deg, transparent, rgba(87, 75, 200, 0.78), transparent);
  transform: scaleY(0);
  transform-origin: top;
}

.build-section.reveal.is-visible .build-visual::before {
  animation: stageLineDrop 760ms var(--ease-architecture) 180ms forwards;
}

.build-stage {
  position: relative;
  min-height: 92px;
  display: grid;
  grid-template-columns: 46px minmax(150px, 0.72fr) minmax(190px, 1fr);
  gap: 28px;
  align-items: center;
  padding: 22px 28px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.44);
  box-shadow: 0 18px 60px rgba(23, 20, 18, 0.06);
}

.build-stage span {
  color: var(--accent);
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
}

.build-stage strong {
  font-family: var(--serif);
  font-size: clamp(1.75rem, 2.2vw, 2.45rem);
  font-weight: 400;
  line-height: 0.95;
}

.build-stage p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.42;
  text-align: right;
}

.build-stage.is-dark {
  color: #fff;
  background: var(--ink);
  border-color: var(--ink);
  box-shadow: 0 26px 80px rgba(23, 20, 18, 0.22);
}

.build-stage.is-dark span {
  color: #bbb5ff;
}

.build-stage.is-dark p {
  color: rgba(255, 255, 255, 0.62);
}

body.modal-open {
  overflow: hidden;
}

body.modal-open .mobile-sticky-cta {
  opacity: 0;
  pointer-events: none;
  transform: translateY(14px);
}

.evaluation-modal[hidden] {
  display: none;
}

.evaluation-modal {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: grid;
  place-items: center;
  padding: 24px;
  opacity: 0;
  transition: opacity 180ms var(--ease);
}

.evaluation-modal.is-open {
  opacity: 1;
}

.evaluation-backdrop {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(23, 20, 18, 0.05) 1px, transparent 1px),
    linear-gradient(180deg, rgba(23, 20, 18, 0.045) 1px, transparent 1px),
    rgba(244, 239, 231, 0.82);
  background-size: 96px 96px;
  backdrop-filter: blur(12px);
}

.evaluation-panel {
  position: relative;
  width: min(100%, 1120px);
  display: grid;
  grid-template-columns: minmax(330px, 0.9fr) minmax(460px, 1.08fr);
  gap: 64px;
  align-items: start;
  padding: 42px;
  border: 1px solid rgba(23, 20, 18, 0.14);
  border-radius: 30px;
  background:
    linear-gradient(90deg, rgba(87, 75, 200, 0.05) 1px, transparent 1px),
    linear-gradient(180deg, rgba(23, 20, 18, 0.04) 1px, transparent 1px),
    rgba(251, 247, 239, 0.96);
  background-size: 32px 32px;
  box-shadow: 0 36px 120px rgba(23, 20, 18, 0.22);
  transform: translateY(18px) scale(0.98);
  transition: transform 240ms var(--ease-architecture);
}

.evaluation-modal.is-open .evaluation-panel {
  transform: translateY(0) scale(1);
}

.modal-close {
  position: absolute;
  top: 18px;
  right: 18px;
  z-index: 2;
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.62);
  cursor: pointer;
  transition: transform 180ms var(--ease), border-color 180ms var(--ease), background 180ms var(--ease);
}

.modal-close:hover,
.modal-close:focus-visible {
  transform: rotate(90deg) scale(1.03);
  border-color: rgba(87, 75, 200, 0.34);
  background: #fff;
}

.modal-close span,
.modal-close span::after {
  width: 16px;
  height: 2px;
  display: block;
  border-radius: 999px;
  background: var(--ink);
}

.modal-close span {
  transform: rotate(45deg);
}

.modal-close span::after {
  content: "";
  transform: rotate(90deg);
}

.modal-logo {
  width: 158px;
  height: 40px;
  object-fit: cover;
  object-position: center;
  margin-bottom: 34px;
}

.modal-copy h2 {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(3.45rem, 5.1vw, 5.4rem);
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 0.92;
}

.modal-copy > p {
  max-width: 420px;
  margin: 22px 0 0;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.56;
}

.modal-points {
  display: grid;
  gap: 17px;
  margin: 34px 0 0;
  padding: 0;
  color: #39332e;
  list-style: none;
  font-size: 16px;
}

.modal-points li {
  position: relative;
  padding-left: 30px;
}

.modal-points li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: -1px;
  color: var(--accent);
  font-weight: 800;
}

.evaluation-form {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.evaluation-form label {
  display: grid;
  gap: 9px;
  color: #514941;
  font-size: 13px;
  font-weight: 600;
}

.evaluation-form .full {
  grid-column: 1 / -1;
}

.evaluation-form input,
.evaluation-form textarea {
  width: 100%;
  min-height: 48px;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px 16px;
  color: var(--ink);
  background: rgba(255, 255, 255, 0.42);
  outline: none;
  transition: border-color 180ms var(--ease), box-shadow 180ms var(--ease), background 180ms var(--ease);
}

.evaluation-form input::placeholder,
.evaluation-form textarea::placeholder {
  color: #948a7f;
}

.evaluation-form textarea {
  min-height: 104px;
}

.evaluation-form textarea {
  resize: vertical;
}

.evaluation-form input:focus,
.evaluation-form textarea:focus {
  border-color: var(--accent);
  background: rgba(255, 255, 255, 0.68);
  box-shadow: 0 0 0 3px rgba(87, 75, 200, 0.12);
}

.evaluation-form button {
  width: 100%;
}

.evaluation-form button:disabled {
  cursor: wait;
  opacity: 0.7;
  transform: none;
}

.form-status {
  min-height: 22px;
  margin: 0;
  color: var(--green);
  font-size: 13px;
  font-weight: 600;
}

.site-footer {
  border-top: 1px solid var(--line);
  background: rgba(251, 247, 239, 0.58);
}

.footer-inner {
  min-height: 118px;
  display: grid;
  grid-template-columns: 190px 1fr auto;
  gap: 28px;
  align-items: center;
  color: var(--muted);
  font-size: 14px;
}

.footer-inner img {
  width: 190px;
}

.footer-inner a {
  color: var(--accent);
  font-weight: 700;
}

.reveal {
  transform: none;
}

.js-ready .reveal .stagger-item {
  opacity: 0;
  transform: translate3d(0, 24px, 0) scale(0.985);
  filter: blur(2px);
  transition:
    opacity 520ms var(--ease),
    filter 620ms var(--ease),
    transform 740ms var(--ease-architecture);
  transition-delay: calc(var(--stagger-index, 0) * 64ms);
  will-change: opacity, transform, filter;
}

.js-ready .reveal.is-visible .stagger-item {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
  filter: blur(0);
}

.js-ready .reveal.is-restaggering .stagger-item {
  opacity: 0;
  transform: translate3d(0, 18px, 0) scale(0.992);
  filter: blur(1.5px);
  transition: none;
}

.case-product,
.build-stage {
  transition: transform 220ms var(--ease), box-shadow 220ms var(--ease), border-color 220ms var(--ease);
}

.case-product::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background: linear-gradient(110deg, transparent 0 34%, rgba(87, 75, 200, 0.12) 48%, transparent 62% 100%);
  opacity: 0;
  transform: translateX(-115%);
}

.case-showcase:hover .case-product,
.build-stage:hover {
  transform: translateY(-3px);
  border-color: rgba(87, 75, 200, 0.28);
  box-shadow: var(--shadow-soft);
}

.system-canvas,
.system-lines path,
.system-lines circle {
  transition: border-color 220ms var(--ease), stroke 220ms var(--ease), stroke-width 220ms var(--ease), opacity 220ms var(--ease);
}

.product-system:hover .system-canvas {
  border-color: rgba(87, 75, 200, 0.3);
}

.product-system:hover .system-lines path {
  stroke-width: 2.65;
}

.product-system:hover .system-lines circle {
  opacity: 1;
}

.reveal.is-visible .case-product::before {
  animation: blueprintSweep 920ms var(--ease-architecture) 160ms both;
}

.reveal.is-visible .kanban div,
.reveal.is-visible .timeline span,
.reveal.is-visible .automation-map span,
.reveal.is-visible .rule-stack b,
.reveal.is-visible .funnel-ui span {
  animation: moduleSettle 640ms var(--ease-architecture) both;
}

.reveal.is-visible .kanban div:nth-child(2),
.reveal.is-visible .timeline span:nth-of-type(2),
.reveal.is-visible .automation-map span:nth-of-type(2),
.reveal.is-visible .rule-stack b:nth-child(2),
.reveal.is-visible .funnel-ui span:nth-child(2) {
  animation-delay: 90ms;
}

.reveal.is-visible .kanban div:nth-child(3),
.reveal.is-visible .timeline span:nth-of-type(3),
.reveal.is-visible .automation-map span:nth-of-type(3),
.reveal.is-visible .rule-stack b:nth-child(3),
.reveal.is-visible .funnel-ui span:nth-child(3) {
  animation-delay: 180ms;
}

.build-section.reveal.is-visible .build-stage {
  animation: stageLock 680ms var(--ease-architecture) both;
}

.build-section.reveal.is-visible .build-stage:nth-of-type(2) {
  animation-delay: 80ms;
}

.build-section.reveal.is-visible .build-stage:nth-of-type(3) {
  animation-delay: 160ms;
}

.build-section.reveal.is-visible .build-stage:nth-of-type(4) {
  animation-delay: 240ms;
}

.case-showcase:hover .timeline i,
.case-showcase:hover .automation-map i {
  animation: linePulse 620ms var(--ease-architecture) forwards;
}

@keyframes businessBoot {
  0% {
    opacity: 0;
    transform: translateX(var(--business-offset-x)) translateY(18px) scale(calc(var(--business-scale) * 0.985));
  }

  100% {
    opacity: 1;
    transform: translateX(var(--business-offset-x)) translate3d(var(--parallax-mid-x), var(--parallax-mid-y), 0) scale(var(--business-scale));
  }
}

@keyframes businessStatus {
  0%,
  100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(22, 163, 74, 0.14);
  }

  50% {
    transform: scale(1.16);
    box-shadow: 0 0 0 7px rgba(22, 163, 74, 0);
  }
}

@keyframes entryArrive {
  0%,
  68%,
  100% {
    opacity: 1;
    transform: translateY(0);
  }

  74% {
    opacity: 0;
    transform: translateY(-9px);
  }

  82% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes businessProgress {
  0%,
  18% {
    transform: scaleX(0.18);
  }

  62%,
  84% {
    transform: scaleX(1);
  }

  100% {
    transform: scaleX(0.18);
  }
}

@keyframes businessCheck {
  0%,
  18% {
    opacity: 0;
    transform: rotate(40deg) scale(0.72);
  }

  30%,
  86% {
    opacity: 1;
    transform: rotate(40deg) scale(1);
  }

  100% {
    opacity: 0;
    transform: rotate(40deg) scale(0.72);
  }
}

@keyframes activeStep {
  0%,
  100% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.08);
  }
}

@keyframes taskCheck {
  0%,
  26%,
  100% {
    opacity: 0;
    transform: rotate(40deg) scale(0.72);
  }

  42%,
  82% {
    opacity: 1;
    transform: rotate(40deg) scale(1);
  }
}

@keyframes kpiRefresh {
  0%,
  40%,
  100% {
    transform: translateY(0);
  }

  52% {
    transform: translateY(-2px);
  }
}

@keyframes activityRefresh {
  0%,
  64%,
  100% {
    opacity: 1;
    transform: translateY(0);
  }

  74% {
    opacity: 0;
    transform: translateY(7px);
  }

  84% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes sparkDraw {
  0%,
  22% {
    stroke-dashoffset: 104;
    opacity: 0.48;
  }

  52%,
  86% {
    stroke-dashoffset: 0;
    opacity: 1;
  }

  100% {
    stroke-dashoffset: 104;
    opacity: 0.48;
  }
}

@keyframes workArrives {
  0%,
  68%,
  100% {
    transform: translateY(0);
  }

  76% {
    transform: translateY(-7px);
  }

  86% {
    transform: translateY(0);
  }
}

@keyframes intakePulse {
  0%,
  30%,
  100% {
    opacity: 0.28;
    transform: translateY(-50%) scaleX(0.58);
  }

  48%,
  72% {
    opacity: 1;
    transform: translateY(-50%) scaleX(1);
  }
}

@keyframes flowPrimary {
  0%,
  16% {
    transform: scaleX(0.08);
  }

  64%,
  86% {
    transform: scaleX(0.78);
  }

  100% {
    transform: scaleX(0.08);
  }
}

@keyframes currentNode {
  0%,
  100% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.055);
  }
}

@keyframes bigCheck {
  0%,
  18% {
    opacity: 0;
    transform: rotate(40deg) scale(0.72);
  }

  32%,
  86% {
    opacity: 1;
    transform: rotate(40deg) scale(1);
  }

  100% {
    opacity: 0;
    transform: rotate(40deg) scale(0.72);
  }
}

@keyframes ecosystemEnter {
  0% {
    opacity: 0;
    transform: translateY(18px) scale(0.985);
  }

  100% {
    opacity: 1;
    transform: translate3d(var(--parallax-mid-x), var(--parallax-mid-y), 0) scale(var(--eco-scale));
  }
}

@keyframes moduleFloat {
  0%,
  100% {
    transform: translate3d(var(--module-x, 0), var(--module-y, 0), 0);
  }

  50% {
    transform: translate3d(var(--module-x, 0), calc(var(--module-y, 0px) - 6px), 0);
  }
}

@keyframes dataRoute {
  0% {
    stroke-dashoffset: 44;
  }

  100% {
    stroke-dashoffset: 0;
  }
}

@keyframes dotPulse {
  0%,
  100% {
    transform: scale(1);
    opacity: 0.82;
  }

  50% {
    transform: scale(1.28);
    opacity: 1;
  }
}

@keyframes lineFill {
  0%,
  100% {
    transform: scaleX(0.48);
    opacity: 0.6;
  }

  50% {
    transform: scaleX(1);
    opacity: 1;
  }
}

@keyframes coreRunner {
  0%,
  12%,
  100% {
    left: 10%;
    opacity: 0;
  }

  24%,
  74% {
    opacity: 1;
  }

  86% {
    left: calc(90% - 8px);
    opacity: 0;
  }
}

@keyframes stepBlink {
  0%,
  36%,
  100% {
    border-color: rgba(87, 75, 200, 0.18);
    background: rgba(255, 255, 255, 0.78);
  }

  52%,
  72% {
    border-color: rgba(87, 75, 200, 0.48);
    background: rgba(87, 75, 200, 0.1);
  }
}

@keyframes resultRise {
  0%,
  100% {
    transform: scaleY(0.76);
  }

  50% {
    transform: scaleY(1);
  }
}

@keyframes appNotify {
  0%,
  100% {
    box-shadow: inset 0 0 0 1px rgba(87, 75, 200, 0.08);
  }

  52%,
  72% {
    box-shadow: inset 0 0 0 1px rgba(87, 75, 200, 0.32), 0 0 0 7px rgba(87, 75, 200, 0.06);
  }
}

@keyframes livePanelIn {
  0% {
    opacity: 0;
    transform: translateX(var(--live-offset-x)) translateY(18px) translate3d(var(--parallax-mid-x), var(--parallax-mid-y), 0) scale(calc(var(--live-scale) * 0.985));
  }

  100% {
    opacity: 1;
    transform: translateX(var(--live-offset-x)) translate3d(var(--parallax-mid-x), var(--parallax-mid-y), 0) scale(var(--live-scale));
  }
}

@keyframes systemBreathing {
  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: 0.6;
  }
}

@keyframes valueCycle {
  0%,
  27% {
    opacity: 1;
    transform: translateY(0);
  }

  33%,
  100% {
    opacity: 0;
    transform: translateY(-4px);
  }
}

@keyframes connectorTravel {
  0% {
    stroke-dashoffset: 180;
    opacity: 0;
  }

  18%,
  70% {
    opacity: 1;
  }

  100% {
    stroke-dashoffset: 0;
    opacity: 0;
  }
}

@keyframes entryFeedCycle {
  0%,
  62%,
  100% {
    opacity: 1;
    transform: translateY(0);
  }

  74% {
    opacity: 0;
    transform: translateY(10px);
  }

  86% {
    opacity: 1;
    transform: translateY(-8px);
  }
}

@keyframes flowLight {
  0% {
    left: 8%;
    opacity: 0;
  }

  12%,
  82% {
    opacity: 1;
  }

  100% {
    left: calc(92% - 10px);
    opacity: 0;
  }
}

@keyframes sequentialCheck {
  0%,
  18%,
  100% {
    opacity: 0.78;
    transform: scale(0.94);
  }

  32%,
  78% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes finalStepComplete {
  0%,
  58%,
  100% {
    border-color: var(--live-accent);
    background: var(--live-card);
    transform: scale(0.96);
  }

  70%,
  86% {
    border-color: var(--live-accent);
    background: var(--live-accent);
    transform: scale(1);
  }
}

@keyframes finalDotFade {
  0%,
  58%,
  100% {
    opacity: 1;
    transform: scale(1);
  }

  70%,
  86% {
    opacity: 0;
    transform: scale(0.55);
  }
}

@keyframes finalCheckAppear {
  0%,
  58%,
  100% {
    opacity: 0;
    transform: rotate(40deg) scale(0.72);
  }

  70%,
  86% {
    opacity: 1;
    transform: rotate(40deg) scale(1);
  }
}

@keyframes activityLiveCycle {
  0%,
  60%,
  100% {
    opacity: 1;
    transform: translateY(0);
  }

  72% {
    opacity: 0;
    transform: translateY(6px);
  }

  84% {
    opacity: 1;
    transform: translateY(-4px);
  }
}

@keyframes activityCheckSurface {
  0%,
  56%,
  100% {
    background: rgba(22, 163, 74, 0.09);
  }

  72% {
    background: rgba(91, 79, 232, 0.07);
  }
}

@keyframes activityCheckAppear {
  0%,
  58%,
  100% {
    opacity: 1;
    transform: rotate(40deg) scale(1);
  }

  72% {
    opacity: 0;
    transform: rotate(40deg) scale(0.68);
  }

  84% {
    opacity: 1;
    transform: rotate(40deg) scale(1.05);
  }
}

@keyframes reveal-up {
  0% {
    opacity: 0;
    transform: translateY(22px) scale(0.985);
  }

  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes operationWake {
  0% {
    opacity: 0;
    transform: translateX(-50%) translateY(18px) scale(calc(var(--system-scale) * 0.985));
  }

  100% {
    opacity: 1;
    transform: translateX(-50%) translate3d(var(--parallax-mid-x), var(--parallax-mid-y), 0) scale(var(--system-scale));
  }
}

@keyframes requestArrive {
  0%,
  100% {
    border-color: rgba(87, 75, 200, 0.18);
    transform: translateY(0);
  }

  14% {
    border-color: rgba(87, 75, 200, 0.42);
    transform: translateY(-3px);
  }

  24% {
    border-color: rgba(87, 75, 200, 0.2);
    transform: translateY(0);
  }
}

@keyframes requestPulse {
  0%,
  100% {
    transform: scale(1);
    box-shadow: 0 0 0 5px rgba(87, 75, 200, 0.08);
  }

  50% {
    transform: scale(1.12);
    box-shadow: 0 0 0 8px rgba(87, 75, 200, 0);
  }
}

@keyframes flowRunner {
  0%,
  10%,
  100% {
    left: 9%;
    opacity: 0;
    transform: scale(0.8);
  }

  16% {
    opacity: 1;
    transform: scale(1);
  }

  78% {
    left: calc(91% - 8px);
    opacity: 1;
    transform: scale(1);
  }

  88% {
    left: calc(91% - 8px);
    opacity: 0;
    transform: scale(0.8);
  }
}

@keyframes stepState {
  0%,
  28%,
  100% {
    border-color: rgba(87, 75, 200, 0.28);
    background: rgba(251, 247, 239, 0.96);
  }

  38%,
  82% {
    border-color: rgba(87, 75, 200, 0.68);
    background: var(--accent);
  }
}

@keyframes checkAppear {
  0%,
  32%,
  100% {
    opacity: 0;
    transform: rotate(40deg) scale(0.7);
  }

  42%,
  82% {
    opacity: 1;
    transform: rotate(40deg) scale(1);
  }
}

@keyframes progressFill {
  0%,
  30%,
  100% {
    opacity: 0.72;
    transform: scaleX(0.28);
  }

  58%,
  84% {
    opacity: 1;
    transform: scaleX(1);
  }
}

@keyframes kpiLift {
  0%,
  38%,
  100% {
    transform: translateY(0);
  }

  50%,
  72% {
    transform: translateY(-2px);
  }
}

@keyframes kpiBar {
  0%,
  34%,
  100% {
    transform: scaleX(0.58);
  }

  56%,
  82% {
    transform: scaleX(1);
  }
}

@keyframes feedItem {
  0%,
  34%,
  100% {
    opacity: 0.56;
    transform: translateY(0);
  }

  48%,
  76% {
    opacity: 1;
    transform: translateY(-2px);
  }
}

@keyframes toastIn {
  0%,
  8%,
  100% {
    opacity: 0;
    transform: translateY(10px) scale(0.98);
  }

  14%,
  32% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }

  40% {
    opacity: 0;
    transform: translateY(-6px) scale(0.99);
  }
}

@keyframes nodeReveal {
  0% {
    opacity: 0;
    filter: blur(2px);
  }

  100% {
    opacity: 1;
    filter: blur(0);
  }
}

@keyframes connection-draw {
  to {
    stroke-dashoffset: 0;
  }
}

@keyframes float-slow {
  0%,
  100% {
    transform: translateY(-4px);
  }

  50% {
    transform: translateY(4px);
  }
}

@keyframes ai-panel-breathe {
  0%,
  100% {
    border-color: rgba(87, 75, 200, 0.26);
    box-shadow: 0 26px 78px rgba(43, 34, 24, 0.16), 0 0 34px rgba(87, 75, 200, 0.1);
  }

  50% {
    border-color: rgba(87, 75, 200, 0.42);
    box-shadow: 0 30px 88px rgba(43, 34, 24, 0.17), 0 0 58px rgba(87, 75, 200, 0.18);
  }
}

@keyframes ai-core-pulse {
  0%,
  100% {
    transform: scale(1);
    box-shadow: 0 0 34px rgba(87, 75, 200, 0.26);
  }

  50% {
    transform: scale(1.02);
    box-shadow: 0 0 48px rgba(87, 75, 200, 0.34);
  }
}

@keyframes ai-glow-breathe {
  0%,
  100% {
    opacity: 0.44;
    transform: scale(0.94);
  }

  50% {
    opacity: 0.78;
    transform: scale(1.06);
  }
}

@keyframes ai-orbit {
  to {
    transform: rotate(360deg);
  }
}

@keyframes pulse-line {
  0% {
    stroke-dashoffset: 1;
  }

  100% {
    stroke-dashoffset: 0;
  }
}

@keyframes workflow-event {
  0%,
  68%,
  100% {
    opacity: 0;
    transform: translateY(6px) scale(0.7);
  }

  72%,
  82% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes workflow-step {
  0%,
  58%,
  100% {
    border-color: rgba(87, 75, 200, 0.18);
    background: rgba(255, 255, 255, 0.62);
    transform: translateY(0) scale(1);
  }

  62%,
  70% {
    border-color: rgba(87, 75, 200, 0.42);
    background: rgba(87, 75, 200, 0.08);
    transform: translateY(-2px) scale(1.025);
  }
}

@keyframes workflow-link {
  0%,
  58%,
  100% {
    opacity: 0.68;
    transform: scaleX(1);
  }

  62%,
  72% {
    opacity: 1;
    transform: scaleX(1.18);
  }
}

@keyframes online-dot {
  0%,
  100% {
    transform: scale(1);
    box-shadow: 0 0 0 5px rgba(53, 163, 112, 0.11);
  }

  50% {
    transform: scale(1.12);
    box-shadow: 0 0 0 8px rgba(53, 163, 112, 0);
  }
}

@keyframes crm-task {
  0%,
  65%,
  100% {
    opacity: 0;
    transform: translateY(4px) scale(0.72);
    box-shadow: 0 0 0 0 rgba(87, 75, 200, 0.22);
  }

  70%,
  82% {
    opacity: 1;
    transform: translateY(0) scale(1);
    box-shadow: 0 0 0 7px rgba(87, 75, 200, 0);
  }
}

@keyframes contact-update {
  0%,
  72%,
  100% {
    transform: scale(1);
  }

  78%,
  86% {
    transform: scale(1.08);
  }
}

@keyframes crm-line-update {
  0%,
  72%,
  100% {
    opacity: 0.72;
    transform: scaleX(1);
  }

  78%,
  86% {
    opacity: 1;
    transform: scaleX(1.08);
  }
}

@keyframes erp-process {
  0%,
  62%,
  100% {
    transform: scaleX(0.88);
    background: rgba(255, 255, 255, 0.58);
  }

  72%,
  86% {
    transform: scaleX(1);
    background: rgba(87, 75, 200, 0.12);
  }
}

@keyframes db-sync {
  0%,
  64%,
  100% {
    transform: translateY(0);
    box-shadow: inset 0 -8px 0 rgba(87, 75, 200, 0.08);
  }

  72%,
  84% {
    transform: translateY(-2px);
    box-shadow: inset 0 -11px 0 rgba(87, 75, 200, 0.15), 0 6px 16px rgba(87, 75, 200, 0.08);
  }
}

@keyframes phone-notification {
  0%,
  68%,
  100% {
    opacity: 0;
    transform: translateY(5px) scale(0.72);
    box-shadow: 0 0 0 0 rgba(87, 75, 200, 0.24);
  }

  72%,
  84% {
    opacity: 1;
    transform: translateY(0) scale(1);
    box-shadow: 0 0 0 7px rgba(87, 75, 200, 0);
  }
}

@keyframes phone-sync {
  0%,
  62%,
  100% {
    opacity: 0.74;
    transform: scaleX(1);
  }

  72%,
  86% {
    opacity: 1;
    transform: scaleX(1.08);
  }
}

@keyframes analytics-curve {
  0%,
  100% {
    stroke-dashoffset: 0;
    transform: translateY(0);
  }

  48% {
    stroke-dashoffset: -0.08;
    transform: translateY(-1px);
  }
}

@keyframes signal-runner {
  0%,
  100% {
    cx: 4px;
    cy: 42px;
    opacity: 0;
  }

  12% {
    opacity: 1;
  }

  38% {
    cx: 55px;
    cy: 22px;
    opacity: 1;
  }

  68% {
    cx: 96px;
    cy: 14px;
    opacity: 1;
  }

  88% {
    cx: 126px;
    cy: 20px;
    opacity: 1;
  }
}

@keyframes glow-breathe {
  0%,
  100% {
    opacity: 0.42;
    filter: drop-shadow(0 0 0 rgba(87, 75, 200, 0));
  }

  50% {
    opacity: 1;
    filter: drop-shadow(0 0 10px rgba(87, 75, 200, 0.22));
  }
}

@keyframes topButtonLaunch {
  0% {
    transform: translateY(0) scale(1);
  }

  35% {
    transform: translateY(-7px) scale(1.06);
  }

  100% {
    transform: translateY(0) scale(1);
  }
}

@keyframes returnPulse {
  0% {
    opacity: 0;
    transform: scale(0.78);
  }

  42% {
    opacity: 1;
    transform: scale(1.18);
  }

  100% {
    opacity: 0;
    transform: scale(1.42);
  }
}

@keyframes arrowLift {
  0%,
  100% {
    transform: translateX(-50%) scaleY(1);
  }

  45% {
    transform: translateX(-50%) scaleY(1.28);
  }
}

@keyframes blueprintSweep {
  0% {
    opacity: 0;
    transform: translateX(-115%);
  }

  18%,
  72% {
    opacity: 1;
  }

  100% {
    opacity: 0;
    transform: translateX(115%);
  }
}

@keyframes moduleSettle {
  0% {
    opacity: 0.42;
    transform: translateY(14px) scale(0.985);
  }

  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes stageLock {
  0% {
    transform: translateY(16px);
    border-color: rgba(87, 75, 200, 0.08);
  }

  70% {
    transform: translateY(-2px);
    border-color: rgba(87, 75, 200, 0.34);
  }

  100% {
    transform: translateY(0);
  }
}

@keyframes stageLineDrop {
  0% {
    opacity: 0;
    transform: scaleY(0);
  }

  24% {
    opacity: 1;
  }

  100% {
    opacity: 1;
    transform: scaleY(1);
  }
}

@keyframes assemble {
  to {
    opacity: 1;
    transform: translate(0, 0);
  }
}

@keyframes blueprintDrift {
  0% {
    background-position: 0 0, 0 0, 0 0;
  }

  100% {
    background-position: 34px 34px, -34px 34px, 0 0;
  }
}

@keyframes pathDraw {
  to {
    stroke-dashoffset: 0;
  }
}

@keyframes circuitPulse {
  0%,
  100% {
    opacity: 0.38;
    stroke-width: 1.6;
  }

  45% {
    opacity: 0.84;
    stroke-width: 2.5;
  }
}

@keyframes nodePlot {
  0% {
    opacity: 0;
    transform: scale(0.62);
  }

  70% {
    opacity: 1;
    transform: scale(1.18);
  }

  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes lineDraw {
  to {
    transform: scaleX(1);
  }
}

@keyframes linePulse {
  0% {
    transform: scaleX(0.45);
  }

  100% {
    transform: scaleX(1);
  }
}

@keyframes barRise {
  to {
    transform: scaleY(1);
  }
}

@keyframes operationScenario {
  0%,
  21% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }

  25%,
  100% {
    opacity: 0;
    transform: translateY(-12px) scale(0.99);
  }
}

@keyframes operationModeActive {
  0%,
  21% {
    color: var(--mode-color);
    opacity: 1;
  }

  25%,
  100% {
    color: var(--muted);
    opacity: 0.54;
  }
}

@keyframes operationModeDot {
  0%,
  21% {
    border-color: var(--mode-color);
    background: var(--mode-color);
    box-shadow: 0 0 0 7px color-mix(in srgb, var(--mode-color) 12%, transparent);
    opacity: 1;
  }

  25%,
  100% {
    border-color: rgba(23, 20, 18, 0.22);
    background: transparent;
    box-shadow: 0 0 0 0 rgba(91, 79, 200, 0);
    opacity: 0.76;
  }
}

@keyframes operationRunner {
  0%,
  10% {
    top: 42px;
    opacity: 0;
    transform: scale(0.72);
  }

  16% {
    top: 42px;
    opacity: 1;
    transform: scale(1);
  }

  82% {
    top: calc(100% - 56px);
    opacity: 1;
    transform: scale(1);
  }

  100% {
    top: calc(100% - 56px);
    opacity: 0;
    transform: scale(0.72);
  }
}

@keyframes operationNodeFloat {
  0%,
  100% {
    transform: translateY(-2px);
  }

  50% {
    transform: translateY(2px);
  }
}

@keyframes operationNodeActive {
  0%,
  54%,
  100% {
    border-color: rgba(230, 225, 216, 0.92);
    box-shadow: 0 14px 40px rgba(43, 34, 24, 0.055);
  }

  62%,
  78% {
    border-color: color-mix(in srgb, var(--scenario-color) 38%, #e6e1d8);
    box-shadow: 0 18px 48px rgba(43, 34, 24, 0.075), 0 0 0 4px color-mix(in srgb, var(--scenario-color) 7%, transparent);
  }
}

@keyframes operationCheck {
  0%,
  56%,
  100% {
    opacity: 0;
    transform: rotate(40deg) scale(0.74);
  }

  66%,
  84% {
    opacity: 1;
    transform: rotate(40deg) scale(1);
  }
}

@keyframes operationEvent {
  0%,
  46%,
  100% {
    opacity: 0.62;
    transform: translateY(0);
  }

  56%,
  78% {
    opacity: 1;
    transform: translateY(-3px);
  }
}

@media (min-width: 1181px) and (max-width: 1375px) {
  .business-live {
    --live-scale: 0.9;
  }

  .live-operation-panel {
    --live-offset-x: clamp(-128px, -9vw, -112px);
  }
}

@media (min-width: 1376px) and (max-width: 1450px) {
  .business-live {
    --live-scale: 0.94;
  }

  .live-operation-panel {
    --live-offset-x: clamp(-104px, -6.8vw, -86px);
  }
}

@media (max-width: 1180px) {
  .hero,
  .case-layout,
  .build-section {
    grid-template-columns: 1fr;
  }

  .operations-layout {
    grid-template-columns: 1fr;
    gap: 44px;
  }

  .project-showcase {
    grid-template-columns: 1fr;
    gap: 34px;
    min-height: auto;
  }

  .project-copy {
    min-height: auto;
    padding: 0;
  }

  .project-media {
    min-height: auto;
  }

  .project-image-shell {
    width: min(100%, 920px);
    min-height: min(58vw, 560px);
    margin-inline: auto;
  }

  .operations-copy h2 {
    font-size: clamp(4.6rem, 13vw, 7.6rem);
  }

  .operations-copy p {
    max-width: 720px;
  }

  .operations-visual {
    min-height: 640px;
  }

  .operations-scenario,
  .operation-flow-map,
  .operation-live-events {
    max-width: none;
    margin-left: 0;
  }

  .product-system {
    min-height: auto;
  }

  .ops-ecosystem {
    --system-scale: 0.92;
    min-height: 470px;
  }

  .operation-live {
    --system-scale: 0.92;
    min-height: 470px;
  }

  .business-live {
    min-height: 520px;
  }

  .live-operation-panel {
    --live-offset-x: 0px;
    width: min(830px, 100%);
  }

  .business-board {
    width: min(900px, 100%);
  }

  .case-pair {
    grid-template-columns: 1fr;
  }

  .case-compact {
    grid-template-columns: 1fr 0.8fr;
  }
}

@media (min-width: 761px) and (max-height: 760px) {
  .hero {
    padding: 16px 0 44px;
    gap: 38px;
  }

  .hero h1 {
    font-size: clamp(3.8rem, 5.2vw, 5.65rem);
  }

  .hero-lede {
    margin-top: 16px;
    font-size: 1.02rem;
    line-height: 1.38;
  }

  .hero-actions {
    margin-top: 18px;
  }

  .product-system {
    min-height: 424px;
  }

  .system-canvas {
    min-height: 390px;
  }

  .main-app {
    top: 38px;
    min-height: 258px;
  }

  .automation-app {
    top: 76px;
  }

  .insight-app {
    top: 236px;
  }
}

@media (max-width: 760px) {
  :root {
    --header-height: 58px;
  }

  html {
    scroll-padding-top: calc(var(--header-height) + 8px);
  }

  body {
    padding-bottom: calc(74px + env(safe-area-inset-bottom, 0px));
    background-size: 64px 64px;
  }

  .page-shell {
    width: min(calc(100% - 28px), var(--max));
  }

  .header-inner {
    min-height: 58px;
  }

  .brand,
  .brand img {
    width: 152px;
    height: 38px;
  }

  .nav-links {
    display: none;
  }

  .header-cta {
    min-height: 38px;
    padding: 0 13px;
    font-size: 12px;
  }

  .mobile-sticky-cta {
    position: fixed;
    z-index: 40;
    left: 14px;
    right: 14px;
    bottom: calc(12px + env(safe-area-inset-bottom, 0px));
    display: inline-flex;
    min-height: 52px;
    opacity: 0;
    pointer-events: none;
    transform: translateY(14px);
  }

  .to-top {
    right: 14px;
    bottom: calc(78px + env(safe-area-inset-bottom, 0px));
    width: 46px;
    height: 46px;
  }

  body.mobile-cta-visible:not(.at-evaluation) .mobile-sticky-cta {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }

  .hero {
    min-height: auto;
    gap: 32px;
    padding: 22px 0 54px;
  }

  .hero-copy {
    display: contents;
  }

  .hero h1 {
    order: 1;
    font-size: clamp(3.15rem, 14vw, 4.65rem);
  }

  .hero-lede {
    order: 2;
    margin-top: 22px;
    font-size: 1rem;
  }

  .hero-actions {
    order: 3;
    display: grid;
    gap: 10px;
    margin-top: 26px;
  }

  .hero-proof {
    order: 5;
    grid-template-columns: 1fr;
    gap: 14px;
    margin-top: 12px;
    padding-top: 18px;
  }

  .hero-proof div {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 18px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--line);
  }

  .hero-proof dt {
    font-size: 2.35rem;
  }

  .hero-proof dd {
    max-width: 170px;
    text-align: right;
  }

  .button {
    width: 100%;
  }

  .projects-section {
    padding: 58px 0 68px;
    background-size: 64px 64px;
  }

  .project-showcase {
    gap: 18px;
  }

  .project-showcase::before {
    right: -40%;
    width: 104vw;
    height: 104vw;
    opacity: 0.62;
  }

  .project-category {
    order: 1;
    margin-bottom: 12px;
    font-size: 10px;
  }

  .project-copy,
  .project-text-stack {
    display: contents;
  }

  .project-copy h2 {
    order: 2;
    font-size: clamp(2.9rem, 12.8vw, 3.95rem);
    letter-spacing: -0.075em;
    white-space: nowrap;
  }

  .project-text-stack {
    min-height: 0;
  }

  .project-description {
    order: 4;
    min-height: 0;
    margin-top: 4px;
    font-size: 1rem;
  }

  .project-features {
    order: 6;
    grid-template-columns: 1fr;
    gap: 11px;
    margin-top: 12px;
  }

  .project-controls {
    order: 5;
    grid-template-columns: 1fr auto;
    gap: 16px;
    margin-top: 8px;
    padding-right: 68px;
    padding-top: 20px;
  }

  .project-dots {
    grid-column: 1;
  }

  .project-arrows {
    grid-row: 1 / span 2;
    grid-column: 2;
  }

  .project-arrows button {
    width: 46px;
    height: 46px;
  }

  .project-image-shell {
    width: 100%;
    min-height: 330px;
  }

  .project-media {
    order: 3;
    justify-items: center;
    margin: 4px 0 8px;
  }

  .project-image-shell::before {
    inset: 4% -6% 0;
    border-radius: 999px;
  }

  .project-image-shell img,
  .project-image-ghost {
    max-height: min(var(--project-image-max-height, 360px), 350px);
  }

  .operations-section {
    padding: 58px 0 68px;
    background-size: 64px 64px;
  }

  .operations-layout {
    gap: 30px;
  }

  .operations-copy h2 {
    font-size: clamp(4.2rem, 17vw, 5.9rem);
    letter-spacing: -0.045em;
  }

  .operations-copy p {
    margin-top: 22px;
    font-size: 1rem;
  }

  .operation-mode-list {
    grid-template-columns: 1fr 1fr;
    gap: 10px 14px;
    margin-top: 28px;
  }

  .operation-mode-list li {
    font-size: 12px;
  }

  .operations-visual {
    min-height: 408px;
    padding: 16px;
    border-radius: 22px;
  }

  .operations-visual::before {
    inset: 14px;
    background-size: 34px 34px;
  }

  .operations-scenario {
    inset: 18px;
    gap: 16px;
  }

  .operation-flow-map {
    gap: 14px;
  }

  .operations-scenario .operation-node {
    display: none;
  }

  .operations-scenario .operation-node:first-of-type,
  .operations-scenario .operation-node:nth-of-type(3),
  .operations-scenario .operation-node:last-of-type {
    display: grid;
  }

  .operation-node {
    grid-template-columns: 44px minmax(0, 1fr);
    gap: 12px;
    min-height: 82px;
    padding: 13px 14px;
    border-radius: 16px;
  }

  .operation-node i {
    width: 38px;
    height: 38px;
    border-radius: 12px;
    font-size: 9px;
  }

  .operation-node strong {
    font-size: 15px;
  }

  .operation-node p {
    font-size: 12px;
  }

  .operation-node em {
    grid-column: 2;
    justify-self: start;
    min-width: auto;
    min-height: 22px;
    margin-top: 4px;
    font-size: 9px;
  }

  .operation-node::after {
    right: 14px;
    bottom: 14px;
  }

  .operation-flow-map::before {
    left: 21px;
    top: 42px;
    bottom: 42px;
  }

  .flow-runner {
    left: 15px;
  }

  .operation-live-events {
    display: none;
  }

  .product-system {
    order: 4;
    min-height: 320px;
  }

  .ops-ecosystem {
    --system-scale: 0.58;
    min-height: 316px;
  }

  .operation-live {
    --system-scale: 0.58;
    min-height: 316px;
  }

  .business-live {
    --business-scale: 0.48;
    --eco-scale: 0.48;
    --live-scale: 0.435;
    min-height: 318px;
    overflow: hidden;
    place-items: start center;
  }

  .live-operation-panel {
    --live-offset-x: -50%;
    position: absolute;
    left: 50%;
    top: 8px;
    width: 880px;
    padding: 18px;
    border-radius: 22px;
    transform-origin: top center;
  }

  .live-panel-top {
    margin-bottom: 16px;
  }

  .live-panel-grid {
    grid-template-columns: 236px 350px 216px;
    gap: 12px;
  }

  .entries-card,
  .summary-card,
  .activity-card,
  .korve-preview-card {
    padding: 14px 12px;
  }

  .operation-card {
    padding: 18px 16px 14px;
  }

  .korve-preview-card {
    min-height: 318px;
  }

  .korve-preview-browser {
    min-height: 214px;
  }

  .korve-preview-browser iframe {
    left: 0;
    top: -24px;
    transform: scale(0.37);
  }

  .entry-row {
    grid-template-columns: 44px minmax(154px, 1fr);
    min-height: 64px;
  }

  .live-flow {
    margin: 28px 0 20px;
  }

  .task-item {
    min-height: 44px;
  }

  .business-live:has(.portfolio-products) {
    --live-scale: 1;
    min-height: 430px;
    overflow: visible;
    place-items: center;
  }

  .live-operation-panel.portfolio-products {
    --live-offset-x: 0px;
    position: relative;
    left: auto;
    top: auto;
    width: min(100%, 430px);
    height: 408px;
    padding: 0;
    border-radius: 0;
    transform: none;
  }

  .portfolio-products::before {
    inset: -16px;
    opacity: 0.28;
  }

  .portfolio-product {
    clip-path: none;
    min-height: 136px;
  }

  .portfolio-product::after {
    width: 14px;
    opacity: 0.18;
  }

  .portfolio-product-korve,
  .portfolio-product-scribblit,
  .portfolio-product-irondistrict {
    --preview-scale: 0.168 !important;
    --preview-hover-scale: 0.168 !important;
  }

  .portfolio-product-korve::after,
  .portfolio-product-irondistrict::after {
    right: 2px;
  }

  .portfolio-product-scribblit::after {
    left: 2px;
  }

  .portfolio-product-copy {
    position: relative;
    right: auto;
    top: auto;
    transform: none;
    align-items: flex-start;
    width: 38%;
    height: 100%;
    padding: 12px 8px 12px 10px;
    text-align: left;
    text-shadow: 0 1px 12px rgba(244, 239, 231, 0.9);
  }

  .portfolio-product-scribblit .portfolio-product-copy {
    padding-left: 18px;
  }

  .portfolio-product-copy span {
    margin-bottom: 4px;
    font-size: 7px;
  }

  .portfolio-product-copy h3 {
    font-size: clamp(1.35rem, 7.6vw, 2rem);
    letter-spacing: -0.082em;
  }

  .portfolio-product-irondistrict .portfolio-product-copy h3 {
    font-size: clamp(1.06rem, 6.2vw, 1.62rem);
  }

  .portfolio-product-copy p {
    max-width: 116px;
    margin-top: 7px;
    font-size: 7.1px;
    line-height: 1.22;
  }

  .portfolio-product-irondistrict .portfolio-product-copy span,
  .portfolio-product-irondistrict .portfolio-product-copy h3,
  .portfolio-product-irondistrict .portfolio-product-copy p {
    color: var(--live-text);
    text-shadow: 0 1px 12px rgba(244, 239, 231, 0.9);
  }

  .portfolio-product-preview,
  .portfolio-product-scribblit .portfolio-product-preview,
  .portfolio-product-irondistrict .portfolio-product-preview {
    inset: 0 0 0 41%;
    border-left: 1px solid rgba(17, 17, 17, 0.04);
    border-right: 0;
  }

  .portfolio-product-preview iframe,
  .portfolio-product-scribblit .portfolio-product-preview iframe,
  .portfolio-product-irondistrict .portfolio-product-preview iframe {
    left: -16px;
  }

  .brand-ecosystem {
    width: 760px;
    height: 500px;
    transform-origin: top center;
  }

  .business-board {
    --business-offset-x: -50%;
    position: absolute;
    left: 50%;
    top: 8px;
    width: 780px;
    max-width: none;
    padding: 0;
    transform: translateX(var(--business-offset-x)) translate3d(var(--parallax-mid-x), var(--parallax-mid-y), 0) scale(var(--business-scale));
    transform-origin: top center;
  }

  .operation-surface {
    padding: 20px;
  }

  .operation-topline {
    margin-bottom: 22px;
  }

  .operation-story {
    grid-template-columns: 150px 360px 132px;
    gap: 20px;
  }

  .order-heading {
    margin-bottom: 28px;
  }

  .order-heading strong {
    font-size: 28px;
  }

  .operation-flow-large {
    gap: 14px;
  }

  .flow-node span {
    width: 50px;
    height: 50px;
  }

  .ops-field {
    top: 10px;
  }

  .operation-board {
    top: 8px;
  }

  .operation-toast {
    display: none;
  }

  .node-note {
    display: none;
  }

  .system-canvas {
    min-height: 432px;
  }

  .system-canvas::after {
    inset: 14px;
  }

  .main-app {
    left: 18px;
    top: 38px;
    width: calc(100% - 36px);
    min-height: 250px;
  }

  .app-layout,
  .product-grid {
    grid-template-columns: 58px 1fr;
    min-height: 208px;
  }

  .app-sidebar,
  .side-nav {
    gap: 10px;
    padding: 14px;
  }

  .app-content,
  .workspace {
    padding: 16px;
  }

  .app-title,
  .workspace-head {
    height: 20px;
    margin-bottom: 18px;
  }

  .metric-row {
    gap: 8px;
    margin-bottom: 16px;
  }

  .metric-row span {
    min-height: 52px;
  }

  .data-table {
    grid-template-columns: repeat(3, 1fr);
    gap: 7px;
  }

  .data-table i {
    height: 23px;
  }

  .automation-app {
    left: 32px;
    right: auto;
    top: 304px;
    width: calc(100% - 64px);
    min-height: 96px;
  }

  .insight-app,
  .system-lines {
    display: none;
  }

  .automation-flow {
    padding: 16px;
  }

  .automation-flow span {
    min-height: 42px;
    font-size: 8px;
  }

  .systems-section,
  .cases-section,
  .build-section {
    padding: 52px 0;
  }

  .build-section {
    padding-bottom: calc(96px + env(safe-area-inset-bottom, 0px));
  }

  .section-intro h2,
  .cases-heading h2,
  .build-copy h2 {
    font-size: clamp(2.9rem, 12vw, 3.85rem);
  }

  .systems-section .section-intro h2 {
    font-size: clamp(2.55rem, 10.7vw, 3.35rem);
  }

  .section-intro > p {
    margin-top: 18px;
    font-size: 1rem;
  }

  .marker-no {
    font-size: 0.56em;
    transform: translateY(-0.12em) rotate(-10deg) skewX(-5deg);
  }

  .systems-list {
    grid-template-columns: 1fr;
    gap: 0;
    margin-top: 30px;
  }

  .systems-list article {
    padding: 22px 0;
    border-bottom: 1px solid var(--line);
  }

  .cases-heading {
    margin-bottom: 30px;
  }

  .case-layout,
  .case-compact {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .case-primary {
    margin-bottom: 34px;
  }

  .case-narrative h3 {
    font-size: clamp(2.9rem, 12vw, 4.1rem);
  }

  .case-narrative p {
    margin-top: 18px;
    font-size: 15px;
  }

  .case-outcomes {
    gap: 12px;
    margin-top: 28px;
  }

  .case-outcomes li {
    padding-top: 12px;
  }

  .case-product-large {
    min-height: 360px;
  }

  .product-chrome,
  .window-bar {
    min-height: 34px;
    font-size: 9px;
  }

  .kanban {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .kanban div {
    min-height: 76px;
  }

  .kanban span:nth-of-type(n + 2) {
    display: none;
  }

  .timeline {
    grid-template-columns: 1fr 0.35fr 1fr;
  }

  .timeline span:nth-of-type(3),
  .timeline i:nth-of-type(2) {
    display: none;
  }

  .case-pair {
    gap: 42px;
  }

  .case-compact .case-product {
    min-height: 250px;
  }

  .build-visual {
    gap: 12px;
    padding-left: 0;
  }

  .build-visual::before {
    left: 23px;
    top: 32px;
    bottom: 32px;
  }

  .build-stage {
    min-height: auto;
    grid-template-columns: 34px 1fr;
    gap: 12px;
    padding: 16px 18px;
    border-radius: 16px;
  }

  .build-stage p {
    grid-column: 2;
    text-align: left;
    font-size: 14px;
  }

  .build-stage strong {
    font-size: 2rem;
  }

  .evaluation-modal {
    padding: 12px;
    align-items: end;
  }

  .evaluation-panel {
    max-height: calc(100dvh - 24px);
    overflow: auto;
    grid-template-columns: 1fr;
    gap: 22px;
    padding: 22px;
  }

  .modal-close {
    top: 12px;
    right: 12px;
  }

  .modal-logo {
    width: 148px;
    height: 38px;
    margin-bottom: 18px;
  }

  .modal-copy h2 {
    font-size: clamp(3rem, 15vw, 4.4rem);
  }

  .modal-copy > p {
    margin-top: 16px;
    font-size: 15px;
  }

  .modal-points {
    gap: 12px;
    margin-top: 22px;
    font-size: 14px;
  }

  .evaluation-form {
    grid-template-columns: 1fr;
    padding: 0;
  }

  .evaluation-form .full {
    grid-column: auto;
  }

  .evaluation-form input,
  .evaluation-form textarea {
    min-height: 48px;
    font-size: 16px;
  }

  .footer-inner {
    grid-template-columns: 1fr;
    padding: 28px 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  html,
  html:focus-within {
    scroll-behavior: auto !important;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
  }

  .app-window,
  .hero-copy h1,
  .hero-lede,
  .hero-actions,
  .hero-proof,
  .product-system,
  .ops-links,
  .ops-node,
  .node-float,
  .reveal,
  .stagger-item,
  .system-lines circle,
  .result-graph span {
    filter: none !important;
    opacity: 1 !important;
    transform: none !important;
  }

  .system-lines path {
    stroke-dashoffset: 0 !important;
  }

  .route-pulse {
    opacity: 0.38 !important;
    stroke-dashoffset: 0 !important;
  }

  .automation-flow i,
  .automation-map i,
  .timeline i {
    transform: none !important;
  }
}
