:root{
  --bg:#081722;
  --bg-2:#0d2332;
  --bg-3:#112f43;
  --panel:rgba(255,255,255,0.08);
  --panel-strong:#10283a;
  --stroke:rgba(255,255,255,0.12);
  --text:#eff6fb;
  --muted:#a9c0d3;
  --dark:#07131d;
  --accent:#2bb5ff;
  --accent-2:#77e1ff;
  --white:#ffffff;
  --shadow:0 20px 60px rgba(0,0,0,.28);
  --radius:24px;
  --container:min(1240px, calc(100% - 48px));
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',Arial,Helvetica,sans-serif;
  background:
    radial-gradient(circle at top left, rgba(43,181,255,.10), transparent 28%),
    radial-gradient(circle at 80% 20%, rgba(119,225,255,.07), transparent 24%),
    linear-gradient(180deg, var(--bg), #06121b 38%, #0b1d2b 100%);
  color:var(--text);
}
body.lang-ar{font-family:'Cairo',Tahoma,Arial,sans-serif}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.site-shell{overflow:hidden;position:relative;z-index:1}
.section{width:var(--container);margin:0 auto;padding:110px 0;position:relative}

.bg-motion{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:0}
.orb,.line{position:absolute;display:block}
.orb{
  border-radius:50%;
  filter:blur(50px);
  opacity:.26;
  animation:floatOrb 14s ease-in-out infinite;
}
.orb-1{width:320px;height:320px;background:#23a6f0;top:8%;left:-4%}
.orb-2{width:280px;height:280px;background:#0d6aa3;top:44%;right:-6%;animation-delay:-4s}
.orb-3{width:220px;height:220px;background:#7ce1ff;bottom:6%;left:18%;animation-delay:-8s}
.line{
  width:1px;height:42vh;background:linear-gradient(180deg,transparent,rgba(124,225,255,.35),transparent);
  animation:lineMove 10s linear infinite;
}
.line-1{left:17%;top:8%}
.line-2{right:14%;top:22%;animation-delay:-5s}
@keyframes floatOrb{
  0%,100%{transform:translate3d(0,0,0) scale(1)}
  50%{transform:translate3d(24px,-28px,0) scale(1.08)}
}
@keyframes lineMove{
  0%{transform:translateY(-8%)}
  50%{transform:translateY(8%)}
  100%{transform:translateY(-8%)}
}

.topbar{
  width:var(--container);
  margin:0 auto;
  padding:26px 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:blur(18px);
}
.topbar:before{
  content:"";
  position:absolute;
  inset:8px -18px;
  background:rgba(6,18,27,.58);
  border:1px solid rgba(255,255,255,.06);
  border-radius:20px;
  z-index:-1;
}
.brand{display:flex;align-items:center;gap:14px;font-weight:800;letter-spacing:-.02em}
.brand-badge{
  background:#fff;border-radius:14px;padding:7px 12px;box-shadow:0 10px 22px rgba(0,0,0,.18)
}
.brand img{width:62px;height:auto}
.brand-name{font-size:1.1rem}
.nav{display:flex;gap:28px;align-items:center}
.nav a{color:var(--muted);font-weight:600;transition:.25s ease}
.nav a:hover,.nav a.active{color:var(--white)}
.lang-link{padding:6px 0}
.menu-toggle{display:none;border:0;background:none;padding:0;cursor:pointer}
.menu-toggle span{display:block;width:26px;height:2px;background:#fff;margin:5px 0;border-radius:99px}

.hero{display:grid;grid-template-columns:1.15fr .85fr;gap:34px;min-height:calc(100vh - 120px);align-items:center;padding-top:40px}
.hero-grid{
  position:absolute;inset:0;pointer-events:none;opacity:.35;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size:70px 70px;
  -webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.9),transparent 85%);
  mask-image:linear-gradient(180deg,rgba(0,0,0,.9),transparent 85%);
}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.84rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--accent-2);margin-bottom:18px}
body.lang-ar .eyebrow{letter-spacing:.04em}
.hero h1,.section-head h2,.intro-strip h2,.cta-section h2{margin:0;letter-spacing:-.045em;line-height:.96}
.hero h1{font-size:clamp(3rem, 6vw, 6rem);max-width:12ch}
.lead{font-size:1.16rem;line-height:1.8;color:var(--muted);max-width:62ch;margin:26px 0 0}
.hero-actions,.cta-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:34px}
.btn{display:inline-flex;align-items:center;justify-content:center;min-width:180px;padding:16px 22px;border-radius:16px;font-weight:700;transition:.25s ease;border:1px solid transparent}
.btn-primary{background:linear-gradient(135deg,var(--accent),#1295de);color:#fff;box-shadow:0 12px 30px rgba(43,181,255,.28)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-secondary{border-color:rgba(255,255,255,.22);background:rgba(255,255,255,.02);color:#fff}
.btn-secondary:hover{background:rgba(255,255,255,.07)}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:42px}
.hero-stats article,.glass-card,.division-card,.service-card,.industry-card,.intro-strip,.cta-section,.contact-card{
  border:1px solid var(--stroke);
  box-shadow:var(--shadow);
}
.hero-stats article{
  padding:22px;border-radius:18px;background:rgba(255,255,255,.04);backdrop-filter:blur(10px)
}
.hero-stats strong{display:block;font-size:1rem;margin-bottom:10px}
.hero-stats span{display:block;color:var(--muted);font-size:.95rem;line-height:1.6}
.hero-panels{display:grid;gap:18px}
.glass-card{
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  border-radius:28px;padding:28px 28px 30px;backdrop-filter:blur(18px)
}
.card-focus{transform:translateY(-20px)}
.card-kicker,.division-badge{display:inline-block;font-size:.8rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2);margin-bottom:14px}
body.lang-ar .card-kicker, body.lang-ar .division-badge{letter-spacing:.04em}
.glass-card h3,.division-card h3,.service-card h3,.industry-card h3,.contact-card h3{margin:0 0 12px;letter-spacing:-.03em}
.glass-card p,.division-card p,.service-card p,.industry-card p,.section-head p,.intro-strip p,.cta-section p,.contact-card p{margin:0;color:var(--muted);line-height:1.8}
.intro-strip{
  display:grid;grid-template-columns:1fr 1fr;gap:28px;padding:36px 40px;border-radius:28px;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03))
}
.intro-strip h2{font-size:clamp(2rem,4vw,3.2rem);max-width:14ch}
.section-head{max-width:860px;margin-bottom:34px}
.section-head h2{font-size:clamp(2.2rem,4vw,4rem);margin-bottom:14px}
.division-split{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.division-card{padding:34px;border-radius:28px;background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03))}
.division-card-dark{background:linear-gradient(180deg, rgba(12,35,50,.95), rgba(8,22,33,.95))}
.division-card ul{list-style:none;padding:0;margin:22px 0 24px;display:grid;gap:14px}
.division-card li{position:relative;padding-left:22px;color:#dce9f2;line-height:1.65}
.division-card li:before{content:"";position:absolute;left:0;top:.74em;width:8px;height:8px;border-radius:99px;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 0 0 4px rgba(43,181,255,.12)}
body.lang-ar .division-card li{padding-left:0;padding-right:22px}
body.lang-ar .division-card li:before{left:auto;right:0}
.text-link{color:var(--accent-2);font-weight:700}
.alt-section{background:linear-gradient(180deg, rgba(255,255,255,.03), transparent 70%);border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05);width:100%;padding-left:0;padding-right:0}
.alt-section > *{width:var(--container);margin-left:auto;margin-right:auto}
.service-grid{display:grid;gap:20px}
.service-grid-3{grid-template-columns:repeat(3,1fr)}
.service-card{padding:28px;border-radius:24px;background:rgba(255,255,255,.045)}
.service-card h3{font-size:1.28rem}
.industry-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.industry-card{padding:28px;border-radius:24px;background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025))}
.industry-card span{display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:18px;background:rgba(43,181,255,.12);color:var(--accent-2);font-weight:800;margin-bottom:18px}
.cta-section{text-align:center;padding:54px 28px;border-radius:30px;background:linear-gradient(180deg, rgba(19,55,77,.92), rgba(9,24,35,.96))}
.cta-section h2{font-size:clamp(2.2rem,4vw,4.2rem);margin-bottom:16px}
.cta-section p{max-width:840px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.footer-logo-wrap{
  display:inline-flex;align-items:center;justify-content:center;background:#fff;border-radius:18px;padding:10px 14px;margin-bottom:16px
}
.footer-logo-wrap img{width:78px}
.contact-card,.footer-brand{padding:30px;border-radius:24px;background:rgba(255,255,255,.045)}

.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.12s}.reveal-delay-2{transition-delay:.24s}

