/* ============ RESET ============ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  font-family: var(--f-body);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--warm);
  background: var(--void);
  overflow-x: hidden;
  cursor: none;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "ss01", "ss02";
}
@media (max-width: 900px) { body { cursor: auto; } }
img, svg, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; background: none; border: none; color: inherit; cursor: none; }
ul { list-style: none; }

/* ============ ATMOSPHERE LAYERS ============ */
.grain {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 100;
  opacity: var(--grain-opacity);
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
.vignette {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 90;
  background: radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,0.55) 100%);
}

/* ============ CUSTOM CURSOR ============ */
.cursor {
  position: fixed;
  top: 0; left: 0;
  width: 28px; height: 28px;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  mix-blend-mode: difference;
  transition: width var(--dur-fast) var(--ease-out),
              height var(--dur-fast) var(--ease-out);
}
.cursor::before, .cursor::after {
  content: "";
  position: absolute;
  background: var(--warm);
}
.cursor::before { left: 50%; top: 0; width: 1px; height: 100%; transform: translateX(-50%); }
.cursor::after { top: 50%; left: 0; height: 1px; width: 100%; transform: translateY(-50%); }
.cursor .ring {
  position: absolute;
  inset: 8px;
  border: 1px solid var(--warm);
  border-radius: 50%;
  transition: inset var(--dur-fast) var(--ease-out), border-color var(--dur-fast);
}
.cursor.is-hot .ring { inset: 2px; border-color: var(--heat); box-shadow: 0 0 16px var(--heat); }
.cursor.is-cold .ring { inset: 2px; border-color: var(--signal); box-shadow: 0 0 16px var(--signal); }

/* ============ NAV ============ */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 80;
  padding: 24px var(--gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  backdrop-filter: blur(14px) saturate(140%);
  background: rgba(10, 10, 10, 0.5);
  border-bottom: 1px solid var(--warm-08);
}
.nav__logo {
  font-family: var(--f-display);
  font-weight: 800;
  font-size: 18px;
  letter-spacing: var(--tr-tight);
  display: flex;
  align-items: center;
  gap: 12px;
}
.nav__logo-word { line-height: 1; }
@media (max-width: 700px) { .nav__logo-word { display: none; } }
.nav__logo .mark--img {
  width: 44px;
  height: 44px;
  object-fit: contain;
  filter: drop-shadow(0 0 12px rgba(61, 220, 151, 0.25));
  transition: filter var(--dur-med), transform var(--dur-med) var(--ease-out);
}
.nav__logo:hover .mark--img {
  transform: rotate(8deg) scale(1.06);
  filter: drop-shadow(0 0 18px rgba(34, 211, 238, 0.45));
}
.nav__menu {
  display: flex;
  gap: 36px;
  font-family: var(--f-mono);
  font-size: var(--fs-mono-sm);
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
}
.nav__menu a {
  position: relative;
  color: var(--warm-65);
  transition: color var(--dur-fast);
}
.nav__menu a:hover { color: var(--warm); }
.nav__menu a::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -8px;
  height: 1px;
  background: var(--heat);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-med) var(--ease-out);
}
.nav__menu a:hover::after { transform: scaleX(1); }
.nav__cta {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-sm);
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
  padding: 12px 20px;
  border: 1px solid var(--warm-20);
  border-radius: 999px;
  position: relative;
  overflow: hidden;
  transition: border-color var(--dur-med), color var(--dur-med);
}
.nav__cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--heat) 0%, var(--signal) 100%);
  transform: translateY(101%);
  transition: transform var(--dur-med) var(--ease-out);
  z-index: -1;
}
.nav__cta:hover { border-color: var(--signal); color: var(--void); }
.nav__cta:hover::before { transform: translateY(0); }
@media (max-width: 900px) { .nav__menu { display: none; } }

/* ============ HERO ============ */
.hero {
  position: relative;
  min-height: 100vh;
  padding: 110px var(--gutter) 110px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 0;
  overflow: hidden;
  isolation: isolate;
}
.hero__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
}
.hero__bg::before {
  content: "";
  position: absolute;
  inset: -10%;
  background:
    radial-gradient(ellipse 60% 40% at 30% 30%, rgba(61, 220, 151, 0.18), transparent 70%),
    radial-gradient(ellipse 60% 40% at 75% 70%, rgba(34, 211, 238, 0.14), transparent 70%);
  filter: blur(40px);
  animation: drift 18s ease-in-out infinite alternate;
}
@keyframes drift {
  0%   { transform: translate(0, 0) scale(1); }
  100% { transform: translate(4%, -2%) scale(1.05); }
}
.hero__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(0deg, var(--warm-04) 1px, transparent 1px),
    linear-gradient(90deg, var(--warm-04) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
  opacity: 0.6;
}
#particles {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}
.hero__meta {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
  color: var(--warm-40);
  display: flex;
  gap: 18px;
  align-items: center;
  margin-bottom: 24px;
}
.hero__meta .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--heat);
  box-shadow: 0 0 12px var(--heat);
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.5; transform: scale(1.4); }
}
/* ======= BRAND STAGE ======= */
.brand-stage {
  position: relative;
  margin: 8px auto 24px;
  width: 100%;
  max-width: 420px;
  aspect-ratio: 1 / 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  isolation: isolate;
  will-change: transform, opacity;
  flex-shrink: 0;
  overflow: visible;
}
@media (max-width: 700px) { .brand-stage { max-width: 300px; } }
/* Outer halo behind video — extends beyond the stage edges so video seems to glow into the void */
.brand-stage::before {
  content: "";
  position: absolute;
  inset: -8% -4%;
  border-radius: 24px;
  background:
    radial-gradient(ellipse at 50% 50%, rgba(61, 220, 151, 0.22) 0%, rgba(34, 211, 238, 0.14) 40%, transparent 70%);
  filter: blur(60px);
  z-index: -2;
  opacity: 0;
  animation: glowIn 2.2s var(--ease-out) 0.2s forwards;
}
.brand-glow {
  position: absolute;
  inset: -2%;
  border-radius: 18px;
  background:
    conic-gradient(from 0deg,
      rgba(61, 220, 151, 0) 0deg,
      rgba(61, 220, 151, 0.18) 90deg,
      rgba(34, 211, 238, 0.20) 180deg,
      rgba(61, 220, 151, 0.14) 270deg,
      rgba(61, 220, 151, 0) 360deg);
  filter: blur(40px);
  z-index: -1;
  opacity: 0;
  animation: glowIn 2.4s var(--ease-out) 0.4s forwards, slowSpin 50s linear infinite;
  transform-origin: center;
}
@keyframes glowIn { to { opacity: 1; } }
@keyframes slowSpin { to { transform: rotate(360deg); } }

