/* ─────────────────────────────────────────────────────────────
   Sync Unit — vanilla CSS
   ───────────────────────────────────────────────────────────── */

/* ─── Google Fonts ────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

/* ─── Monoblock font ──────────────────────────────────────── */
@font-face { font-family:'Monoblock'; src:url('fonts/Monoblock-Thin.woff2') format('woff2'); font-weight:100; font-display:swap; }
@font-face { font-family:'Monoblock'; src:url('fonts/Monoblock-ExtraLight.woff2') format('woff2'); font-weight:200; font-display:swap; }
@font-face { font-family:'Monoblock'; src:url('fonts/Monoblock-Light.woff2') format('woff2'); font-weight:300; font-display:swap; }
@font-face { font-family:'Monoblock'; src:url('fonts/Monoblock-Regular.woff2') format('woff2'); font-weight:400; font-display:swap; }
@font-face { font-family:'Monoblock'; src:url('fonts/Monoblock-Medium.woff2') format('woff2'); font-weight:500; font-display:swap; }
@font-face { font-family:'Monoblock'; src:url('fonts/Monoblock-SemiBold.woff2') format('woff2'); font-weight:600; font-display:swap; }
@font-face { font-family:'Monoblock'; src:url('fonts/Monoblock-Bold.woff2') format('woff2'); font-weight:700; font-display:swap; }
@font-face { font-family:'Monoblock'; src:url('fonts/Monoblock-ExtraBold.woff2') format('woff2'); font-weight:800; font-display:swap; }
@font-face { font-family:'Monoblock'; src:url('fonts/Monoblock-Black.woff2') format('woff2'); font-weight:900; font-display:swap; }

/* ─── Variables ───────────────────────────────────────────── */
:root {
  --bg:           #F8F7F5;
  --surface:      #FFFFFF;
  --surface-2:    #F2F1EE;
  --surface-3:    #E8E6E2;
  --ink:          #1C1C1C;
  --ink-muted:    #5A5A5A;
  --ink-light:    #9A9A9A;
  --border:       #E5E3DF;
  --burgundy:     #D4620A;
  --burgundy-bg:  #FEF5EE;
  --violet:       #4A3D6B;
  --violet-hover: #3B3058;
  --violet-bg:    #F0EEF7;
  --container:    1200px;
  --radius-lg:    0.75rem;   /* rounded-xl  */
  --radius-2xl:   1rem;      /* rounded-2xl */
  --ease-expo:    cubic-bezier(0.16,1,0.3,1);
}

/* ─── Reset ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body { font-family: 'Inter', system-ui, -apple-system, sans-serif; background: var(--bg); color: var(--ink); line-height: 1.6; }
img { display: block; max-width: 100%; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }
a { text-decoration: none; color: inherit; }
ul, ol { list-style: none; }
svg { display: block; flex-shrink: 0; }

/* ─── Scrollbar ───────────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: #F2F1EE; }
::-webkit-scrollbar-thumb { background: #C5C2BC; border-radius: 3px; }
:focus-visible { outline: 2px solid var(--burgundy); outline-offset: 3px; border-radius: 4px; }

/* ─── Layout helpers ─────────────────────────────────────── */
.container { max-width: var(--container); margin: 0 auto; padding: 0 1.5rem; }

/* ─── Typography ─────────────────────────────────────────── */
.font-display { font-family: 'Monoblock', 'Inter', system-ui, sans-serif; }

/* ─── Reveal animations ──────────────────────────────────── */
.reveal {
  opacity: 0; transform: translateY(32px);
  transition: opacity .8s var(--ease-expo), transform .8s var(--ease-expo);
}
.reveal.visible { opacity:1; transform:translateY(0); }

.reveal-left {
  opacity:0; transform:translateX(-32px);
  transition: opacity .8s var(--ease-expo), transform .8s var(--ease-expo);
}
.reveal-left.visible { opacity:1; transform:translateX(0); }

.reveal-right {
  opacity:0; transform:translateX(32px);
  transition: opacity .8s var(--ease-expo), transform .8s var(--ease-expo);
}
.reveal-right.visible { opacity:1; transform:translateX(0); }

.reveal-scale {
  opacity:0; transform:scale(.95);
  transition: opacity .8s var(--ease-expo), transform .8s var(--ease-expo);
}
.reveal-scale.visible { opacity:1; transform:scale(1); }

.reveal-blur {
  opacity:0; filter:blur(6px); transform:translateY(18px);
  transition: opacity .9s var(--ease-expo), filter .9s var(--ease-expo), transform .9s var(--ease-expo);
}
.reveal-blur.visible { opacity:1; filter:blur(0); transform:translateY(0); }

/* ─── Stagger delays ─────────────────────────────────────── */
.delay-50  { transition-delay:  50ms; }
.delay-100 { transition-delay: 100ms; }
.delay-150 { transition-delay: 150ms; }
.delay-200 { transition-delay: 200ms; }
.delay-250 { transition-delay: 250ms; }
.delay-300 { transition-delay: 300ms; }
.delay-400 { transition-delay: 400ms; }
.delay-500 { transition-delay: 500ms; }
.delay-600 { transition-delay: 600ms; }
.delay-700 { transition-delay: 700ms; }
.delay-800 { transition-delay: 800ms; }
.delay-900 { transition-delay: 900ms; }

/* ─── Keyframes ──────────────────────────────────────────── */
@keyframes float      { 0%,100%{transform:translateY(0)}  50%{transform:translateY(-10px)} }
@keyframes float-slow { 0%,100%{transform:translateY(0) rotate(0deg)} 50%{transform:translateY(-14px) rotate(3deg)} }
@keyframes pulse-ring { 0%{transform:scale(1);opacity:.7} 100%{transform:scale(2.6);opacity:0} }
@keyframes signal-blink { 0%,100%{opacity:1} 50%{opacity:.25} }
@keyframes bar-up    { 0%,100%{height:4px}  50%{height:20px} }
@keyframes rotate-slow         { from{transform:rotate(0deg)}   to{transform:rotate(360deg)} }
@keyframes rotate-slow-reverse { from{transform:rotate(0deg)}   to{transform:rotate(-360deg)} }
@keyframes scan-line { 0%{top:-4px;opacity:0} 5%{opacity:1} 95%{opacity:1} 100%{top:100%;opacity:0} }
@keyframes shimmer   { 0%{background-position:-200% center} 100%{background-position:200% center} }
@keyframes camera-drift {
  0%  {transform:translate(0,0)     scale(1.04)}
  20% {transform:translate(-6px,-4px) scale(1.04)}
  45% {transform:translate(-10px,-8px) scale(1.045)}
  70% {transform:translate(5px,-6px) scale(1.04)}
  100%{transform:translate(0,0)     scale(1.04)}
}
@keyframes beam-breathe {
  0%,100%{opacity:.55;transform:scaleX(1)}
  40%    {opacity:.85;transform:scaleX(1.08)}
  70%    {opacity:.45;transform:scaleX(0.92)}
}
@keyframes glow-pulse-text { 0%,100%{opacity:.85;filter:blur(0)}  50%{opacity:1;filter:blur(.3px)} }
@keyframes fog-drift {
  0%  {transform:translateX(0)   scaleX(1);opacity:.4}
  50% {transform:translateX(8%)  scaleX(1.1);opacity:.6}
  100%{transform:translateX(0)   scaleX(1);opacity:.4}
}
@keyframes floor-glow { 0%,100%{opacity:.5} 50%{opacity:.8} }
@keyframes bar-drift {
  0%  {opacity:.6;transform:translateY(0)    scaleY(1)}
  30% {opacity:1; transform:translateY(-12px) scaleY(1.04)}
  65% {opacity:.7;transform:translateY(8px)  scaleY(0.97)}
  100%{opacity:.6;transform:translateY(0)    scaleY(1)}
}
@keyframes hero-scan {
  0%,100% { opacity:0; transform:scaleX(0.4); }
  40%,60% { opacity:1; transform:scaleX(1); }
}
@keyframes hero-grid-pulse { 0%,100%{opacity:0} 20%,80%{opacity:1} 50%{opacity:.45} }
@keyframes bounce { 0%,100%{transform:translateY(0) translateX(-50%)} 50%{transform:translateY(-6px) translateX(-50%)} }
@keyframes fade-in { from{opacity:0} to{opacity:1} }
@keyframes fade-up { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }

