/* ============================================================
   PREMIUM DESIGN SYSTEM — infoSite
   Token-driven, RTL-first, glassmorphic, motion-aware.
   ============================================================ */

/* ---------- 1. TOKENS ---------- */
:root {
  /* Brand (overridden by inline :root in head) */
  --main:        #6C63FF;
  --hover:       #5B53E8;
  --main2:       linear-gradient(135deg, #6C63FF, #8B5CF6);

  /* Premium palette */
  --bg:          #0B0F1E;
  --bg-soft:     #11162A;
  --bg-elev:     #161C36;
  --surface:     rgba(255,255,255,0.04);
  --surface-2:   rgba(255,255,255,0.06);
  --border:      rgba(255,255,255,0.08);
  --border-strong: rgba(255,255,255,0.14);

  --ink:         #F4F6FB;
  --ink-soft:    #C6CADB;
  --ink-mute:    #8A91AE;

  --primary:     #6C63FF;
  --primary-2:   #8B5CF6;
  --accent:      #06B6D4;
  --accent-2:    #22D3EE;
  --success:     #10B981;
  --warn:        #F59E0B;
  --danger:      #EF4444;

  /* Gradients */
  --grad-primary: linear-gradient(135deg, #6C63FF 0%, #8B5CF6 60%, #06B6D4 100%);
  --grad-hero:    radial-gradient(60% 50% at 80% 10%, rgba(108,99,255,.35) 0%, transparent 60%),
                  radial-gradient(50% 50% at 10% 90%, rgba(6,182,212,.25) 0%, transparent 60%),
                  radial-gradient(40% 40% at 50% 50%, rgba(139,92,246,.18) 0%, transparent 60%);
  --grad-text:    linear-gradient(120deg, #ffffff 0%, #C6CADB 60%, #8B5CF6 100%);
  --grad-border:  linear-gradient(135deg, rgba(255,255,255,.22), rgba(255,255,255,.04));

  /* Radii */
  --r-xs: 6px;
  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 22px;
  --r-xl: 32px;
  --r-pill: 999px;

  /* Spacing scale (8px base) */
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 24px;
  --s-6: 32px;
  --s-7: 48px;
  --s-8: 64px;
  --s-9: 96px;
  --s-10: 128px;

  /* Shadows */
  --sh-sm:  0 1px 2px rgba(0,0,0,.20), 0 1px 1px rgba(0,0,0,.06);
  --sh-md:  0 8px 24px rgba(0,0,0,.25), 0 2px 6px rgba(0,0,0,.10);
  --sh-lg:  0 24px 60px rgba(0,0,0,.35), 0 8px 16px rgba(0,0,0,.18);
  --sh-glow: 0 0 0 1px rgba(108,99,255,.25), 0 20px 60px rgba(108,99,255,.35);

  /* Typography */
  --font-sans: 'Cairo', 'IBM Plex Sans Arabic', 'Tajawal', 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --font-display: 'Cairo', 'IBM Plex Sans Arabic', 'Tajawal', 'Inter', system-ui, sans-serif;

  /* Motion */
  --ease:        cubic-bezier(.2,.7,.2,1);
  --ease-out:    cubic-bezier(.16,1,.3,1);
  --ease-in:     cubic-bezier(.7,0,.84,0);
  --dur-1: 160ms;
  --dur-2: 280ms;
  --dur-3: 480ms;
  --dur-4: 800ms;

  /* Layout */
  --nav-h: 80px;
  --container: 1240px;
}

/* ---------- 2. RESET ---------- */
*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

/* Keep the fixed/sticky header from covering section titles when we
   scrollIntoView() them from the navbar / footer links. */
section[id] { scroll-margin-top: 96px; }
@media (max-width: 960px) {
  section[id] { scroll-margin-top: 80px; }
}
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink);
  background: var(--bg);
  background-image:
    radial-gradient(60% 50% at 80% -10%, rgba(108,99,255,.18) 0%, transparent 60%),
    radial-gradient(50% 50% at -10% 30%, rgba(6,182,212,.10) 0%, transparent 60%),
    linear-gradient(180deg, #0B0F1E 0%, #0B0F1E 100%);
  background-attachment: fixed;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  direction: rtl;
  text-align: right;
}

img, svg, video { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; transition: color var(--dur-1) var(--ease); }
button { font-family: inherit; cursor: pointer; }
ul { padding: 0; margin: 0; list-style: none; }
p { margin: 0 0 var(--s-3); color: var(--ink-soft); }

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

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, var(--primary), var(--primary-2));
  border-radius: 999px;
  border: 2px solid var(--bg);
}

/* ---------- 3. TYPOGRAPHY ---------- */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  color: var(--ink);
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin: 0 0 var(--s-4);
  font-weight: 800;
}

h1 { font-size: clamp(2.2rem, 5.2vw, 4.4rem); letter-spacing: -0.02em; }
h2 { font-size: clamp(1.8rem, 3.6vw, 3rem); }
h3 { font-size: clamp(1.5rem, 2.6vw, 2.25rem); }
h4 { font-size: clamp(1.2rem, 1.8vw, 1.5rem); }
h5 { font-size: 1.125rem; }
h6 { font-size: 1rem; text-transform: uppercase; letter-spacing: .12em; font-weight: 700; }