.brand-logo {
  position: relative;
  z-index: 2;
  width: 100%;
  height: auto;
  display: block;
  transform-origin: center center;
  opacity: 0;
  transform: scale(0.85) rotateZ(-8deg);
  filter: blur(24px) brightness(0.55);
  animation:
    logoLand 1.8s var(--ease-out) 0.6s forwards,
    logoIdleDrift 14s ease-in-out 2.6s infinite;
  will-change: transform, opacity, filter;
}
@keyframes logoLand {
  0%   { opacity: 0; transform: scale(0.85) rotateZ(-8deg); filter: blur(24px) brightness(0.55); }
  60%  { opacity: 0.95; filter: blur(6px) brightness(0.9); }
  100% { opacity: 1; transform: scale(1.55) rotateZ(0); filter: blur(0) brightness(1); }
}
@keyframes logoIdleDrift {
  0%, 100% { transform: scale(1.55) rotateZ(0) translateY(0); }
  50%      { transform: scale(1.575) rotateZ(0.6deg) translateY(-4px); }
}
.brand-tagline {
  position: absolute;
  bottom: -8px;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
  color: var(--warm-40);
  display: flex;
  gap: 12px;
  white-space: nowrap;
  opacity: 0;
  animation: fade 1.2s var(--ease-out) 2s forwards;
  z-index: 3;
}
.brand-tagline .dot-sep { color: var(--heat); }

/* When user scrolls, JS adds .is-blasting which fires the explosion CSS */
.brand-stage.is-blasting .brand-logo {
  animation: none;
}

.hero__title {
  font-family: var(--f-display);
  font-size: var(--fs-h1);
  line-height: var(--lh-tight);
  letter-spacing: var(--tr-display);
  font-weight: 900;
  text-transform: uppercase;
  max-width: 16ch;
  margin: 16px 0 32px;
}
.hero__title .line {
  display: block;
  overflow: hidden;
}
.hero__title .word {
  display: inline-block;
  transform: translateY(110%);
  animation: rise 1.1s var(--ease-out) forwards;
}
.hero__title .line:nth-child(1) .word { animation-delay: 0.05s; }
.hero__title .line:nth-child(2) .word { animation-delay: 0.18s; }
.hero__title .line:nth-child(3) .word { animation-delay: 0.31s; }
@keyframes rise { to { transform: translateY(0); } }
.hero__title em {
  font-style: normal;
  background: var(--grad-bridge);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero__sub {
  font-family: var(--f-body);
  font-size: var(--fs-body-lg);
  line-height: 1.4;
  color: var(--warm-65);
  max-width: 52ch;
  opacity: 0;
  animation: fade 1.2s var(--ease-out) 0.5s forwards;
}
@keyframes fade { to { opacity: 1; } }
.hero__sub strong { color: var(--warm); font-weight: 500; }
.hero__sub em {
  font-style: normal;
  font-weight: 600;
  background: var(--grad-bridge);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero__cta-row {
  display: flex;
  gap: 16px;
  margin-top: 32px;
  margin-bottom: 24px;
  flex-wrap: wrap;
  opacity: 0;
  animation: fade 1.2s var(--ease-out) 0.7s forwards;
}
.btn {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-sm);
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
  padding: 18px 32px;
  border-radius: 999px;
  position: relative;
  overflow: hidden;
  transition: transform var(--dur-fast) var(--ease-out);
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.btn:hover { transform: translateY(-2px); }
.btn--primary {
  background: linear-gradient(135deg, var(--heat) 0%, var(--signal) 100%);
  background-size: 200% 100%;
  background-position: 0% 0%;
  color: var(--void);
  box-shadow: 0 0 40px rgba(61, 220, 151, 0.25), 0 0 80px rgba(34, 211, 238, 0.2);
  transition: transform var(--dur-fast) var(--ease-out),
              background-position var(--dur-med) var(--ease-out),
              box-shadow var(--dur-med);
}
.btn--primary:hover {
  background-position: 100% 0%;
  box-shadow: 0 0 50px rgba(34, 211, 238, 0.4), 0 0 90px rgba(61, 220, 151, 0.3);
}
.btn--ghost {
  border: 1px solid var(--warm-20);
  color: var(--warm);
}
.btn--ghost:hover { border-color: var(--warm); }
.btn .arrow {
  display: inline-block;
  transition: transform var(--dur-fast) var(--ease-out);
}
.btn:hover .arrow { transform: translateX(4px); }
.hero__indicator {
  position: absolute;
  bottom: 40px;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
  color: var(--warm-40);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  opacity: 0;
  animation: fade 1.2s var(--ease-out) 1.2s forwards;
}
.hero__indicator .line {
  width: 1px; height: 60px;
  background: linear-gradient(180deg, var(--warm-40), transparent);
  animation: scrollHint 2s ease-in-out infinite;
}
@keyframes scrollHint {
  0%, 100% { transform: scaleY(1); transform-origin: top; }
  50% { transform: scaleY(0.4); transform-origin: top; }
}

/* ============ SECTION FRAMES ============ */
.section {
  padding: var(--section-pad) var(--gutter);
  position: relative;
}
.section__head {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 48px;
  margin-bottom: 80px;
  align-items: end;
}
.section__num {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-sm);
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
  color: var(--warm-40);
  border-top: 1px solid var(--warm-20);
  padding-top: 16px;
}
.section__title {
  font-family: var(--f-display);
  font-size: var(--fs-h2);
  line-height: var(--lh-tight);
  letter-spacing: var(--tr-display);
  font-weight: 900;
  text-transform: uppercase;
  max-width: 18ch;
}
.section__title em {
  font-style: normal;
  background: linear-gradient(100deg, var(--heat) 0%, var(--signal) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
@media (max-width: 800px) {
  .section__head { grid-template-columns: 1fr; gap: 24px; }
}

/* ============ TWO LANES (HARDWARE + SOFTWARE) ============ */
.pillars {
  position: relative;
  border-top: 1px solid var(--warm-08);
}
.pillars__intro {
  padding: var(--section-pad) var(--gutter) 60px;
  margin-bottom: 0;
  align-items: end;
}
.pillars__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  position: relative;
  min-height: 80vh;
}
.pillars__seam {
  position: absolute;
  top: 0; bottom: 0;
  left: 50%;
  width: 2px;
  transform: translateX(-50%);
  background: var(--grad-bridge);
  background-size: 200% 200%;
  animation: seam 6s ease-in-out infinite;
  box-shadow: 0 0 30px rgba(61, 220, 151, 0.3), 0 0 60px rgba(34, 211, 238, 0.2);
  z-index: 2;
}
@keyframes seam {
  0%, 100% { background-position: 0% 0%; opacity: 0.7; }
  50% { background-position: 100% 100%; opacity: 1; }
}
.pillar {
  padding: var(--section-pad) calc(var(--gutter) + 20px);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 80vh;
}
.pillar--fab {
  background:
    radial-gradient(ellipse at 0% 100%, rgba(61, 220, 151, 0.08), transparent 60%);
}
.pillar--fab::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(135deg, var(--warm-04) 1px, transparent 1px);
  background-size: 24px 24px;
  opacity: 0.5;
  pointer-events: none;
}
.pillar--soft {
  background:
    radial-gradient(ellipse at 100% 0%, rgba(34, 211, 238, 0.08), transparent 60%);
}
.pillar--soft::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at center, var(--warm-08) 1px, transparent 1px);
  background-size: 20px 20px;
  opacity: 0.6;
  pointer-events: none;
}
.pillar__tag {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
  margin-bottom: 24px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
}
.pillar--fab .pillar__tag { color: var(--heat); }
.pillar--soft .pillar__tag { color: var(--signal); }
.pillar__tag::before {
  content: "";
  width: 24px; height: 1px;
}
.pillar--fab .pillar__tag::before { background: var(--heat); }
.pillar--soft .pillar__tag::before { background: var(--signal); }
.pillar__title {
  font-family: var(--f-display);
  font-size: var(--fs-h2);
  line-height: var(--lh-tight);
  letter-spacing: var(--tr-display);
  font-weight: 900;
  text-transform: uppercase;
  margin-bottom: 32px;
  max-width: 12ch;
}
.pillar__copy {
  font-size: var(--fs-body-lg);
  color: var(--warm-65);
  max-width: 42ch;
  margin-bottom: 40px;
}
.pillar__list {
  display: grid;
  gap: 14px;
  font-family: var(--f-mono);
  font-size: var(--fs-mono-sm);
  text-transform: uppercase;
  letter-spacing: var(--tr-mono);
}
.pillar__list li {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 16px;
  align-items: baseline;
  color: var(--warm-65);
}
.pillar__list li::before {
  content: attr(data-n);
  color: var(--warm-40);
  font-size: var(--fs-mono-xs);
}
.pillar__footer {
  margin-top: 48px;
  font-family: var(--f-display);
  font-size: var(--fs-h4);
  font-weight: 700;
  letter-spacing: var(--tr-tight);
  color: var(--warm);
}
@media (max-width: 900px) {
  .pillars__grid { grid-template-columns: 1fr; }
  .pillars__seam { left: 0; right: 0; top: 50%; bottom: auto; width: 100%; height: 2px; transform: none; }
}