/* ─── Animation utilities ────────────────────────────────── */
.animate-float      { animation: float 4s ease-in-out infinite; }
.animate-float-slow { animation: float-slow 7s ease-in-out infinite; }
.animate-signal     { animation: signal-blink 1.6s ease-in-out infinite; }
.animate-rotate     { animation: rotate-slow 22s linear infinite; }
.animate-rotate-rev { animation: rotate-slow-reverse 28s linear infinite; }
.animate-scan       { animation: scan-line 7s linear infinite; }
.animate-bounce     { animation: bounce 1.8s ease-in-out infinite; }
.animate-shimmer {
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,.1) 50%, transparent 100%);
  background-size: 200% 100%;
  animation: shimmer 2.5s linear infinite;
}
.animate-pulse { animation: signal-blink .9s ease-in-out infinite; }

/* ─── Wave bars ──────────────────────────────────────────── */
.wave-bars { display:flex; align-items:flex-end; gap:2px; height:20px; }
.wave-bar {
  display:inline-block; width:3px; background:currentColor;
  border-radius:2px; animation:bar-up 1.1s ease-in-out infinite; transform-origin:bottom;
}
.wave-bar:nth-child(1){animation-delay:.00s;height:8px}
.wave-bar:nth-child(2){animation-delay:.12s;height:14px}
.wave-bar:nth-child(3){animation-delay:.24s;height:6px}
.wave-bar:nth-child(4){animation-delay:.36s;height:18px}
.wave-bar:nth-child(5){animation-delay:.18s;height:10px}
.wave-bar:nth-child(6){animation-delay:.42s;height:16px}
.wave-bar:nth-child(7){animation-delay:.06s;height:8px}

