[hidden]{display:none !important}
:root{
  --teal:#013A54;
  --gold:#9E8551;
  --bg:#ffffff;
  --muted:#f4f6f8;
  --text:#0f172a;
  --sub:#334155;
  --border:rgba(15,23,42,.12);
  --shadow:0 18px 50px rgba(2,6,23,.10);
  --radius:18px;
  --font-ar:"Cairo", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-ar);
  line-height:1.7;
}

a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{max-width:1150px;margin:0 auto;padding:0 18px}
.section{padding:64px 0}
.section--alt{background:var(--muted)}
.sectionHead{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:18px}
.sectionHead p{margin:0;color:var(--sub);max-width:720px}

.topbar{
  background:var(--teal);
  color:#fff;
  font-size:14px;
}
.topbar__inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 0;
  gap:12px;
}
.topbar__right{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.topbar__hint{opacity:.9}
.pill{
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.22);
  padding:6px 12px;border-radius:999px;
  transition:.2s;
  white-space:nowrap;
}
.pill:hover{background:rgba(255,255,255,.22)}
.topbar__mini{opacity:.95}

.header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
.header__inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;padding:14px 0;
}
.brand__logo{height:40px;width:auto}
.nav{display:flex;gap:12px;align-items:center}
.nav a{
  font-size:14px;color:var(--sub);
  padding:6px 8px;border-radius:10px;
}
.nav a:hover{background:rgba(1,58,84,.06);color:var(--teal)}
.header__cta{display:flex;gap:10px;align-items:center}

.hamburger{display:none;background:transparent;border:0;cursor:pointer}
.hamburger span{display:block;width:22px;height:2px;background:var(--teal);margin:5px 0;border-radius:2px}

.mobileNav{
  border-top:1px solid var(--border);
  padding:10px 18px 18px;
  display:grid;gap:8px;
}
.mobileNav a{
  padding:10px 12px;border-radius:12px;background:#fff;border:1px solid var(--border);
  color:var(--sub);
}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 14px;border-radius:14px;
  border:1px solid var(--border);
  background:#fff;color:var(--text);
  font-weight:800;
  transition:.2s;
}
.btn--primary{
  background:var(--teal);
  border-color:rgba(1,58,84,.45);
  color:#fff;
  box-shadow:0 10px 24px rgba(1,58,84,.18);
}
.btn--primary:hover{transform:translateY(-1px)}
.btn--ghost{
  background:transparent;
  border-color:rgba(1,58,84,.22);
  color:var(--teal);
}
.btn--ghost:hover{background:rgba(1,58,84,.06)}
.btn--block{width:100%}

.hero{
  position:relative;
  padding:56px 0 40px;
  overflow:hidden;
}
.hero__bg{
  position:absolute;inset:-40% -20% auto -20%;
  height:520px;
  background:radial-gradient(circle at 35% 30%, rgba(1,58,84,.18), transparent 55%),
             radial-gradient(circle at 70% 30%, rgba(158,133,81,.16), transparent 55%);
  pointer-events:none;
}
.hero__inner{display:grid;grid-template-columns:1.15fr .85fr;gap:22px;position:relative}
.eyebrow{display:inline-block;color:var(--gold);font-weight:900;letter-spacing:.6px;margin:0 0 6px}
.hero h1{font-size:42px;line-height:1.2;margin:0 0 10px}
.lead{color:var(--sub);margin:0 0 18px;max-width:56ch}
.hero__actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}