.gradient-text {
  background: var(--grad-text);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
}
.brand-text {
  background: var(--grad-primary);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 6px 14px;
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-pill);
  font-size: .82rem;
  font-weight: 600;
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: .15em;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.eyebrow::before {
  content: "";
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--accent-2);
  box-shadow: 0 0 0 4px rgba(34,211,238,.18);
  animation: pulseDot 2s ease-in-out infinite;
}
@keyframes pulseDot {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%      { transform: scale(1.3); opacity: .55; }
}

/* ---------- 4. LAYOUT ---------- */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding-inline: clamp(20px, 4vw, 48px);
}

.sec-padd {
  padding: clamp(72px, 9vw, 140px) 0 !important;
  position: relative;
}

.the_title {
  text-align: center;
  max-width: 760px;
  margin: 0 auto clamp(40px, 6vw, 72px) !important;
}
.the_title h3 {
  font-size: clamp(1.8rem, 3.6vw, 3rem) !important;
  font-weight: 800 !important;
  letter-spacing: -.02em;
  background: var(--grad-text);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
}
.the_title p { color: var(--ink-mute); font-size: 1.05rem; max-width: 620px; margin: 0 auto; }

.body-content { margin-top: 0 !important; }

/* ---------- 5. BUTTONS ---------- */
.btn-main,
.btn-ghost,
.btn-line {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  padding: 14px 28px;
  font-weight: 700;
  font-size: .95rem;
  line-height: 1.2;
  border-radius: var(--r-pill);
  border: 1px solid transparent;
  transition: transform var(--dur-2) var(--ease),
              box-shadow var(--dur-2) var(--ease),
              background var(--dur-2) var(--ease),
              color var(--dur-1) var(--ease);
  will-change: transform;
  letter-spacing: .01em;
  cursor: pointer;
  text-decoration: none;
  overflow: hidden;
  isolation: isolate;
  white-space: nowrap;     /* never wrap button text */
  word-break: keep-all;
}
.btn-main > *,
.btn-ghost > *,
.btn-line > * { white-space: nowrap; }
.btn-main {
  color: #fff;
  background: var(--grad-primary);
  box-shadow: var(--sh-md), 0 0 0 1px rgba(255,255,255,.08) inset;
}
.btn-main::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(135deg, #8B5CF6, #06B6D4);
  opacity: 0;
  transition: opacity var(--dur-2) var(--ease);
  z-index: -1;
}
.btn-main:hover {
  transform: translateY(-2px);
  box-shadow: var(--sh-lg), 0 0 0 1px rgba(255,255,255,.12) inset;
  color: #fff;
}
.btn-main:hover::before { opacity: 1; }
.btn-main:active { transform: translateY(0); }

.btn-ghost {
  color: var(--ink);
  background: var(--surface-2);
  border-color: var(--border-strong);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.btn-ghost:hover {
  background: var(--surface);
  border-color: rgba(255,255,255,.22);
  transform: translateY(-2px);
  color: #fff;
}

.btn-line {
  color: var(--ink);
  background: transparent;
  border-color: var(--border-strong);
}
.btn-line:hover {
  border-color: var(--primary-2);
  color: #fff;
  background: rgba(108,99,255,.08);
}

/* ---------- 6. CARDS / GLASS ---------- */
.glass {
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border: 1px solid var(--border-strong);
  border-radius: var(--r-lg);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  box-shadow: var(--sh-md);
}

.glow-card {
  position: relative;
  border-radius: var(--r-lg);
  isolation: isolate;
  transition: transform var(--dur-3) var(--ease-out),
              box-shadow var(--dur-3) var(--ease-out);
}
.glow-card::before {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: var(--grad-border);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
}
.glow-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--sh-lg);
}

/* ============================================================
   7. NAVBAR
   ============================================================ */
header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  height: var(--nav-h);
  display: flex; align-items: center;
  background: linear-gradient(180deg, rgba(11,15,30,.55), rgba(11,15,30,.0));
  transition: background var(--dur-2) var(--ease),
              backdrop-filter var(--dur-2) var(--ease),
              box-shadow var(--dur-2) var(--ease),
              border-color var(--dur-2) var(--ease);
  border-bottom: 1px solid transparent;
}
header.is-scrolled {
  background: rgba(11,15,30,.72);
  backdrop-filter: saturate(160%) blur(18px);
  -webkit-backdrop-filter: saturate(160%) blur(18px);
  border-bottom-color: var(--border);
  box-shadow: 0 10px 30px -10px rgba(0,0,0,.6);
}
header > .container { width: 100%; }

.the-logo {
  height: 42px;
  width: auto;
  filter: drop-shadow(0 4px 14px rgba(108,99,255,.35));
  transition: transform var(--dur-2) var(--ease);
}
a:hover .the-logo { transform: scale(1.03); }