/* ─── Background patterns ────────────────────────────────── */
.fine-grid {
  background-image:
    linear-gradient(rgba(212,98,10,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(212,98,10,.05) 1px,transparent 1px);
  background-size:64px 64px;
}
.fine-grid-dark {
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:64px 64px;
}

/* ─── Common UI pieces ───────────────────────────────────── */
.section-line { width:40px; height:3px; background:var(--burgundy); border-radius:2px; flex-shrink:0; }
.section-label { display:flex; align-items:center; gap:.75rem; margin-bottom:1.5rem; }
.section-label span { font-size:.7rem; font-weight:700; letter-spacing:.18em; color:var(--burgundy); text-transform:uppercase; }

.gradient-text {
  background: linear-gradient(135deg,#4A3D6B 0%,#D4620A 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.gradient-text-orange {
  background: linear-gradient(135deg,#D4620A 0%,#a855f7 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

.hover-underline { position:relative; }
.hover-underline::after {
  content:''; position:absolute; left:0; bottom:-2px; width:0; height:1.5px;
  background:currentColor; transition:width .3s var(--ease-expo);
}
.hover-underline:hover::after { width:100%; }

/* ─── Buttons ────────────────────────────────────────────── */
.btn-violet {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.875rem 1.75rem; background:var(--violet); color:#fff;
  font-size:.9rem; font-weight:600; border-radius:var(--radius-lg);
  transition:background .2s,box-shadow .2s,transform .2s;
  box-shadow:0 2px 12px rgba(74,61,107,.30);
}
.btn-violet:hover { background:var(--violet-hover); box-shadow:0 4px 20px rgba(74,61,107,.45); transform:translateY(-1px); }

.btn-outline-violet {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.625rem 1.25rem; border:1px solid var(--violet); color:var(--violet);
  font-size:.875rem; font-weight:600; border-radius:var(--radius-lg);
  transition:background .2s,color .2s;
}
.btn-outline-violet:hover { background:var(--violet); color:#fff; }

.btn-white-glass {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.875rem 1.75rem; color:rgba(255,255,255,.85);
  font-size:.9rem; font-weight:600; border-radius:var(--radius-lg);
  background:rgba(255,255,255,.07); backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.18);
  transition:transform .2s,background .2s;
}
.btn-white-glass:hover { transform:translateY(-2px); background:rgba(255,255,255,.12); }

/* ─────────────────────────────────────────────────────────────
   NAVBAR
   ───────────────────────────────────────────────────────────── */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:50;
  transition:background .5s var(--ease-expo), box-shadow .5s var(--ease-expo);
}
.navbar.scrolled {
  background:rgba(248,247,245,.96);
  backdrop-filter:blur(18px) saturate(1.5);
  -webkit-backdrop-filter:blur(18px) saturate(1.5);
  border-bottom:1px solid rgba(229,227,223,.8);
  box-shadow:0 1px 24px rgba(28,28,28,.06);
}
.navbar-inner {
  max-width:var(--container); margin:0 auto; padding:0 1.5rem;
  height:4rem; display:flex; align-items:center; justify-content:space-between;
}
.navbar-logo { display:flex; align-items:center; }
.navbar-logo svg { height:1.75rem; width:auto; }
.navbar-links { display:none; align-items:center; gap:.25rem; }
.nav-link {
  position:relative; padding:.5rem 1rem; font-size:.875rem; font-weight:500;
  color:var(--ink-muted); border-radius:.5rem;
  transition:color .2s,background .2s;
}
.nav-link::after {
  content:''; position:absolute; bottom:4px; left:1rem; right:1rem;
  height:1px; background:rgba(74,61,107,.4);
  transform:scaleX(0); transform-origin:left; transition:transform .3s var(--ease-expo);
  border-radius:1px;
}
.nav-link:hover { color:var(--ink); background:rgba(28,28,28,.05); }
.nav-link:hover::after { transform:scaleX(1); }

.navbar-cta {
  display:none;
  padding:.625rem 1.25rem; background:var(--violet); color:#fff;
  font-size:.875rem; font-weight:600; border-radius:.5rem;
  transition:background .2s,box-shadow .2s,transform .2s;
  box-shadow:0 2px 12px rgba(74,61,107,.30);
}
.navbar-cta:hover { background:var(--violet-hover); box-shadow:0 4px 20px rgba(74,61,107,.45); transform:translateY(-1px); }

/* Hamburger */
.hamburger {
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:5px; width:2.5rem; height:2.5rem;
}
.hamburger span {
  display:block; width:22px; height:1.5px; border-radius:2px;
  background:var(--ink); transform-origin:center;
  transition:transform .35s var(--ease-expo),opacity .2s;
}

/* Mobile menu */
.mobile-menu {
  overflow:hidden; max-height:0; opacity:0;
  background:rgba(248,247,245,.98); backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  transition:max-height .45s var(--ease-expo),opacity .3s;
}
.mobile-menu.open { max-height:360px; opacity:1; border-bottom:1px solid rgba(229,227,223,.8); }
.mobile-menu-inner { padding:.75rem 1.5rem 1.5rem; display:flex; flex-direction:column; gap:.25rem; }
.mobile-nav-link {
  text-align:left; padding:.75rem; font-size:1rem; font-weight:500;
  color:var(--ink-muted); border-radius:.75rem;
  transition:color .2s,background .2s,transform .4s var(--ease-expo),opacity .4s;
  transform:translateX(-8px); opacity:0;
}
.mobile-menu.open .mobile-nav-link { transform:translateX(0); opacity:1; }
.mobile-nav-link:hover { color:var(--ink); background:rgba(28,28,28,.04); }
.mobile-menu-cta {
  margin-top:.75rem; padding:.875rem; color:#fff; font-size:.875rem; font-weight:600;
  border-radius:.75rem; background:var(--violet); text-align:center;
  transition:transform .4s var(--ease-expo),opacity .4s;
  transform:translateX(-8px); opacity:0;
}
.mobile-menu.open .mobile-menu-cta { transform:translateX(0); opacity:1; }

/* Stagger mobile links */
.mobile-nav-link:nth-child(1){transition-delay:0ms}
.mobile-nav-link:nth-child(2){transition-delay:50ms}
.mobile-nav-link:nth-child(3){transition-delay:100ms}
.mobile-nav-link:nth-child(4){transition-delay:150ms}
.mobile-menu-cta           {transition-delay:200ms}

/* ─────────────────────────────────────────────────────────────
   HERO
   ───────────────────────────────────────────────────────────── */
.hero {
  position:relative; min-height:92vh; display:flex; flex-direction:column;
  justify-content:center; background:var(--bg); overflow:hidden; padding-top:4rem;
}
.hero-grid { position:absolute; inset:0; pointer-events:none; }
.hero-scan-beam { display:none; }
.hero-grid-h {
  position:absolute; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(212,98,10,.22) 15%,rgba(139,92,246,.16) 50%,rgba(212,98,10,.22) 85%,transparent);
  opacity:0; animation:hero-grid-pulse 7s ease-in-out infinite;
}
.hero-grid-v {
  position:absolute; top:0; bottom:0; width:1px;
  background:linear-gradient(to bottom,transparent,rgba(212,98,10,.18) 20%,rgba(139,92,246,.14) 55%,rgba(212,98,10,.18) 80%,transparent);
  opacity:0; animation:hero-grid-pulse 9s ease-in-out infinite;
}
.hero-glow-r {
  position:absolute; top:0; right:0; width:700px; height:700px;
  background:radial-gradient(circle,rgba(212,98,10,.08),transparent 65%);
  transform:translate(20%,-20%); pointer-events:none;
}
.hero-glow-l {
  position:absolute; bottom:0; left:0; width:500px; height:500px;
  background:radial-gradient(circle,rgba(107,91,138,.07),transparent 65%);
  transform:translate(-30%,30%); pointer-events:none;
}
.hero-left-strip {
  position:absolute; top:0; left:0; width:4px; height:100%;
  background:linear-gradient(to bottom,rgba(212,98,10,0),rgba(212,98,10,.5),rgba(212,98,10,0));
  pointer-events:none;
}
.hero-rings {
  display:none; position:absolute; top:25%; right:8%; width:14rem; height:14rem;
  pointer-events:none; opacity:.06;
}
.hero-inner {
  position:relative; max-width:var(--container); margin:0 auto;
  padding:4rem 1.5rem 5rem; width:100%;
}
.hero-grid-layout { display:grid; gap:3rem; align-items:center; }

/* Left copy */
.hero-eyebrow { display:flex; align-items:center; gap:.75rem; margin-bottom:1.75rem; }
.hero-eyebrow-dot { width:.5rem; height:.5rem; border-radius:50%; background:var(--burgundy); flex-shrink:0; }
.hero-eyebrow-line { width:2rem; height:1px; background:var(--burgundy); flex-shrink:0; }
.hero-eyebrow-text { font-size:.7rem; font-weight:700; letter-spacing:.2em; color:var(--burgundy); text-transform:uppercase; }

.hero-h1 {
  font-family:'Monoblock','Inter',system-ui,sans-serif;
  font-size:clamp(2.2rem,6vw,3.4rem); font-weight:900;
  line-height:1.05; letter-spacing:-.02em; color:var(--ink); margin-bottom:1.75rem;
}
.hero-lead { font-size:1.1rem; color:var(--ink-muted); line-height:1.7; max-width:32rem; margin-bottom:2.25rem; }
.hero-ctas { display:flex; flex-wrap:wrap; gap:1rem; margin-bottom:3rem; }
.hero-btn-secondary {
  padding:.875rem 1.75rem; background:var(--surface); color:var(--ink);
  font-size:.9rem; font-weight:600; border-radius:var(--radius-lg);
  border:1px solid var(--border); transition:border-color .2s,background .2s,transform .2s;
}
.hero-btn-secondary:hover { border-color:rgba(212,98,10,.4); background:var(--surface-2); transform:translateY(-1px); }

.hero-stats { display:flex; flex-wrap:wrap; gap:2rem; padding-top:2rem; border-top:1px solid var(--border); }
.hero-stat-num { font-size:1.875rem; font-weight:900; color:var(--burgundy); line-height:1; display:block; }
.hero-stat-label { font-size:.875rem; color:var(--ink-muted); margin-top:.125rem; display:block; }

/* Production Monitor */
.monitor-wrap {
  position:relative; height:300px;
  transition:opacity 1s var(--ease-expo),transform 1s var(--ease-expo);
}
.monitor-box {
  position:relative; width:100%; height:100%; border-radius:1rem;
  overflow:hidden; box-shadow:0 25px 50px -12px rgba(0,0,0,.5); background:#070610;
  user-select:none;
}
.monitor-drift {
  position:absolute; inset:0; will-change:transform;
  animation:camera-drift 18s ease-in-out infinite;
}
.monitor-floor {
  position:absolute; bottom:0; left:0; right:0; height:40%;
  background:linear-gradient(to top,rgba(74,61,107,.40),rgba(212,98,10,.15) 45%,transparent);
  animation:floor-glow 6s ease-in-out infinite; pointer-events:none;
}
.monitor-floor-line {
  position:absolute; left:0; right:0; bottom:28%; height:1px;
  background:linear-gradient(90deg,transparent,rgba(212,98,10,.35) 20%,rgba(255,255,255,.25) 50%,rgba(212,98,10,.35) 80%,transparent);
  pointer-events:none;
}
.monitor-beam { position:absolute; top:0; pointer-events:none; }
.monitor-vignette {
  position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse at 50% 45%,transparent 30%,rgba(4,3,10,.75) 100%);
}
.monitor-noise {
  position:absolute; inset:0; pointer-events:none; opacity:.035;
  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='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px;
}
.monitor-scanline-wrap { position:absolute; inset:0; overflow:hidden; pointer-events:none; }
.monitor-scanline {
  position:absolute; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(212,98,10,.3),rgba(139,92,246,.3),transparent);
}
.monitor-topbar {
  position:absolute; top:0; left:0; right:0;
  display:flex; align-items:center; justify-content:space-between;
  padding:.625rem 1rem; border-bottom:1px solid rgba(255,255,255,.07);
  background:rgba(7,6,16,.65); backdrop-filter:blur(16px);
}
.monitor-topbar-left { display:flex; align-items:center; gap:.5rem; }
.monitor-live-dot { width:.5rem; height:.5rem; border-radius:50%; background:#ef4444; }
.monitor-live-text { font-size:.55rem; font-weight:700; letter-spacing:.22em; color:rgba(255,255,255,.6); text-transform:uppercase; }
.monitor-topbar-right { display:flex; align-items:center; gap:.75rem; }
.monitor-topbar-right .wave-bars { color:rgba(212,98,10,.75); }
.monitor-res { font-size:.55rem; color:rgba(255,255,255,.3); font-family:monospace; }
.monitor-bottombar {
  position:absolute; bottom:0; left:0; right:0; padding:.875rem 1rem;
  background:rgba(7,6,16,.55); backdrop-filter:blur(16px);
  border-top:1px solid rgba(255,255,255,.06);
}
.monitor-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:.5rem; }
.monitor-stat-card {
  padding:.5rem .625rem; border-radius:.5rem;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07);
}
.monitor-stat-label { font-size:.5rem; font-weight:700; letter-spacing:.1em; color:rgba(255,255,255,.35); text-transform:uppercase; margin-bottom:.25rem; }
.monitor-stat-val { font-size:.75rem; font-weight:700; color:#fff; font-family:monospace; line-height:1; margin-bottom:.375rem; }
.monitor-stat-bar { height:2px; border-radius:1px; overflow:hidden; background:rgba(255,255,255,.08); }
.monitor-stat-fill { height:100%; border-radius:1px; }

.monitor-sync-text {
  position:absolute; inset:0; display:flex; flex-direction:column;
  align-items:center; justify-content:center; pointer-events:none; top:-4%;
}
.monitor-pill {
  margin-bottom:1.25rem; padding:.375rem 1rem; border-radius:9999px;
  display:flex; align-items:center; gap:.5rem;
  background:rgba(255,255,255,.04); backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.08); box-shadow:0 2px 20px rgba(0,0,0,.4);
}
.monitor-pill-text { font-size:.55rem; font-weight:700; letter-spacing:.25em; color:rgba(255,255,255,.5); text-transform:uppercase; }
.monitor-word {
  font-size:clamp(1.4rem,3.5vw,2.4rem); font-weight:900; text-transform:uppercase;
  letter-spacing:.28em; color:#fff; animation:glow-pulse-text 4s ease-in-out infinite;
  text-shadow:0 0 14px rgba(212,98,10,1),0 0 35px rgba(212,98,10,.7),0 0 70px rgba(212,98,10,.4),0 0 110px rgba(74,61,107,.6);
}
.monitor-unit { display:flex; align-items:center; gap:.75rem; margin-top:.75rem; }
.monitor-unit-line { width:1.5rem; height:1px; background:rgba(212,98,10,.4); }
.monitor-unit-text { font-size:.6875rem; font-weight:300; letter-spacing:.45em; color:rgba(255,255,255,.35); text-transform:uppercase; }

