/* ================================================================
   NEXOROX — BRIGHT MODE OVERRIDE (v5.0)
   Light, vibrant, energetic — preserves cyan/blue brand DNA
   Loaded AFTER nexorox.css to override dark palette
   ================================================================ */

:root{
  /* ============ Surface inversion ============ */
  --graphite:#FFFFFF;
  --white:#0A1F4D;
  --slate:#F2F6FF;

  /* ============ Brand colours kept ============ */
  --navy:#0A1F4D;
  --blue:#146BFF;
  --cyan:#28D7FF;
  --steel:#3A5CFF;

  /* ============ New vibrant accents ============ */
  --magenta:#FF3D8B;
  --violet:#7B5CFF;
  --aqua:#00E5D1;
  --sunset:#FF8A3D;

  /* ============ Light-mode surfaces ============ */
  --bg-soft:#F8FAFE;
  --bg-card:#FFFFFF;
  --bg-section:#FBFCFF;
  --text-primary:#0A1F4D;
  --text-secondary:#1F3A8A;
  --text-muted:#5C6B8A;
  --text-faint:#94A3C4;
  --border-soft:rgba(20,107,255,.12);
  --border-mid:rgba(20,107,255,.20);
  --border-strong:rgba(20,107,255,.30);

  /* ============ Glass ============ */
  --glass-bg:rgba(255,255,255,.70);
  --glass-border:rgba(20,107,255,.18);

  /* ============ Gradients (vibrant) ============ */
  --grad-1:linear-gradient(135deg,#146BFF 0%,#28D7FF 100%);
  --grad-2:linear-gradient(135deg,#28D7FF 0%,#7B5CFF 50%,#FF3D8B 100%);
  --grad-text:linear-gradient(135deg,#146BFF 0%,#7B5CFF 35%,#FF3D8B 70%,#28D7FF 100%);
  --grad-vibrant:linear-gradient(135deg,#28D7FF 0%,#7B5CFF 50%,#FF3D8B 100%);
  --grad-cta:linear-gradient(135deg,#146BFF 0%,#7B5CFF 100%);
  --grad-cta-hover:linear-gradient(135deg,#7B5CFF 0%,#FF3D8B 100%);

  --grad-mesh:
    radial-gradient(at 18% 8%, rgba(40,215,255,.45) 0%, transparent 45%),
    radial-gradient(at 82% 28%, rgba(123,92,255,.30) 0%, transparent 50%),
    radial-gradient(at 30% 92%, rgba(255,61,139,.22) 0%, transparent 55%),
    radial-gradient(at 92% 88%, rgba(20,107,255,.32) 0%, transparent 55%);

  /* ============ Shadows ============ */
  --shadow-glow:0 0 60px rgba(40,215,255,.30), 0 0 120px rgba(123,92,255,.18);
  --shadow-card:0 10px 36px rgba(20,107,255,.08), 0 2px 8px rgba(20,107,255,.05);
  --shadow-card-hover:0 22px 60px rgba(20,107,255,.18), 0 8px 20px rgba(123,92,255,.12);
  --shadow-glow-vibrant:0 14px 40px rgba(255,61,139,.20), 0 4px 16px rgba(123,92,255,.18);
  --shadow-soft:0 4px 16px rgba(20,107,255,.06);
}

/* BODY */
body{
  background:var(--bg-soft) !important;
  color:var(--text-primary) !important;
}
::selection{background:var(--violet);color:#fff}

/* LOADER */
#loader{background:#FFFFFF !important}
.loader-bar{background:rgba(20,107,255,.12) !important}
.loader-text{color:var(--blue) !important}
.loader-mark img{filter:drop-shadow(0 8px 24px rgba(20,107,255,.40)) !important}

/* CURSOR */
.cursor-dot{
  background:var(--blue) !important;
  mix-blend-mode:multiply !important;
  box-shadow:0 0 12px rgba(20,107,255,.50) !important;
}
.cursor-dot.hover{
  background:var(--magenta) !important;
  mix-blend-mode:normal !important;
  box-shadow:0 0 22px rgba(255,61,139,.55) !important;
}
.cursor-dot.text{background:var(--violet) !important}

/* BACKGROUND */
#bgCanvas{opacity:.30 !important}
.mesh-bg{
  background:var(--grad-mesh) !important;
  opacity:1 !important;
}
.grid-overlay{
  background-image:
    linear-gradient(rgba(20,107,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(20,107,255,.06) 1px, transparent 1px) !important;
}
.ambient-glow.one{background:radial-gradient(circle, rgba(40,215,255,.45) 0%, transparent 70%) !important}
.ambient-glow.two{background:radial-gradient(circle, rgba(123,92,255,.32) 0%, transparent 70%) !important}
.ambient-glow.three{background:radial-gradient(circle, rgba(255,61,139,.28) 0%, transparent 70%) !important}
.ribbon{background:var(--grad-vibrant) !important}

/* NAVBAR */
nav.main-nav{
  background:rgba(255,255,255,.55) !important;
  backdrop-filter:blur(24px) saturate(180%) !important;
  -webkit-backdrop-filter:blur(24px) saturate(180%) !important;
  border-bottom:1px solid var(--border-soft) !important;
}
nav.main-nav.scrolled{
  background:rgba(255,255,255,.92) !important;
  box-shadow:0 6px 28px rgba(20,107,255,.10) !important;
}
.logo-mark img{filter:drop-shadow(0 4px 12px rgba(20,107,255,.30)) !important}
.logo:hover .logo-mark img{filter:drop-shadow(0 8px 22px rgba(255,61,139,.55)) !important}
.logo-name, .logo-name-img{color:var(--navy) !important}
.logo-tag{color:var(--blue) !important}
.nav-links a{color:rgba(10,31,77,.78) !important}
.nav-links a:hover, .nav-links a.active{color:var(--blue) !important}
.nav-links a::after{background:var(--grad-vibrant) !important}
.lang-switch{background:rgba(20,107,255,.06) !important;border:1px solid var(--border-soft) !important;border-radius:999px}
.lang-switch button{color:var(--text-muted) !important;background:transparent !important}
.lang-switch button.active{background:var(--grad-1) !important;color:#fff !important}
.burger span{background:var(--navy) !important}

/* TYPOGRAPHY */
h1,h2,h3,h4,h5,h6{color:var(--navy) !important}
p, li, span, label, td, th{color:var(--text-primary) !important}
.muted, .subtitle, small{color:var(--text-muted) !important}
.text-glow{text-shadow:0 4px 24px rgba(20,107,255,.18) !important}

/* GRADIENT TEXT */
.gradient, .gradient-text, .hero-title .gradient, h1 .gradient, h2 .gradient{
  background:var(--grad-vibrant) !important;
  background-size:200% 200% !important;
  -webkit-background-clip:text !important;
  background-clip:text !important;
  -webkit-text-fill-color:transparent !important;
  color:transparent !important;
  animation:gradShiftLight 8s ease infinite !important;
}
@keyframes gradShiftLight{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}

/* BUTTONS */
.btn, .btn-primary, button.primary, a.btn-primary{
  background:var(--grad-1) !important;
  color:#fff !important;
  border:none !important;
  box-shadow:0 8px 24px rgba(20,107,255,.32), 0 2px 6px rgba(123,92,255,.18) !important;
  transition:all .35s cubic-bezier(.4,0,.2,1) !important;
}
.btn:hover, .btn-primary:hover, button.primary:hover, a.btn-primary:hover{
  transform:translateY(-3px) !important;
  box-shadow:0 14px 36px rgba(255,61,139,.32), 0 4px 12px rgba(20,107,255,.28) !important;
  background:var(--grad-vibrant) !important;
  background-size:200% 200% !important;
  animation:gradShiftLight 4s ease infinite !important;
}
.btn-outline, .btn-secondary, button.secondary, a.btn-outline{
  background:rgba(255,255,255,.7) !important;
  color:var(--blue) !important;
  border:1.5px solid var(--blue) !important;
  backdrop-filter:blur(8px) !important;
}
.btn-outline:hover, .btn-secondary:hover{
  background:var(--blue) !important;
  color:#fff !important;
  box-shadow:0 8px 24px rgba(20,107,255,.28) !important;
}
.btn-ghost{color:var(--blue) !important;background:transparent !important}

/* CARDS / SURFACES */
.card, .feature-card, .service-card, .pkg-card, .portfolio-card, .testimonial-card, .stat-card, .timeline-card{
  background:var(--bg-card) !important;
  border:1px solid var(--border-soft) !important;
  border-radius:24px !important;
  box-shadow:0 6px 20px rgba(10,31,77,.06), 0 1px 3px rgba(10,31,77,.04) !important;
  color:var(--text-primary) !important;
  transition:all .4s cubic-bezier(.4,0,.2,1) !important;
}
.card:hover, .feature-card:hover, .service-card:hover, .portfolio-card:hover, .timeline-card:hover{
  transform:translateY(-6px) !important;
  border-color:rgba(20,107,255,.25) !important;
  box-shadow:0 18px 48px rgba(20,107,255,.14), 0 4px 12px rgba(123,92,255,.10) !important;
}

/* SECTIONS */
section{background:transparent !important}
.section-alt, .section-tint{
  background:linear-gradient(180deg, rgba(20,107,255,.04) 0%, rgba(255,255,255,0) 100%) !important;
}
.divider, hr{border-color:var(--border-soft) !important; background:var(--border-soft) !important}

/* FORMS */
input, textarea, select{
  background:#fff !important;
  color:var(--text-primary) !important;
  border:1.5px solid var(--border-soft) !important;
  border-radius:12px !important;
}
input:focus, textarea:focus, select:focus{
  border-color:var(--blue) !important;
  box-shadow:0 0 0 4px rgba(20,107,255,.14) !important;
  outline:none !important;
}
input::placeholder, textarea::placeholder{color:rgba(10,31,77,.42) !important}
label{color:var(--text-primary) !important; font-weight:600}

/* FOOTER */
footer, .footer, .site-footer{
  background:linear-gradient(180deg, #F1F5FE 0%, #E8EFFB 100%) !important;
  border-top:1px solid var(--border-soft) !important;
  color:var(--text-primary) !important;
}
footer a, .footer a{color:var(--blue) !important}
footer a:hover{color:var(--magenta) !important}
footer h4, footer h5{color:var(--navy) !important}

/* BREADCRUMB / HERO MINI */
.breadcrumb, .page-hero, .hero-mini{
  background:linear-gradient(135deg, rgba(20,107,255,.08) 0%, rgba(123,92,255,.06) 50%, rgba(255,61,139,.05) 100%) !important;
  border-bottom:1px solid var(--border-soft) !important;
}

/* ============ PRICING / PACKAGES ============ */
.pkg-tabs, .pkg-tab-bar{
  background:rgba(255,255,255,.65) !important;
  border:1px solid var(--border-soft) !important;
  backdrop-filter:blur(12px) !important;
  border-radius:999px !important;
}
.pkg-tab, .pkg-tab button{
  color:var(--text-muted) !important;
  background:transparent !important;
}
.pkg-tab.active, .pkg-tab[aria-selected="true"]{
  background:var(--grad-1) !important;
  color:#fff !important;
  box-shadow:0 6px 18px rgba(20,107,255,.28) !important;
}

.pkg-grid{gap:28px !important}

.pkg-card{
  background:var(--bg-card) !important;
  border:1.5px solid var(--border-soft) !important;
  border-radius:28px !important;
  padding:36px 28px !important;
  position:relative !important;
  overflow:hidden !important;
  transition:all .45s cubic-bezier(.4,0,.2,1) !important;
}
.pkg-card::after{
  content:"";
  position:absolute;
  top:-60px; right:-60px;
  width:180px; height:180px;
  background:radial-gradient(circle, rgba(40,215,255,.18) 0%, transparent 70%);
  pointer-events:none;
  transition:all .6s ease;
}
.pkg-card:hover{
  transform:translateY(-8px) !important;
  border-color:rgba(20,107,255,.35) !important;
  box-shadow:0 24px 60px rgba(20,107,255,.16), 0 6px 16px rgba(123,92,255,.10) !important;
}
.pkg-card:hover::after{
  transform:scale(1.4) rotate(20deg);
  background:radial-gradient(circle, rgba(255,61,139,.22) 0%, transparent 70%);
}

/* Featured pkg card with gradient border */
.pkg-card.featured, .pkg-card.popular, .pkg-card.most-popular{
  background:var(--bg-card) !important;
  border:none !important;
  box-shadow:0 24px 60px rgba(20,107,255,.18), 0 8px 22px rgba(255,61,139,.14) !important;
  transform:translateY(-4px);
}
.pkg-card.featured::before, .pkg-card.popular::before, .pkg-card.most-popular::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:28px;
  padding:2.5px;
  background:var(--grad-vibrant);
  background-size:200% 200%;
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  animation:gradShiftLight 6s ease infinite;
  pointer-events:none;
  z-index:1;
}
.pkg-card.featured:hover, .pkg-card.popular:hover{
  transform:translateY(-12px);
  box-shadow:0 32px 72px rgba(20,107,255,.22), 0 12px 28px rgba(255,61,139,.20) !important;
}

.pkg-badge{
  position:absolute !important;
  top:18px; right:18px;
  background:var(--grad-vibrant) !important;
  background-size:200% 200% !important;
  color:#fff !important;
  font-size:11px !important;
  font-weight:700 !important;
  letter-spacing:.08em !important;
  text-transform:uppercase !important;
  padding:6px 14px !important;
  border-radius:999px !important;
  box-shadow:0 6px 16px rgba(255,61,139,.32) !important;
  animation:gradShiftLight 5s ease infinite !important;
  z-index:2 !important;
}
html[dir="rtl"] .pkg-badge{right:auto !important; left:18px !important}

.pkg-tier, .pkg-title{
  color:var(--navy) !important;
  font-size:22px !important;
  font-weight:800 !important;
  margin-bottom:8px !important;
  position:relative;
  z-index:2;
}
.pkg-tagline, .pkg-subtitle{color:var(--text-muted) !important; font-size:14px !important; position:relative; z-index:2}

.pkg-price{
  margin:22px 0 8px !important;
  display:flex !important;
  align-items:baseline !important;
  gap:6px !important;
  position:relative;
  z-index:2;
}
html[dir="rtl"] .pkg-price{justify-content:flex-end}
.pkg-price .currency{
  font-size:22px !important;
  color:var(--blue) !important;
  font-weight:600 !important;
}
.pkg-price .amount{
  font-size:54px !important;
  font-weight:900 !important;
  line-height:1 !important;
  background:var(--grad-vibrant) !important;
  background-size:200% 200% !important;
  -webkit-background-clip:text !important;
  background-clip:text !important;
  -webkit-text-fill-color:transparent !important;
  color:transparent !important;
  animation:gradShiftLight 7s ease infinite !important;
}
.pkg-price .period{
  font-size:14px !important;
  color:var(--text-muted) !important;
  margin-left:4px !important;
}

.pkg-features, .pkg-card ul{
  list-style:none !important;
  padding:0 !important;
  margin:24px 0 0 !important;
  position:relative;
  z-index:2;
}
.pkg-features li, .pkg-card ul li{
  color:var(--text-primary) !important;
  font-size:14px !important;
  line-height:1.6 !important;
  padding:9px 0 9px 28px !important;
  border-bottom:1px dashed rgba(20,107,255,.10) !important;
  position:relative !important;
  list-style:none !important;
}
html[dir="rtl"] .pkg-features li, html[dir="rtl"] .pkg-card ul li{
  padding:9px 28px 9px 0 !important;
}
.pkg-features li::before, .pkg-card ul li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:9px;
  width:20px; height:20px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--grad-1);
  color:#fff;
  border-radius:50%;
  font-size:11px;
  font-weight:900;
  box-shadow:0 3px 8px rgba(20,107,255,.28);
}
html[dir="rtl"] .pkg-features li::before, html[dir="rtl"] .pkg-card ul li::before{
  left:auto !important;
  right:0 !important;
}
.pkg-features li:last-child{border-bottom:none !important}

.pkg-card .btn, .pkg-card .btn-primary{
  width:100% !important;
  margin-top:24px !important;
  position:relative;
  z-index:2;
}

/* ICONS */
.icon, .feature-icon, .service-icon{
  background:var(--grad-1) !important;
  color:#fff !important;
  box-shadow:0 8px 20px rgba(20,107,255,.28) !important;
}
.icon-outline{background:transparent !important; color:var(--blue) !important; border:1.5px solid var(--blue) !important}

/* TIMELINE / PROCESS */
.timeline::before, .process-line{background:var(--grad-1) !important}
.timeline-dot, .process-dot{
  background:var(--grad-vibrant) !important;
  background-size:200% 200% !important;
  animation:gradShiftLight 6s ease infinite !important;
  box-shadow:0 4px 14px rgba(255,61,139,.32) !important;
}

/* STATS / NUMBERS */
.stat-number, .counter, .big-number{
  background:var(--grad-vibrant) !important;
  background-size:200% 200% !important;
  -webkit-background-clip:text !important;
  background-clip:text !important;
  -webkit-text-fill-color:transparent !important;
  color:transparent !important;
  animation:gradShiftLight 8s ease infinite !important;
  font-weight:900 !important;
}

/* TAGS / CHIPS */
.tag, .chip, .badge:not(.pkg-badge){
  background:rgba(20,107,255,.10) !important;
  color:var(--blue) !important;
  border:1px solid rgba(20,107,255,.20) !important;
}

/* MOBILE MENU */
.mobile-menu, .nav-mobile, .menu-overlay{
  background:rgba(255,255,255,.96) !important;
  backdrop-filter:blur(24px) !important;
  color:var(--text-primary) !important;
}
.mobile-menu a{color:var(--navy) !important}

/* HERO OVERLAY */
.hero-overlay, .video-overlay{
  background:linear-gradient(135deg, rgba(255,255,255,.45) 0%, rgba(248,250,254,.65) 50%, rgba(20,107,255,.18) 100%) !important;
}

/* DARK-BG FALLBACKS — anywhere a dark color leaks through */
[style*="background:#0D1220"], [style*="background-color:#0D1220"],
[style*="background:#081F4D"], [style*="background-color:#081F4D"]{
  background:var(--bg-soft) !important;
  background-color:var(--bg-soft) !important;
  color:var(--text-primary) !important;
}

/* SCROLLBAR */
::-webkit-scrollbar{width:10px; height:10px}
::-webkit-scrollbar-track{background:#F1F5FE}
::-webkit-scrollbar-thumb{
  background:var(--grad-1);
  border-radius:10px;
}
::-webkit-scrollbar-thumb:hover{background:var(--grad-vibrant)}

/* SELECTION */
::selection{background:rgba(255,61,139,.22); color:var(--navy)}
::-moz-selection{background:rgba(255,61,139,.22); color:var(--navy)}


/* ============================================================
   ELEGANT EXTENSIONS — Nav dropdown, Video, Services, Blog, Consultation
   ============================================================ */

/* ============ SERVICES DROPDOWN ============ */
.nav-links li.has-dropdown{position:relative}
.nav-links li.has-dropdown > a{cursor:pointer; position:relative}
.nav-links li.has-dropdown > a::after{content:" ▾"; font-size:9px; opacity:.5; margin-left:4px; transition:transform .3s ease; display:inline-block}
.nav-links li.has-dropdown:hover > a::after{transform:rotate(180deg); opacity:1}

.dropdown-menu{
  position:absolute !important;
  top:calc(100% + 14px);
  left:50%;
  transform:translateX(-50%) translateY(10px);
  min-width:280px;
  background:rgba(255,255,255,.98) !important;
  backdrop-filter:blur(28px) saturate(180%) !important;
  -webkit-backdrop-filter:blur(28px) saturate(180%) !important;
  border:1px solid rgba(20,107,255,.15) !important;
  border-radius:20px !important;
  padding:14px !important;
  list-style:none !important;
  opacity:0;
  visibility:hidden;
  transition:all .35s cubic-bezier(.4,0,.2,1);
  box-shadow:0 24px 60px rgba(10,31,77,.18), 0 4px 12px rgba(20,107,255,.10) !important;
  z-index:200;
}
[dir="rtl"] .dropdown-menu{left:auto; right:50%; transform:translateX(50%) translateY(10px)}
.nav-links li.has-dropdown:hover .dropdown-menu,
.nav-links li.has-dropdown:focus-within .dropdown-menu{
  opacity:1 !important;
  visibility:visible !important;
  transform:translateX(-50%) translateY(0) !important;
}
[dir="rtl"] .nav-links li.has-dropdown:hover .dropdown-menu{transform:translateX(50%) translateY(0) !important}

.dropdown-menu::before{
  content:"";
  position:absolute;
  top:-6px; left:50%;
  transform:translateX(-50%) rotate(45deg);
  width:12px; height:12px;
  background:#fff;
  border-top:1px solid rgba(20,107,255,.15);
  border-left:1px solid rgba(20,107,255,.15);
}

.dropdown-menu li{margin:0 !important; list-style:none !important}
.dropdown-menu li a{
  display:flex !important;
  align-items:center;
  gap:12px;
  padding:13px 16px !important;
  border-radius:12px !important;
  color:var(--text-primary, #0A1F4D) !important;
  text-decoration:none;
  transition:all .3s ease !important;
  font-size:14px !important;
}
.dropdown-menu li a:hover{
  background:linear-gradient(135deg, rgba(20,107,255,.08), rgba(123,92,255,.06)) !important;
  color:var(--blue, #146BFF) !important;
  transform:translateX(4px);
}
[dir="rtl"] .dropdown-menu li a:hover{transform:translateX(-4px)}

.dropdown-icon{
  width:32px; height:32px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  background:linear-gradient(135deg, rgba(20,107,255,.10), rgba(40,215,255,.08));
  color:var(--blue, #146BFF);
  flex-shrink:0;
}
.dropdown-icon svg{width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:2}

.dropdown-text{display:flex; flex-direction:column; gap:2px}
.dropdown-text strong{font-weight:700; font-size:13.5px}
.dropdown-text small{font-size:11px; color:var(--text-muted, rgba(10,31,77,.5)); font-weight:500}
[dir="rtl"] .dropdown-text strong{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:14.5px}
[dir="rtl"] .dropdown-text small{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:12px}

/* Mobile dropdown */
@media (max-width:980px){
  .dropdown-menu{
    position:static !important;
    opacity:1;
    visibility:visible;
    transform:none !important;
    background:transparent !important;
    backdrop-filter:none !important;
    border:none !important;
    box-shadow:none !important;
    padding:8px 0 8px 24px !important;
    margin-top:6px;
    display:none;
  }
  .dropdown-menu::before{display:none}
  .nav-links li.has-dropdown.open .dropdown-menu{display:block}
}

/* ============ WIDE VIDEO / SHOWREEL SECTION ============ */
.showreel-section{
  position:relative;
  padding:100px 5% 100px;
  background:linear-gradient(180deg, rgba(20,107,255,.03) 0%, rgba(255,255,255,0) 100%);
}
.showreel-head{
  text-align:center;
  max-width:760px;
  margin:0 auto 50px;
}
.showreel-num{
  font-family:'JetBrains Mono',monospace;
  color:var(--blue, #146BFF);
  font-size:12px;
  letter-spacing:3px;
  text-transform:uppercase;
  font-weight:700;
  margin-bottom:14px;
  display:inline-block;
}
[dir="rtl"] .showreel-num{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:1px; text-transform:none; font-size:14px}
.showreel-head h2{
  font-family:'Space Grotesk',sans-serif;
  font-weight:800;
  font-size:clamp(32px,4.5vw,52px);
  line-height:1.05;
  letter-spacing:-1.5px;
  margin-bottom:16px;
  color:var(--navy, #0A1F4D);
}
[dir="rtl"] .showreel-head h2{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:-.5px}
.showreel-head p{
  color:var(--text-muted, rgba(10,31,77,.62));
  font-size:17px;
  line-height:1.7;
  max-width:600px;
  margin:0 auto;
  font-weight:400;
}
[dir="rtl"] .showreel-head p{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:18px; line-height:1.9}

.showreel-frame{
  position:relative;
  max-width:1400px;
  margin:0 auto;
  border-radius:28px;
  overflow:hidden;
  aspect-ratio:16/9;
  background:linear-gradient(135deg, #0A1F4D 0%, #146BFF 50%, #28D7FF 100%);
  box-shadow:
    0 40px 100px rgba(20,107,255,.25),
    0 16px 40px rgba(123,92,255,.15),
    0 0 0 1px rgba(255,255,255,.5);
}
.showreel-frame::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:28px;
  padding:2.5px;
  background:linear-gradient(135deg,#146BFF 0%,#7B5CFF 35%,#FF3D8B 70%,#28D7FF 100%);
  background-size:200% 200%;
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  animation:launchGrad 8s ease infinite;
  pointer-events:none;
  z-index:3;
}
.showreel-frame video, .showreel-frame iframe{
  width:100% !important;
  height:100% !important;
  object-fit:cover;
  display:block;
  position:relative;
  z-index:1;
}

/* Placeholder when no video uploaded */
.showreel-placeholder{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  color:#fff;
  text-align:center;
  padding:40px;
  z-index:2;
}
.showreel-play-btn{
  width:88px; height:88px;
  border-radius:50%;
  background:rgba(255,255,255,.16);
  backdrop-filter:blur(16px);
  border:2px solid rgba(255,255,255,.5);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:22px;
  cursor:pointer;
  transition:all .4s ease;
  position:relative;
}
.showreel-play-btn::before{
  content:"";
  position:absolute;
  inset:-8px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.3);
  animation:pulseRing 2.5s ease-in-out infinite;
}
@keyframes pulseRing{
  0%,100%{transform:scale(1); opacity:1}
  50%{transform:scale(1.2); opacity:.3}
}
.showreel-play-btn:hover{
  background:rgba(255,255,255,.28);
  transform:scale(1.1);
  border-color:#fff;
}
.showreel-play-btn svg{width:30px; height:30px; margin-left:4px; fill:#fff}
.showreel-placeholder h3{
  font-family:'Space Grotesk',sans-serif;
  font-weight:800;
  font-size:28px;
  margin-bottom:8px;
  color:#fff !important;
  text-shadow:0 4px 24px rgba(0,0,0,.3);
}
[dir="rtl"] .showreel-placeholder h3{font-family:'IBM Plex Sans Arabic',sans-serif}
.showreel-placeholder p{
  font-size:14px;
  color:rgba(255,255,255,.85) !important;
  font-family:'JetBrains Mono',monospace;
  letter-spacing:2px;
  text-transform:uppercase;
}
[dir="rtl"] .showreel-placeholder p{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:0; text-transform:none; font-size:15px}

/* ============ SERVICE DETAIL PAGES ============ */
.service-hero{
  padding:140px 5% 80px;
  position:relative;
  text-align:center;
}
.service-hero .service-eyebrow{
  display:inline-block;
  padding:8px 18px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(20,107,255,.10), rgba(123,92,255,.08));
  border:1px solid rgba(20,107,255,.20);
  color:var(--blue, #146BFF);
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  letter-spacing:2.5px;
  text-transform:uppercase;
  font-weight:700;
  margin-bottom:24px;
}
[dir="rtl"] .service-hero .service-eyebrow{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:.5px; text-transform:none; font-size:13px}
.service-hero h1{
  font-family:'Space Grotesk',sans-serif;
  font-weight:900;
  font-size:clamp(40px,6vw,72px);
  line-height:1;
  letter-spacing:-2.5px;
  margin-bottom:24px;
  color:var(--navy, #0A1F4D);
}
[dir="rtl"] .service-hero h1{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:-1px}
.service-hero .service-sub{
  color:var(--text-muted, rgba(10,31,77,.62));
  font-size:18px;
  line-height:1.7;
  max-width:680px;
  margin:0 auto 40px;
  font-weight:400;
}
[dir="rtl"] .service-hero .service-sub{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:19px; line-height:1.9}
.service-hero-cta{
  display:inline-flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  justify-content:center;
}
.service-cta-primary, .service-cta-secondary{
  padding:16px 32px;
  border-radius:14px;
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;
  font-size:13px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  text-decoration:none;
  transition:all .4s ease;
}
[dir="rtl"] .service-cta-primary, [dir="rtl"] .service-cta-secondary{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:.5px; text-transform:none; font-size:15px}
.service-cta-primary{
  background:linear-gradient(135deg,#146BFF,#7B5CFF);
  color:#fff !important;
  box-shadow:0 10px 28px rgba(20,107,255,.32);
}
.service-cta-primary:hover{transform:translateY(-3px); box-shadow:0 14px 36px rgba(255,61,139,.36); background:linear-gradient(135deg,#FF3D8B,#7B5CFF,#28D7FF); background-size:200% 200%; animation:launchGrad 4s ease infinite}
.service-cta-secondary{
  background:rgba(255,255,255,.7);
  color:var(--blue, #146BFF) !important;
  border:1.5px solid rgba(20,107,255,.30);
  backdrop-filter:blur(8px);
}
.service-cta-secondary:hover{background:var(--blue,#146BFF); color:#fff !important; border-color:transparent}

.service-section{padding:70px 5%}
.service-section .container{max-width:1280px; margin:0 auto}
.service-section-head{text-align:center; max-width:680px; margin:0 auto 50px}
.service-section-head .label{
  font-family:'JetBrains Mono',monospace;
  color:var(--blue, #146BFF);
  font-size:11px;
  letter-spacing:3px;
  text-transform:uppercase;
  font-weight:700;
  margin-bottom:12px;
  display:inline-block;
}
[dir="rtl"] .service-section-head .label{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:0; text-transform:none; font-size:13px}
.service-section-head h2{
  font-family:'Space Grotesk',sans-serif;
  font-weight:800;
  font-size:clamp(28px,4vw,42px);
  line-height:1.1;
  letter-spacing:-1px;
  margin-bottom:14px;
  color:var(--navy, #0A1F4D);
}
[dir="rtl"] .service-section-head h2{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:0}
.service-section-head p{color:var(--text-muted, rgba(10,31,77,.6)); font-size:16px; line-height:1.7}
[dir="rtl"] .service-section-head p{font-family:'IBM Plex Sans Arabic',sans-serif; line-height:1.9}

/* Capabilities grid */
.capabilities-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:20px;
}
@media (max-width:900px){.capabilities-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.capabilities-grid{grid-template-columns:1fr}}

.cap-card{
  background:#fff;
  border:1px solid rgba(20,107,255,.10);
  border-radius:20px;
  padding:30px 24px;
  transition:all .4s ease;
}
.cap-card:hover{
  transform:translateY(-6px);
  border-color:rgba(20,107,255,.30);
  box-shadow:0 18px 44px rgba(20,107,255,.14);
}
.cap-card .cap-icon{
  width:52px; height:52px;
  border-radius:14px;
  background:linear-gradient(135deg, rgba(20,107,255,.10), rgba(40,215,255,.08));
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:18px;
  color:var(--blue, #146BFF);
}
.cap-card .cap-icon svg{width:24px; height:24px; stroke:currentColor; fill:none; stroke-width:2}
.cap-card h3{
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;
  font-size:18px;
  margin-bottom:10px;
  color:var(--navy, #0A1F4D);
}
[dir="rtl"] .cap-card h3{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:19px}
.cap-card p{
  color:var(--text-muted, rgba(10,31,77,.65));
  font-size:14px;
  line-height:1.65;
}
[dir="rtl"] .cap-card p{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:15px; line-height:1.85}

/* Process timeline (service pages) */
.process-steps{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:20px;
  counter-reset:step;
}
@media (max-width:900px){.process-steps{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.process-steps{grid-template-columns:1fr}}

.process-step{
  background:#fff;
  border:1px solid rgba(20,107,255,.10);
  border-radius:18px;
  padding:28px 22px;
  position:relative;
  counter-increment:step;
}
.process-step::before{
  content:"0" counter(step);
  position:absolute;
  top:18px; right:20px;
  font-family:'JetBrains Mono',monospace;
  font-size:32px;
  font-weight:700;
  background:linear-gradient(135deg,#146BFF,#7B5CFF);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  opacity:.85;
}
[dir="rtl"] .process-step::before{right:auto; left:20px}
.process-step h4{
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;
  font-size:17px;
  margin-bottom:10px;
  margin-top:36px;
  color:var(--navy, #0A1F4D);
}
[dir="rtl"] .process-step h4{font-family:'IBM Plex Sans Arabic',sans-serif}
.process-step p{
  color:var(--text-muted, rgba(10,31,77,.65));
  font-size:13.5px;
  line-height:1.6;
}
[dir="rtl"] .process-step p{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:14.5px; line-height:1.8}

/* Tech stack grid */
.tech-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(150px,1fr));
  gap:14px;
}
.tech-item{
  background:#fff;
  border:1px solid rgba(20,107,255,.12);
  border-radius:14px;
  padding:18px 16px;
  text-align:center;
  font-family:'JetBrains Mono',monospace;
  font-size:13px;
  color:var(--navy, #0A1F4D);
  font-weight:700;
  letter-spacing:.5px;
  transition:all .35s ease;
}
[dir="rtl"] .tech-item{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:0; font-size:14px}
.tech-item:hover{
  border-color:rgba(20,107,255,.35);
  background:linear-gradient(135deg, rgba(20,107,255,.04), rgba(40,215,255,.03));
  transform:translateY(-3px);
  box-shadow:0 8px 22px rgba(20,107,255,.10);
  color:var(--blue, #146BFF);
}

/* ============ BOOK CONSULTATION PAGE ============ */
.consult-wrap{
  max-width:1280px;
  margin:0 auto;
  padding:0 5% 80px;
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:50px;
  align-items:start;
}
@media (max-width:980px){.consult-wrap{grid-template-columns:1fr; gap:40px}}

.consult-form{
  background:#fff;
  border:1px solid rgba(20,107,255,.12);
  border-radius:28px;
  padding:40px 36px;
  box-shadow:0 18px 48px rgba(10,31,77,.06);
}
@media (max-width:600px){.consult-form{padding:30px 22px}}

.consult-form h2{
  font-family:'Space Grotesk',sans-serif;
  font-weight:800;
  font-size:28px;
  margin-bottom:8px;
  color:var(--navy, #0A1F4D);
  letter-spacing:-.5px;
}
[dir="rtl"] .consult-form h2{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:0; font-size:30px}
.consult-form .form-sub{color:var(--text-muted, rgba(10,31,77,.6)); font-size:14px; margin-bottom:30px}
[dir="rtl"] .consult-form .form-sub{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:15px}

.form-row{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:18px}
.form-row.single{grid-template-columns:1fr}
@media (max-width:560px){.form-row{grid-template-columns:1fr}}

.form-group{display:flex; flex-direction:column}
.form-group label{
  font-size:12px;
  font-weight:700;
  letter-spacing:.5px;
  text-transform:uppercase;
  color:var(--navy, #0A1F4D);
  margin-bottom:8px;
  font-family:'JetBrains Mono',monospace;
}
[dir="rtl"] .form-group label{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:0; text-transform:none; font-size:14px}
.form-group input, .form-group select, .form-group textarea{
  background:#F8FAFE;
  color:var(--text-primary, #0A1F4D);
  border:1.5px solid rgba(20,107,255,.15);
  border-radius:12px;
  padding:13px 16px;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:14px;
  transition:all .3s ease;
}
[dir="rtl"] .form-group input, [dir="rtl"] .form-group select, [dir="rtl"] .form-group textarea{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:15px}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus{
  background:#fff;
  border-color:var(--blue, #146BFF);
  outline:none;
  box-shadow:0 0 0 4px rgba(20,107,255,.10);
}
.form-group textarea{min-height:110px; resize:vertical}

.project-types{display:grid; grid-template-columns:repeat(2,1fr); gap:10px; margin-top:6px}
.project-types label{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  background:#F8FAFE;
  border:1.5px solid rgba(20,107,255,.12);
  border-radius:12px;
  cursor:pointer;
  transition:all .3s ease;
  font-size:13.5px;
  font-weight:600;
  letter-spacing:0;
  text-transform:none;
  color:var(--navy, #0A1F4D);
  font-family:'Plus Jakarta Sans',sans-serif;
}
[dir="rtl"] .project-types label{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:14.5px}
.project-types label:hover{border-color:rgba(20,107,255,.30); background:#fff}
.project-types input[type="radio"]{accent-color:var(--blue, #146BFF); cursor:pointer}
.project-types input[type="radio"]:checked + span{color:var(--blue, #146BFF); font-weight:700}
.project-types label:has(input:checked){
  background:linear-gradient(135deg, rgba(20,107,255,.06), rgba(123,92,255,.04));
  border-color:var(--blue, #146BFF);
}

.consult-submit{
  width:100%;
  margin-top:10px;
  padding:16px;
  background:linear-gradient(135deg,#146BFF,#7B5CFF);
  color:#fff;
  border:none;
  border-radius:14px;
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;
  font-size:14px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  cursor:pointer;
  transition:all .4s ease;
  box-shadow:0 10px 28px rgba(20,107,255,.32);
}
[dir="rtl"] .consult-submit{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:.5px; text-transform:none; font-size:16px}
.consult-submit:hover{
  background:linear-gradient(135deg,#FF3D8B,#7B5CFF,#28D7FF);
  background-size:200% 200%;
  animation:launchGrad 4s ease infinite;
  transform:translateY(-2px);
  box-shadow:0 14px 36px rgba(255,61,139,.36);
}

/* Consult sidebar */
.consult-side{display:flex; flex-direction:column; gap:24px}
.consult-card{
  background:linear-gradient(135deg, rgba(20,107,255,.04), rgba(123,92,255,.03), rgba(255,61,139,.02));
  border:1px solid rgba(20,107,255,.12);
  border-radius:24px;
  padding:32px 28px;
}
.consult-card h3{
  font-family:'Space Grotesk',sans-serif;
  font-weight:800;
  font-size:20px;
  margin-bottom:18px;
  color:var(--navy, #0A1F4D);
}
[dir="rtl"] .consult-card h3{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:22px}

.consult-steps{list-style:none; padding:0; margin:0; counter-reset:cstep}
.consult-steps li{
  position:relative;
  padding:14px 0 14px 50px;
  border-bottom:1px dashed rgba(20,107,255,.10);
  counter-increment:cstep;
  font-size:14px;
  color:var(--text-primary, #0A1F4D);
  font-weight:600;
  line-height:1.5;
}
[dir="rtl"] .consult-steps li{padding:14px 50px 14px 0; font-family:'IBM Plex Sans Arabic',sans-serif; font-size:15px}
.consult-steps li:last-child{border-bottom:none}
.consult-steps li::before{
  content:counter(cstep, decimal-leading-zero);
  position:absolute;
  left:0; top:11px;
  width:34px; height:34px;
  border-radius:10px;
  background:linear-gradient(135deg,#146BFF,#7B5CFF);
  color:#fff;
  font-family:'JetBrains Mono',monospace;
  font-size:13px;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 12px rgba(20,107,255,.28);
}
[dir="rtl"] .consult-steps li::before{left:auto; right:0; font-family:'JetBrains Mono',monospace}
.consult-steps li small{
  display:block;
  color:var(--text-muted, rgba(10,31,77,.55));
  font-weight:500;
  font-size:12.5px;
  margin-top:3px;
}
[dir="rtl"] .consult-steps li small{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:13.5px}

.consult-whatsapp{
  display:flex;
  align-items:center;
  gap:14px;
  padding:18px 22px;
  background:#25D366;
  border-radius:16px;
  text-decoration:none;
  transition:all .35s ease;
  box-shadow:0 10px 28px rgba(37,211,102,.32);
}
.consult-whatsapp:hover{transform:translateY(-3px); box-shadow:0 14px 36px rgba(37,211,102,.42)}
.consult-whatsapp svg{width:32px; height:32px; fill:#fff; flex-shrink:0}
.consult-whatsapp strong{color:#fff !important; display:block; font-weight:700; font-size:15px}
.consult-whatsapp small{color:rgba(255,255,255,.85) !important; font-size:12.5px}
[dir="rtl"] .consult-whatsapp strong{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:16px}
[dir="rtl"] .consult-whatsapp small{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:13.5px}

/* ============ BLOG ============ */
.blog-wrap{max-width:1320px; margin:0 auto; padding:0 5% 80px}
.blog-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:28px;
}
@media (max-width:980px){.blog-grid{grid-template-columns:repeat(2,1fr); gap:24px}}
@media (max-width:620px){.blog-grid{grid-template-columns:1fr; gap:20px}}

.blog-card{
  background:#fff;
  border:1px solid rgba(20,107,255,.10);
  border-radius:22px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:all .4s ease;
  text-decoration:none;
  color:inherit;
}
.blog-card:hover{
  transform:translateY(-8px);
  border-color:rgba(20,107,255,.30);
  box-shadow:0 24px 56px rgba(20,107,255,.14);
}
.blog-thumb{
  aspect-ratio:16/10;
  background:linear-gradient(135deg,#146BFF 0%,#7B5CFF 50%,#FF3D8B 100%);
  position:relative;
  overflow:hidden;
}
.blog-thumb.var-2{background:linear-gradient(135deg,#28D7FF 0%,#146BFF 50%,#7B5CFF 100%)}
.blog-thumb.var-3{background:linear-gradient(135deg,#FF3D8B 0%,#7B5CFF 50%,#28D7FF 100%)}
.blog-thumb.var-4{background:linear-gradient(135deg,#7B5CFF 0%,#FF3D8B 50%,#FF8A3D 100%)}
.blog-thumb.var-5{background:linear-gradient(135deg,#00E5D1 0%,#146BFF 50%,#0A1F4D 100%)}
.blog-thumb.var-6{background:linear-gradient(135deg,#FF8A3D 0%,#FF3D8B 50%,#7B5CFF 100%)}
.blog-thumb::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 30% 50%, rgba(255,255,255,.18) 0%, transparent 50%),
    radial-gradient(circle at 70% 80%, rgba(0,0,0,.15) 0%, transparent 50%);
}
.blog-thumb-icon{
  position:absolute;
  bottom:20px;
  left:24px;
  font-family:'JetBrains Mono',monospace;
  color:rgba(255,255,255,.92);
  font-size:11px;
  font-weight:700;
  letter-spacing:2.5px;
  text-transform:uppercase;
  z-index:2;
  display:flex;
  align-items:center;
  gap:8px;
}
[dir="rtl"] .blog-thumb-icon{left:auto; right:24px; font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:.5px; text-transform:none; font-size:13px}
.blog-thumb-icon::before{
  content:"";
  width:24px; height:2px;
  background:#fff;
}

.blog-content{padding:24px 22px 26px; flex:1; display:flex; flex-direction:column}
.blog-meta{
  display:flex;
  gap:14px;
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--blue, #146BFF);
  font-weight:700;
  margin-bottom:12px;
}
[dir="rtl"] .blog-meta{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:0; text-transform:none; font-size:12.5px}
.blog-meta span:not(:last-child)::after{content:"·"; margin-left:14px; color:rgba(10,31,77,.3)}
.blog-card h3{
  font-family:'Space Grotesk',sans-serif;
  font-weight:800;
  font-size:20px;
  line-height:1.25;
  letter-spacing:-.4px;
  margin-bottom:10px;
  color:var(--navy, #0A1F4D);
  transition:color .3s ease;
}
[dir="rtl"] .blog-card h3{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:0; font-size:21px; line-height:1.4}
.blog-card:hover h3{color:var(--blue, #146BFF)}
.blog-card p{
  color:var(--text-muted, rgba(10,31,77,.62));
  font-size:14px;
  line-height:1.65;
  flex:1;
  margin-bottom:18px;
}
[dir="rtl"] .blog-card p{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:15px; line-height:1.85}
.blog-read{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-family:'JetBrains Mono',monospace;
  font-size:12px;
  font-weight:700;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--blue, #146BFF);
  transition:gap .3s ease;
}
[dir="rtl"] .blog-read{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:0; text-transform:none; font-size:14px}
.blog-card:hover .blog-read{gap:12px}

/* Blog post (article) */
.blog-article{max-width:780px; margin:0 auto; padding:0 5% 80px}
.blog-article .article-meta{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  font-family:'JetBrains Mono',monospace;
  font-size:12px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--blue, #146BFF);
  font-weight:700;
  margin-bottom:20px;
}
[dir="rtl"] .blog-article .article-meta{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:0; text-transform:none; font-size:14px}
.blog-article h1{
  font-family:'Space Grotesk',sans-serif;
  font-weight:900;
  font-size:clamp(32px,5vw,52px);
  line-height:1.1;
  letter-spacing:-1.5px;
  margin-bottom:24px;
  color:var(--navy, #0A1F4D);
}
[dir="rtl"] .blog-article h1{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:-.5px}
.blog-article .article-hero{
  aspect-ratio:16/9;
  border-radius:24px;
  background:linear-gradient(135deg,#146BFF 0%,#7B5CFF 50%,#FF3D8B 100%);
  margin-bottom:40px;
  position:relative;
  overflow:hidden;
}
.blog-article h2{
  font-family:'Space Grotesk',sans-serif;
  font-weight:800;
  font-size:28px;
  line-height:1.2;
  margin:40px 0 16px;
  color:var(--navy, #0A1F4D);
  letter-spacing:-.5px;
}
[dir="rtl"] .blog-article h2{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:0; font-size:30px}
.blog-article h3{
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;
  font-size:22px;
  line-height:1.25;
  margin:32px 0 14px;
  color:var(--navy, #0A1F4D);
}
[dir="rtl"] .blog-article h3{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:24px}
.blog-article p{
  color:var(--text-primary, #1B2845);
  font-size:17px;
  line-height:1.85;
  margin-bottom:20px;
}
[dir="rtl"] .blog-article p{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:18px; line-height:2}
.blog-article ul, .blog-article ol{margin:0 0 20px 24px; padding:0}
.blog-article li{
  color:var(--text-primary, #1B2845);
  font-size:16px;
  line-height:1.85;
  margin-bottom:8px;
}
[dir="rtl"] .blog-article li{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:17px; line-height:2}
.blog-article blockquote{
  margin:32px 0;
  padding:24px 28px;
  border-left:4px solid var(--blue, #146BFF);
  background:linear-gradient(135deg, rgba(20,107,255,.04), rgba(123,92,255,.03));
  border-radius:0 16px 16px 0;
  font-style:italic;
  font-size:18px;
  color:var(--navy, #0A1F4D);
}
[dir="rtl"] .blog-article blockquote{border-left:none; border-right:4px solid var(--blue, #146BFF); border-radius:16px 0 0 16px; font-family:'IBM Plex Sans Arabic',sans-serif}

/* Article footer CTA */
.article-foot-cta{
  margin-top:60px;
  padding:40px 32px;
  border-radius:24px;
  background:linear-gradient(135deg,#0A1F4D 0%,#146BFF 50%,#7B5CFF 100%);
  text-align:center;
  color:#fff;
}
.article-foot-cta h3{color:#fff !important; font-family:'Space Grotesk',sans-serif; font-size:26px; margin-bottom:10px; font-weight:800}
[dir="rtl"] .article-foot-cta h3{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:28px}
.article-foot-cta p{color:rgba(255,255,255,.85) !important; font-size:15px; margin-bottom:22px}
[dir="rtl"] .article-foot-cta p{font-family:'IBM Plex Sans Arabic',sans-serif; font-size:16px}
.article-foot-cta a{
  display:inline-block;
  padding:14px 30px;
  background:#fff;
  color:var(--navy, #0A1F4D) !important;
  border-radius:12px;
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;
  font-size:13px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  text-decoration:none;
  transition:all .3s ease;
}
[dir="rtl"] .article-foot-cta a{font-family:'IBM Plex Sans Arabic',sans-serif; letter-spacing:.5px; text-transform:none; font-size:15px}
.article-foot-cta a:hover{transform:translateY(-2px); background:#28D7FF; box-shadow:0 10px 28px rgba(255,255,255,.32)}

/* Book Now CTA nav button */
.nav-book{
  background:linear-gradient(135deg,#FF3D8B,#7B5CFF) !important;
  color:#fff !important;
  padding:10px 20px !important;
  border-radius:999px !important;
  font-family:'JetBrains Mono',monospace !important;
  font-size:11px !important;
  letter-spacing:1.5px !important;
  text-transform:uppercase !important;
  font-weight:700 !important;
  text-decoration:none;
  box-shadow:0 6px 18px rgba(255,61,139,.32) !important;
  transition:all .35s ease !important;
}
[dir="rtl"] .nav-book{font-family:'IBM Plex Sans Arabic',sans-serif !important; letter-spacing:.5px !important; text-transform:none !important; font-size:13px !important}
.nav-book:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 26px rgba(255,61,139,.45) !important;
  background:linear-gradient(135deg,#FF3D8B,#7B5CFF,#28D7FF) !important;
  background-size:200% 200% !important;
  animation:launchGrad 4s ease infinite !important;
}


/* ===========================================================
   MOBILE OVERHAUL — Side menu, animated burger, full responsive
   =========================================================== */

/* Prevent horizontal scroll globally */
html, body { overflow-x: hidden !important; max-width: 100vw }
nav.main-nav { width: 100% !important; max-width: 100vw !important; box-sizing: border-box }

/* Hide ::after chevron on mobile (replaced by ::before + sign) */
@media (max-width: 1100px) {
  .nav-links li.has-dropdown > a::after { display: none !important }
}

/* ================ MOBILE NAV PANEL (≤1100px) ================ */
@media (max-width: 1100px) {

  /* Override the OLD dark dropdown menu with new slide-in panel */
  .nav-links {
    display: flex !important;
    position: fixed !important;
    top: 0 !important;
    right: -110% !important;
    left: auto !important;
    bottom: 0 !important;
    height: 100vh !important;
    height: 100dvh !important;
    width: min(380px, 88vw) !important;
    flex-direction: column !important;
    background: #ffffff !important;
    padding: 96px 22px 32px !important;
    gap: 0 !important;
    align-items: stretch !important;
    transition: right .42s cubic-bezier(.4,0,.2,1) !important;
    box-shadow: -30px 0 80px rgba(10,31,77,.18) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    z-index: 1005 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    border-left: 1px solid rgba(20,107,255,.08);
    border-radius: 0 !important;
  }
  
  [dir="rtl"] .nav-links {
    right: auto !important;
    left: -110% !important;
    transition: left .42s cubic-bezier(.4,0,.2,1) !important;
    box-shadow: 30px 0 80px rgba(10,31,77,.18) !important;
    border-left: none;
    border-right: 1px solid rgba(20,107,255,.08);
  }
  
  /* Open state */
  .nav-links.open { right: 0 !important }
  [dir="rtl"] .nav-links.open { left: 0 !important; right: auto !important }
  
  /* Items styling */
  .nav-links li {
    width: 100% !important;
    margin: 0 !important;
    list-style: none !important;
    border-bottom: 1px solid rgba(20,107,255,.06);
  }
  .nav-links > li:last-child { border-bottom: none }
  
  .nav-links li > a {
    display: flex !important;
    align-items: center !important;
    padding: 16px 6px !important;
    color: var(--navy, #0A1F4D) !important;
    font-family: 'Space Grotesk', sans-serif !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
    min-height: 56px !important;
    width: 100% !important;
    text-decoration: none !important;
    line-height: 1.3 !important;
    position: relative !important;
  }
  [dir="rtl"] .nav-links li > a {
    font-family: 'IBM Plex Sans Arabic', sans-serif !important;
    font-size: 17px !important;
  }
  
  .nav-links li > a::after { display: none !important }
  
  .nav-links li > a .num {
    display: inline-flex !important;
    margin-right: 14px !important;
    width: 28px !important;
    color: var(--blue, #146BFF) !important;
    opacity: 1 !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    flex-shrink: 0;
    font-family: 'JetBrains Mono', monospace !important;
  }
  [dir="rtl"] .nav-links li > a .num {
    margin-right: 0 !important;
    margin-left: 14px !important;
  }
  
  .nav-links li > a:hover,
  .nav-links li > a.active {
    color: var(--blue, #146BFF) !important;
  }
  
  /* Services dropdown — chevron/plus indicator */
  .nav-links li.has-dropdown > a {
    padding-right: 44px !important;
  }
  [dir="rtl"] .nav-links li.has-dropdown > a {
    padding-right: 6px !important;
    padding-left: 44px !important;
  }
  
  .nav-links li.has-dropdown > a::before {
    content: "+" !important;
    position: absolute !important;
    right: 4px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 28px !important;
    height: 28px !important;
    line-height: 26px !important;
    text-align: center !important;
    background: linear-gradient(135deg, rgba(20,107,255,.10), rgba(123,92,255,.06)) !important;
    color: var(--blue, #146BFF) !important;
    border-radius: 50% !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    font-family: 'Space Grotesk', sans-serif !important;
    transition: all .3s ease !important;
    display: block !important;
  }
  [dir="rtl"] .nav-links li.has-dropdown > a::before {
    right: auto !important;
    left: 4px !important;
  }
  .nav-links li.has-dropdown.open > a::before {
    content: "−" !important;
    background: linear-gradient(135deg, var(--blue, #146BFF), var(--violet, #7B5CFF)) !important;
    color: #fff !important;
    transform: translateY(-50%) rotate(180deg) !important;
  }
  
  /* Dropdown menu inside mobile (expand inline) */
  .nav-links .dropdown-menu {
    position: static !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    background: linear-gradient(180deg, rgba(20,107,255,.025), rgba(123,92,255,.015)) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 12px !important;
    width: 100% !important;
    max-height: 0 !important;
    overflow: hidden !important;
    transition: max-height .42s ease, padding .3s ease, margin .3s ease !important;
    display: block !important;
    list-style: none !important;
  }
  .nav-links .dropdown-menu::before { display: none !important }
  
  .nav-links li.has-dropdown.open .dropdown-menu {
    max-height: 520px !important;
    padding: 6px 8px 10px !important;
    margin: 4px 0 12px !important;
  }
  
  .nav-links .dropdown-menu li {
    border-bottom: none !important;
    width: 100% !important;
    margin: 2px 0 !important;
  }
  .nav-links .dropdown-menu li a {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 12px 14px !important;
    min-height: 52px !important;
    background: transparent !important;
    border-radius: 10px !important;
    font-size: 14px !important;
    transition: background .25s ease !important;
  }
  .nav-links .dropdown-menu li a:hover {
    background: rgba(20,107,255,.06) !important;
    transform: none !important;
  }
  .nav-links .dropdown-menu .dropdown-icon {
    width: 32px !important;
    height: 32px !important;
    flex-shrink: 0 !important;
  }
  .nav-links .dropdown-menu .dropdown-icon svg {
    width: 15px !important;
    height: 15px !important;
  }
  .nav-links .dropdown-menu .dropdown-text strong {
    font-size: 13.5px !important;
    line-height: 1.3 !important;
  }
  .nav-links .dropdown-menu .dropdown-text small {
    font-size: 11.5px !important;
    line-height: 1.3 !important;
    margin-top: 2px !important;
  }
  
  /* =========== ANIMATED BURGER BUTTON =========== */
  .menu-toggle {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
    width: 44px !important;
    height: 44px !important;
    background-color: #ffffff !important;
    background-image: linear-gradient(var(--navy, #0A1F4D), var(--navy, #0A1F4D)) !important;
    background-size: 18px 2px !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border: 1.5px solid rgba(20,107,255,.18) !important;
    border-radius: 12px !important;
    cursor: pointer !important;
    padding: 0 !important;
    color: transparent !important;
    font-size: 0 !important;
    z-index: 1010 !important;
    flex-shrink: 0 !important;
    transition: all .3s ease !important;
    box-shadow: 0 4px 12px rgba(20,107,255,.08) !important;
  }
  .menu-toggle:hover {
    border-color: var(--blue, #146BFF) !important;
    background-color: rgba(20,107,255,.04) !important;
  }
  .menu-toggle::before, .menu-toggle::after {
    content: "" !important;
    position: absolute !important;
    left: 50% !important;
    width: 18px !important;
    height: 2px !important;
    background: var(--navy, #0A1F4D) !important;
    border-radius: 2px !important;
    transform: translateX(-50%) !important;
    transition: all .35s cubic-bezier(.4,0,.2,1) !important;
  }
  .menu-toggle::before { top: 13px }
  .menu-toggle::after { bottom: 13px }
  
  /* Open state — X */
  body.menu-open .menu-toggle {
    background-image: none !important;
    border-color: var(--blue, #146BFF) !important;
    background-color: rgba(20,107,255,.06) !important;
  }
  body.menu-open .menu-toggle::before {
    top: 50% !important;
    transform: translate(-50%, -50%) rotate(45deg) !important;
    background: var(--blue, #146BFF) !important;
  }
  body.menu-open .menu-toggle::after {
    bottom: auto !important;
    top: 50% !important;
    transform: translate(-50%, -50%) rotate(-45deg) !important;
    background: var(--blue, #146BFF) !important;
  }
  
  /* =========== BACKDROP — futuristic tech feel (grid + glow, no darkening) =========== */
  body.menu-open::after {
    content: "" !important;
    position: fixed !important;
    inset: 0 !important;
    background:
      /* Tech grid pattern — very subtle */
      linear-gradient(rgba(40,215,255,.07) 1px, transparent 1px) 0 0 / 36px 36px,
      linear-gradient(90deg, rgba(40,215,255,.07) 1px, transparent 1px) 0 0 / 36px 36px,
      /* Radial violet glow emanating from the menu side */
      radial-gradient(ellipse 75% 100% at 100% 50%, rgba(123,92,255,.20) 0%, transparent 55%),
      /* Cool brand-tinted veil — light, not dim */
      linear-gradient(135deg, rgba(10,31,77,.32) 0%, rgba(20,30,90,.28) 50%, rgba(40,20,90,.38) 100%) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    z-index: 1001 !important;
    animation: navBackdropTech .55s cubic-bezier(.4,0,.2,1) !important;
    pointer-events: none !important;
  }
  /* RTL: flip the radial glow to come from the left (menu side) */
  [dir="rtl"] body.menu-open::after {
    background:
      linear-gradient(rgba(40,215,255,.07) 1px, transparent 1px) 0 0 / 36px 36px,
      linear-gradient(90deg, rgba(40,215,255,.07) 1px, transparent 1px) 0 0 / 36px 36px,
      radial-gradient(ellipse 75% 100% at 0% 50%, rgba(123,92,255,.20) 0%, transparent 55%),
      linear-gradient(135deg, rgba(40,20,90,.38) 0%, rgba(20,30,90,.28) 50%, rgba(10,31,77,.32) 100%) !important;
  }
  @keyframes navBackdropTech {
    from { opacity: 0; transform: scale(1.015); }
    to { opacity: 1; transform: scale(1); }
  }
  
  /* =========== MENU PANEL — glowing tech edge =========== */
  .nav-links.open {
    border-left: 1px solid rgba(40,215,255,.25) !important;
    box-shadow:
      -1px 0 0 rgba(40,215,255,.5),
      -8px 0 30px rgba(20,107,255,.18),
      -30px 0 80px rgba(10,31,77,.18) !important;
  }
  [dir="rtl"] .nav-links.open {
    border-left: none !important;
    border-right: 1px solid rgba(40,215,255,.25) !important;
    box-shadow:
      1px 0 0 rgba(40,215,255,.5),
      8px 0 30px rgba(20,107,255,.18),
      30px 0 80px rgba(10,31,77,.18) !important;
  }
  
  /* Lock body scroll when menu open */
  body.menu-open { overflow: hidden !important; height: 100vh !important }
  
  /* =========== NAV ACTIONS ON MOBILE =========== */
  .nav-actions {
    gap: 10px !important;
    align-items: center !important;
  }
  
  /* Hide lang-switch on mobile (visible on desktop only) */
  .nav-actions .lang-switch { display: none !important }
  
  /* Book Now CTA — make smaller on mobile */
  .nav-actions .nav-book {
    padding: 9px 14px !important;
    font-size: 10px !important;
    letter-spacing: 1px !important;
    border-radius: 999px !important;
  }
  [dir="rtl"] .nav-actions .nav-book {
    font-size: 12px !important;
    letter-spacing: 0 !important;
  }
  
  /* Logo must stay above the menu */
  nav.main-nav .logo {
    position: relative !important;
    z-index: 1010 !important;
  }
  
  /* On bright bg, ensure nav itself is solid for visibility */
  nav.main-nav {
    background: rgba(255,255,255,.92) !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    padding: 14px 5% !important;
  }
}

/* Even smaller screens: hide Book Now in top nav (still in side menu) */
@media (max-width: 480px) {
  .nav-actions .nav-book { display: none !important }
  nav.main-nav { padding: 12px 4% !important }
  nav.main-nav .logo-wordmark .logo-tag { display: none !important }
  nav.main-nav .logo-wordmark .logo-name-img { max-height: 18px !important }
  nav.main-nav .logo-mark img { max-height: 26px !important }
}

/* ================ FULL RESPONSIVE PADDING & SIZING ================ */

/* Hero adjustments */
@media (max-width: 768px) {
  .hero {
    padding: 110px 5% 60px !important;
    min-height: auto !important;
  }
  .hero h1, .hero-content h1 {
    font-size: clamp(38px, 10vw, 64px) !important;
    line-height: 1 !important;
    letter-spacing: -2px !important;
  }
  .hero-sub { gap: 8px !important }
  .hero-sub .pill { font-size: 10px !important; padding: 6px 12px !important }
  [dir="rtl"] .hero-sub .pill { font-size: 12px !important }
  .hero p, .hero .hero-desc { font-size: 14px !important; line-height: 1.7 !important }
  .hero-coords { font-size: 8px !important; letter-spacing: 1.5px !important }
  .hero-frame { inset: 80px 4% 60px 4% !important }
  .hero-centerpiece { transform: scale(0.6) !important; opacity: 0.7 !important }
}

@media (max-width: 480px) {
  .hero { padding: 100px 4% 50px !important }
  .hero-frame, .hero-coords, .hero-centerpiece, .scroll-indicator { display: none !important }
  .hero-cta {
    flex-direction: column !important;
    gap: 10px !important;
    width: 100% !important;
    align-items: stretch !important;
  }
  .hero-cta .btn-primary,
  .hero-cta .btn-secondary,
  .hero-cta a {
    width: 100% !important;
    justify-content: center !important;
    text-align: center !important;
  }
  .hero h1, .hero-content h1 {
    font-size: clamp(32px, 11vw, 48px) !important;
  }
}

/* Showreel */
@media (max-width: 768px) {
  .showreel-section { padding: 50px 4% 50px !important }
  .showreel-head { margin-bottom: 28px !important }
  .showreel-head h2 { font-size: clamp(26px, 7vw, 40px) !important }
  .showreel-head p { font-size: 14px !important; line-height: 1.7 !important }
  .showreel-frame { border-radius: 16px !important }
  .showreel-frame::before { border-radius: 16px !important }
  .showreel-play-btn { width: 60px !important; height: 60px !important; margin-bottom: 14px !important }
  .showreel-play-btn svg { width: 20px !important; height: 20px !important }
  .showreel-placeholder { padding: 24px !important }
  .showreel-placeholder h3 { font-size: 18px !important; margin-bottom: 6px !important }
  .showreel-placeholder p { font-size: 11px !important; letter-spacing: 1.5px !important }
}

/* Page headers */
@media (max-width: 768px) {
  .page-header { padding: 110px 5% 36px !important }
  .page-header h1 {
    font-size: clamp(32px, 9vw, 56px) !important;
    line-height: 1.05 !important;
  }
  .page-header p { font-size: 14px !important }
  .breadcrumb { font-size: 10px !important; letter-spacing: 1.5px !important }
}

/* Service hero */
@media (max-width: 768px) {
  .service-hero { padding: 110px 5% 50px !important }
  .service-hero h1 {
    font-size: clamp(34px, 9vw, 56px) !important;
    line-height: 1 !important;
    letter-spacing: -1.5px !important;
  }
  .service-hero .service-sub { font-size: 15px !important; line-height: 1.7 !important }
  .service-hero-cta {
    flex-direction: column !important;
    gap: 10px !important;
    width: 100% !important;
    align-items: stretch !important;
  }
  .service-hero-cta a {
    width: 100% !important;
    text-align: center !important;
    padding: 14px 20px !important;
    font-size: 12px !important;
  }
  [dir="rtl"] .service-hero-cta a { font-size: 14px !important }
}

/* Service sections */
@media (max-width: 768px) {
  .service-section { padding: 50px 5% !important }
  .service-section-head { margin-bottom: 28px !important }
  .service-section-head h2 {
    font-size: clamp(24px, 7vw, 36px) !important;
    line-height: 1.15 !important;
  }
  .service-section-head p { font-size: 14px !important }
  .cap-card { padding: 24px 20px !important }
  .cap-card h3 { font-size: 16px !important }
  .cap-card p { font-size: 13.5px !important }
  .process-step { padding: 24px 18px !important }
  .process-step h4 { font-size: 16px !important; margin-top: 28px !important }
  .process-step::before { font-size: 26px !important; top: 14px !important; right: 16px !important }
  [dir="rtl"] .process-step::before { left: 16px !important; right: auto !important }
}

/* Pricing page */
@media (max-width: 980px) {
  .pricing-grid { grid-template-columns: 1fr !important; gap: 20px !important }
}
@media (max-width: 768px) {
  .pricing-card { padding: 30px 24px !important }
}

/* Consultation page */
@media (max-width: 768px) {
  .consult-wrap { padding: 0 4% 60px !important; gap: 30px !important }
  .consult-form { padding: 28px 20px !important; border-radius: 20px !important }
  .consult-form h2 { font-size: 22px !important }
  [dir="rtl"] .consult-form h2 { font-size: 24px !important }
  .consult-form .form-sub { font-size: 13px !important }
  .project-types { grid-template-columns: 1fr !important; gap: 8px !important }
  .project-types label { padding: 14px 16px !important; font-size: 14px !important; min-height: 48px }
  .form-group input, .form-group select, .form-group textarea {
    padding: 14px 16px !important;
    font-size: 15px !important;
    min-height: 48px;
  }
  .consult-submit {
    padding: 16px !important;
    font-size: 13px !important;
    min-height: 52px;
  }
  .consult-card { padding: 26px 22px !important; border-radius: 18px !important }
  .consult-card h3 { font-size: 18px !important }
  .consult-steps li { font-size: 13.5px !important; padding-left: 46px !important }
  [dir="rtl"] .consult-steps li { padding-left: 0 !important; padding-right: 46px !important }
  .consult-steps li::before { width: 30px !important; height: 30px !important; font-size: 12px !important }
}

/* Blog */
@media (max-width: 768px) {
  .blog-wrap { padding: 0 4% 60px !important }
  .blog-card { border-radius: 18px !important }
  .blog-content { padding: 20px 18px 22px !important }
  .blog-card h3 { font-size: 18px !important; line-height: 1.3 !important }
  [dir="rtl"] .blog-card h3 { font-size: 19px !important }
  .blog-card p { font-size: 13.5px !important }
  .blog-meta { font-size: 10px !important }
  [dir="rtl"] .blog-meta { font-size: 11.5px !important }
  
  /* Article */
  .blog-article { padding: 0 5% 60px !important }
  .blog-article h1 {
    font-size: clamp(28px, 8vw, 44px) !important;
    line-height: 1.1 !important;
    letter-spacing: -1px !important;
  }
  .blog-article h2 { font-size: 22px !important; margin: 32px 0 12px !important }
  [dir="rtl"] .blog-article h2 { font-size: 24px !important }
  .blog-article h3 { font-size: 18px !important; margin: 26px 0 10px !important }
  [dir="rtl"] .blog-article h3 { font-size: 20px !important }
  .blog-article p { font-size: 15px !important; line-height: 1.8 !important }
  [dir="rtl"] .blog-article p { font-size: 16px !important; line-height: 1.95 !important }
  .blog-article ul, .blog-article ol { margin-left: 18px !important }
  [dir="rtl"] .blog-article ul, [dir="rtl"] .blog-article ol { margin-left: 0 !important; margin-right: 18px !important }
  .blog-article li { font-size: 14.5px !important }
  [dir="rtl"] .blog-article li { font-size: 15.5px !important }
  .blog-article blockquote {
    padding: 18px 22px !important;
    font-size: 16px !important;
    margin: 26px 0 !important;
  }
  .blog-article .article-meta { font-size: 10px !important; gap: 10px !important }
  [dir="rtl"] .blog-article .article-meta { font-size: 12px !important }
  .article-hero { border-radius: 14px !important; margin-bottom: 28px !important }
  .article-foot-cta {
    padding: 30px 22px !important;
    border-radius: 18px !important;
    margin-top: 40px !important;
  }
  .article-foot-cta h3 { font-size: 20px !important }
  [dir="rtl"] .article-foot-cta h3 { font-size: 22px !important }
  .article-foot-cta p { font-size: 14px !important }
  .article-foot-cta a {
    padding: 13px 22px !important;
    font-size: 12px !important;
    width: 100% !important;
    text-align: center;
    box-sizing: border-box;
  }
  [dir="rtl"] .article-foot-cta a { font-size: 14px !important }
}

/* Quick contact button */
@media (max-width: 600px) {
  .quick-trigger {
    bottom: 16px !important;
    right: 16px !important;
    padding: 12px 14px !important;
    font-size: 9px !important;
    letter-spacing: 1px !important;
  }
  [dir="rtl"] .quick-trigger {
    right: auto !important;
    left: 16px !important;
    font-size: 11px !important;
    letter-spacing: 0 !important;
  }
  .quick-trigger svg { width: 12px !important; height: 12px !important }
}

/* Footer */
@media (max-width: 768px) {
  .main-footer { padding: 50px 5% 30px !important }
  .footer-grid {
    gap: 28px !important;
    grid-template-columns: 1fr 1fr !important;
  }
  .footer-brand { grid-column: span 2 !important; margin-bottom: 8px }
  .footer-col h4 { font-size: 12px !important }
  .footer-col ul li a { font-size: 13px !important }
  .footer-bottom {
    flex-direction: column !important;
    gap: 12px !important;
    text-align: center !important;
    font-size: 11px !important;
  }
}
@media (max-width: 480px) {
  .footer-grid { grid-template-columns: 1fr !important }
  .footer-brand { grid-column: span 1 !important }
}

/* Tech grid mobile */
@media (max-width: 480px) {
  .tech-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important }
  .tech-item { padding: 14px 10px !important; font-size: 12px !important }
}

/* Capabilities grid on small */
@media (max-width: 480px) {
  .capabilities-grid { gap: 14px !important }
  .cap-card { padding: 22px 18px !important }
}

/* Pillars & cards on small */
@media (max-width: 600px) {
  .stats-band { padding: 50px 5% !important }
  .stats-grid { grid-template-columns: repeat(2,1fr) !important; gap: 20px !important }
}

/* Loader on mobile */
@media (max-width: 480px) {
  #loader .loader-mark img { max-width: 60px !important; height: auto }
}

/* Touch target enforcement: all clickable elements minimum 44px tall */
@media (max-width: 768px) {
  a, button, input[type="submit"], input[type="button"], .cta-btn {
    min-height: 44px;
  }
}

/* Fix any aspect-ratio frames that overflow on small screens */
@media (max-width: 480px) {
  .showreel-frame { aspect-ratio: 16/10 !important }
  .article-hero { aspect-ratio: 16/10 !important }
}


/* ============ MOBILE NAV ACTIONS FIX — show Book Now + lang switch ============ */
@media (max-width: 1100px) {
  /* The old CSS hides .cta-btn.nav-cta on mobile; force-show our new nav-book */
  .nav-actions .cta-btn.nav-cta.nav-book {
    display: inline-flex !important;
    align-items: center !important;
  }
  /* Show language switch (smaller) on mobile */
  .nav-actions .lang-switch {
    display: flex !important;
    gap: 0 !important;
    background: rgba(20,107,255,.06) !important;
    border-radius: 999px !important;
    padding: 3px !important;
    border: 1px solid rgba(20,107,255,.12) !important;
  }
  .nav-actions .lang-switch button {
    padding: 4px 10px !important;
    font-size: 10px !important;
    border: none !important;
    background: transparent !important;
    color: var(--navy, #0A1F4D) !important;
    cursor: pointer !important;
    border-radius: 999px !important;
    font-weight: 700 !important;
    transition: all .3s ease !important;
    min-height: 26px !important;
    line-height: 1 !important;
  }
  .nav-actions .lang-switch button.active {
    background: linear-gradient(135deg, var(--blue, #146BFF), var(--violet, #7B5CFF)) !important;
    color: #fff !important;
  }
}

/* Below 600px — hide lang switch from top bar (Book Now stays as primary CTA) */
@media (max-width: 600px) {
  .nav-actions .lang-switch { display: none !important }
}

/* Add lang switch + extras inside the side menu at bottom via :nth-child trick — done via JS */


/* =================================================================
   ELEGANT FUTURISTIC MOBILE MENU — Full-screen takeover
   Overrides previous slide-in approach. iOS-safe (no backdrop-filter).
   ================================================================= */

@media (max-width: 1100px) {

  /* Kill the body backdrop pseudo — menu is full-screen, no overlay needed */
  body.menu-open::after { display: none !important; content: none !important }

  /* ============ FULL-SCREEN MENU OVERLAY ============ */
  .nav-links {
    display: flex !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    height: 100dvh !important;
    max-width: 100vw !important;
    margin: 0 !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    align-items: stretch !important;
    padding: 110px 30px 50px !important;
    gap: 0 !important;
    border: none !important;
    border-radius: 0 !important;
    z-index: 1005 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    box-shadow: none !important;

    /* Hidden state */
    opacity: 0 !important;
    visibility: hidden !important;
    transform: scale(1.04) !important;
    transition:
      opacity .5s cubic-bezier(.4,0,.2,1),
      transform .5s cubic-bezier(.4,0,.2,1),
      visibility 0s linear .5s !important;

    /* Futuristic navy background — tech grid + brand glow orbs */
    background:
      /* Subtle tech grid (cyan tinted) */
      linear-gradient(rgba(40,215,255,.07) 1px, transparent 1px) 0 0 / 44px 44px,
      linear-gradient(90deg, rgba(40,215,255,.07) 1px, transparent 1px) 0 0 / 44px 44px,
      /* Brand glow orbs - blue top-right, violet bottom-left, faint magenta center */
      radial-gradient(circle at 85% 12%, rgba(20,107,255,.40) 0%, transparent 42%),
      radial-gradient(circle at 12% 88%, rgba(123,92,255,.32) 0%, transparent 42%),
      radial-gradient(circle at 50% 50%, rgba(255,61,139,.10) 0%, transparent 50%),
      /* Base navy gradient */
      linear-gradient(165deg, #07173f 0%, #0d2155 40%, #131e5a 70%, #1a1e5c 100%) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  /* RTL: mirror the glow positions */
  [dir="rtl"] .nav-links {
    background:
      linear-gradient(rgba(40,215,255,.07) 1px, transparent 1px) 0 0 / 44px 44px,
      linear-gradient(90deg, rgba(40,215,255,.07) 1px, transparent 1px) 0 0 / 44px 44px,
      radial-gradient(circle at 15% 12%, rgba(20,107,255,.40) 0%, transparent 42%),
      radial-gradient(circle at 88% 88%, rgba(123,92,255,.32) 0%, transparent 42%),
      radial-gradient(circle at 50% 50%, rgba(255,61,139,.10) 0%, transparent 50%),
      linear-gradient(195deg, #07173f 0%, #0d2155 40%, #131e5a 70%, #1a1e5c 100%) !important;
  }

  /* Open state */
  .nav-links.open {
    opacity: 1 !important;
    visibility: visible !important;
    transform: scale(1) !important;
    transition:
      opacity .5s cubic-bezier(.4,0,.2,1),
      transform .5s cubic-bezier(.4,0,.2,1),
      visibility 0s !important;
  }

  /* ============ "NAVIGATE" ELEGANT HEADER ============ */
  .nav-links::before {
    content: "NAVIGATE" !important;
    position: absolute !important;
    top: 96px !important;
    left: 30px !important;
    font-family: 'JetBrains Mono', monospace !important;
    font-size: 10px !important;
    letter-spacing: 4px !important;
    color: rgba(40,215,255,.75) !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    z-index: 2 !important;
  }
  [dir="rtl"] .nav-links::before {
    left: auto !important;
    right: 30px !important;
    content: "التنقل" !important;
    font-family: 'IBM Plex Sans Arabic', sans-serif !important;
    letter-spacing: 2px !important;
    font-size: 12px !important;
  }

  /* ============ NAV ITEMS — LIGHT TEXT, ELEGANT TYPOGRAPHY ============ */
  .nav-links li {
    width: 100% !important;
    margin: 0 !important;
    list-style: none !important;
    border-bottom: 1px solid rgba(255,255,255,.07) !important;
    padding: 0 !important;
    position: relative !important;

    /* Cascading entrance animation */
    opacity: 0;
    transform: translateY(16px);
  }
  .nav-links > li:last-child { border-bottom: none !important }

  /* Animate items in when menu opens */
  .nav-links.open > li { animation: navItemEnter .55s cubic-bezier(.4,0,.2,1) both }
  .nav-links.open > li:nth-child(1) { animation-delay: .1s }
  .nav-links.open > li:nth-child(2) { animation-delay: .16s }
  .nav-links.open > li:nth-child(3) { animation-delay: .22s }
  .nav-links.open > li:nth-child(4) { animation-delay: .28s }
  .nav-links.open > li:nth-child(5) { animation-delay: .34s }
  .nav-links.open > li:nth-child(6) { animation-delay: .40s }
  .nav-links.open > li:nth-child(7) { animation-delay: .46s }
  @keyframes navItemEnter {
    from { opacity: 0; transform: translateY(16px) }
    to { opacity: 1; transform: translateY(0) }
  }

  .nav-links li > a {
    display: flex !important;
    align-items: center !important;
    padding: 20px 8px !important;
    color: rgba(255,255,255,.93) !important;
    font-family: 'Space Grotesk', sans-serif !important;
    font-size: 22px !important;
    font-weight: 600 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
    line-height: 1 !important;
    text-decoration: none !important;
    position: relative !important;
    min-height: 60px !important;
    width: 100% !important;
    transition: color .3s ease, padding .3s ease, transform .3s ease !important;
  }
  [dir="rtl"] .nav-links li > a {
    font-family: 'IBM Plex Sans Arabic', sans-serif !important;
    font-size: 23px !important;
    font-weight: 700 !important;
  }
  .nav-links li > a::after { display: none !important }

  /* Numbers — cyan/blue gradient text */
  .nav-links li > a .num {
    display: inline-block !important;
    margin-right: 20px !important;
    width: 34px !important;
    font-family: 'JetBrains Mono', monospace !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    background: linear-gradient(135deg, var(--cyan, #28D7FF), var(--blue, #146BFF)) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    color: transparent !important;
    opacity: 1 !important;
    flex-shrink: 0 !important;
  }
  [dir="rtl"] .nav-links li > a .num {
    margin-right: 0 !important;
    margin-left: 20px !important;
  }

  /* Hover state — shifts to cyan with slide */
  .nav-links li > a:hover,
  .nav-links li > a.active {
    color: var(--cyan, #28D7FF) !important;
    padding-left: 16px !important;
  }
  [dir="rtl"] .nav-links li > a:hover,
  [dir="rtl"] .nav-links li > a.active {
    padding-left: 8px !important;
    padding-right: 16px !important;
  }

  /* ============ SERVICES DROPDOWN INDICATOR ============ */
  .nav-links li.has-dropdown > a {
    padding-right: 56px !important;
  }
  [dir="rtl"] .nav-links li.has-dropdown > a {
    padding-right: 8px !important;
    padding-left: 56px !important;
  }
  .nav-links li.has-dropdown > a::before {
    content: "+" !important;
    position: absolute !important;
    right: 8px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 32px !important;
    height: 32px !important;
    line-height: 30px !important;
    text-align: center !important;
    background: rgba(40,215,255,.08) !important;
    border: 1px solid rgba(40,215,255,.30) !important;
    color: var(--cyan, #28D7FF) !important;
    border-radius: 50% !important;
    font-size: 20px !important;
    font-weight: 300 !important;
    font-family: 'Space Grotesk', sans-serif !important;
    transition: all .4s cubic-bezier(.4,0,.2,1) !important;
    display: block !important;
  }
  [dir="rtl"] .nav-links li.has-dropdown > a::before {
    right: auto !important;
    left: 8px !important;
  }
  .nav-links li.has-dropdown.open > a::before {
    content: "−" !important;
    background: linear-gradient(135deg, var(--cyan, #28D7FF), var(--violet, #7B5CFF)) !important;
    color: #fff !important;
    border-color: transparent !important;
    transform: translateY(-50%) rotate(180deg) !important;
    box-shadow: 0 4px 16px rgba(40,215,255,.3) !important;
  }

  /* ============ DROPDOWN SUB-ITEMS ============ */
  .nav-links .dropdown-menu {
    position: static !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
    width: 100% !important;
    max-height: 0 !important;
    overflow: hidden !important;
    transition: max-height .5s cubic-bezier(.4,0,.2,1), padding .3s ease, margin .3s ease !important;
    display: block !important;
    list-style: none !important;
  }
  .nav-links .dropdown-menu::before { display: none !important }
  .nav-links li.has-dropdown.open .dropdown-menu {
    max-height: 600px !important;
    padding: 6px 0 18px 16px !important;
    margin: 4px 0 14px !important;
    border-left: 1px solid rgba(40,215,255,.22) !important;
  }
  [dir="rtl"] .nav-links li.has-dropdown.open .dropdown-menu {
    padding: 6px 16px 18px 0 !important;
    border-left: none !important;
    border-right: 1px solid rgba(40,215,255,.22) !important;
  }
  .nav-links .dropdown-menu li {
    border: none !important;
    width: 100% !important;
    margin: 0 !important;
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
  }
  .nav-links .dropdown-menu li a {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    padding: 13px 14px !important;
    min-height: 54px !important;
    background: transparent !important;
    border-radius: 10px !important;
    font-size: 15px !important;
    color: rgba(255,255,255,.72) !important;
    transition: background .25s ease, color .25s ease !important;
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-weight: 500 !important;
  }
  [dir="rtl"] .nav-links .dropdown-menu li a {
    font-family: 'IBM Plex Sans Arabic', sans-serif !important;
    font-size: 16px !important;
  }
  .nav-links .dropdown-menu li a:hover {
    background: rgba(40,215,255,.07) !important;
    color: #fff !important;
    transform: none !important;
  }
  .nav-links .dropdown-menu .dropdown-icon {
    width: 36px !important;
    height: 36px !important;
    background: rgba(40,215,255,.10) !important;
    color: var(--cyan, #28D7FF) !important;
    flex-shrink: 0 !important;
    border-radius: 10px !important;
  }
  .nav-links .dropdown-menu .dropdown-icon svg {
    width: 16px !important;
    height: 16px !important;
  }
  .nav-links .dropdown-menu .dropdown-text strong {
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
    color: rgba(255,255,255,.92) !important;
  }
  .nav-links .dropdown-menu .dropdown-text small {
    font-size: 11.5px !important;
    line-height: 1.4 !important;
    margin-top: 2px !important;
    color: rgba(255,255,255,.5) !important;
  }

  /* ============ NAV BAR WHEN MENU IS OPEN ============ */
  nav.main-nav { z-index: 1010 !important }
  body.menu-open nav.main-nav {
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    box-shadow: none !important;
    border-bottom: 1px solid rgba(255,255,255,.08) !important;
  }
  body.menu-open nav.main-nav .logo-mark img {
    filter: drop-shadow(0 0 12px rgba(40,215,255,.4)) !important;
  }
  body.menu-open nav.main-nav .logo-wordmark .logo-name-img {
    filter: brightness(2.2) contrast(1.1) !important;
  }
  body.menu-open nav.main-nav .logo-wordmark .logo-tag {
    color: var(--cyan, #28D7FF) !important;
  }
  body.menu-open .nav-actions .nav-book {
    background: linear-gradient(135deg, var(--cyan, #28D7FF), var(--blue, #146BFF)) !important;
    color: var(--navy, #07173f) !important;
    box-shadow: 0 6px 22px rgba(40,215,255,.35) !important;
  }
  body.menu-open .nav-actions .nav-book span {
    color: var(--navy, #07173f) !important;
  }

  /* ============ BURGER BUTTON OPEN STATE — cyan glow ============ */
  body.menu-open .menu-toggle {
    border-color: rgba(40,215,255,.45) !important;
    background-color: rgba(40,215,255,.10) !important;
    background-image: none !important;
    box-shadow: 0 0 20px rgba(40,215,255,.3) !important;
  }
  body.menu-open .menu-toggle::before,
  body.menu-open .menu-toggle::after {
    background: var(--cyan, #28D7FF) !important;
  }

  /* Lang switch in nav when menu open — adjust for dark bg */
  body.menu-open .nav-actions .lang-switch {
    background: rgba(40,215,255,.08) !important;
    border-color: rgba(40,215,255,.25) !important;
  }
  body.menu-open .nav-actions .lang-switch button {
    color: rgba(255,255,255,.7) !important;
  }
  body.menu-open .nav-actions .lang-switch button.active {
    background: linear-gradient(135deg, var(--cyan, #28D7FF), var(--violet, #7B5CFF)) !important;
    color: var(--navy, #07173f) !important;
  }
}


/* =================================================================
   ULTRA-ELEGANT MOBILE MENU — Editorial + Tech Node Design
   Overrides all previous mobile menu styling
   ================================================================= */

@media (max-width: 1100px) {

  /* ============ TYPOGRAPHY ENHANCEMENTS (use new elegant fonts) ============ */
  body, html { font-family: 'Plus Jakarta Sans', 'IBM Plex Sans Arabic', sans-serif }
  
  /* ============ MENU CONTAINER — Premium Navy Atmosphere ============ */
  .nav-links {
    /* Most rules inherited from previous, just refine the background subtly */
    background:
      /* Sharper grid */
      linear-gradient(rgba(40,215,255,.06) 1px, transparent 1px) 0 0 / 48px 48px,
      linear-gradient(90deg, rgba(40,215,255,.06) 1px, transparent 1px) 0 0 / 48px 48px,
      /* Vertical accent line on the left (the "rail") */
      linear-gradient(180deg, transparent 0%, rgba(40,215,255,.4) 20%, rgba(123,92,255,.3) 80%, transparent 100%) 30px 0 / 1px 100% no-repeat,
      /* Brand glow orbs - dispersed */
      radial-gradient(ellipse 60% 50% at 100% 0%, rgba(20,107,255,.32) 0%, transparent 60%),
      radial-gradient(ellipse 60% 50% at 0% 100%, rgba(123,92,255,.28) 0%, transparent 60%),
      radial-gradient(circle at 50% 50%, rgba(255,61,139,.06) 0%, transparent 70%),
      /* Deep navy gradient base */
      linear-gradient(170deg, #050f33 0%, #0a1a4a 40%, #0e1f55 70%, #14215c 100%) !important;
    padding: 110px 0 50px !important;
  }
  
  [dir="rtl"] .nav-links {
    background:
      linear-gradient(rgba(40,215,255,.06) 1px, transparent 1px) 0 0 / 48px 48px,
      linear-gradient(90deg, rgba(40,215,255,.06) 1px, transparent 1px) 0 0 / 48px 48px,
      linear-gradient(180deg, transparent 0%, rgba(40,215,255,.4) 20%, rgba(123,92,255,.3) 80%, transparent 100%) right 30px top 0 / 1px 100% no-repeat,
      radial-gradient(ellipse 60% 50% at 0% 0%, rgba(20,107,255,.32) 0%, transparent 60%),
      radial-gradient(ellipse 60% 50% at 100% 100%, rgba(123,92,255,.28) 0%, transparent 60%),
      radial-gradient(circle at 50% 50%, rgba(255,61,139,.06) 0%, transparent 70%),
      linear-gradient(190deg, #050f33 0%, #0a1a4a 40%, #0e1f55 70%, #14215c 100%) !important;
  }

  /* ============ SCAN LINE ANIMATION (sweeps once when menu opens) ============ */
  .nav-links::before {
    content: "EXPLORE" !important;
    position: absolute !important;
    top: 92px !important;
    left: 64px !important;
    font-family: 'JetBrains Mono', monospace !important;
    font-size: 10px !important;
    letter-spacing: 5px !important;
    color: rgba(40,215,255,.85) !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    z-index: 3 !important;
    padding-left: 36px !important;
  }
  .nav-links::before::before { content: ""; position: absolute; left: 0; top: 50%; width: 24px; height: 1px; background: linear-gradient(90deg, var(--cyan), transparent); }
  [dir="rtl"] .nav-links::before {
    left: auto !important;
    right: 64px !important;
    content: "استكشف" !important;
    font-family: 'IBM Plex Sans Arabic', sans-serif !important;
    letter-spacing: 3px !important;
    font-size: 13px !important;
    padding-left: 0 !important;
    padding-right: 36px !important;
  }

  /* Horizontal scan line that sweeps across the top once when menu opens */
  .nav-links.open::after {
    content: "" !important;
    position: absolute !important;
    top: 116px !important;
    left: 0 !important;
    height: 1px !important;
    width: 100% !important;
    background: linear-gradient(90deg, 
      transparent 0%, 
      var(--cyan, #28D7FF) 30%, 
      var(--violet, #7B5CFF) 60%,
      transparent 100%) !important;
    transform-origin: left !important;
    animation: scanLine 1.1s cubic-bezier(.6,0,.2,1) .2s both !important;
    pointer-events: none !important;
    z-index: 2 !important;
    box-shadow: 0 0 12px rgba(40,215,255,.5) !important;
  }
  @keyframes scanLine {
    0% { transform: scaleX(0); opacity: 0 }
    20% { opacity: 1 }
    100% { transform: scaleX(1); opacity: .3 }
  }

  /* ============ EACH NAV ITEM = ELEGANT EDITORIAL ROW ============ */
  .nav-links > li {
    width: 100% !important;
    margin: 0 !important;
    list-style: none !important;
    padding: 0 30px !important;
    border-bottom: none !important;
    position: relative !important;
    
    /* Cascading entrance */
    opacity: 0;
    transform: translateY(20px);
  }
  
  /* Item underline — only between items (subtle gradient) */
  .nav-links > li:not(:last-child)::after {
    content: "" !important;
    position: absolute !important;
    bottom: 0 !important;
    left: 30px !important;
    right: 30px !important;
    height: 1px !important;
    background: linear-gradient(90deg, 
      transparent 0%,
      rgba(40,215,255,.18) 20%,
      rgba(40,215,255,.18) 80%,
      transparent 100%) !important;
  }

  .nav-links.open > li { animation: navItemSlideIn .65s cubic-bezier(.4,0,.2,1) both }
  .nav-links.open > li:nth-child(1) { animation-delay: .15s }
  .nav-links.open > li:nth-child(2) { animation-delay: .22s }
  .nav-links.open > li:nth-child(3) { animation-delay: .29s }
  .nav-links.open > li:nth-child(4) { animation-delay: .36s }
  .nav-links.open > li:nth-child(5) { animation-delay: .43s }
  .nav-links.open > li:nth-child(6) { animation-delay: .50s }
  .nav-links.open > li:nth-child(7) { animation-delay: .57s }
  @keyframes navItemSlideIn {
    from { opacity: 0; transform: translateY(20px) }
    to { opacity: 1; transform: translateY(0) }
  }

  /* ============ THE LINK ROW ============ */
  .nav-links > li > a {
    display: flex !important;
    align-items: center !important;
    padding: 26px 0 !important;
    color: rgba(255,255,255,.94) !important;
    font-family: 'Space Grotesk', 'IBM Plex Sans Arabic', sans-serif !important;
    font-size: 24px !important;
    font-weight: 500 !important;
    letter-spacing: -.3px !important;
    text-transform: none !important;
    line-height: 1 !important;
    text-decoration: none !important;
    position: relative !important;
    min-height: 70px !important;
    width: 100% !important;
    transition: padding .35s cubic-bezier(.4,0,.2,1), color .35s ease !important;
  }
  [dir="rtl"] .nav-links > li > a {
    font-family: 'IBM Plex Sans Arabic', sans-serif !important;
    font-size: 25px !important;
    font-weight: 600 !important;
    letter-spacing: 0 !important;
  }
  .nav-links > li > a::after { display: none !important; content: none !important }

  /* ========== GLOWING NODE DOT (on the left of each item) ========== */
  .nav-links > li > a > .num {
    /* Hide raw text "01" — we'll style separately */
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    margin-right: 26px !important;
    padding-left: 22px !important;
    width: auto !important;
    min-width: 50px !important;
    font-family: 'JetBrains Mono', monospace !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 1px !important;
    background: linear-gradient(135deg, var(--cyan, #28D7FF) 0%, var(--blue, #146BFF) 100%) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    color: transparent !important;
    opacity: 1 !important;
    flex-shrink: 0 !important;
    transition: all .35s ease !important;
  }
  [dir="rtl"] .nav-links > li > a > .num {
    margin-right: 0 !important;
    margin-left: 26px !important;
    padding-left: 0 !important;
    padding-right: 22px !important;
  }
  
  /* The glowing dot itself (CSS pseudo) */
  .nav-links > li > a > .num::before {
    content: "" !important;
    position: absolute !important;
    left: 0 !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 8px !important;
    height: 8px !important;
    border-radius: 50% !important;
    background: var(--cyan, #28D7FF) !important;
    box-shadow: 
      0 0 0 3px rgba(40,215,255,.15),
      0 0 14px rgba(40,215,255,.7),
      0 0 24px rgba(40,215,255,.3) !important;
    transition: all .4s cubic-bezier(.4,0,.2,1) !important;
  }
  [dir="rtl"] .nav-links > li > a > .num::before {
    left: auto !important;
    right: 0 !important;
  }
  
  /* Subtle pulse on active item */
  .nav-links > li > a.active > .num::before,
  .nav-links > li > a:hover > .num::before {
    background: linear-gradient(135deg, var(--cyan, #28D7FF), var(--violet, #7B5CFF)) !important;
    width: 10px !important;
    height: 10px !important;
    box-shadow:
      0 0 0 4px rgba(123,92,255,.2),
      0 0 18px rgba(40,215,255,.9),
      0 0 32px rgba(123,92,255,.5) !important;
  }

  /* ========== ARROW INDICATOR (right side of each link) ========== */
  .nav-links > li:not(.has-dropdown) > a::before {
    content: "→" !important;
    position: absolute !important;
    right: 0 !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-family: 'JetBrains Mono', monospace !important;
    font-size: 20px !important;
    color: rgba(40,215,255,.4) !important;
    font-weight: 400 !important;
    transition: all .4s cubic-bezier(.4,0,.2,1) !important;
    display: block !important;
  }
  [dir="rtl"] .nav-links > li:not(.has-dropdown) > a::before {
    content: "←" !important;
    right: auto !important;
    left: 0 !important;
  }
  
  .nav-links > li > a:hover::before {
    color: var(--cyan, #28D7FF) !important;
    transform: translateY(-50%) translateX(6px) !important;
  }
  [dir="rtl"] .nav-links > li > a:hover::before {
    transform: translateY(-50%) translateX(-6px) !important;
  }

  /* ========== HOVER STATE — shift item right + brighten ========== */
  .nav-links > li > a:hover,
  .nav-links > li > a.active {
    color: #ffffff !important;
    padding-left: 8px !important;
  }
  [dir="rtl"] .nav-links > li > a:hover,
  [dir="rtl"] .nav-links > li > a.active {
    padding-left: 0 !important;
    padding-right: 8px !important;
  }

  /* ============ SERVICES DROPDOWN — REDESIGNED + INDICATOR ============ */
  .nav-links > li.has-dropdown > a {
    padding-right: 48px !important;
  }
  [dir="rtl"] .nav-links > li.has-dropdown > a {
    padding-right: 0 !important;
    padding-left: 48px !important;
  }
  
  .nav-links > li.has-dropdown > a::before {
    content: "+" !important;
    position: absolute !important;
    right: 0 !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 30px !important;
    height: 30px !important;
    line-height: 28px !important;
    text-align: center !important;
    background: transparent !important;
    border: 1px solid rgba(40,215,255,.35) !important;
    color: var(--cyan, #28D7FF) !important;
    border-radius: 50% !important;
    font-size: 18px !important;
    font-weight: 400 !important;
    font-family: 'Space Grotesk', sans-serif !important;
    transition: all .4s cubic-bezier(.4,0,.2,1) !important;
    display: block !important;
  }
  [dir="rtl"] .nav-links > li.has-dropdown > a::before {
    right: auto !important;
    left: 0 !important;
  }
  .nav-links > li.has-dropdown.open > a::before {
    content: "−" !important;
    background: linear-gradient(135deg, var(--cyan, #28D7FF), var(--violet, #7B5CFF)) !important;
    color: #fff !important;
    border-color: transparent !important;
    transform: translateY(-50%) rotate(180deg) !important;
    box-shadow: 0 4px 18px rgba(40,215,255,.4) !important;
  }

  /* ============ DROPDOWN MENU (Services sub-items) ============ */
  .nav-links .dropdown-menu {
    position: static !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
    width: 100% !important;
    max-height: 0 !important;
    overflow: hidden !important;
    transition: max-height .55s cubic-bezier(.4,0,.2,1), padding .3s ease, margin .3s ease !important;
    display: block !important;
    list-style: none !important;
  }
  .nav-links .dropdown-menu::before { display: none !important; content: none !important }
  
  .nav-links > li.has-dropdown.open .dropdown-menu {
    max-height: 600px !important;
    padding: 6px 0 22px 26px !important;
    margin: 0 0 14px 0 !important;
    border-left: 1px solid rgba(40,215,255,.25) !important;
    position: relative !important;
  }
  [dir="rtl"] .nav-links > li.has-dropdown.open .dropdown-menu {
    padding: 6px 26px 22px 0 !important;
    border-left: none !important;
    border-right: 1px solid rgba(40,215,255,.25) !important;
  }
  
  .nav-links .dropdown-menu li {
    border: none !important;
    border-bottom: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
  }
  .nav-links .dropdown-menu li::after { display: none !important; content: none !important }
  
  .nav-links .dropdown-menu li a {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    padding: 14px 12px !important;
    min-height: 56px !important;
    background: transparent !important;
    border-radius: 12px !important;
    font-size: 15px !important;
    color: rgba(255,255,255,.78) !important;
    transition: background .25s ease, color .25s ease, transform .25s ease !important;
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-weight: 500 !important;
    margin: 2px 0 !important;
  }
  [dir="rtl"] .nav-links .dropdown-menu li a {
    font-family: 'IBM Plex Sans Arabic', sans-serif !important;
    font-size: 16px !important;
    font-weight: 600 !important;
  }
  .nav-links .dropdown-menu li a:hover {
    background: linear-gradient(135deg, rgba(40,215,255,.08), rgba(123,92,255,.05)) !important;
    color: #fff !important;
    transform: translateX(4px) !important;
  }
  [dir="rtl"] .nav-links .dropdown-menu li a:hover {
    transform: translateX(-4px) !important;
  }
  
  .nav-links .dropdown-menu .dropdown-icon {
    width: 38px !important;
    height: 38px !important;
    background: linear-gradient(135deg, rgba(40,215,255,.12), rgba(123,92,255,.08)) !important;
    border: 1px solid rgba(40,215,255,.20) !important;
    color: var(--cyan, #28D7FF) !important;
    flex-shrink: 0 !important;
    border-radius: 10px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
  .nav-links .dropdown-menu .dropdown-icon svg {
    width: 17px !important;
    height: 17px !important;
  }
  .nav-links .dropdown-menu .dropdown-text {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
  }
  .nav-links .dropdown-menu .dropdown-text strong {
    font-size: 14.5px !important;
    font-weight: 600 !important;
    line-height: 1.25 !important;
    color: rgba(255,255,255,.95) !important;
    font-family: 'Space Grotesk', sans-serif !important;
  }
  [dir="rtl"] .nav-links .dropdown-menu .dropdown-text strong {
    font-family: 'IBM Plex Sans Arabic', sans-serif !important;
    font-size: 16px !important;
    font-weight: 700 !important;
  }
  .nav-links .dropdown-menu .dropdown-text small {
    font-size: 12px !important;
    line-height: 1.3 !important;
    color: rgba(255,255,255,.45) !important;
    font-weight: 400 !important;
    font-family: 'Plus Jakarta Sans', sans-serif !important;
  }
  [dir="rtl"] .nav-links .dropdown-menu .dropdown-text small {
    font-family: 'IBM Plex Sans Arabic', sans-serif !important;
    font-size: 13px !important;
  }
}


/* =================================================================
   FIX — Make menu items visible (override broken cascade animation)
   ================================================================= */
@media (max-width: 1100px) {
  /* Items default visible — no opacity 0 hidden state */
  .nav-links > li {
    opacity: 1 !important;
    transform: none !important;
  }
  /* Remove cascade animation - it was hiding items on iOS */
  .nav-links.open > li,
  .nav-links.open > li:nth-child(1),
  .nav-links.open > li:nth-child(2),
  .nav-links.open > li:nth-child(3),
  .nav-links.open > li:nth-child(4),
  .nav-links.open > li:nth-child(5),
  .nav-links.open > li:nth-child(6),
  .nav-links.open > li:nth-child(7) {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
  }

  /* Container — remove scale, simple fade only (iOS-safe) */
  .nav-links {
    transform: none !important;
    transition: opacity .35s ease, visibility 0s linear .35s !important;
  }
  .nav-links.open {
    transform: none !important;
    transition: opacity .35s ease, visibility 0s !important;
  }

  /* Ensure full viewport coverage — use dvh + fallback */
  .nav-links {
    height: 100vh !important;
    height: 100dvh !important;
    min-height: 100vh !important;
    min-height: 100dvh !important;
  }
}