/* ============ BRIDGE (scroll animation) ============ */
.bridge {
  background: var(--void);
  position: relative;
  border-top: 1px solid var(--warm-08);
}
.bridge__sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  padding: 0 var(--gutter);
  /* overflow: hidden removed — Firefox flattens 3D descendants when an ancestor clips */
}
.bridge__copy {
  max-width: 44ch;
}
.bridge__copy h2 {
  font-family: var(--f-display);
  font-size: var(--fs-h2);
  line-height: var(--lh-tight);
  letter-spacing: var(--tr-display);
  font-weight: 900;
  text-transform: uppercase;
  margin-bottom: 32px;
}
.bridge__copy p {
  font-size: var(--fs-body-lg);
  color: var(--warm-65);
  margin-bottom: 16px;
}
.bridge__copy p strong {
  color: var(--warm);
  font-weight: 500;
}
.bridge__stage {
  /* perspective removed — now applied inline in cube's transform via JS so Firefox
     computes it reliably. grid -> flex to avoid FF grid+3D oddness. */
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}
.cube {
  width: var(--cube-size);
  height: var(--cube-size);
  position: relative;
  transform-style: preserve-3d;
  /* no initial transform — JS owns the cube's transform exclusively */
  will-change: transform;
}
.cube__face {
  position: absolute;
  top: 0;
  left: 0;
  width: var(--cube-size);
  height: var(--cube-size);
  border: 1px solid var(--warm-20);
  background: linear-gradient(135deg, #1f1f1f 0%, #0c0c0c 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 18px 14px 48px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: var(--tr-wide);
  color: var(--warm-40);
  /* overflow: hidden and isolation: isolate removed — both can flatten 3D in Firefox */
  transform-style: preserve-3d;
  -webkit-transform-style: preserve-3d;
  box-sizing: border-box;
}
.cube__face::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(0deg, var(--warm-08) 1px, transparent 1px),
    linear-gradient(90deg, var(--warm-08) 1px, transparent 1px);
  background-size: 16px 16px;
  opacity: 0;
  transition: opacity var(--dur-slow);
}
.cube__face::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent 30%, rgba(61, 220, 151, 0.4) 50%, transparent 70%);
  opacity: 0;
  transition: opacity var(--dur-slow);
}
.cube.is-tech .cube__face::before { opacity: 1; }
.cube.is-tech .cube__face::after { opacity: 0.5; background: linear-gradient(135deg, transparent 30%, rgba(34, 211, 238, 0.5) 50%, transparent 70%); }
.cube.is-heating .cube__face::after { opacity: 1; }
/* PRODUCT MARKS on cube faces
   NOTE: deliberately avoiding `filter: drop-shadow` and transform animations on these —
   Firefox flattens 3D-preserving ancestors when descendants have filters or 2D transforms.
   Glow is applied to the face itself (::before pseudo) instead. */
.prod-mark {
  width: 92%;
  max-width: 260px;
  height: auto;
  flex-shrink: 0;
  color: var(--heat);
}
.cube__face--back .prod-mark,
.cube__face--left .prod-mark,
.cube__face--top .prod-mark {
  color: var(--signal);
}
.prod-mark--cs {
  width: 100%;
  max-width: 300px;
}
/* Face-level inner glow via pseudo-element — doesn't pollute 3D rendering */
.cube__face .prod-mark + .cube__face-label,
.cube__face .prod-mark {
  position: relative;
  z-index: 2;
}
.cube__face-label {
  position: static;
  margin-top: auto;
  text-align: center;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.32em;
  color: var(--warm);
  text-transform: uppercase;
  flex-shrink: 0;
}
/* prodFloat animation removed — was causing Firefox to flatten 3D-preserving cube faces.
   The cube's own scroll-driven rotation provides plenty of motion. */