.nav_bar {
  display: flex;
  align-items: center;
  gap: clamp(8px, 1.4vw, 22px);
  margin: 0 var(--s-7);
  padding: 6px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.nav_bar > li > a {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: 9px 18px;
  border-radius: var(--r-pill);
  color: var(--ink-soft);
  font-weight: 600;
  font-size: .94rem;
  white-space: nowrap;
  transition: color var(--dur-1) var(--ease), background var(--dur-2) var(--ease);
}
.nav_bar > li > a:hover {
  color: #fff;
  background: rgba(255,255,255,.06);
}
.nav_bar > li > a.active {
  color: #fff;
  background: var(--grad-primary);
  box-shadow: 0 8px 22px -10px rgba(108,99,255,.7);
}

.dropdown { position: relative; }
.dropdown > .dropdown-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 10px 18px;
  background: var(--surface-2);
  border: 1px solid var(--border-strong);
  color: var(--ink);
  border-radius: var(--r-pill);
  font-weight: 600;
  font-size: .9rem;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: background var(--dur-2) var(--ease), border-color var(--dur-2) var(--ease);
}
.dropdown > .dropdown-toggle:hover,
.dropdown > .dropdown-toggle:focus {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.25);
  color: #fff;
}
.dropdown-menu {
  background: rgba(17,22,42,.92);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-md);
  padding: var(--s-2);
  min-width: 160px;
  box-shadow: var(--sh-lg);
  margin-top: var(--s-2);
}
.dropdown-menu .dropdown-item {
  display: block;
  padding: 10px 14px;
  border-radius: var(--r-sm);
  color: var(--ink-soft);
  font-weight: 600;
  font-size: .9rem;
  transition: background var(--dur-1) var(--ease), color var(--dur-1) var(--ease);
}
.dropdown-menu .dropdown-item:hover {
  background: var(--surface-2);
  color: #fff;
}

.close-open-nav {
  display: none;
  width: 44px; height: 44px;
  border-radius: 12px;
  background: var(--surface-2);
  border: 1px solid var(--border-strong);
  align-items: center; justify-content: center;
  cursor: pointer;
  margin-inline-start: var(--s-3);
  transition: background var(--dur-2) var(--ease), border-color var(--dur-2) var(--ease);
}
.close-open-nav > div {
  position: relative;
  width: 22px; height: 16px;
}
.close-open-nav span {
  position: absolute;
  left: 0; right: 0;
  height: 2px;
  background: var(--ink);
  border-radius: 2px;
  transition: transform var(--dur-2) var(--ease),
              top var(--dur-2) var(--ease),
              opacity var(--dur-1) var(--ease);
}
.close-open-nav span:nth-child(1) { top: 0; }
.close-open-nav span:nth-child(2) { top: 7px; }
.close-open-nav span:nth-child(3) { top: 14px; }
.close-open-nav.active span:nth-child(1) { top: 7px; transform: rotate(45deg); }
.close-open-nav.active span:nth-child(2) { opacity: 0; }
.close-open-nav.active span:nth-child(3) { top: 7px; transform: rotate(-45deg); }

/* Navbar CTA button — explicit single-line guarantee + no shrink */
header .btn-main {
  min-width: 132px;
  width: auto;
  flex-shrink: 0;
  white-space: nowrap;
  padding-inline: 22px;
}
header .btn-main > * { white-space: nowrap; }

/* The right-side cluster (lang dropdown + CTA + burger) must not shrink the CTA */
header .d-flex.align-items-center { flex-shrink: 0; }

/* ============================================================
   8. HERO / SLIDER
   ============================================================ */