.trust{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.trust__item{
  display:flex;gap:10px;align-items:flex-start;
  background:#fff;border:1px solid var(--border);
  padding:12px;border-radius:var(--radius);
  box-shadow:0 10px 26px rgba(2,6,23,.05);
}
.trust__icon{
  width:26px;height:26px;border-radius:10px;
  background:rgba(158,133,81,.16);
  color:var(--gold);display:flex;align-items:center;justify-content:center;
  font-weight:900;flex:0 0 auto
}
.trust__title{font-weight:900}
.trust__sub{font-size:13px;color:var(--sub)}

.heroCard{
  background:#fff;border:1px solid var(--border);
  border-radius:22px;padding:18px;
  box-shadow:var(--shadow);
}
.heroCard h3{margin:0 0 8px}
.heroCard ul{margin:0 0 16px;padding:0 18px;color:var(--sub)}
.heroCard__actions{display:grid;gap:10px}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:start}
.panel{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);padding:18px;
  box-shadow:0 10px 26px rgba(2,6,23,.05);
}
.panel h3{margin:0 0 10px}
.bullets{margin:0;padding:0 18px;color:var(--sub)}
.bullets li{margin:6px 0}
.muted{color:var(--sub);margin:0}

.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.chip{
  background:rgba(1,58,84,.06);
  border:1px solid rgba(1,58,84,.14);
  color:var(--teal);
  padding:6px 10px;border-radius:999px;
  font-weight:900;font-size:13px;
}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}

.cardMedia{
  height: 150px;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
  margin: -4px -4px 14px;
}
.cardMedia .card{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);padding:16px;
  box-shadow:0 10px 26px rgba(2,6,23,.05);
  transition:.2s;
}
.card:hover{transform:translateY(-2px)}
.card h3{margin:0 0 6px}
.card p{margin:0;color:var(--sub)}
.card--accent{
  background:linear-gradient(180deg, rgba(1,58,84,.03), transparent 55%), #fff;
  border-color:rgba(1,58,84,.18);
}
.ctaStrip{
  margin-top:18px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:rgba(1,58,84,.08);
  border:1px solid rgba(1,58,84,.16);
  border-radius:22px;padding:18px;
}
.ctaStrip h3{margin:0 0 4px}
.ctaStrip p{margin:0;color:var(--sub)}

.contactCard{
  margin-top:14px;
  background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);padding:14px;
}
.contactRow{
  display:flex;justify-content:space-between;gap:10px;padding:10px 0;
  border-bottom:1px dashed rgba(15,23,42,.12)
}
.contactRow:last-child{border-bottom:0}
.contactLink{color:var(--teal);font-weight:900}
.contactActions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}

.footer{
  background:var(--teal);
  color:#fff;
  padding:14px 0;
}
.footer__inner{
  display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap
}
.footer__brand .footer__brand p{margin:8px 0 0;opacity:.9}
.footer__links{display:flex;gap:12px;flex-wrap:wrap;opacity:.95}
.footer__copy{opacity:.9;font-size:13px}


.divider{height:1px;background:rgba(15,23,42,.10);margin:14px 0}

.waFloat{
  position:fixed;
  left:18px;
  bottom:18px;
  background:#25D366;
  color:#fff;
  font-weight:900;
  border-radius:999px;
  padding:12px 16px;
  box-shadow:0 16px 40px rgba(2,6,23,.22);
  z-index:60;
}