/* === Per-product animations === */

/* CreateQuote — document with pulsing dots + animated tally lines */
.anim-pulse {
  animation: pulseOpacity 1.4s ease-in-out infinite;
  transform-origin: center;
  transform-box: fill-box;
}
.anim-pulse--2 { animation-delay: 0.5s; }
@keyframes pulseOpacity {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.25; transform: scale(1.5); }
}
.anim-line {
  stroke-dasharray: 40;
  stroke-dashoffset: 40;
  animation: lineDraw 3.2s ease-in-out infinite;
}
.anim-line--2 { animation-delay: 0.25s; stroke-dasharray: 30; stroke-dashoffset: 30; }
.anim-line--3 { animation-delay: 0.5s; stroke-dasharray: 20; stroke-dashoffset: 20; }
@keyframes lineDraw {
  0%   { stroke-dashoffset: 40; }
  45%  { stroke-dashoffset: 0; }
  55%  { stroke-dashoffset: 0; }
  100% { stroke-dashoffset: -40; }
}
.anim-breathe { animation: breathe 3s ease-in-out infinite; transform-origin: center; transform-box: fill-box; }
@keyframes breathe {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.03); }
}

/* WeldWorks — drawing arc + multiple sparks */
.anim-draw {
  stroke-dasharray: 160;
  stroke-dashoffset: 160;
  animation: weldDraw 2.4s ease-in-out infinite;
}
@keyframes weldDraw {
  0%   { stroke-dashoffset: 160; }
  45%  { stroke-dashoffset: 0; }
  55%  { stroke-dashoffset: 0; }
  100% { stroke-dashoffset: -160; }
}
.anim-spark {
  animation: spark 2.4s ease-out infinite;
  transform-origin: center;
  transform-box: fill-box;
  opacity: 0;
}
.anim-spark--2 { animation-delay: 0.4s; }
.anim-spark--3 { animation-delay: 0.8s; }
.anim-spark--4 { animation-delay: 1.2s; }
@keyframes spark {
  0%   { opacity: 0; transform: translateY(0) scale(0.3); }
  20%  { opacity: 1; transform: translateY(-3px) scale(1); }
  100% { opacity: 0; transform: translateY(-24px) scale(0.2); }
}

/* LoanMatch — matching circles with traveling connections */
.anim-path {
  stroke-dasharray: 60;
  stroke-dashoffset: 60;
  animation: matchPath 2.2s ease-in-out infinite;
}
.anim-path--delay { animation-delay: 0.5s; }
@keyframes matchPath {
  0%   { stroke-dashoffset: 60; }
  50%  { stroke-dashoffset: 0; }
  100% { stroke-dashoffset: -60; }
}
.anim-orbit {
  animation: orbitPulse 2s ease-in-out infinite;
  transform-origin: center;
  transform-box: fill-box;
}
.anim-orbit--2 { animation-delay: 1s; }
@keyframes orbitPulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%      { transform: scale(1.15); opacity: 0.7; }
}

/* Attuned — concentric rings + core pulse */
.anim-ring { opacity: 0; animation: attRing 2s ease-out infinite; transform-origin: center; transform-box: fill-box; }
.anim-ring--2 { animation-delay: 0.5s; }
.anim-ring--3 { animation-delay: 1s; }
@keyframes attRing {
  0%   { opacity: 0.9; transform: scale(0.2); stroke-width: 4; }
  100% { opacity: 0; transform: scale(1.2); stroke-width: 1; }
}
.anim-core {
  animation: coreBeat 1s ease-in-out infinite;
  transform-origin: center;
  transform-box: fill-box;
}
@keyframes coreBeat {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.4); }
}

/* RecruitFlow — particles travelling along flow */
.anim-flow-2 { animation: flowPulse 2s ease-in-out infinite; animation-delay: 0.3s; transform-origin: center; transform-box: fill-box; }
.anim-flow-3 { animation: flowPulse 2s ease-in-out infinite; animation-delay: 0.6s; transform-origin: center; transform-box: fill-box; }
@keyframes flowPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.3; transform: scale(0.7); }
}
.anim-particle {
  animation: particleFly 2s linear infinite;
  transform-origin: center;
  transform-box: fill-box;
}
.anim-particle--2 { animation-delay: 1s; }
@keyframes particleFly {
  0%   { transform: translateX(0); opacity: 0; }
  20%  { opacity: 1; }
  80%  { opacity: 1; }
  100% { transform: translateX(64px); opacity: 0; }
}

/* RecruitFlow bracket arms — two paths start at left-middle, arc up/down-across-back, meet at right-middle
   in sync with the particle travel through the pipeline. */
.flow-bracket {
  stroke-dasharray: 124;
  stroke-dashoffset: 124;
  animation: flowBracketDraw 2s linear infinite;
  opacity: 0.7;
}
@keyframes flowBracketDraw {
  0%   { stroke-dashoffset: 124; opacity: 0.6; }
  80%  { stroke-dashoffset: 0; opacity: 1; }
  100% { stroke-dashoffset: -124; opacity: 0; }
}

/* BOTTOM face — flip content 180° so label reads right-side-up when cube tilts to show bottom.
   Using static transforms only (no animation) to avoid Firefox 3D flattening. */
.cube__face--bottom .prod-mark {
  transform: rotate(180deg);
}
.cube__face--bottom .cube__face-label {
  transform: rotate(180deg);
}

.cube__face--front  { transform: translateZ(var(--cube-half)); }
.cube__face--back   { transform: translateZ(calc(-1 * var(--cube-half))) rotateY(180deg); }
.cube__face--right  { transform: translateX(var(--cube-half)) rotateY(90deg); }
.cube__face--left   { transform: translateX(calc(-1 * var(--cube-half))) rotateY(-90deg); }
.cube__face--top    { transform: translateY(calc(-1 * var(--cube-half))) rotateX(90deg); }
.cube__face--bottom { transform: translateY(var(--cube-half)) rotateX(-90deg); }