.owl-index {
  position: relative;
  min-height: 100vh;
  padding-top: calc(var(--nav-h) + 32px);
}
.owl-index .item {
  position: relative;
  min-height: calc(100vh - var(--nav-h));
}
.info_owl {
  position: relative;
  min-height: calc(100vh - var(--nav-h));
  display: grid;
  align-items: center;
  overflow: hidden;
}
.info_owl::before {
  content: "";
  position: absolute; inset: 0;
  background: var(--grad-hero);
  pointer-events: none;
  z-index: 1;
}
.info_owl::after {
  content: "";
  position: absolute; inset: 0;
  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: 56px 56px;
  mask-image: radial-gradient(ellipse at 50% 30%, #000 30%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at 50% 30%, #000 30%, transparent 70%);
  pointer-events: none;
  z-index: 0;
  animation: drift 30s linear infinite;
}
@keyframes drift {
  from { background-position: 0 0, 0 0; }
  to   { background-position: 560px 560px, 560px 560px; }
}

.info_owl .container {
  position: relative;
  z-index: 3;
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: clamp(20px, 4vw, 64px);
  align-items: center;
  width: 100%;
}

.ads_wol {
  max-width: 720px;
  animation: fadeUp 1s var(--ease-out) both;
}
.ads_wol .hero-eyebrow { margin-bottom: var(--s-4); }
.ads_wol h3 {
  font-size: clamp(2.4rem, 5.8vw, 4.6rem);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.025em;
  margin-bottom: var(--s-5);
  background: linear-gradient(120deg, #ffffff 0%, #DCE0F5 50%, #8B5CF6 100%);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
}
.ads_wol p {
  font-size: clamp(1.05rem, 1.4vw, 1.2rem);
  color: var(--ink-soft);
  line-height: 1.65;
  margin-bottom: var(--s-6);
  max-width: 620px;
}
.hero-actions {
  display: flex; flex-wrap: wrap;
  gap: var(--s-3);
  margin-bottom: var(--s-7);
}
.hero-trust {
  display: flex; flex-wrap: wrap;
  gap: var(--s-5);
  color: var(--ink-mute);
  font-size: .9rem;
  align-items: center;
}
.hero-trust .star { color: #fbbf24; }
.hero-trust strong { color: var(--ink); }

.img_owl_index {
  position: relative;
  display: grid; place-items: center;
  min-height: 480px;
  animation: fadeUp 1.1s var(--ease-out) both;
  animation-delay: .15s;
}
.img_owl_index::before {
  content: "";
  position: absolute;
  width: 78%; height: 78%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(108,99,255,.55) 0%, transparent 70%);
  filter: blur(50px);
  z-index: 0;
}
.img_owl_index img {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 540px;
  height: auto;
  border-radius: var(--r-xl);
  box-shadow: var(--sh-lg);
  border: 1px solid var(--border-strong);
  animation: float 6s ease-in-out infinite;
}
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-14px); }
}

.hero-floats {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 3;
}
.hero-float-card {
  position: absolute;
  padding: 14px 18px;
  background: rgba(22,28,54,.85);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-md);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: var(--sh-lg);
  pointer-events: auto;
  display: flex; align-items: center; gap: 12px;
  animation: float 7s ease-in-out infinite;
}
.hero-float-card .icon {
  width: 40px; height: 40px;
  display: grid; place-items: center;
  background: var(--grad-primary);
  border-radius: 12px;
  color: #fff;
  font-size: 1.1rem;
}
.hero-float-card .label { font-size: .75rem; color: var(--ink-mute); }
.hero-float-card .value { font-weight: 800; color: #fff; font-size: 1.1rem; }
.hero-float-card.fc-1 { top: 8%; inset-inline-start: -4%; animation-delay: -1s; }
.hero-float-card.fc-2 { bottom: 14%; inset-inline-end: -2%; animation-delay: -3s; }
.hero-float-card.fc-3 { bottom: 38%; inset-inline-start: 50%; animation-delay: -5s; }

.scroll-cue {
  position: absolute;
  bottom: 28px; left: 50%;
  transform: translateX(-50%);
  z-index: 4;
  display: flex; flex-direction: column; align-items: center;
  gap: 8px;
  color: var(--ink-mute);
  font-size: .8rem;
  letter-spacing: .14em; text-transform: uppercase;
}
.scroll-cue .bar {
  width: 1px; height: 42px;
  background: linear-gradient(180deg, transparent, var(--ink-mute), transparent);
  animation: scrollBar 2s ease-in-out infinite;
}
@keyframes scrollBar {
  0%, 100% { transform: scaleY(.5); opacity: .5; transform-origin: top; }
  50%      { transform: scaleY(1);  opacity: 1; }
}

.owl-index .owl-nav,
.owl-index .owl-dots {
  position: absolute;
  z-index: 5;
}
.owl-index .owl-nav {
  bottom: 80px;
  inset-inline-end: clamp(20px, 4vw, 48px);
  display: flex; gap: 10px;
  width: auto !important;
}
.owl-index .owl-nav button.owl-prev,
.owl-index .owl-nav button.owl-next {
  width: 44px; height: 44px;
  border-radius: 50% !important;
  background: var(--surface-2) !important;
  border: 1px solid var(--border-strong) !important;
  color: var(--ink) !important;
  display: grid; place-items: center;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: background var(--dur-2) var(--ease), transform var(--dur-2) var(--ease);
}
.owl-index .owl-nav button:hover {
  background: var(--grad-primary) !important;
  transform: translateY(-2px);
}
.owl-index .owl-dots {
  bottom: 90px;
  inset-inline-start: clamp(20px, 4vw, 48px);
  display: flex; gap: 8px;
}
.owl-index .owl-dots .owl-dot span {
  width: 24px !important; height: 4px !important;
  border-radius: 2px !important;
  background: rgba(255,255,255,.2) !important;
  margin: 0 !important;
  transition: background var(--dur-2) var(--ease), width var(--dur-2) var(--ease);
}
.owl-index .owl-dots .owl-dot.active span {
  width: 44px !important;
  background: var(--grad-primary) !important;
}

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   9. ABOUT
   ============================================================ */
#who_we {
  background:
    radial-gradient(60% 50% at 100% 0%, rgba(6,182,212,.10) 0%, transparent 60%),
    radial-gradient(50% 50% at 0% 100%, rgba(108,99,255,.10) 0%, transparent 60%);
}
.info_JM h4.main-color {
  color: #fff !important;
  font-size: clamp(1.8rem, 3.4vw, 2.8rem) !important;
  font-weight: 800;
  letter-spacing: -.02em;
  margin-bottom: var(--s-5) !important;
}
.info_JM p.grey-color {
  color: var(--ink-soft) !important;
  font-size: 1.05rem;
  line-height: 1.8;
}
.info_JM .about-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-3);
  margin-top: var(--s-6);
}
.info_JM .about-stats .stat {
  padding: var(--s-4);
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-md);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.info_JM .about-stats .stat .num {
  font-size: 1.8rem; font-weight: 900;
  background: var(--grad-primary);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.info_JM .about-stats .stat .lbl { font-size: .85rem; color: var(--ink-mute); }

.img_info_JM {
  position: relative;
  min-height: 480px;
}
.img_info_JM img {
  position: absolute;
  border-radius: var(--r-xl);
  box-shadow: var(--sh-lg);
  border: 1px solid var(--border-strong);
  transition: transform var(--dur-3) var(--ease);
}
.img_info_JM img:nth-child(1) {
  width: 64%; top: 0; inset-inline-end: 0;
}
.img_info_JM img:nth-child(2) {
  width: 54%; bottom: 0; inset-inline-start: 0;
  outline: 8px solid var(--bg);
}
.img_info_JM:hover img:nth-child(1) { transform: translateY(-8px); }
.img_info_JM:hover img:nth-child(2) { transform: translateY(8px); }

/* ============================================================
   10. HOW WORK (timeline)
   ============================================================ */
.sec_howwork { padding: clamp(72px, 9vw, 140px) 0; position: relative; }
.figure_body {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--s-5) !important;
  position: relative;
  counter-reset: step;
}
.figure_body::before {
  content: "";
  position: absolute;
  top: 80px; left: 5%; right: 5%;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(108,99,255,.5), rgba(6,182,212,.5), transparent);
  z-index: 0;
}
.figure_body figure {
  counter-increment: step;
  position: relative;
  margin: 0 !important;
  padding: var(--s-6) var(--s-5) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border: 1px solid var(--border-strong);
  border-radius: var(--r-lg);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  text-align: center;
  transition: transform var(--dur-3) var(--ease), box-shadow var(--dur-3) var(--ease), border-color var(--dur-2) var(--ease);
  z-index: 1;
}
.figure_body figure::before {
  content: counter(step, decimal-leading-zero);
  position: absolute;
  top: -18px; inset-inline-start: 50%;
  transform: translateX(-50%);
  background: var(--grad-primary);
  color: #fff;
  font-weight: 800;
  font-size: .8rem;
  padding: 6px 14px;
  border-radius: var(--r-pill);
  box-shadow: 0 10px 24px -8px rgba(108,99,255,.7);
}
.figure_body figure:hover {
  transform: translateY(-8px);
  border-color: rgba(108,99,255,.45);
  box-shadow: var(--sh-lg);
}
.figure_body figure img {
  width: 88px; height: 88px;
  margin: 12px auto 18px;
  object-fit: contain;
  filter: drop-shadow(0 10px 22px rgba(108,99,255,.35));
}
.figure_body figcaption {
  color: #fff;
  font-weight: 700;
  font-size: 1.05rem;
}