body.lang-ar{direction:rtl;text-align:right}
body.lang-ar .topbar, body.lang-ar .brand, body.lang-ar .nav, body.lang-ar .hero-actions, body.lang-ar .cta-actions{flex-direction:row-reverse}
body.lang-ar .hero{grid-template-columns:.85fr 1.15fr}
body.lang-ar .hero-copy{order:2}
body.lang-ar .hero-panels{order:1}
body.lang-ar .hero h1, body.lang-ar .lead, body.lang-ar .section-head, body.lang-ar .intro-strip, body.lang-ar .division-card, body.lang-ar .service-card, body.lang-ar .industry-card, body.lang-ar .contact-card, body.lang-ar .footer-brand{text-align:right}
body.lang-ar .hero-stats article{text-align:right}
body.lang-ar .industry-card span{margin-left:0;margin-right:0}

@media (max-width:1100px){
  .hero{grid-template-columns:1fr;min-height:auto;padding-top:20px}
  .card-focus{transform:none}
  .hero h1{max-width:14ch}
  .hero-stats,.service-grid-3,.industry-grid,.division-split,.intro-strip,.footer-grid{grid-template-columns:1fr}
  body.lang-ar .hero{grid-template-columns:1fr}
  body.lang-ar .hero-copy, body.lang-ar .hero-panels{order:initial}
}
@media (max-width:780px){
  .section{padding:78px 0}
  .topbar{padding:18px 0}
  .topbar:before{inset:4px -8px;border-radius:16px}
  .menu-toggle{display:block;position:relative;z-index:60}
  .nav{
    position:fixed;inset:92px 16px auto 16px;display:grid;gap:10px;padding:16px;border-radius:20px;
    background:rgba(8,23,34,.96);border:1px solid rgba(255,255,255,.08);transform:translateY(-20px);opacity:0;pointer-events:none;
    transition:.25s ease;box-shadow:var(--shadow)
  }
  body.menu-open .nav{transform:translateY(0);opacity:1;pointer-events:auto}
  .hero h1{font-size:clamp(2.5rem,11vw,4.2rem)}
  .lead{font-size:1rem}
  .hero-actions,.cta-actions{flex-direction:column}
  body.lang-ar .hero-actions, body.lang-ar .cta-actions{flex-direction:column}
  .btn{width:100%}
  .brand img{width:48px}
  .brand-badge{padding:6px 10px}
}