.bridge__progress {
  position: absolute;
  bottom: 40px;
  left: var(--gutter);
  right: var(--gutter);
  display: flex;
  justify-content: space-between;
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
  color: var(--warm-40);
}
.bridge__progress .bar {
  position: absolute;
  left: 0; right: 0;
  bottom: -16px;
  height: 1px;
  background: var(--warm-08);
}
.bridge__progress .bar::after {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: var(--p, 0%);
  background: var(--grad-bridge);
  transition: width 100ms linear;
}
.bridge__spacer { height: 200vh; }
@media (max-width: 900px) {
  .bridge__sticky { grid-template-columns: 1fr; padding-top: 80px; padding-bottom: 80px; }
}

/* ============ RECENT BUILDS (work) ============ */
.work {
  background: var(--void);
  padding: 140px var(--gutter) 120px;
  position: relative;
}
.work__head {
  max-width: 880px;
  margin: 0 auto 64px;
  text-align: center;
}
.work__num {
  display: inline-block;
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  color: var(--warm-40);
  margin-bottom: 18px;
}
.work__title {
  font-family: var(--f-display);
  font-size: var(--fs-h2);
  line-height: var(--lh-tight);
  letter-spacing: var(--tr-display);
  font-weight: 900;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.work__title em {
  font-style: normal;
  background: linear-gradient(135deg, var(--heat) 0%, var(--signal) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.work__sub {
  font-family: var(--f-body);
  font-size: var(--fs-body);
  color: var(--warm-65);
  max-width: 56ch;
  margin: 0 auto;
}
.work__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  max-width: 1280px;
  margin: 0 auto;
}
.work__tile {
  position: relative;
  border: 1px solid var(--warm-08);
  background: linear-gradient(135deg, #141414 0%, #0a0a0a 100%);
  overflow: hidden;
  transition: border-color var(--dur-med), transform var(--dur-med) var(--ease-out);
}
.work__tile:hover {
  border-color: var(--heat);
  transform: translateY(-4px);
}
.work__media {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: #000;
}
.work__video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: saturate(1.05) contrast(1.02);
}
.work__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(10,10,10,0.65) 100%);
  pointer-events: none;
}
.work__info {
  padding: 26px 28px 30px;
}
.work__tag {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  color: var(--heat);
  margin-bottom: 12px;
}
.work__name {
  font-family: var(--f-display);
  font-size: 28px;
  letter-spacing: var(--tr-tight);
  font-weight: 800;
  text-transform: uppercase;
  margin-bottom: 14px;
  color: var(--warm);
}
.work__copy {
  font-family: var(--f-body);
  font-size: 15px;
  line-height: 1.65;
  color: var(--warm-65);
}
@media (max-width: 900px) {
  .work { padding: 80px var(--gutter); }
  .work__grid { grid-template-columns: 1fr; gap: 24px; }
  .work__head { margin-bottom: 40px; }
  .work__name { font-size: 22px; }
}

/* ============ DISCIPLINES (5-row list) ============ */
.disciplines { border-top: 1px solid var(--warm-08); }
.disc-list {
  border-top: 1px solid var(--warm-20);
}
.disc {
  display: grid;
  grid-template-columns: 80px 1.4fr 1fr;
  gap: 48px;
  padding: 48px 0;
  border-bottom: 1px solid var(--warm-08);
  transition: background var(--dur-med);
  align-items: start;
  position: relative;
}
.disc::before {
  content: "";
  position: absolute;
  left: 0; right: 0; top: 0;
  height: 1px;
  background: var(--grad-bridge);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--dur-slow) var(--ease-out);
}
.disc:hover::before { transform: scaleX(1); }
.disc:hover { background: var(--warm-04); }
.disc__num {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-sm);
  color: var(--warm-40);
  letter-spacing: var(--tr-wide);
  transition: color var(--dur-med);
}
.disc:hover .disc__num { color: var(--heat); }
.disc__name {
  font-family: var(--f-display);
  font-size: var(--fs-h3);
  font-weight: 900;
  letter-spacing: var(--tr-display);
  text-transform: uppercase;
  margin-bottom: 14px;
  line-height: 1;
  transition: transform var(--dur-med) var(--ease-out);
}
.disc:hover .disc__name { transform: translateX(8px); }
.disc__line {
  font-size: var(--fs-body-lg);
  color: var(--warm-65);
  max-width: 38ch;
  line-height: 1.4;
}
.disc__skills {
  display: grid;
  gap: 10px;
  font-family: var(--f-mono);
  font-size: var(--fs-mono-sm);
  text-transform: uppercase;
  letter-spacing: var(--tr-mono);
  color: var(--warm-65);
  align-self: center;
}
.disc__skills li {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 14px;
  align-items: baseline;
}
.disc__skills li::before {
  content: "";
  display: block;
  width: 10px;
  height: 1px;
  background: var(--warm-40);
  align-self: center;
}
@media (max-width: 800px) {
  .disc { grid-template-columns: 1fr; gap: 16px; padding: 36px 0; }
  .disc__num { color: var(--heat); }
}