.monitor-corner-r { position:absolute; top:3rem; right:.75rem; display:flex; flex-direction:column; align-items:flex-end; gap:.25rem; pointer-events:none; }
.monitor-corner-l { position:absolute; top:3rem; left:.75rem; display:flex; flex-direction:column; align-items:flex-start; gap:.25rem; pointer-events:none; }

/* Floating badges */
.monitor-badge {
  position:absolute; background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-lg); box-shadow:0 10px 40px rgba(0,0,0,.12);
  padding:.625rem .875rem; display:flex; align-items:center; gap:.75rem; z-index:10;
}
.monitor-badge-sync { left:-1rem; top:33%; transform:translateY(-50%); }
.monitor-badge-ready { right:-1rem; bottom:3.5rem; }
.badge-icon {
  width:2rem; height:2rem; border-radius:.5rem; background:var(--burgundy-bg);
  display:flex; align-items:center; justify-content:center;
  color:var(--burgundy); flex-shrink:0;
}
.badge-title { font-size:.55rem; font-weight:700; color:var(--ink-light); text-transform:uppercase; letter-spacing:.1em; line-height:1; margin-bottom:.125rem; }
.badge-sub { font-size:.75rem; font-weight:700; color:var(--ink); line-height:1; }
.badge-dot { width:.5rem; height:.5rem; border-radius:50%; background:#34d399; flex-shrink:0; }

.monitor-corner-lines-br { position:absolute; bottom:-12px; right:-12px; pointer-events:none; }
.monitor-corner-lines-tl { position:absolute; top:-12px; left:-12px; pointer-events:none; }
.corner-h { position:absolute; height:1px; background:rgba(212,98,10,.3); }
.corner-v { position:absolute; width:1px; background:rgba(212,98,10,.3); }
.corner-h-v { position:absolute; height:1px; background:rgba(74,61,107,.2); }
.corner-v-tl { position:absolute; width:1px; background:rgba(74,61,107,.2); }

/* Scroll indicator */
.scroll-indicator {
  position:absolute; bottom:2rem; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:.375rem;
  opacity:.4; animation:bounce 1.8s ease-in-out infinite;
}
.scroll-indicator-text { font-size:.55rem; color:var(--ink-light); letter-spacing:.2em; text-transform:uppercase; }

/* ─────────────────────────────────────────────────────────────
   WHAT WE DO
   ───────────────────────────────────────────────────────────── */
.what-we-do { padding:6rem 0; background:var(--surface); }
.section-header { max-width:48rem; margin-bottom:4rem; }
.section-h2 { font-size:clamp(1.75rem,4vw,3rem); font-weight:900; color:var(--ink); line-height:1.2; margin-bottom:1.5rem; }
.section-lead { font-size:1.1rem; color:var(--ink-muted); line-height:1.7; }
.pillars-grid { display:grid; gap:1.5rem; }
.pillar-card {
  padding:2rem; border-radius:var(--radius-2xl); background:var(--bg);
  border:1px solid var(--border); transition:border-color .3s,box-shadow .3s;
}
.pillar-card:hover { border-color:rgba(212,98,10,.3); box-shadow:0 4px 16px rgba(0,0,0,.08); }
.pillar-icon {
  width:2.5rem; height:2.5rem; display:flex; align-items:center; justify-content:center;
  border-radius:.75rem; background:var(--burgundy-bg); color:var(--burgundy); margin-bottom:1.25rem;
}
.pillar-title { font-size:1.1rem; font-weight:700; color:var(--ink); margin-bottom:.75rem; }
.pillar-desc { font-size:.875rem; color:var(--ink-muted); line-height:1.7; }

/* ─────────────────────────────────────────────────────────────
   TECH BANNER (WebGL)
   ───────────────────────────────────────────────────────────── */
.tech-banner { position:relative; overflow:hidden; min-height:540px; background:#070610; }
.tech-banner canvas { position:absolute; inset:0; width:100%; height:100%; touch-action:none; pointer-events:none; }
.tech-banner-overlay {
  position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(to bottom,rgba(4,3,12,.55),rgba(4,3,12,.25) 50%,rgba(4,3,12,.60));
}
.tech-banner-overlay-2 {
  position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse 80% 100% at 20% 50%,transparent 30%,rgba(4,3,12,.5));
}
.tech-banner-line-top {
  position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(212,98,10,.5) 40%,rgba(74,61,107,.4) 60%,transparent);
  pointer-events:none;
}
.tech-banner-line-bot {
  position:absolute; bottom:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(212,98,10,.3) 50%,transparent);
  pointer-events:none;
}
.tech-banner-inner { position:relative; max-width:var(--container); margin:0 auto; padding:6rem 1.5rem; }
.tech-banner-grid { display:grid; gap:4rem; align-items:center; }
.tech-banner-h2 {
  font-family:'Monoblock','Inter',system-ui,sans-serif;
  font-size:clamp(1.75rem,4vw,3.4rem); font-weight:900;
  color:#fff; line-height:1.05; letter-spacing:-.02em; margin-bottom:1.5rem;
}
.tech-banner-lead { font-size:1.1rem; color:rgba(255,255,255,.55); line-height:1.7; max-width:32rem; margin-bottom:2.5rem; }
.tech-banner-btn {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.875rem 1.75rem; color:#fff; font-weight:600; font-size:.9rem;
  border-radius:var(--radius-lg);
  background:linear-gradient(135deg,#4A3D6B,#3B3058);
  box-shadow:0 4px 20px rgba(74,61,107,.4);
  transition:box-shadow .2s,transform .2s;
}
.tech-banner-btn:hover { box-shadow:0 8px 28px rgba(74,61,107,.55); transform:translateY(-1px); }
.tech-banner-stats { display:flex; flex-direction:column; gap:1px; }
.tech-stat-row {
  display:flex; align-items:center; gap:1.5rem; padding:1.25rem 1.5rem;
  border-radius:var(--radius-lg); cursor:default;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(12px); transition:background .3s,border-color .3s;
}
.tech-stat-row:hover { background:rgba(212,98,10,.10); border-color:rgba(212,98,10,.28); }
.tech-stat-num { font-size:.75rem; font-family:monospace; color:rgba(255,255,255,.2); flex-shrink:0; width:1.5rem; }
.tech-stat-divider { width:1px; align-self:stretch; background:rgba(212,98,10,.25); }
.tech-stat-val { font-size:1rem; font-weight:700; color:#fff; display:block; line-height:1.3; }
.tech-stat-sub { font-size:.875rem; color:rgba(255,255,255,.55); }
.tech-stat-arrow { margin-left:auto; opacity:0; transition:opacity .3s; color:var(--burgundy); }
.tech-stat-row:hover .tech-stat-arrow { opacity:1; }

/* ─────────────────────────────────────────────────────────────
   SERVICES
   ───────────────────────────────────────────────────────────── */
.services { padding:6rem 0; background:var(--bg); }
.services-header-grid {
  display:grid; grid-template-columns:1fr; gap:2rem; margin-bottom:4rem; align-items:end;
}
.services-header-right { display:flex; flex-direction:column; gap:0; }
@media(min-width:768px) {
  .services-header-grid { grid-template-columns:1fr 1fr; gap:4rem; }
}
.services-grid { display:grid; gap:1.25rem; }
.service-card {
  position:relative; border-radius:var(--radius-2xl); border:1px solid var(--border);
  background:var(--surface); overflow:hidden; transition:border-color .3s,box-shadow .3s;
}
.service-card:hover { box-shadow:0 8px 30px rgba(0,0,0,.1); }
.service-card.highlight { border-color:rgba(212,98,10,.2); box-shadow:0 1px 4px rgba(0,0,0,.05); }
.service-card.highlight:hover { border-color:rgba(212,98,10,.4); box-shadow:0 8px 30px rgba(0,0,0,.12); }
.service-highlight-strip {
  position:absolute; left:0; top:0; bottom:0; width:2px;
  background:linear-gradient(to bottom,rgba(212,98,10,0),#D4620A,rgba(212,98,10,0));
}
.service-img { position:relative; height:11rem; overflow:hidden; }
.service-img img { width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease-expo); }
.service-card:hover .service-img img { transform:scale(1.05); }
.service-img-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(255,255,255,.9) 0%,rgba(255,255,255,.2) 50%,transparent); }
.service-img-num { position:absolute; top:.75rem; right:1rem; font-size:2.5rem; font-weight:900; color:rgba(255,255,255,.2); line-height:1; }
.service-img-badge {
  position:absolute; top:.75rem; left:1rem; display:flex; align-items:center; gap:.375rem;
  background:rgba(0,0,0,.4); backdrop-filter:blur(6px); border-radius:9999px; padding:.25rem .625rem;
}
.service-img-badge span { font-size:.55rem; font-weight:700; color:rgba(255,255,255,.8); text-transform:uppercase; letter-spacing:.1em; }
.service-visual {
  margin:2rem 2rem 0; height:8rem; border-radius:.75rem; overflow:hidden;
  display:flex; align-items:center; justify-content:center; position:relative;
}
.service-visual.highlight-visual {
  background:linear-gradient(135deg,rgba(212,98,10,.1),rgba(212,98,10,.05),rgba(74,61,107,.1));
}
.service-visual.plain-visual { background:var(--surface-2); }
.service-visual .fine-grid { position:absolute; inset:0; opacity:.6; }
.service-visual-num { font-size:4.5rem; font-weight:900; line-height:1; z-index:1; }
.service-visual-signal {
  position:absolute; top:.75rem; left:.75rem; display:flex; align-items:center; gap:.375rem;
}
.service-visual-signal span { font-size:.55rem; font-weight:700; color:rgba(212,98,10,.6); text-transform:uppercase; letter-spacing:.1em; }
.service-body { padding:1.25rem 2rem 2rem; }
.service-img + .service-body { padding-top:1.25rem; }
.service-title { font-size:1.25rem; font-weight:700; color:var(--ink); margin-bottom:.75rem; transition:color .3s; }
.service-card:hover .service-title { color:var(--burgundy); }
.service-desc { font-size:.875rem; color:var(--ink-muted); line-height:1.7; margin-bottom:1.25rem; }
.service-tags { display:flex; flex-wrap:wrap; gap:.5rem; }
.service-tag {
  padding:.25rem .75rem; font-size:.75rem; font-weight:500;
  color:var(--ink-muted); background:var(--surface-2); border:1px solid var(--border); border-radius:9999px;
}
.services-cta { margin-top:3rem; text-align:center; }
.services-cta p { color:var(--ink-muted); margin-bottom:1.25rem; }