/* ============================================================
   11. SERVICES
   ============================================================ */
.services-section {
  background:
    radial-gradient(45% 40% at 90% 0%, rgba(139,92,246,.10) 0%, transparent 60%),
    radial-gradient(40% 40% at 0% 100%, rgba(6,182,212,.10) 0%, transparent 60%);
}
.services-title-wrapper {
  text-align: center;
  max-width: 760px;
  margin: 0 auto clamp(40px, 6vw, 72px);
}
.services-main-title {
  font-size: clamp(1.8rem, 3.6vw, 3rem) !important;
  font-weight: 800;
  background: var(--grad-text);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: var(--s-4);
}
.services-description p {
  color: var(--ink-mute);
  font-size: 1.05rem;
  max-width: 620px;
  margin: 0 auto;
}

.services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--s-5);
}
.service-card {
  position: relative;
  height: 320px;
  perspective: 1400px;
}
.service-card-inner {
  position: relative;
  width: 100%; height: 100%;
  transition: transform .8s var(--ease-out);
  transform-style: preserve-3d;
}
.service-card:hover .service-card-inner { transform: rotateY(180deg); }
.service-front, .service-back {
  position: absolute; inset: 0;
  border-radius: var(--r-lg);
  padding: var(--s-6);
  display: flex; flex-direction: column;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  border: 1px solid var(--border-strong);
  overflow: hidden;
}
.service-front {
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  align-items: flex-start;
  justify-content: space-between;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.service-front::after {
  content: "";
  position: absolute; inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(108,99,255,.7), rgba(6,182,212,.4), transparent);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity: 0;
  transition: opacity var(--dur-2) var(--ease);
  pointer-events: none;
}
.service-card:hover .service-front::after { opacity: 1; }