/* ============ IDENTITY (the third thing) ============ */
.identity {
  border-top: 1px solid var(--warm-08);
  background:
    radial-gradient(ellipse at 25% 30%, rgba(61, 220, 151, 0.07), transparent 60%),
    radial-gradient(ellipse at 75% 80%, rgba(34, 211, 238, 0.07), transparent 60%);
  padding-top: clamp(120px, 16vw, 240px);
  padding-bottom: clamp(120px, 16vw, 240px);
}
.identity__inner { max-width: 1100px; margin: 0 auto; }
.identity__num {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-sm);
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
  color: var(--warm-40);
  border-top: 1px solid var(--warm-20);
  padding-top: 16px;
  margin-bottom: 56px;
  display: inline-block;
}
.identity__title {
  font-family: var(--f-display);
  font-size: var(--fs-h1);
  line-height: var(--lh-tight);
  letter-spacing: var(--tr-display);
  font-weight: 900;
  text-transform: uppercase;
  margin-bottom: 80px;
  max-width: 14ch;
}
.identity__title em {
  font-style: normal;
  background: var(--grad-bridge);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.identity__claims {
  display: grid;
  gap: 0;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: clamp(28px, 4.4vw, 56px);
  line-height: 1.1;
  letter-spacing: var(--tr-display);
  text-transform: uppercase;
  margin-bottom: 64px;
}
.identity__voice {
  font-family: var(--f-body);
  font-size: var(--fs-body-lg);
  line-height: 1.55;
  color: var(--warm-65);
  max-width: 56ch;
  font-style: italic;
  padding-left: 24px;
  border-left: 2px solid var(--heat);
}
.claim {
  color: var(--warm-40);
  border-bottom: 1px solid var(--warm-08);
  padding: 28px 0;
}
.claim:last-child { border-bottom: none; }
.claim span { color: var(--warm); }
.claim--punch { color: var(--warm); }
.claim--punch em {
  font-style: normal;
  background: var(--grad-bridge);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* ============ PRODUCTS ============ */
.products {
  border-top: 1px solid var(--warm-08);
}
.products__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: minmax(220px, auto);
  gap: 16px;
}
.card {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--warm-08);
  padding: 32px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
  isolation: isolate;
  transition: transform var(--dur-med) var(--ease-out), border-color var(--dur-med);
}
.card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  opacity: 0;
  transition: opacity var(--dur-med);
}
.card:hover { transform: translateY(-4px); }
.card[data-tag="fab"]:hover { border-color: var(--heat); box-shadow: 0 20px 60px -20px rgba(61, 220, 151, 0.4); }
.card[data-tag="fab"]::before { background: radial-gradient(ellipse at top right, rgba(61, 220, 151, 0.15), transparent 60%); }
.card[data-tag="fab"]:hover::before { opacity: 1; }
.card[data-tag="soft"]:hover { border-color: var(--signal); box-shadow: 0 20px 60px -20px rgba(34, 211, 238, 0.4); }
.card[data-tag="soft"]::before { background: radial-gradient(ellipse at top right, rgba(34, 211, 238, 0.15), transparent 60%); }
.card[data-tag="soft"]:hover::before { opacity: 1; }
.card[data-tag="both"]:hover { border-color: transparent; }
.card[data-tag="both"]:hover { box-shadow: 0 20px 60px -20px rgba(61, 220, 151, 0.3), 0 20px 60px -20px rgba(34, 211, 238, 0.3); }
.card[data-tag="both"]::after {
  content: "";
  position: absolute;
  inset: -1px;
  background: var(--grad-bridge);
  z-index: -2;
  opacity: 0;
  transition: opacity var(--dur-med);
  border-radius: inherit;
}
.card[data-tag="both"]:hover::after { opacity: 1; }
.card__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
  color: var(--warm-40);
  margin-bottom: 60px;
}
.card__tag {
  padding: 6px 10px;
  border: 1px solid var(--warm-20);
  border-radius: 999px;
}
.card[data-tag="fab"] .card__tag { color: var(--heat); border-color: var(--heat); }
.card[data-tag="soft"] .card__tag { color: var(--signal); border-color: var(--signal); }
.card[data-tag="both"] .card__tag {
  background: var(--grad-bridge);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  border-color: var(--warm);
}
.card__name {
  font-family: var(--f-display);
  font-size: var(--fs-h4);
  line-height: var(--lh-snug);
  font-weight: 800;
  letter-spacing: var(--tr-tight);
  text-transform: uppercase;
  margin-bottom: 12px;
}
.card__desc {
  font-size: 15px;
  color: var(--warm-65);
  max-width: 38ch;
}
.card--xl { grid-column: span 4; grid-row: span 2; }
.card--lg { grid-column: span 3; }
.card--md { grid-column: span 2; }
.card--sm { grid-column: span 2; }
.card--wide { grid-column: span 4; }
.card--narrow { grid-column: span 2; }
.card--bg-fab {
  background:
    linear-gradient(135deg, rgba(61, 220, 151, 0.08), transparent 70%),
    var(--surface);
}
.card--bg-soft {
  background:
    linear-gradient(135deg, rgba(34, 211, 238, 0.08), transparent 70%),
    var(--surface);
}
.card__visual {
  position: absolute;
  inset: 0;
  z-index: -1;
  opacity: 0.4;
  pointer-events: none;
}
.card__visual--rings {
  background: radial-gradient(circle at 80% 20%, transparent 0%, transparent 60px, var(--warm-08) 61px, transparent 62px),
              radial-gradient(circle at 80% 20%, transparent 0%, transparent 100px, var(--warm-08) 101px, transparent 102px),
              radial-gradient(circle at 80% 20%, transparent 0%, transparent 140px, var(--warm-08) 141px, transparent 142px);
}
.card__visual--lines {
  background-image:
    linear-gradient(90deg, var(--warm-08) 1px, transparent 1px);
  background-size: 8px 100%;
  mask-image: linear-gradient(180deg, transparent, black 50%, transparent);
}

/* === In-card video / screenshot — block element at top of card === */
.card__thumb {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 10;
  padding: 0;
  margin-bottom: 28px;
  border: 1px solid var(--warm-20);
  background: #000;
  cursor: pointer;
  overflow: hidden;
  position: relative;
  z-index: 2;
  flex-shrink: 0;
  transition: border-color var(--dur-fast), transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast);
}
.card__thumb:hover {
  border-color: var(--heat);
  box-shadow: 0 8px 24px -8px rgba(61, 220, 151, 0.5);
}
.card__thumb-video,
.card__thumb-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  pointer-events: none;
}
.card__thumb-play {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  color: var(--warm);
  background: rgba(0, 0, 0, 0.35);
  opacity: 0;
  transition: opacity var(--dur-fast);
  pointer-events: none;
}
.card__thumb:hover .card__thumb-play { opacity: 1; }
.card__thumb-play--ext {
  font-size: 20px;
  background: rgba(0, 0, 0, 0.55);
}
a.card__thumb { display: block; text-decoration: none; }