/* ─────────────────────────────────────────────────────────────
   FOR WHOM
   ───────────────────────────────────────────────────────────── */
.for-whom { padding:6rem 0; background:var(--surface); }
.for-whom-grid { display:grid; gap:4rem; align-items:start; }
.for-whom-profiles { display:flex; flex-direction:column; gap:1rem; }
.profile-card {
  display:flex; gap:1.25rem; padding:1.5rem; border-radius:.75rem;
  border:1px solid var(--border); background:var(--bg); transition:border-color .3s,background .3s;
}
.profile-card:hover { border-color:rgba(74,61,107,.3); background:rgba(240,238,247,.5); }
.profile-icon {
  flex-shrink:0; width:2.75rem; height:2.75rem; display:flex; align-items:center;
  justify-content:center; border-radius:.75rem; background:var(--surface);
  border:1px solid var(--border); color:var(--violet); transition:border-color .3s,color .3s;
}
.profile-card:hover .profile-icon { border-color:rgba(74,61,107,.4); }
.profile-title { font-weight:700; color:var(--ink); margin-bottom:.375rem; transition:color .3s; }
.profile-card:hover .profile-title { color:var(--violet); }
.profile-desc { font-size:.875rem; color:var(--ink-muted); line-height:1.7; }

/* ─────────────────────────────────────────────────────────────
   HOW WE WORK
   ───────────────────────────────────────────────────────────── */