.service-icon {
  width: 64px; height: 64px;
  background: var(--grad-primary);
  border-radius: var(--r-md);
  display: grid; place-items: center;
  margin-bottom: var(--s-4);
  box-shadow: 0 16px 40px -16px rgba(108,99,255,.7);
}
.service-icon img {
  width: 36px; height: 36px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}
.service-title {
  color: #fff;
  font-size: 1.3rem;
  font-weight: 800;
  margin: 0 0 var(--s-3);
}
.service-hover-text {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--accent-2);
  font-weight: 700;
  font-size: .9rem;
  margin-top: auto;
}
.service-back {
  background: var(--grad-primary);
  color: #fff;
  transform: rotateY(180deg);
}
.service-back-content { display: flex; flex-direction: column; height: 100%; }
.service-back .service-title { color: #fff; }
.service-description-text {
  color: rgba(255,255,255,.92);
  font-size: .95rem;
  line-height: 1.7;
  overflow-y: auto;
}
.service-description-text p { color: inherit; margin: 0; }

/* ============================================================
   12. PARTNERS
   ============================================================ */
.owl-brands { padding: var(--s-3) 0; }
.owl-brands .item {
  display: flex; flex-direction: column; align-items: center;
  gap: var(--s-3);
  padding: var(--s-5);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  margin: 0 8px;
  transition: transform var(--dur-2) var(--ease), border-color var(--dur-2) var(--ease), background var(--dur-2) var(--ease);
}
.owl-brands .item:hover {
  transform: translateY(-6px);
  border-color: rgba(108,99,255,.4);
  background: rgba(255,255,255,.05);
}
.owl-brands .item img {
  width: auto !important; height: 64px !important; max-width: 180px;
  object-fit: contain;
  filter: grayscale(1) brightness(1.6) opacity(.7);
  transition: filter var(--dur-2) var(--ease);
}
.owl-brands .item:hover img { filter: grayscale(0) brightness(1) opacity(1); }
.owl-brands .item-name {
  font-size: .85rem;
  color: var(--ink-mute);
  font-weight: 600;
}

/* ============================================================
   13. CONTACT
   ============================================================ */
#connect_us { position: relative; }
#connect_us::before {
  content: "";
  position: absolute;
  inset-inline: 0; bottom: 0;
  height: 60%;
  background: radial-gradient(40% 60% at 50% 100%, rgba(108,99,255,.18) 0%, transparent 70%);
  pointer-events: none;
}

.form-content {
  position: relative;
  padding: clamp(28px, 4vw, 48px);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border: 1px solid var(--border-strong);
  border-radius: var(--r-xl);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  box-shadow: var(--sh-lg);
}
.form-content::before {
  content: "";
  position: absolute; inset: -1px;
  border-radius: inherit; padding: 1px;
  background: linear-gradient(135deg, rgba(108,99,255,.7), rgba(6,182,212,.35), transparent 70%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  pointer-events: none;
}

.send-message .form-group { position: relative; margin-bottom: var(--s-4); }
.send-message .form-control,
.send-message textarea.form-control {
  width: 100%;
  background: rgba(255,255,255,.04) !important;
  border: 1px solid var(--border-strong) !important;
  color: var(--ink) !important;
  border-radius: var(--r-md) !important;
  padding: 16px 18px !important;
  font-size: 1rem !important;
  height: auto !important;
  line-height: 1.5 !important;
  transition: border-color var(--dur-2) var(--ease), background var(--dur-2) var(--ease), box-shadow var(--dur-2) var(--ease) !important;
  font-family: inherit;
}
.send-message textarea.form-control { min-height: 140px; resize: vertical; }
.send-message .form-control::placeholder { color: var(--ink-mute); }
.send-message .form-control:focus {
  outline: none !important;
  border-color: var(--primary) !important;
  background: rgba(255,255,255,.06) !important;
  box-shadow: 0 0 0 4px rgba(108,99,255,.22) !important;
}
.send-message .form-control.is-invalid {
  border-color: var(--danger) !important;
  box-shadow: 0 0 0 4px rgba(239,68,68,.18) !important;
}
.send-message .invalid-feedback {
  display: none;
  color: #fca5a5 !important;
  font-size: .85rem !important;
  margin-top: 6px !important;
  height: auto !important;
  line-height: 1.4 !important;
}
.send-message .form-control.is-invalid ~ .invalid-feedback,
.send-message .is-invalid ~ .invalid-feedback {
  display: block !important;
}
.send-message button[type="submit"] {
  margin-top: var(--s-3);
  width: 100%;
  padding: 16px 28px;
}

.contact-grid {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: var(--s-6);
  align-items: stretch;
}
.contact-info {
  display: flex; flex-direction: column;
  gap: var(--s-4);
}
.contact-info .info-card {
  display: flex; align-items: center; gap: var(--s-4);
  padding: var(--s-5);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border: 1px solid var(--border-strong);
  border-radius: var(--r-lg);
  transition: transform var(--dur-2) var(--ease), border-color var(--dur-2) var(--ease);
}
.contact-info .info-card:hover { transform: translateY(-4px); border-color: rgba(108,99,255,.4); }
.contact-info .info-card .ic {
  flex-shrink: 0;
  width: 52px; height: 52px;
  border-radius: var(--r-md);
  display: grid; place-items: center;
  background: var(--grad-primary);
  color: #fff;
  font-size: 1.2rem;
}
.contact-info .info-card .lbl { color: var(--ink-mute); font-size: .85rem; }
.contact-info .info-card .val { color: #fff; font-weight: 700; font-size: 1.05rem; word-break: break-word; }
.contact-info .info-card .val a { color: inherit; }
.contact-info .info-card .val a:hover { color: var(--accent-2); }

/* ============================================================
   14. FOOTER
   ============================================================ */
footer {
  position: relative;
  padding: clamp(56px, 7vw, 90px) 0 var(--s-5);
  margin-top: clamp(60px, 8vw, 100px);
  background: linear-gradient(180deg, rgba(11,15,30,0), rgba(7,10,22,1));
}
footer::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(108,99,255,.55), rgba(6,182,212,.4), transparent);
}
footer .logo_footer { height: 56px; width: auto; margin-bottom: var(--s-3); filter: drop-shadow(0 8px 22px rgba(108,99,255,.3)); }
footer .footer-desc { color: var(--ink-mute); max-width: 320px; }