/* === Rotating screenshot carousel (WeldWorks / LoanMatch) === */
.shot-rotator {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 10;
  margin-bottom: 28px;
  border: 1px solid var(--warm-20);
  background: #0a0a0a;
  overflow: hidden;
  position: relative;
  z-index: 2;
  flex-shrink: 0;
  text-decoration: none;
  transition: border-color var(--dur-fast), transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast);
}
.shot-rotator:hover {
  border-color: var(--signal);
  transform: translateY(-2px);
  box-shadow: 0 14px 40px -16px rgba(34, 211, 238, 0.4);
}
.shot-rotator img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  opacity: 0;
  animation: shotFade 20s linear infinite;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  pointer-events: none;
}
.shot-rotator img:nth-child(1) { animation-delay: 0s; }
.shot-rotator img:nth-child(2) { animation-delay: 5s; }
.shot-rotator img:nth-child(3) { animation-delay: 10s; }
.shot-rotator img:nth-child(4) { animation-delay: 15s; }
.shot-rotator:hover img { animation-play-state: paused; }
.shot-rotator .card__thumb-play--ext { z-index: 4; }
.shot-rotator:hover .card__thumb-play--ext { opacity: 1; }
@keyframes shotFade {
  0%   { opacity: 0; }
  5%   { opacity: 1; }
  25%  { opacity: 1; }
  30%  { opacity: 0; }
  100% { opacity: 0; }
}
/* 7-slide variant (CreateQuote) — 28s cycle, 4s per slide */
.shot-rotator--7 img { animation-name: shotFade7; animation-duration: 28s; }
.shot-rotator--7 img:nth-child(1) { animation-delay: 0s; }
.shot-rotator--7 img:nth-child(2) { animation-delay: 4s; }
.shot-rotator--7 img:nth-child(3) { animation-delay: 8s; }
.shot-rotator--7 img:nth-child(4) { animation-delay: 12s; }
.shot-rotator--7 img:nth-child(5) { animation-delay: 16s; }
.shot-rotator--7 img:nth-child(6) { animation-delay: 20s; }
.shot-rotator--7 img:nth-child(7) { animation-delay: 24s; }
@keyframes shotFade7 {
  0%     { opacity: 0; }
  3%     { opacity: 1; }
  14.3%  { opacity: 1; }
  17.3%  { opacity: 0; }
  100%   { opacity: 0; }
}
/* 6-slide variant (CreateQuote, Fireball shot removed) — 24s, 4s per slide */
.shot-rotator--6 img { animation-name: shotFade6; animation-duration: 24s; }
.shot-rotator--6 img:nth-child(1) { animation-delay: 0s; }
.shot-rotator--6 img:nth-child(2) { animation-delay: 4s; }
.shot-rotator--6 img:nth-child(3) { animation-delay: 8s; }
.shot-rotator--6 img:nth-child(4) { animation-delay: 12s; }
.shot-rotator--6 img:nth-child(5) { animation-delay: 16s; }
.shot-rotator--6 img:nth-child(6) { animation-delay: 20s; }
@keyframes shotFade6 {
  0%    { opacity: 0; }
  3%    { opacity: 1; }
  16.7% { opacity: 1; }
  19.7% { opacity: 0; }
  100%  { opacity: 0; }
}
/* narrow cards show the WHOLE portrait screenshot (square box, contain) */
.card--narrow .shot-rotator { aspect-ratio: 1 / 1; }
.card--narrow .shot-rotator img { object-fit: contain; object-position: center; }
/* product cards: top-align content so the bottom-pinned logos line up across each row */
.products__grid .card { justify-content: flex-start; }
.card__link {
  display: inline-block;
  margin-top: 14px;
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  color: var(--signal);
  text-decoration: none;
  transition: color var(--dur-fast);
}
.card__link:hover { color: var(--heat); }
.card__partner {
  margin: auto 0 0 auto;       /* push to bottom-right; all logos line up across a row */
  width: 104px;
  opacity: 0.95;
  display: block;
  transition: opacity var(--dur-fast);
  z-index: 2;
}
.card__partner:hover { opacity: 1; }
.card__partner img { width: 100%; height: auto; display: block; }
/* CreateStage mark — larger + breathing glow (dead-ringer on dark) */
.card__partner--cs { width: 180px; }
.card__partner--cs img { animation: csBreath 3.6s ease-in-out infinite; will-change: filter; }
@keyframes csBreath {
  0%, 100% { filter: brightness(1) saturate(1) drop-shadow(0 0 0 rgba(224, 170, 70, 0)); }
  50%      { filter: brightness(1.3) saturate(1.18) drop-shadow(0 0 24px rgba(224, 170, 70, 0.8)); }
}
@media (max-width: 700px) {
  .card__partner { width: 84px; }
  .card__partner--cs { width: 150px; }
}

