/* ═══════════════════════════════════════════════════════════
   OMNIS — Cinematic Animation System
   omnis-animate.css
   ═══════════════════════════════════════════════════════════ */

/* ── REVEALS ── */
.rv{opacity:0;transform:translateY(32px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.rv-l{opacity:0;transform:translateX(-48px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.rv-r{opacity:0;transform:translateX(48px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.rv-s{opacity:0;transform:scale(.92);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1)}
.rv-clip{clip-path:inset(100% 0 0 0);transition:clip-path .8s cubic-bezier(.22,1,.36,1)}
.rv.v,.rv-l.v,.rv-r.v,.rv-s.v{opacity:1;transform:none}
.rv-clip.v{clip-path:inset(0 0 0 0)}

/* ── STAGGER DELAYS ── */
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}
.d4{transition-delay:.32s}.d5{transition-delay:.4s}.d6{transition-delay:.48s}
.stagger>.rv:nth-child(1),.stagger>.rv-l:nth-child(1),.stagger>.rv-r:nth-child(1){transition-delay:.08s}
.stagger>.rv:nth-child(2),.stagger>.rv-l:nth-child(2),.stagger>.rv-r:nth-child(2){transition-delay:.16s}
.stagger>.rv:nth-child(3),.stagger>.rv-l:nth-child(3),.stagger>.rv-r:nth-child(3){transition-delay:.24s}
.stagger>.rv:nth-child(4),.stagger>.rv-l:nth-child(4),.stagger>.rv-r:nth-child(4){transition-delay:.32s}
.stagger>.rv:nth-child(5),.stagger>.rv-l:nth-child(5),.stagger>.rv-r:nth-child(5){transition-delay:.4s}
.stagger>.rv:nth-child(6),.stagger>.rv-l:nth-child(6),.stagger>.rv-r:nth-child(6){transition-delay:.48s}

/* ── TYPOGRAPHY EFFECTS ── */
.hw .word{display:inline-block;opacity:0;transform:translateY(20px);transition:opacity .5s,transform .5s}
.hw.v .word{opacity:1;transform:none}
.typewriter{overflow:hidden;white-space:nowrap;border-right:2px solid var(--c,#E8234A);width:0;transition:none}
.typewriter.v{animation:tw 2s steps(40) forwards,twb .7s step-end infinite}
@keyframes tw{to{width:100%}}
@keyframes twb{50%{border-color:transparent}}

/* ── SELF-DRAWING ── */
.draw-border{position:relative}
.draw-border::after{content:'';position:absolute;inset:-2px;border:1px solid var(--c,#E8234A);border-radius:inherit;clip-path:inset(0 100% 100% 0);transition:clip-path 1s cubic-bezier(.22,1,.36,1)}
.draw-border.v::after{clip-path:inset(0 0 0 0)}
.draw-line{height:1px;background:linear-gradient(90deg,transparent,var(--c,#E8234A),transparent);transform:scaleX(0);transition:transform .8s cubic-bezier(.22,1,.36,1)}
.draw-line.v{transform:scaleX(1)}
.svg-draw path{stroke-dasharray:1000;stroke-dashoffset:1000;transition:stroke-dashoffset 2s cubic-bezier(.22,1,.36,1)}
.svg-draw.v path{stroke-dashoffset:0}

/* ── MICRO INTERACTIONS ── */
.tilt{transition:transform .15s ease-out}
.ripple{position:relative;overflow:hidden}
.ripple .rp-wave{position:absolute;border-radius:50%;background:rgba(255,255,255,.12);transform:scale(0);animation:rp-expand .6s ease-out forwards;pointer-events:none}
@keyframes rp-expand{to{transform:scale(4);opacity:0}}
.card-glow{position:relative;overflow:hidden}
.card-glow::before{content:'';position:absolute;width:200px;height:200px;background:radial-gradient(circle,rgba(232,35,74,.08),transparent 70%);border-radius:50%;pointer-events:none;opacity:0;transition:opacity .3s;transform:translate(-50%,-50%)}
.card-glow:hover::before{opacity:1}
.link-draw{position:relative;text-decoration:none}
.link-draw::after{content:'';position:absolute;bottom:-2px;left:0;width:100%;height:1px;background:rgba(255,255,255,.15);transform:scaleX(0);transform-origin:right;transition:transform .3s}
.link-draw:hover::after{transform:scaleX(1);transform-origin:left;background:rgba(255,255,255,.3)}

/* ── CTA ── */
.cta-glow{position:relative;transition:all .2s}
.cta-glow::after{content:'';position:absolute;inset:-4px;border-radius:inherit;background:var(--c,#E8234A);filter:blur(16px);opacity:0;transition:opacity .3s;z-index:-1}
.cta-glow:hover::after{opacity:.25}

/* ── MOTION ── */
.float{animation:omFloat 3s ease-in-out infinite}
@keyframes omFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.breathe{animation:omBreathe 4s ease-in-out infinite}
@keyframes omBreathe{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.98)}}
.pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--g,#2DD4A8);animation:omPulse 2s infinite}
@keyframes omPulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(45,212,168,.4)}50%{opacity:.6;box-shadow:0 0 0 8px rgba(45,212,168,0)}}

/* ── DIVIDERS ── */
.glow-line{height:1px;background:linear-gradient(90deg,transparent,rgba(232,35,74,.3),transparent);opacity:0;transition:opacity .8s}
.glow-line.v{opacity:1}

/* ── COUNTER ── */
[data-target]{font-variant-numeric:tabular-nums}

/* ── SCROLL PROGRESS BAR ── */

/* ── BOOT LOADER ── */
#om-boot{position:fixed;inset:0;z-index:100000;background:#030305;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .5s}
#om-boot.done{opacity:0;pointer-events:none}
#om-boot-lines{font-family:'JetBrains Mono',monospace;font-size:12px;color:rgba(255,255,255,.4);text-align:left;line-height:2}
#om-boot-lines .lit{color:#E8234A}

/* ── PAGE TRANSITION ── */
#om-wipe{position:fixed;inset:0;z-index:99999;background:#030305;transform:scaleY(0);transform-origin:bottom;pointer-events:none;transition:transform .4s cubic-bezier(.65,0,.35,1)}
#om-wipe.in{transform:scaleY(1);transform-origin:top}
#om-wipe.out{transform:scaleY(0);transform-origin:bottom}

/* ── FLOATING PARTICLES ── */

/* ── WORD CYCLE (hero heading morph) ── */
.word-cycle{display:inline-block;position:relative;overflow:hidden;vertical-align:bottom;height:1.2em;width:auto}
.wc-words{display:block;animation:wordSlide 8s ease-in-out infinite}
.wc-words span{display:block;height:1.2em;line-height:1.2}
@keyframes wordSlide{0%,16%{transform:translateY(0)}20%,36%{transform:translateY(-20%)}40%,56%{transform:translateY(-40%)}60%,76%{transform:translateY(-60%)}80%,100%{transform:translateY(-80%)}}

/* ── CURSOR GLOW (follows mouse, full page) ── */
.om-cursor-glow{position:fixed;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(232,35,74,.035),transparent 70%);pointer-events:none;z-index:0;transform:translate(-50%,-50%);transition:left .15s ease-out,top .15s ease-out,opacity .3s;opacity:0}
body:hover .om-cursor-glow{opacity:1}

/* ── AMBIENT GRADIENT ZONES (per-section) ── */
.om-ambient{position:relative;overflow:hidden}
.om-ambient::before{content:'';position:absolute;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,var(--amb-color,rgba(232,35,74,.03)),transparent 70%);pointer-events:none;z-index:0}
.om-ambient>*{position:relative;z-index:1}

/* ── BUTTON PRESS DEPTH ── */
.btn-primary:active{transform:translateY(1px) !important;box-shadow:0 1px 4px rgba(0,0,0,.4) !important}
.btn-ghost:active{transform:translateY(1px) !important}

/* ── SEQUENTIAL DRAW (staggered draw-border) ── */
.draw-seq .draw-border:nth-child(1)::after{transition-delay:0s}
.draw-seq .draw-border:nth-child(2)::after{transition-delay:.12s}
.draw-seq .draw-border:nth-child(3)::after{transition-delay:.24s}
.draw-seq .draw-border:nth-child(4)::after{transition-delay:.36s}
.draw-seq .draw-border:nth-child(5)::after{transition-delay:.48s}
.draw-seq .draw-border:nth-child(6)::after{transition-delay:.6s}
.draw-seq .draw-border:nth-child(7)::after{transition-delay:.72s}
.draw-seq .draw-border:nth-child(8)::after{transition-delay:.84s}

/* ── DOCK STATUS MORPH (cycling colors) ── */
/* Stagger children for sequential draw */
.svg-scene.v *:nth-child(1){transition-delay:0s}
.svg-scene.v *:nth-child(2){transition-delay:.15s}
.svg-scene.v *:nth-child(3){transition-delay:.3s}
.svg-scene.v *:nth-child(4){transition-delay:.45s}
.svg-scene.v *:nth-child(5){transition-delay:.6s}
.svg-scene.v *:nth-child(6){transition-delay:.75s}
.svg-scene.v *:nth-child(7){transition-delay:.9s}
.svg-scene.v *:nth-child(8){transition-delay:1.05s}
.svg-scene.v *:nth-child(9){transition-delay:1.2s}
.svg-scene.v *:nth-child(10){transition-delay:1.35s}
.svg-scene.v *:nth-child(11){transition-delay:1.5s}
.svg-scene.v *:nth-child(12){transition-delay:1.65s}

/* Fill fades in after stroke draws */
.svg-scene.v [data-fill]{fill:var(--fill-color,rgba(232,35,74,.06));fill-opacity:0;transition:stroke-dashoffset 1.5s cubic-bezier(.22,1,.36,1),fill-opacity .8s .8s}
.svg-scene.v [data-fill]{fill-opacity:1}

/* ── ANIMATED LINE ART / DATA FLOW ── */
.om-flow-line{position:relative;height:60px;overflow:hidden;margin:0 auto;max-width:800px}
.om-flow-line svg{width:100%;height:100%;overflow:visible}
.om-flow-line path{fill:none;stroke-width:.8;stroke-dasharray:8 6;stroke-dashoffset:0;animation:flowDash 3s linear infinite}
@keyframes flowDash{to{stroke-dashoffset:-60}}

/* Signal path — data flowing between two points */
.om-signal-path{position:relative;padding:16px 0}
.om-signal-path svg{width:100%;height:40px;overflow:visible}
.om-signal-path .sp-line{fill:none;stroke-width:.5;opacity:.15;stroke-dasharray:4 8;animation:flowDash 4s linear infinite}
.om-signal-path .sp-dot{r:3;animation:spTravel var(--sp-dur,6s) linear infinite}
@keyframes spTravel{0%{opacity:0}5%{opacity:1}95%{opacity:1}100%{opacity:0}}

/* Connector lines between sections (vertical) */
.om-vline{display:flex;justify-content:center;padding:0;height:48px;position:relative}
.om-vline::after{content:'';width:1px;height:100%;background:linear-gradient(to bottom,transparent,var(--vl-color,rgba(232,35,74,.15)),transparent);animation:vlinePulse 3s ease-in-out infinite}
@keyframes vlinePulse{0%,100%{opacity:.3}50%{opacity:.8}}
.om-vline .vl-dot{position:absolute;width:4px;height:4px;border-radius:50%;background:var(--vl-color,#E8234A);left:50%;transform:translateX(-50%);animation:vdotTravel 2.5s ease-in-out infinite}
@keyframes vdotTravel{0%{top:0;opacity:0}20%{opacity:1}80%{opacity:1}100%{top:100%;opacity:0}}

/* Horizontal data flow between cards */
.om-hflow{display:flex;align-items:center;justify-content:center;padding:8px 0}
.om-hflow svg{width:200px;height:20px;overflow:visible}
.om-hflow .hf-line{fill:none;stroke-dasharray:4 4;animation:flowDash 2s linear infinite}
.om-hflow .hf-dot{animation:hfMove 2s linear infinite}
@keyframes hfMove{0%{cx:0;opacity:0}10%{opacity:1}90%{opacity:1}100%{cx:200;opacity:0}}

/* ── LIVE ACTIVITY TICKER (simulated real-time ops) ── */
.om-live-ticker{max-width:800px;margin:0 auto;padding:0 24px;overflow:hidden;height:200px;position:relative;mask-image:linear-gradient(transparent,black 15%,black 85%,transparent)}
.om-live-ticker-inner{display:flex;flex-direction:column;gap:6px;animation:tickerScroll 30s linear infinite}
@keyframes tickerScroll{0%{transform:translateY(0)}100%{transform:translateY(-50%)}}
.om-tick{display:flex;align-items:center;gap:12px;padding:8px 14px;background:rgba(255,255,255,.015);border:1px solid rgba(255,255,255,.03);border-radius:10px;font-size:12px;transition:all .3s}
.om-tick:hover{background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.06)}
.om-tick-time{font-family:'JetBrains Mono',monospace;font-size:10px;color:rgba(255,255,255,.15);min-width:70px}
.om-tick-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.om-tick-msg{color:rgba(255,255,255,.4);flex:1}
.om-tick-msg strong{color:rgba(255,255,255,.6);font-weight:500}
.om-tick-badge{font-family:'JetBrains Mono',monospace;font-size:9px;padding:2px 8px;border-radius:100px;text-transform:uppercase;letter-spacing:.04em}

/* Live dot pulse in ticker header */
.om-live-dot{width:6px;height:6px;border-radius:50%;background:#2DD4A8;display:inline-block;animation:omPulse 2s infinite;vertical-align:middle;margin-right:6px}

/* ── MIXED MEDIA LAYERED COMPOSITIONS ── */

/* Layered hero backdrop — grain + mesh + radial glow stacked */
.om-hero{position:relative}
.om-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 40%,rgba(232,35,74,.04),transparent 60%),radial-gradient(ellipse at 70% 60%,rgba(159,108,247,.03),transparent 50%);pointer-events:none;z-index:1}
.om-hero::after{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");opacity:.015;mix-blend-mode:overlay;pointer-events:none;z-index:2}
.om-hero-content{position:relative;z-index:3}

/* Textured section backgrounds — subtle noise per section */
.om-section{position:relative}
.om-section::before{content:'';position:absolute;inset:0;opacity:.008;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 128 128' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");mix-blend-mode:overlay;pointer-events:none}

/* Layered stat band — gradient underlay + grain */
.om-stat-band{position:relative}
.om-stat-band::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(232,35,74,.02),rgba(159,108,247,.02),rgba(0,194,240,.02));pointer-events:none}

/* Mock cards — inner glow layer */
.om-mock::before{content:'';position:absolute;inset:0;border-radius:inherit;background:radial-gradient(ellipse at 50% 0%,rgba(255,255,255,.02),transparent 70%);pointer-events:none;z-index:0}
.om-mock>*{position:relative;z-index:1}

/* ── COSMIC WAVE (canvas-rendered, CSS fallback) ── */
/* Canvas handles the wave rendering — these are fallback/utility classes */

/* Layered full-width mock — scanline overlay */
.om-full-mock{position:relative;overflow:hidden}
.om-full-mock::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px);pointer-events:none;z-index:1;border-radius:inherit}

/* Accent band — dual gradient + grain */
.om-accent-band{position:relative;overflow:hidden}
.om-accent-band::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(255,255,255,.015),transparent 50%);pointer-events:none}

/* CTA band — ambient glow behind buttons */
.om-cta-band{position:relative}
.om-cta-band::before{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:400px;height:200px;background:radial-gradient(ellipse,rgba(232,35,74,.04),transparent 70%);pointer-events:none;z-index:0}
.om-cta-band>*{position:relative;z-index:1}

/* ── LIQUID MOTION EFFECTS ── */

/* Morphing blob — organic shape that breathes behind hero */
.om-blob{position:absolute;border-radius:30% 70% 70% 30% / 30% 30% 70% 70%;filter:blur(80px);pointer-events:none;z-index:0;animation:blobMorph 8s ease-in-out infinite alternate}
@keyframes blobMorph{
  0%{border-radius:30% 70% 70% 30% / 30% 30% 70% 70%;transform:rotate(0deg) scale(1)}
  25%{border-radius:58% 42% 34% 66% / 63% 68% 32% 37%}
  50%{border-radius:50% 50% 34% 66% / 56% 68% 32% 44%;transform:rotate(45deg) scale(1.05)}
  75%{border-radius:33% 67% 58% 42% / 63% 38% 62% 37%}
  100%{border-radius:70% 30% 30% 70% / 70% 70% 30% 30%;transform:rotate(90deg) scale(1)}
}

/* Secondary blob with offset timing */
.om-blob-2{animation:blobMorph2 10s ease-in-out infinite alternate}
@keyframes blobMorph2{
  0%{border-radius:70% 30% 50% 50% / 40% 60% 40% 60%;transform:rotate(0deg) scale(1)}
  33%{border-radius:40% 60% 70% 30% / 50% 40% 60% 50%}
  66%{border-radius:55% 45% 35% 65% / 65% 55% 45% 35%;transform:rotate(-60deg) scale(1.08)}
  100%{border-radius:30% 70% 60% 40% / 55% 45% 55% 45%;transform:rotate(-120deg) scale(1)}
}

/* Liquid gradient text — flowing color shift on headings */
.liquid-text{background:linear-gradient(135deg,#E8234A,#9F6CF7,#00C2F0,#E8234A);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:liquidShift 6s ease-in-out infinite}
@keyframes liquidShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

/* Liquid border glow — morphing gradient border on cards */
.liquid-border{position:relative;z-index:1}
.liquid-border::before{content:'';position:absolute;inset:-1px;border-radius:inherit;background:linear-gradient(135deg,rgba(232,35,74,.2),rgba(159,108,247,.2),rgba(0,194,240,.2),rgba(45,212,168,.2));background-size:300% 300%;animation:liquidShift 8s ease-in-out infinite;z-index:-1;opacity:0;transition:opacity .3s}
.liquid-border:hover::before{opacity:1}

/* Fluid section divider — wavy SVG line */
.om-wave-divider{width:100%;overflow:hidden;height:40px;margin:-1px 0}
.om-wave-divider svg{width:100%;height:100%;display:block}
.om-wave-divider path{animation:waveDrift 6s ease-in-out infinite alternate}
@keyframes waveDrift{0%{d:path('M0,20 C160,35 320,5 480,20 C640,35 800,5 960,20 L960,40 L0,40Z')}100%{d:path('M0,20 C160,5 320,35 480,20 C640,5 800,35 960,20 L960,40 L0,40Z')}}

/* Ripple ring — expanding rings from a point */

/* ── ANIMATED GRADIENT EFFECTS ── */

/* Aurora gradient — slow-moving color wash behind content */
.om-aurora{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.om-aurora::before,.om-aurora::after{content:'';position:absolute;width:150%;height:150%;border-radius:50%;filter:blur(120px);opacity:.06}
.om-aurora::before{background:conic-gradient(from 0deg,#E8234A,#9F6CF7,#00C2F0,#2DD4A8,#E5A011,#E8234A);top:-40%;left:-25%;animation:auroraRotate 20s linear infinite}
.om-aurora::after{background:conic-gradient(from 180deg,#9F6CF7,#00C2F0,#E8234A,#2DD4A8,#9F6CF7);bottom:-40%;right:-25%;animation:auroraRotate 25s linear infinite reverse}
@keyframes auroraRotate{to{transform:rotate(360deg)}}

/* Gradient orb — floating sphere with animated gradient fill */

/* Gradient line — horizontal animated gradient strip */
.om-grad-line{height:1px;background:linear-gradient(90deg,transparent,#E8234A,#9F6CF7,#00C2F0,transparent);background-size:200% 100%;animation:gradLineShift 4s linear infinite;opacity:.15}
@keyframes gradLineShift{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* Shimmer bar — loading/progress with gradient sweep */
.om-shimmer{height:2px;background:linear-gradient(90deg,transparent 0%,rgba(232,35,74,.4) 30%,rgba(159,108,247,.4) 50%,rgba(0,194,240,.4) 70%,transparent 100%);background-size:300% 100%;animation:shimmerSweep 2s ease-in-out infinite;border-radius:1px}
@keyframes shimmerSweep{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* Section gradient accent — colored wash at section edges */
.om-section-glow{position:relative}
.om-section-glow::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--sg-color,rgba(232,35,74,.15)),transparent);animation:gradLineShift 6s linear infinite;background-size:200% 100%}

/* ── GLOBAL BACKGROUND ANIMATION ── */

/* Slow-drifting gradient that covers the entire page body */
body{background:#030305;background-image:
  radial-gradient(ellipse at 10% 20%,rgba(232,35,74,.03),transparent 50%),
  radial-gradient(ellipse at 90% 80%,rgba(159,108,247,.025),transparent 50%),
  radial-gradient(ellipse at 50% 50%,rgba(0,194,240,.02),transparent 60%);
  background-attachment:fixed}

/* Animated gradient underlay that drifts across the body */
.om-bg-drift{position:fixed;inset:-50%;width:200%;height:200%;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse at 30% 40%,rgba(232,35,74,.035),transparent 50%),
             radial-gradient(ellipse at 70% 60%,rgba(159,108,247,.03),transparent 45%);
  animation:bgDrift 30s ease-in-out infinite alternate}
@keyframes bgDrift{
  0%{transform:translate(0,0)}
  33%{transform:translate(5%,-3%)}
  66%{transform:translate(-3%,4%)}
  100%{transform:translate(2%,-2%)}}

/* Per-page hero aurora variants */
.om-hero-neural .om-aurora::before{background:conic-gradient(from 0deg,#9F6CF7,#E8234A,#9F6CF7)}
.om-hero-twin .om-aurora::before{background:conic-gradient(from 0deg,#00C2F0,#2DD4A8,#00C2F0)}
.om-hero-dock .om-aurora::before{background:conic-gradient(from 0deg,#E8234A,#E5A011,#E8234A)}
.om-hero-voice .om-aurora::before{background:conic-gradient(from 0deg,#2DD4A8,#00C2F0,#2DD4A8)}
.om-hero-inventory .om-aurora::before{background:conic-gradient(from 0deg,#E5A011,#E8234A,#E5A011)}

@media(prefers-reduced-motion:reduce){
  .om-aurora,.om-blob,.om-bg-drift,.om-gradient-orb,.om-particle,.om-glow{animation:none !important}
}

/* ── AI CHAT DRAWER ── */
.om-chat{position:fixed;bottom:20px;right:20px;z-index:999;font-family:'Figtree',system-ui,sans-serif}
.om-chat-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:rgba(8,8,11,.9);backdrop-filter:blur(16px);border:1px solid rgba(159,108,247,.15);border-radius:100px;cursor:pointer;transition:all .25s;font-family:'JetBrains Mono',monospace;font-size:11px;color:rgba(159,108,247,.6)}
.om-chat-btn:hover{border-color:rgba(159,108,247,.3);color:#9F6CF7;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.om-chat-btn .one-dot{width:6px;height:6px;border-radius:50%;background:#9F6CF7;animation:omPulse 2s infinite}
.om-chat-drawer{position:absolute;bottom:52px;right:0;width:360px;max-height:480px;background:rgba(8,8,11,.95);backdrop-filter:blur(24px);border:1px solid rgba(159,108,247,.1);border-radius:16px;overflow:hidden;transform:translateY(10px) scale(.95);opacity:0;pointer-events:none;transition:all .25s cubic-bezier(.22,1,.36,1);display:flex;flex-direction:column;box-shadow:0 24px 64px rgba(0,0,0,.5)}
.om-chat-drawer.open{transform:translateY(0) scale(1);opacity:1;pointer-events:auto}
.om-chat-head{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.04);display:flex;justify-content:space-between;align-items:center}
.om-chat-head span{font-family:'JetBrains Mono',monospace;font-size:11px;color:#9F6CF7;text-transform:uppercase;letter-spacing:.06em}
.om-chat-close{width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.04);border:none;color:rgba(255,255,255,.3);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .15s}
.om-chat-close:hover{background:rgba(255,255,255,.08);color:#fff}
.om-chat-msgs{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:10px;min-height:200px;max-height:340px}
.om-chat-msgs::-webkit-scrollbar{width:3px}
.om-chat-msgs::-webkit-scrollbar-thumb{background:rgba(255,255,255,.06);border-radius:3px}
.om-chat-msg{font-size:13px;line-height:1.6;padding:10px 14px;border-radius:12px;max-width:90%;word-wrap:break-word}
.om-chat-msg.ai{background:rgba(159,108,247,.06);border:1px solid rgba(159,108,247,.08);color:rgba(255,255,255,.7);align-self:flex-start}
.om-chat-msg.user{background:rgba(232,35,74,.08);border:1px solid rgba(232,35,74,.1);color:rgba(255,255,255,.8);align-self:flex-end}
.om-chat-msg.typing{color:rgba(159,108,247,.4);font-style:italic}
.om-chat-input{display:flex;gap:8px;padding:12px 16px;border-top:1px solid rgba(255,255,255,.04)}
.om-chat-input input{flex:1;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:100px;padding:8px 14px;font-size:13px;color:#E8E8EC;font-family:'Figtree',sans-serif;outline:none;transition:border-color .15s}
.om-chat-input input:focus{border-color:rgba(159,108,247,.2)}
.om-chat-input input::placeholder{color:rgba(255,255,255,.15)}
.om-chat-send{width:32px;height:32px;border-radius:50%;background:#9F6CF7;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.om-chat-send:hover{background:#B088FF}
.om-chat-send:disabled{opacity:.3;cursor:not-allowed}
@media(max-width:480px){.om-chat-drawer{width:calc(100vw - 40px);right:-10px;bottom:56px}}

/* ── SWIPEABLE CARD CAROUSEL ── */
.om-carousel{position:relative;padding:0 24px;overflow:hidden}
.om-carousel-track{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:8px 0}
.om-carousel-track::-webkit-scrollbar{display:none}
.om-carousel-card{flex:0 0 85%;max-width:400px;scroll-snap-align:center;border-radius:20px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.04);overflow:hidden;transition:transform .25s}
.om-carousel-card:hover{transform:translateY(-4px)}
.om-carousel-visual{height:240px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:rgba(255,255,255,.01)}
.om-carousel-text{padding:20px 24px 28px}
.om-carousel-text h3{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:1.1rem;margin-bottom:8px;color:#fff}
.om-carousel-text p{font-size:14px;color:rgba(255,255,255,.35);line-height:1.6}
.om-carousel-dots{display:flex;justify-content:center;gap:8px;padding:20px 0}
.om-carousel-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.15);transition:all .25s;cursor:pointer}
.om-carousel-dot:hover{background:rgba(255,255,255,.3)}
.om-carousel-dot.active{background:#E8234A;transform:scale(1.2)}
@media(min-width:768px){.om-carousel-card{flex:0 0 45%;max-width:500px}}
@media(min-width:1024px){.om-carousel-card{flex:0 0 35%;max-width:440px}}

/* ── TECH PERFORMANCE CARDS (Framer-style) ── */
.om-perf-card{border-radius:20px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.04);overflow:hidden}
.om-perf-visual{height:300px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:40px}
.om-perf-text{padding:24px}
.om-perf-text h3{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:1.15rem;color:#fff;margin-bottom:8px}
.om-perf-text h3 span{color:rgba(255,255,255,.35);font-weight:400}
.om-perf-text p{font-size:14px;color:rgba(255,255,255,.3);line-height:1.7}
.om-tech-pill{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:11px;padding:2px 10px;border-radius:4px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.5);vertical-align:middle}

/* ── PAGE WIPE TRANSITION (enhanced) ── */
#om-wipe{position:fixed;inset:0;z-index:99999;background:#030305;transform:scaleY(0);transform-origin:bottom;pointer-events:none}
#om-wipe.in{transform:scaleY(1);transform-origin:top;transition:transform .4s cubic-bezier(.65,0,.35,1)}
#om-wipe.out{transform:scaleY(0);transform-origin:bottom;transition:transform .4s cubic-bezier(.65,0,.35,1)}

/* ── SIGNAL BUS VISUALIZATION (globe-style network) ── */
.om-signal-viz{position:relative;width:100%;height:300px;display:flex;align-items:center;justify-content:center}
.om-signal-viz canvas{width:100%;height:100%}

/* ── Skip-to-content (hidden until focused) ── */
.om-skip-nav{position:absolute;top:-100px;left:16px;z-index:100001;background:#E8234A;color:#fff;padding:8px 16px;border-radius:100px;font-size:13px;text-decoration:none;opacity:0;transition:top .2s,opacity .2s}
.om-skip-nav:focus{top:12px;opacity:1;outline:2px solid #fff;outline-offset:2px}

/* ── Ambient Glow Orbs ── */
.om-glow{position:fixed;border-radius:50%;pointer-events:none;z-index:0;opacity:.015;filter:blur(100px);animation:omGlowDrift 20s ease-in-out infinite alternate}
@keyframes omGlowDrift{0%{transform:translate(0,0)}50%{transform:translate(30px,-20px)}100%{transform:translate(-20px,15px)}}

/* ── ONE Narrations ── */
.om-narration{font-family:'JetBrains Mono',monospace;font-size:12px;color:rgba(159,108,247,.45);padding:8px 20px;border-left:2px solid rgba(159,108,247,.2);max-width:800px;margin:8px auto}
.om-narration::before{content:'> ONE: ';color:rgba(159,108,247,.65)}

/* ── Neural Dividers ── */
.om-neural-divider{display:flex;justify-content:center;padding:32px 0}
.om-neural-divider svg{width:120px;height:40px;overflow:visible}
.nd-line{stroke:var(--nd-color,#E8234A);stroke-width:.8;opacity:.3;stroke-dasharray:4 4;animation:ndDash 8s linear infinite}
.nd-dot{fill:var(--nd-color,#E8234A);opacity:.7;animation:ndPulse 3s ease-in-out infinite}
.nd-dot:nth-child(4){animation-delay:.4s}
.nd-dot:nth-child(5){animation-delay:.8s}
.nd-dot:nth-child(6){animation-delay:1.2s}
.nd-dot:nth-child(7){animation-delay:1.6s}
@keyframes ndDash{to{stroke-dashoffset:-60}}
@keyframes ndPulse{0%,100%{opacity:.3}50%{opacity:.7}}