footer .social-m {
  display: flex !important; gap: var(--s-2) !important;
  margin-top: var(--s-4) !important;
  padding: 0;
  flex-wrap: wrap;
}
footer .social-m li { list-style: none; }
footer .social-m a {
  display: grid; place-items: center;
  width: 42px; height: 42px;
  border-radius: 50%;
  background: var(--surface-2);
  border: 1px solid var(--border-strong);
  color: var(--ink);
  transition: transform var(--dur-2) var(--ease), background var(--dur-2) var(--ease), border-color var(--dur-2) var(--ease), color var(--dur-2) var(--ease);
}
footer .social-m a:hover {
  background: var(--grad-primary);
  border-color: transparent;
  color: #fff;
  transform: translateY(-3px) rotate(-4deg);
}

footer .Tfooter {
  color: #fff;
  font-weight: 800;
  margin-bottom: var(--s-4);
  font-size: 1.05rem;
  letter-spacing: .02em;
}
footer .link-footer { display: flex; flex-direction: column; gap: 10px; }
footer .link-footer li {
  color: var(--ink-soft);
  display: inline-flex; align-items: center; gap: 10px;
  transition: color var(--dur-1) var(--ease), transform var(--dur-1) var(--ease);
  font-size: .95rem;
}
footer .link-footer li i { color: var(--accent-2); font-size: .9rem; opacity: .85; }
footer .link-footer li a { color: inherit; }
footer .link-footer li a:hover { color: #fff; }
footer .link-footer li:hover { transform: translateX(-4px); }

.under_footer {
  margin-top: var(--s-7);
  padding-top: var(--s-4);
  border-top: 1px solid var(--border);
  text-align: center;
  color: var(--ink-mute);
  font-size: .9rem;
}
.under_footer a { color: var(--ink); font-weight: 700; }
.under_footer a:hover { color: var(--accent-2); }

/* ============================================================
   15. LOADER
   ============================================================ */
.loader {
  position: fixed; inset: 0;
  background: var(--bg);
  display: grid; place-items: center;
  z-index: 9999;
  transition: opacity .6s var(--ease);
}
.loader::before {
  content: "";
  position: absolute;
  width: 220px; height: 220px;
  border-radius: 50%;
  background: var(--grad-primary);
  filter: blur(80px);
  opacity: .5;
  animation: pulse 2.2s ease-in-out infinite;
}
.loader img {
  position: relative;
  width: 110px; height: auto;
  z-index: 2;
  animation: spinSoft 2.4s var(--ease) infinite alternate;
}
@keyframes pulse {
  0%,100% { transform: scale(1); opacity: .35; }
  50%     { transform: scale(1.15); opacity: .7; }
}
@keyframes spinSoft {
  0%   { transform: rotate(-8deg) scale(1); }
  100% { transform: rotate(8deg) scale(1.04); }
}

/* ============================================================
   16. ANIMATIONS / REVEAL
   Progressive enhancement: hidden state only applies when <html> has
   class "js" (added by inline script before paint). If JS fails for
   any reason, content stays fully visible — never trapped invisible.
   ============================================================ */
.js .reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .8s var(--ease-out), transform .8s var(--ease-out);
  will-change: transform, opacity;
}
.js .reveal.in {
  opacity: 1; transform: none;
}
.js .reveal-stagger > * {
  opacity: 0; transform: translateY(20px);
  transition: opacity .7s var(--ease-out), transform .7s var(--ease-out);
}
.js .reveal-stagger.in > *      { opacity: 1; transform: none; }
.reveal-stagger.in > *:nth-child(1) { transition-delay: 0ms; }
.reveal-stagger.in > *:nth-child(2) { transition-delay: 80ms; }
.reveal-stagger.in > *:nth-child(3) { transition-delay: 160ms; }
.reveal-stagger.in > *:nth-child(4) { transition-delay: 240ms; }
.reveal-stagger.in > *:nth-child(5) { transition-delay: 320ms; }
.reveal-stagger.in > *:nth-child(6) { transition-delay: 400ms; }
.reveal-stagger.in > *:nth-child(7) { transition-delay: 480ms; }
.reveal-stagger.in > *:nth-child(8) { transition-delay: 560ms; }