/* === Custom Fab — scrolling photo marquee === */
.fab-marquee {
  display: block;
  width: 100%;
  height: 280px;
  margin-bottom: 28px;
  overflow: hidden;
  position: relative;
  z-index: 2;
  border: 1px solid var(--warm-20);
  background: #000;
}
.fab-marquee::before,
.fab-marquee::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 36px;
  z-index: 3;
  pointer-events: none;
}
.fab-marquee::before { left: 0;  background: linear-gradient(90deg, #000 0%, transparent 100%); }
.fab-marquee::after  { right: 0; background: linear-gradient(270deg, #000 0%, transparent 100%); }
.fab-marquee__track {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  width: max-content;
  height: 280px;
  gap: 8px;
  animation: fab-scroll 25s linear infinite;
  will-change: transform;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}
.fab-marquee:hover .fab-marquee__track {
  animation-play-state: paused;
}
.fab-marquee__track img {
  height: 280px;
  width: auto;
  flex-shrink: 0;
  display: block;
  object-fit: cover;
  filter: saturate(1.05) contrast(1.04);
  transition: filter var(--dur-fast);
}
.fab-marquee__track img:hover {
  filter: saturate(1.15) contrast(1.08) brightness(1.05);
}
@keyframes fab-scroll {
  0%   { transform: translate3d(0, 0, 0); }
  100% { transform: translate3d(-50%, 0, 0); }
}
@media (max-width: 1100px) {
  .fab-marquee { height: 240px; }
  .fab-marquee__track { height: 240px; }
  .fab-marquee__track img { height: 240px; }
}
@media (max-width: 700px) {
  .fab-marquee { height: 180px; margin-bottom: 20px; }
  .fab-marquee__track { height: 180px; animation-duration: 30s; }
  .fab-marquee__track img { height: 180px; }
}
@media (max-width: 700px) {
  .card__thumb { margin-bottom: 20px; }
}

/* === Video modal === */
.vmodal {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(0, 0, 0, 0.92);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 40px 24px;
}
.vmodal.is-open { display: flex; }
.vmodal__frame {
  position: relative;
  width: 100%;
  max-width: 1100px;
  max-height: 86vh;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.vmodal__video {
  width: 100%;
  max-height: 80vh;
  background: #000;
  border: 1px solid var(--warm-20);
  display: block;
}
.vmodal__caption {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-sm);
  letter-spacing: var(--tr-wide);
  text-transform: uppercase;
  color: var(--warm-65);
  text-align: center;
}
.vmodal__close {
  position: absolute;
  top: 16px;
  right: 20px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid var(--warm-20);
  background: rgba(0, 0, 0, 0.6);
  color: var(--warm);
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  z-index: 1;
  transition: border-color var(--dur-fast), color var(--dur-fast);
}
.vmodal__close:hover { border-color: var(--heat); color: var(--heat); }
@media (max-width: 1100px) {
  .products__grid { grid-template-columns: repeat(4, 1fr); }
  .card--xl { grid-column: span 4; grid-row: span 1; }
  .card--lg { grid-column: span 4; }
  .card--md { grid-column: span 2; }
  .card--sm { grid-column: span 2; }
  .card--wide { grid-column: span 4; }
  .card--narrow { grid-column: span 2; }
}
@media (max-width: 700px) {
  .products__grid { grid-template-columns: 1fr; }
  .card--xl, .card--lg, .card--md, .card--sm,
  .card--wide, .card--narrow { grid-column: span 1; }
}

/* ============ PROCESS ============ */
.process {
  border-top: 1px solid var(--warm-08);
}
.process__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--warm-20);
}
.step {
  padding: 48px 32px 48px 0;
  border-right: 1px solid var(--warm-08);
  position: relative;
}
.step:last-child { border-right: none; }
.step__num {
  font-family: var(--f-display);
  font-size: 96px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: var(--tr-display);
  color: var(--warm-08);
  margin-bottom: 24px;
  transition: color var(--dur-slow), background var(--dur-slow);
  background-clip: text;
  -webkit-background-clip: text;
}
.step:hover .step__num {
  background: linear-gradient(110deg, var(--heat) 0%, var(--signal) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.step__label {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-sm);
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
  color: var(--warm);
  margin-bottom: 16px;
}
.step__desc {
  font-size: 15px;
  color: var(--warm-65);
  max-width: 32ch;
}
@media (max-width: 1000px) {
  .process__list { grid-template-columns: repeat(2, 1fr); }
  .step:nth-child(2) { border-right: none; }
}
@media (max-width: 600px) {
  .process__list { grid-template-columns: 1fr; }
  .step { border-right: none; border-bottom: 1px solid var(--warm-08); }
}

/* ============ ABOUT ============ */
.about {
  border-top: 1px solid var(--warm-08);
}
.about__grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 80px;
  align-items: start;
}
.about__quote {
  font-family: var(--f-display);
  font-size: var(--fs-h3);
  line-height: 1.15;
  font-weight: 700;
  letter-spacing: var(--tr-tight);
}
.about__quote em {
  font-style: normal;
  background: var(--grad-bridge);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.about__copy {
  font-size: var(--fs-body-lg);
  color: var(--warm-65);
  display: grid;
  gap: 20px;
}
.about__copy p strong { color: var(--warm); font-weight: 500; }
.about__sig {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--warm-08);
  font-family: var(--f-mono);
  font-size: var(--fs-mono-sm);
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
  color: var(--warm-40);
  display: flex;
  justify-content: space-between;
}
@media (max-width: 900px) { .about__grid { grid-template-columns: 1fr; gap: 48px; } }

/* ============ CONTACT ============ */
.contact {
  border-top: 1px solid var(--warm-08);
  background:
    radial-gradient(ellipse at 0% 100%, rgba(61, 220, 151, 0.05), transparent 60%),
    radial-gradient(ellipse at 100% 0%, rgba(34, 211, 238, 0.05), transparent 60%),
    var(--void);
}
.contact__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: end;
}
.contact__pitch {
  font-family: var(--f-display);
  font-size: clamp(40px, 7vw, 120px);
  line-height: 0.95;
  letter-spacing: var(--tr-display);
  font-weight: 900;
  text-transform: uppercase;
}
.contact__pitch em {
  font-style: normal;
  color: var(--heat);
}
.grad-fade {
  background: linear-gradient(90deg, var(--warm) 0%, var(--heat) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.grad-fade-reverse {
  background: linear-gradient(90deg, var(--heat) 0%, var(--warm) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.grad-dip {
  background: linear-gradient(90deg, var(--heat) 0%, var(--signal) 50%, var(--heat) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.accent-signal {
  color: var(--signal);
  font-style: normal;
}
/* "title block" style — callback to shop drawings */
.contact__card {
  border: 1px solid var(--warm-20);
  font-family: var(--f-mono);
  font-size: var(--fs-mono-sm);
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
  position: relative;
}
.contact__card::before {
  content: "LEO-CTA-001 · REV A";
  position: absolute;
  top: -10px; left: 16px;
  background: var(--void);
  padding: 0 8px;
  color: var(--warm-40);
  font-size: var(--fs-mono-xs);
}
.contact__row {
  display: grid;
  grid-template-columns: 120px 1fr;
  border-bottom: 1px solid var(--warm-08);
}
.contact__row:last-child { border-bottom: none; }
.contact__row .k {
  padding: 18px 16px;
  color: var(--warm-40);
  border-right: 1px solid var(--warm-08);
}
.contact__row .v {
  padding: 18px 16px;
  color: var(--warm);
}
.contact__row .v a:hover { color: var(--heat); }
.contact__big-cta {
  margin-top: 40px;
  display: inline-flex;
}
@media (max-width: 900px) { .contact__inner { grid-template-columns: 1fr; gap: 48px; } }

/* ============ FOOTER (title-block style) ============ */
.footer {
  border-top: 1px solid var(--warm-20);
  padding: 32px var(--gutter);
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
  color: var(--warm-40);
}
.footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
  gap: 24px;
  border: 1px solid var(--warm-08);
}
.footer__cell {
  padding: 18px 16px;
  border-right: 1px solid var(--warm-08);
}
.footer__cell:last-child { border-right: none; }
.footer__cell .label {
  display: block;
  color: var(--warm-40);
  margin-bottom: 6px;
  font-size: 9px;
}
.footer__cell .value { color: var(--warm); font-size: 12px; }
.footer__cell.brand .value {
  font-family: var(--f-display);
  font-size: 18px;
  font-weight: 900;
  letter-spacing: var(--tr-tight);
  text-transform: uppercase;
}
.footer__socials {
  margin-top: 16px;
  display: flex;
  gap: 24px;
}
.footer__socials a:hover { color: var(--heat); }
@media (max-width: 800px) {
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .footer__cell { border-right: none; border-bottom: 1px solid var(--warm-08); }
}

/* ============ REVEAL ON SCROLL ============ */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1.2s var(--ease-out), transform 1.2s var(--ease-out);
}
.reveal.is-in {
  opacity: 1;
  transform: translateY(0);
}