@media (max-width: 980px){
  .nav{display:none}
  .hamburger{display:block}
  .hero__inner{grid-template-columns:1fr}
  .trust{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .ctaStrip{flex-direction:column;align-items:stretch}
}


/* v3 enhancements */
.section--alt{background: linear-gradient(180deg, rgba(1,58,84,.04), rgba(255,255,255,0));}
.sectionHeader p{max-width: 70ch;}

.panel{background: #fff; border:1px solid var(--border); border-radius: var(--radius); padding:18px; box-shadow: var(--shadow);}
.panel__grid{display:grid; grid-template-columns:1fr; gap:12px; margin-bottom:12px;}
.panelCard{border:1px solid var(--border); border-radius:16px; padding:14px; background:#fff;}
.panelCard--muted{background: rgba(1,58,84,.03);}
.tag{display:inline-block; font-size:12px; font-weight:700; color:var(--teal); background:rgba(158,133,81,.12); border:1px solid rgba(158,133,81,.25); padding:6px 10px; border-radius:999px; margin-bottom:10px;}

.bulletsBox{margin-top:18px; border:1px dashed rgba(1,58,84,.25); background: rgba(1,58,84,.03); padding:14px; border-radius:16px;}
.bulletsBox h3{margin:0 0 10px}

.miniGrid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px;}
.miniCard{border:1px solid var(--border); border-radius:18px; padding:14px; background:#fff; box-shadow: var(--shadow);}
.miniCard h3{margin:0 0 6px; font-size:16px;}
.miniCard p{margin:0; color:var(--sub); line-height:1.8}

.solutions{margin-top:18px;}
.solutions h3{margin:0 0 12px;}
.solutionsGrid{display:grid; grid-template-columns:repeat(3,1fr); gap:12px;}
.solutionCard{border:1px solid var(--border); border-radius:16px; padding:12px; background: rgba(1,58,84,.03);}
.solutionCard p{margin:0; color:var(--text); line-height:1.8}

.timeline{display:grid; grid-template-columns:repeat(4,1fr); gap:12px;}
.step{border:1px solid var(--border); border-radius:18px; padding:12px; background:#fff; box-shadow: var(--shadow); display:flex; gap:10px; align-items:flex-start;}
.step span{flex:0 0 auto; width:34px; height:34px; border-radius:12px; display:grid; place-items:center; font-weight:800; color:#fff; background: var(--teal);}
.step p{margin:0; color:var(--text); line-height:1.6}

.faq{display:grid; gap:10px;}
.faqItem{border:1px solid var(--border); border-radius:18px; padding:12px 14px; background:#fff; box-shadow: var(--shadow);}
.faqItem summary{cursor:pointer; font-weight:700; color:var(--text);}
.faqItem p{margin:10px 0 0; color:var(--sub); line-height:1.8}

.formCard{border:1px solid var(--border); border-radius: var(--radius); padding:16px; box-shadow: var(--shadow); background:#fff;}
.formCard label{display:block; font-weight:700; color:var(--text); margin:10px 0 6px;}
.formCard input,.formCard select,.formCard textarea{width:100%; border:1px solid var(--border); border-radius:14px; padding:10px 12px; font-family:inherit; font-size:14px; outline:none;}
.formCard input:focus,.formCard select:focus,.formCard textarea:focus{border-color:rgba(1,58,84,.6); box-shadow:0 0 0 4px rgba(1,58,84,.12);}
.hint{margin:10px 0 0; color:var(--sub); font-size:13px; line-height:1.6}

@media (max-width: 900px){
  .miniGrid{grid-template-columns:1fr;}
  .solutionsGrid{grid-template-columns:1fr;}
  .timeline{grid-template-columns:1fr;}
}

.footer__logo{height:40px;width:auto;max-width:220px;opacity:.95}

.mobileNav[hidden]{display:none !important}



/* --- Language switcher (AR/EN) --- */
.topbar__actions { display:flex; align-items:center; gap:10px; }
.topbar__badge {
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border);
  font-size: 12px;
  opacity: .95;
}
.topbar__link{
  text-decoration:none;
  color: var(--text);
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  font-size: 12px;
  opacity: .95;
}
.topbar__link:hover{ opacity: 1; }

.nav__lang{
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  border-radius: 999px;
  padding: 8px 10px;
  opacity: .95;
}
.nav__lang:hover{ opacity: 1; }

/* LTR tweaks */
html[dir="ltr"] body { direction:ltr; }
html[dir="ltr"] .waFloat { left: auto; right: 18px; }


/* --- Improve menu button visibility --- */
.navToggle{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.navToggle span{
  display:block;
  width: 20px;
  height: 2px;
  background: var(--text);
  border-radius: 999px;
  margin: 3px 0;
}
.navToggle:hover{
  background: rgba(255,255,255,.07);
}


/* --- Clients logo marquee --- */
.logoMarquee{
  overflow:hidden;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.03);
  border-radius: 18px;
  padding: 14px 0;
  position: relative;
}
.logoMarquee::before,
.logoMarquee::after{
  content:"";
  position:absolute;
  top:0; bottom:0;
  width: 70px;
  pointer-events:none;
  z-index:2;
}
.logoMarquee::before{
  left:0;
  background: linear-gradient(to right, var(--bg), rgba(0,0,0,0));
}
.logoMarquee::after{
  right:0;
  background: linear-gradient(to left, var(--bg), rgba(0,0,0,0));
}
.logoTrack{
  display:flex;
  align-items:center;
  gap: 38px;
  width: max-content;
  animation: marquee 28s linear infinite;
  padding: 4px 18px;
}
.logoItem{
  display:flex;
  align-items:center;
  justify-content:center;
  min-width: 110px;
}
.logoItem img{
  height: 44px;
  width:auto;
  max-width: 160px;
  object-fit: contain;
  filter: grayscale(1);
  opacity: .85;
  transition: opacity .2s ease, filter .2s ease;
}
.logoItem img:hover{
  filter: grayscale(0);
  opacity: 1;
}

  to { transform: translateX(-50%); }
}
@media (max-width: 680px){
  .logoItem img{ height: 34px; max-width: 140px; }
  .logoTrack{ gap: 26px; animation-duration: 22s; }
  .logoMarquee::before, .logoMarquee::after{ width: 42px; }
}


/* --- Clients logo marquee: visibility tweaks --- */
.logoItem{
  min-width: 140px;
  padding: 10px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 10px 22px rgba(0,0,0,.14);
}
.logoItem img{
  height: 46px;
  max-width: 180px;
  width: auto;
  object-fit: contain;
  filter: none;
  opacity: 1;
}
@media (max-width: 680px){
  .logoItem{ min-width: 120px; padding: 8px 10px; border-radius: 14px; }
  .logoItem img{ height: 36px; max-width: 150px; }
}


/* --- Marquee speed + smoother infinite loop --- */
.logoTrack{
  animation-duration: 60s; /* slower */
  will-change: transform;
  transform: translate3d(0,0,0);
}
@media (max-width: 680px){
  .logoTrack{ animation-duration: 48s; }
}


/* --- Clients marquee (true infinite loop, no blank) --- */
.logoMarquee{
  overflow: hidden;
}
.logoTrack{
  --marquee-distance: 0px;
  --marquee-duration: 60s;
  display: flex;
  align-items: center;
  gap: 16px;
  width: max-content;
  animation: marquee var(--marquee-duration) linear infinite;
  will-change: transform;
  transform: translate3d(0,0,0);
}
@keyframes marquee{
  from { transform: translate3d(0,0,0); }
  to { transform: translate3d(calc(-1 * var(--marquee-distance)), 0, 0); }
}
@media (prefers-reduced-motion: reduce){
  .logoTrack{ animation: none !important; transform: none !important; }
}


/* --- Clients strip: scrollable (no auto animation) --- */
.logoScroller{
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  padding: 14px 10px;
  border-radius: 18px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  cursor: grab;
  user-select: none;
  scroll-snap-type: x proximity;
}
.logoScroller.grabbing{ cursor: grabbing; }

.logoTrack{
  animation: none !important;
  transform: none !important;
  display: flex;
  align-items: center;
  gap: 14px;
  width: max-content;
  padding: 6px 10px;
}

.logoItem{
  flex: 0 0 auto;
  scroll-snap-align: center;
  border-radius: 14px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  padding: 10px 12px;
  min-width: 170px; height: 92px;
  display: grid;
  place-items: center;
}
.logoItem img{
  max-height: 62px; max-width: 190px;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
}

/* Make sure it's visible/usable on mobile */
@media (max-width: 680px){
  .logoItem{ min-width: 190px; height: 104px; }
  .logoItem img{ max-height: 72px; max-width: 210px; }
}

/* Optional: subtle scrollbar */
.logoScroller::-webkit-scrollbar{ height: 10px; }
.logoScroller::-webkit-scrollbar-track{ background: rgba(255,255,255,0.03); border-radius: 999px; }
.logoScroller::-webkit-scrollbar-thumb{ background: rgba(255,255,255,0.12); border-radius: 999px; }



/* =========================================================
   v18 – MLD Brand UI (Teal #013A54 + Gold #9E8551)
   Clean, premium, and consistent with the brand identity.
   ========================================================= */

.srOnly{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

/* Base background with very subtle brand tints (NOT colorful) */
html, body{
  background:
    radial-gradient(900px 520px at 8% -12%, rgba(1,58,84,.06), transparent 60%),
    radial-gradient(900px 520px at 92% 0%, rgba(158,133,81,.07), transparent 60%),
    linear-gradient(180deg, #ffffff 0%, #f6f7f9 100%) !important;
}

/* Section rhythm */
.section--alt{
  background:
    radial-gradient(820px 420px at 12% 20%, rgba(158,133,81,.06), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.78) 0%, rgba(255,255,255,.42) 100%) !important;
  border-top: 1px solid rgba(2,6,23,.06);
  border-bottom: 1px solid rgba(2,6,23,.06);
}
.section--contact{
  background:
    radial-gradient(900px 520px at 20% 0%, rgba(1,58,84,.07), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.86) 0%, rgba(255,255,255,.50) 100%) !important;
  border-top: 1px solid rgba(2,6,23,.06);
}

/* Section title underline */
.sectionHeader h2{
  position:relative;
  display:inline-block;
}
.sectionHeader h2::after{
  content:"";
  display:block;
  margin-top:10px;
  height:3px;
  border-radius:999px;
  background: linear-gradient(90deg, rgba(158,133,81,.95), rgba(1,58,84,.70), rgba(158,133,81,.14));
}

/* Cards: subtle premium top bar */
.card, .faqItem, .serviceCard, .solutionCard, .contactCard{
  border: 1px solid rgba(2,6,23,.10) !important;
  box-shadow: 0 14px 34px rgba(2,6,23,.08);
  position:relative;
  overflow:hidden;
}
.card::before, .faqItem::before, .serviceCard::before, .solutionCard::before, .contactCard::before{
  content:"";
  position:absolute;
  left:0; right:0; top:0;
  height:3px;
  background: linear-gradient(90deg, rgba(158,133,81,.85), rgba(1,58,84,.65), rgba(158,133,81,.20));
}
.card:hover, .serviceCard:hover, .solutionCard:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 44px rgba(2,6,23,.10);
}

/* Buttons: identity-safe */
.btn--primary{
  background: linear-gradient(135deg, var(--teal), #024a6b) !important;
  box-shadow: 0 16px 34px rgba(1,58,84,.18);
}
.btn--primary:hover{ box-shadow: 0 20px 46px rgba(1,58,84,.22); }
.btn--gold{
  background: linear-gradient(135deg, var(--gold), #b49a60) !important;
  box-shadow: 0 16px 34px rgba(158,133,81,.18);
}
.btn--gold:hover{ box-shadow: 0 20px 46px rgba(158,133,81,.22); }

/* Clients band */
.logoScroller{
  background: rgba(1,58,84,.05) !important;
  border: 1px solid rgba(1,58,84,.14) !important;
}

/* Floating WhatsApp: icon-only (official look) */
.waFloat{
  width:56px;
  height:56px;
  padding:0 !important;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:#25D366 !important;
  border: 1px solid rgba(255,255,255,.28);
}
.waFloat svg{
  width:28px;
  height:28px;
  display:block;
}
.waFloat .waIconBubble{ fill:#fff; }
.waFloat .waIconPhone{ fill:#fff; }
.waFloat:hover{
  transform: translateY(-2px);
  box-shadow: 0 20px 52px rgba(2,6,23,.26);
}