/* Defensive: Owl Carousel sets `.owl-carousel { display: none }` by default
   and only adds `display: block` after `.owl-loaded`. If JS fails to load
   the carousel (e.g. empty data, init error, RTL bug), the hero would
   disappear entirely. Force the hero wrapper to render so sections below
   stay visible too. */
.owl-carousel.owl-index { display: block !important; }
.owl-carousel.owl-brands { display: block !important; }
/* Before owl initializes, items stack vertically — limit to first slide */
.owl-carousel:not(.owl-loaded) > .item ~ .item { display: none; }
.owl-carousel:not(.owl-loaded) > .item { width: 100%; }

.cursor-glow {
  position: fixed;
  top: 0; left: 0;
  width: 380px; height: 380px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(108,99,255,.18) 0%, transparent 70%);
  pointer-events: none;
  z-index: 1;
  transform: translate(-50%, -50%);
  transition: opacity var(--dur-3) var(--ease);
  opacity: 0;
  mix-blend-mode: screen;
}
@media (hover: hover) and (pointer: fine) {
  body:hover .cursor-glow { opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
  .reveal, .reveal-stagger > * { opacity: 1; transform: none; }
}

/* ============================================================
   17. UTILITIES (legacy class compatibility)
   ============================================================ */
.main-color { color: #fff; }
.grey-color { color: var(--ink-soft); }
.mb-20 { margin-bottom: var(--s-5); }
.mb-30 { margin-bottom: var(--s-6); }
.mb-40 { margin-bottom: var(--s-7); }
.bacg_section { background-color: transparent; }
.row { row-gap: var(--s-5); }

/* ============================================================
   18. RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
  .info_owl .container { grid-template-columns: 1fr; gap: var(--s-7); text-align: center; }
  .ads_wol { margin: 0 auto; }
  .ads_wol p { margin-inline: auto; }
  .hero-actions { justify-content: center; }
  .hero-trust { justify-content: center; }
  .img_owl_index { min-height: 360px; }
  .hero-float-card.fc-1 { top: 0%; inset-inline-start: 0; }
  .hero-float-card.fc-2 { bottom: 0%; inset-inline-end: 0; }
  .hero-float-card.fc-3 { display: none; }
}

@media (max-width: 1180px) {
  /* On tighter desktops/tablets, hide the navbar CTA so menu items stay
     on one line. Contact is still reachable via the "Contact Us" nav link
     and the footer. */
  header .btn-main { display: none; }
  /* Free up room: drop the brand text label, keep just the logo */
  header .brand-text { display: none; }
}

@media (max-width: 960px) {
  :root { --nav-h: 70px; }

  .nav_bar {
    position: fixed;
    top: var(--nav-h);
    inset-inline-end: 16px;
    inset-inline-start: 16px;
    margin: 0;
    padding: var(--s-3);
    flex-direction: column;
    align-items: stretch;
    border-radius: var(--r-lg);
    background: rgba(11,15,30,.92);
    border: 1px solid var(--border-strong);
    box-shadow: var(--sh-lg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    gap: 4px;
    transform: translateY(-12px);
    opacity: 0;
    pointer-events: none;
    transition: transform var(--dur-2) var(--ease), opacity var(--dur-2) var(--ease);
  }
  .nav_bar.active {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }
  .nav_bar > li > a {
    width: 100%;
    padding: 14px 18px;
    justify-content: flex-start;
  }
  .close-open-nav { display: inline-flex; }

  .img_info_JM { min-height: 380px; }
  .figure_body::before { display: none; }

  .contact-grid { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
  body { font-size: 15px; }
  .ads_wol h3 { font-size: clamp(2rem, 9vw, 3rem); }
  .img_info_JM img:nth-child(1) { width: 80%; }
  .img_info_JM img:nth-child(2) { width: 60%; }
  .services-grid { grid-template-columns: 1fr; }
  .service-card { height: 360px; }
  footer .row > [class*="col-"] { margin-bottom: var(--s-5); }
  .hero-float-card { display: none; }
  .info_JM .about-stats { grid-template-columns: repeat(3, 1fr); gap: var(--s-2); }
  .info_JM .about-stats .stat { padding: var(--s-3); }
  .info_JM .about-stats .stat .num { font-size: 1.3rem; }
}

@media (max-width: 480px) {
  .hero-actions .btn-main,
  .hero-actions .btn-ghost { width: 100%; }
}

/* ============================================================
   19. FONT-AWESOME tweaks
   ============================================================ */
[class^="fa-"], [class*=" fa-"] { line-height: 1; }