.how-we-work { padding:6rem 0; background:var(--bg); }
.steps-list { display:flex; flex-direction:column; gap:2rem; }
.step-card {
  padding:2rem; background:var(--surface); border-radius:var(--radius-2xl);
  border:1px solid var(--border); transition:border-color .3s,box-shadow .3s;
}
.step-card:hover { border-color:rgba(212,98,10,.2); box-shadow:0 4px 16px rgba(0,0,0,.07); }
.step-num { font-size:3rem; font-weight:900; color:var(--surface-3); line-height:1; margin-bottom:1rem; }
.step-title { font-size:1.25rem; font-weight:700; color:var(--ink); margin-bottom:.75rem; }
.step-desc { font-size:.875rem; color:var(--ink-muted); line-height:1.7; margin-bottom:1rem; }
.step-detail { display:flex; align-items:center; gap:.5rem; }
.step-detail-dot { width:6px; height:6px; border-radius:50%; background:var(--burgundy); flex-shrink:0; }
.step-detail-text { font-size:.75rem; font-weight:600; color:var(--burgundy); }

/* ─────────────────────────────────────────────────────────────
   WHY SYNC UNIT
   ───────────────────────────────────────────────────────────── */
.why-sync {
  position:relative; padding:6rem 0; background:var(--ink); overflow:hidden;
}
.why-sync-bg-img {
  position:absolute; inset:0; background-size:cover; background-position:center;
  opacity:.06; pointer-events:none;
  background-image:url('https://images.unsplash.com/photo-1478737270239-2f02b77fc618?auto=format&fit=crop&w=1600&q=60');
}
.why-sync-orb-r {
  position:absolute; top:0; right:0; width:24rem; height:24rem;
  background:radial-gradient(circle,rgba(212,98,10,.12),transparent 70%);
  transform:translate(30%,-30%); pointer-events:none;
}
.why-sync-orb-l {
  position:absolute; bottom:0; left:0; width:20rem; height:20rem;
  background:radial-gradient(circle,rgba(107,91,138,.1),transparent 70%);
  transform:translate(-30%,30%); pointer-events:none;
}
.why-sync-ring { display:none; position:absolute; right:5%; top:50%; transform:translateY(-50%); opacity:.08; }
.why-sync-inner { position:relative; max-width:var(--container); margin:0 auto; padding:0 1.5rem; }
.reasons-grid { display:grid; gap:1rem; }
.reason-card {
  position:relative; padding:2rem; border-radius:var(--radius-2xl);
  border:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.04);
  overflow:hidden; transition:background .3s,border-color .3s;
}
.reason-card:hover { background:rgba(255,255,255,.07); border-color:rgba(212,98,10,.4); }
.reason-card-shimmer { position:absolute; inset:0; opacity:0; pointer-events:none; transition:opacity .5s; }
.reason-card:hover .reason-card-shimmer { opacity:1; }
.reason-icon {
  width:2.75rem; height:2.75rem; flex-shrink:0; display:flex; align-items:center;
  justify-content:center; border-radius:.75rem; background:rgba(212,98,10,.15);
  color:var(--burgundy); transition:background .3s,color .3s;
}
.reason-card:hover .reason-icon { background:var(--burgundy); color:#fff; }
.reason-body { margin-left:0; }
.reason-title { font-size:1rem; font-weight:700; color:#fff; margin-bottom:.5rem; }
.reason-desc { font-size:.875rem; color:rgba(255,255,255,.55); line-height:1.7; }
.reason-flex { display:flex; align-items:flex-start; gap:1.25rem; }
.why-cta-strip {
  margin-top:3.5rem; padding-top:3rem; border-top:1px solid rgba(255,255,255,.1);
  display:flex; flex-direction:column; gap:1.5rem; align-items:flex-start;
}
.why-cta-title { font-size:1.5rem; font-weight:700; color:#fff; margin-bottom:.25rem; }
.why-cta-sub { color:rgba(255,255,255,.5); }

/* ─────────────────────────────────────────────────────────────
   FAQ
   ───────────────────────────────────────────────────────────── */
.faq { padding:6rem 0; background:var(--surface); }
.faq-grid { display:grid; gap:4rem; }
.faq-list { display:flex; flex-direction:column; }
.faq-item { border-bottom:1px solid var(--border); }
.faq-item:last-child { border-bottom:none; }
.faq-question {
  width:100%; display:flex; align-items:flex-start; justify-content:space-between;
  gap:1rem; padding:1.25rem 0; text-align:left; cursor:pointer;
}
.faq-question-left { display:flex; align-items:flex-start; gap:1rem; }
.faq-q-num { flex-shrink:0; font-size:.75rem; font-weight:700; color:var(--ink-light); margin-top:2px; font-variant-numeric:tabular-nums; }
.faq-q-text { font-weight:600; color:var(--ink); transition:color .2s; }
.faq-question:hover .faq-q-text,
.faq-item.open .faq-q-text { color:var(--burgundy); }
.faq-toggle {
  flex-shrink:0; width:1.5rem; height:1.5rem; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border); background:var(--surface);
  transition:background .3s,border-color .3s,transform .3s;
}
.faq-item.open .faq-toggle { background:var(--burgundy); border-color:var(--burgundy); transform:rotate(45deg); }
.faq-toggle svg { width:.75rem; height:.75rem; color:var(--ink-muted); transition:color .3s; }
.faq-item.open .faq-toggle svg { color:#fff; }
.faq-answer {
  overflow:hidden; max-height:0;
  transition:max-height .4s var(--ease-expo),padding .3s;
}
.faq-item.open .faq-answer { max-height:300px; }
.faq-answer p { padding:0 0 1.25rem 2.5rem; color:var(--ink-muted); line-height:1.7; }

/* ─────────────────────────────────────────────────────────────
   EVENT INTRO
   ───────────────────────────────────────────────────────────── */
.event-intro { background:var(--ink); padding:6rem 0; overflow:hidden; position:relative; }
.event-intro-inner { position:relative; max-width:var(--container); margin:0 auto; padding:0 1.5rem; }
.event-types { display:grid; gap:1rem; grid-template-columns:1fr 1fr; margin-bottom:5rem; }
.event-card {
  border-radius:var(--radius-2xl); padding:1.5rem;
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.07);
  transition:transform .3s,background .3s,border-color .3s;
}
.event-card:hover { transform:translateY(-4px); }
.event-card-icon {
  width:2.75rem; height:2.75rem; border-radius:.75rem;
  display:flex; align-items:center; justify-content:center; margin-bottom:1rem;
  transition:background .3s;
}
.event-card-title { font-size:1rem; font-weight:700; color:#fff; margin-bottom:.5rem; }
.event-card-desc { font-size:.875rem; color:rgba(255,255,255,.6); line-height:1.6; }
.event-divider { height:1px; margin-bottom:5rem; background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent); }
.event-steps { display:grid; gap:2rem; margin-bottom:4rem; }
.event-step { position:relative; display:flex; align-items:flex-start; gap:1rem; }
.event-step-num { font-size:2.5rem; font-weight:900; line-height:1; flex-shrink:0; }
.event-step-title { font-size:1rem; font-weight:700; color:#fff; margin-bottom:.375rem; }
.event-step-desc { font-size:.875rem; color:rgba(255,255,255,.6); line-height:1.6; }
.event-cta { display:flex; flex-wrap:wrap; align-items:center; gap:1rem; }
.event-cta-sep { color:rgba(255,255,255,.5); font-size:.875rem; }
.event-cta-phone { color:rgba(255,255,255,.6); font-weight:600; font-size:.875rem; transition:color .2s; }
.event-cta-phone:hover { color:#fff; }

/* ─────────────────────────────────────────────────────────────
   SHADER CTA
   ───────────────────────────────────────────────────────────── */
.shader-cta { position:relative; width:100%; overflow:hidden; min-height:480px; }
.shader-cta canvas { position:absolute; inset:0; width:100%; height:100%; touch-action:none; }
.shader-cta-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom,rgba(4,3,12,.55),rgba(4,3,12,.35) 50%,rgba(4,3,12,.65));
  pointer-events:none;
}
.shader-cta-content {
  position:relative; z-index:10; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center; padding:6rem 1.5rem;
}
.shader-cta-badge {
  margin-bottom:2rem; padding:.5rem 1.25rem; border-radius:9999px;
  display:flex; align-items:center; gap:.625rem;
  background:rgba(212,98,10,.12); backdrop-filter:blur(12px); border:1px solid rgba(212,98,10,.30);
}
.shader-cta-badge span { font-size:.75rem; font-weight:700; letter-spacing:.22em; color:rgba(255,210,180,1); text-transform:uppercase; }
.shader-cta-h2 {
  font-size:clamp(2rem,5vw,3.5rem); font-weight:900; line-height:1.1; color:#fff;
  margin-bottom:1.25rem; max-width:48rem;
  text-shadow:0 2px 40px rgba(0,0,0,.6);
}
.shader-cta-sub {
  font-size:1rem; color:rgba(255,255,255,.7); line-height:1.7; max-width:36rem; margin-bottom:2.5rem;
  text-shadow:0 1px 10px rgba(0,0,0,.5);
}
.shader-cta-btns { display:flex; flex-wrap:wrap; gap:1rem; align-items:center; justify-content:center; }
.shader-cta-btn-main {
  padding:1rem 2rem; font-weight:600; border-radius:var(--radius-lg); color:#fff;
  background:linear-gradient(135deg,#D4620A,#4A3D6B);
  box-shadow:0 4px 24px rgba(212,98,10,.35); transition:transform .2s,box-shadow .2s;
}
.shader-cta-btn-main:hover { transform:scale(1.03); box-shadow:0 8px 32px rgba(212,98,10,.5); }
.shader-cta-trust { margin-top:3.5rem; display:flex; flex-wrap:wrap; justify-content:center; gap:2rem; }
.shader-trust-item { display:flex; flex-direction:column; align-items:center; gap:.25rem; }
.shader-trust-num { font-size:1.5rem; font-weight:900; color:#fff; text-shadow:0 0 20px rgba(212,98,10,.6); }
.shader-trust-label { font-size:.75rem; color:rgba(255,255,255,.45); letter-spacing:.1em; text-transform:uppercase; }

/* ─────────────────────────────────────────────────────────────
   CONTACT
   ───────────────────────────────────────────────────────────── */
.contact { padding:6rem 0; background:var(--bg); }
.contact-grid { display:grid; gap:4rem; }
.contact-detail { display:flex; align-items:center; gap:1rem; }
.contact-detail-icon {
  width:2.75rem; height:2.75rem; display:flex; align-items:center; justify-content:center;
  border-radius:.75rem; border:1px solid var(--border); background:var(--surface);
  color:var(--ink-muted); transition:border-color .2s,color .2s; flex-shrink:0;
}
.contact-detail:hover .contact-detail-icon { border-color:rgba(212,98,10,.4); color:var(--burgundy); }
.contact-detail-label { font-size:.65rem; font-weight:500; color:var(--ink-light); text-transform:uppercase; letter-spacing:.1em; }
.contact-detail-val { font-weight:600; color:var(--ink); transition:color .2s; }
.contact-detail:hover .contact-detail-val { color:var(--burgundy); }
.contact-details { display:flex; flex-direction:column; gap:1.25rem; }

/* Form */
.contact-form-wrap { background:var(--surface); border-radius:var(--radius-2xl); border:1px solid var(--border); padding:2rem; box-shadow:0 1px 3px rgba(0,0,0,.05); }
.form-row { display:grid; gap:1rem; margin-bottom:1rem; }
.form-group { display:flex; flex-direction:column; gap:.375rem; }
.form-label { font-size:.65rem; font-weight:600; color:var(--ink-muted); text-transform:uppercase; letter-spacing:.1em; }
.form-input, .form-select, .form-textarea {
  width:100%; padding:.75rem 1rem; border-radius:.75rem;
  border:1px solid var(--border); background:var(--bg);
  color:var(--ink); font-size:.875rem; font-family:inherit;
  transition:border-color .2s,background .2s; appearance:none;
}
.form-input::placeholder, .form-textarea::placeholder { color:var(--ink-light); }
.form-input:focus, .form-select:focus, .form-textarea:focus {
  outline:none; border-color:rgba(212,98,10,.6); background:#fff;
}
.form-textarea { resize:none; }
.form-submit {
  width:100%; padding:1rem; background:var(--violet); color:#fff;
  font-weight:600; border-radius:.75rem; font-size:1rem;
  transition:background .2s,box-shadow .2s,opacity .2s;
  display:flex; align-items:center; justify-content:center; gap:.5rem;
}
.form-submit:hover { background:var(--violet-hover); box-shadow:0 4px 16px rgba(74,61,107,.35); }
.form-submit:disabled { opacity:.6; cursor:not-allowed; }
.form-note { text-align:center; font-size:.75rem; color:var(--ink-light); margin-top:1rem; }
.form-success {
  display:none; flex-direction:column; align-items:center; justify-content:center;
  padding:4rem 2rem; text-align:center;
}
.form-success.visible { display:flex; }
.form-success-icon {
  width:4rem; height:4rem; border-radius:50%; background:var(--burgundy-bg);
  display:flex; align-items:center; justify-content:center; margin-bottom:1.5rem;
}
.form-success-icon svg { color:var(--burgundy); }
.form-success h3 { font-size:1.5rem; font-weight:700; color:var(--ink); margin-bottom:.75rem; }
.form-success p { color:var(--ink-muted); max-width:20rem; }
.spinner {
  width:1rem; height:1rem; border:2px solid rgba(255,255,255,.4);
  border-top-color:#fff; border-radius:50%;
  animation:rotate-slow .7s linear infinite; display:none;
}
.form-submit.loading .spinner { display:block; }
.form-submit.loading .submit-text { display:none; }

/* ─────────────────────────────────────────────────────────────
   FOOTER
   ───────────────────────────────────────────────────────────── */
.footer { background:var(--ink); color:#fff; }
.footer-top { max-width:var(--container); margin:0 auto; padding:4rem 1.5rem 3rem; }
.footer-grid { display:grid; gap:2.5rem; }
.footer-brand-logo { margin-bottom:1rem; }
.footer-brand-logo svg { height:2.5rem; width:auto; opacity:.6; }
.footer-brand-desc { color:rgba(255,255,255,.6); line-height:1.7; font-size:.875rem; max-width:22rem; margin-bottom:1.5rem; }
.footer-contact-links { display:flex; flex-direction:column; gap:.5rem; }
.footer-contact-link { display:flex; align-items:center; gap:.5rem; font-size:.875rem; color:rgba(255,255,255,.6); transition:color .2s; }
.footer-contact-link:hover { color:#fff; }
.footer-col-title { font-size:.75rem; font-weight:700; letter-spacing:.14em; color:rgba(255,255,255,.4); text-transform:uppercase; margin-bottom:1rem; }
.footer-nav-list { display:flex; flex-direction:column; gap:.625rem; }
.footer-nav-btn { font-size:.875rem; color:rgba(255,255,255,.6); transition:color .2s; text-align:left; }
.footer-nav-btn:hover { color:#fff; }
.footer-divider { border:none; border-top:1px solid rgba(255,255,255,.1); }
.footer-bottom { max-width:var(--container); margin:0 auto; padding:1.5rem 1.5rem; display:flex; flex-direction:column; gap:1rem; align-items:center; }
.footer-copy { font-size:.75rem; color:rgba(255,255,255,.3); text-align:center; }

/* ─────────────────────────────────────────────────────────────
   RESPONSIVE
   ───────────────────────────────────────────────────────────── */
@media (min-width:640px) {
  .event-types { grid-template-columns:repeat(2,1fr); }
  .event-steps  { grid-template-columns:repeat(3,1fr); }
  .hero-stats { flex-wrap:nowrap; }
}

@media (min-width:768px) {
  .what-we-do  { padding:8rem 0; }
  .services    { padding:8rem 0; }
  .for-whom    { padding:8rem 0; }
  .how-we-work { padding:8rem 0; }
  .why-sync    { padding:8rem 0; }
  .faq         { padding:8rem 0; }
  .event-intro { padding:8rem 0; }
  .contact     { padding:8rem 0; }

  .pillars-grid    { grid-template-columns:repeat(3,1fr); }
  .services-grid   { grid-template-columns:repeat(2,1fr); }
  .reasons-grid    { grid-template-columns:repeat(2,1fr); }
  .form-row        { grid-template-columns:repeat(2,1fr); }
  .footer-grid     { grid-template-columns:1fr 1fr; }
  .footer-bottom   { flex-direction:row; justify-content:space-between; }
  .why-sync-ring   { display:block; }
}

@media (min-width:1024px) {
  .navbar-links  { display:flex; }
  .navbar-cta    { display:block; }
  .hamburger     { display:none; }
  .hero-rings    { display:block; }
  .hero-grid-layout    { grid-template-columns:1fr 1fr; gap:4rem; }
  .monitor-wrap        { height:390px; }
  .monitor-badge-sync  { left:-1.5rem; }
  .monitor-badge-ready { right:-1.5rem; }
  .tech-banner-grid    { grid-template-columns:1fr 1fr; }
  .for-whom-grid       { grid-template-columns:1fr 1fr; gap:6rem; }
  .for-whom-sticky     { position:sticky; top:7rem; }
  .faq-grid            { grid-template-columns:1fr 1fr; gap:6rem; }
  .faq-sticky          { position:sticky; top:7rem; height:fit-content; }
  .contact-grid        { grid-template-columns:1fr 1fr; gap:6rem; }
  .footer-grid         { grid-template-columns:2fr 1fr 1fr; }
  .how-steps-desktop   { display:block; }

  /* Steps zig-zag desktop */
  .steps-list { position:relative; gap:0; }
  .steps-list::before {
    content:''; position:absolute; left:50%; top:0; bottom:0; width:1px;
    background:var(--border); transform:translateX(-50%);
  }
  .step-row {
    position:relative; display:flex; align-items:center; gap:0; margin-bottom:2rem;
  }
  .step-row:last-child { margin-bottom:0; }
  .step-card-wrap { width:calc(50% - 3rem); }
  .step-row:nth-child(even) .step-card-wrap { margin-left:auto; padding-left:3rem; }
  .step-row:nth-child(odd)  .step-card-wrap { margin-right:auto; padding-right:3rem; }
  .step-dot {
    position:absolute; left:50%; transform:translateX(-50%);
    width:1.5rem; height:1.5rem; border-radius:50%; background:var(--burgundy);
    border:4px solid var(--bg); z-index:1; display:flex; align-items:center; justify-content:center;
  }
  .step-dot-inner { width:.5rem; height:.5rem; border-radius:50%; background:#fff; }
  .step-spacer { width:calc(50% - 3rem); }
  .why-cta-strip { flex-direction:row; align-items:center; justify-content:space-between; }
  .event-types { grid-template-columns:repeat(4,1fr); }
}

/* ═════════════════════════════════════════════════════════════
   ANIMATIONS — scroll progress · cursor · marquee
   ═════════════════════════════════════════════════════════════ */

/* ─── Scroll progress bar ────────────────────────────────── */
#scroll-progress {
  position: fixed; top: 0; left: 0; z-index: 9998;
  height: 2px; width: 0%;
  background: linear-gradient(90deg, #D4620A 0%, #4A3D6B 100%);
  pointer-events: none;
  transition: width .08s linear;
  transform-origin: left;
}

/* ─── Custom cursor (desktop) ────────────────────────────── */
body.custom-cursor,
body.custom-cursor * { cursor: none !important; }
body.custom-cursor input,
body.custom-cursor textarea,
body.custom-cursor select { cursor: text !important; }

.cursor-ring {
  position: fixed; z-index: 9996;
  width: 36px; height: 36px; border-radius: 50%;
  border: 1.5px solid rgba(212, 98, 10, 0.5);
  pointer-events: none;
  transform: translate(-50%, -50%);
  opacity: 0;
  transition:
    opacity .3s ease,
    width .3s var(--ease-expo),
    height .3s var(--ease-expo),
    border-color .25s ease,
    background-color .25s ease;
}
.cursor-ring.active  { opacity: 1; }
.cursor-ring.hovered {
  width: 54px; height: 54px;
  border-color: rgba(74, 61, 107, 0.6);
  background-color: rgba(74, 61, 107, 0.05);
}
.cursor-dot {
  position: fixed; z-index: 9999;
  width: 6px; height: 6px; border-radius: 50%;
  background: #D4620A;
  pointer-events: none;
  transform: translate(-50%, -50%);
  opacity: 0;
  transition: opacity .2s ease;
}
.cursor-dot.active { opacity: 1; }

/* ─── Marquee expertise strip ────────────────────────────── */
.marquee-strip {
  overflow: hidden; position: relative;
  border-top: 1px solid rgba(255,255,255,.07);
  border-bottom: 1px solid rgba(255,255,255,.07);
  background: #0a0818;
  padding: .875rem 0;
  user-select: none;
}
.marquee-track {
  display: inline-flex; align-items: center;
  white-space: nowrap;
  animation: marquee-scroll 32s linear infinite;
  will-change: transform;
}
.marquee-track:hover { animation-play-state: paused; }
.marquee-item {
  display: inline-flex; align-items: center; gap: .75rem;
  padding: 0 1.75rem;
  font-size: .68rem; font-weight: 700;
  letter-spacing: .15em; text-transform: uppercase;
  color: rgba(255,255,255,.38);
  transition: color .2s ease;
}
.marquee-item:hover { color: #D4620A; }
.marquee-sep {
  display: inline-block; flex-shrink: 0;
  width: 3px; height: 3px; border-radius: 50%;
  background: #D4620A; opacity: .4;
}
@keyframes marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ─── Reduced-motion overrides ───────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .marquee-track { animation: none; }
  .cursor-ring, .cursor-dot { display: none; }
  #scroll-progress { transition: none; }
}
