/* ===================== ORDOSAFE THEME — main.css ===================== */
:root{
  --navy:#14233F; --navy-2:#1B2E4E; --brand:#406098; --brand-strong:#34527F;
  --brand-bright:#5B83C4; --silver:#C3C9D4; --steel:#7E8AA0;
  --paper:#F3F6FA; --card:#FFFFFF; --line:#E1E6EE; --line-d:rgba(255,255,255,.12);
  --muted:#54607A; --muted-d:#9AA6BE; --ink:#16213A;
  --display:'Plus Jakarta Sans',system-ui,sans-serif; --body:'Hanken Grotesk',system-ui,sans-serif;
  --maxw:1200px; --r:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--paper);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.12;letter-spacing:-.02em;color:var(--ink)}
.eyebrow{font-family:var(--display);font-size:.74rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--brand);display:inline-flex;align-items:center;gap:.6em}
.eyebrow::before{content:"";width:24px;height:2px;background:var(--brand-bright);display:inline-block}
.eyebrow--d{color:var(--brand-bright)}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--body);font-weight:700;font-size:1rem;padding:14px 26px;border-radius:12px;cursor:pointer;border:1px solid transparent;transition:background .2s,transform .15s,border-color .2s}
.btn--p{background:var(--brand);color:#fff}.btn--p:hover{background:var(--brand-bright);transform:translateY(-2px);color:#fff}
.btn--g{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.28)}.btn--g:hover{border-color:#fff;color:#fff}
.ar{transition:transform .2s}.btn:hover .ar{transform:translateX(3px)}
.skip{position:absolute;left:-999px}.skip:focus{left:8px;top:8px;z-index:999;background:var(--navy);color:#fff;padding:12px 18px;border-radius:8px}
.topbar{height:5px;background:linear-gradient(90deg,var(--brand),var(--brand-bright))}

/* header + nav */
header.site{position:sticky;top:0;z-index:100;background:rgba(243,246,250,.92);backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:80px}
.brand img{height:40px;width:auto}
.brand .wm{font-family:var(--display);font-weight:800;color:var(--navy);font-size:1.2rem}
ul.menu{display:flex;align-items:center;gap:2px;list-style:none}
ul.menu li{position:relative}
ul.menu li a{display:flex;align-items:center;gap:5px;padding:10px 13px;font-size:.93rem;font-weight:600;color:var(--ink);border-radius:9px;transition:.18s}
ul.menu li a:hover{background:#E8EDF5;color:var(--brand)}
ul.menu li.menu-item-has-children>a::after{content:"";width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);opacity:.55}
ul.menu .sub-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:264px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 24px 50px -22px rgba(20,35,63,.35);padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s;list-style:none;display:block}
ul.menu li:hover>.sub-menu,ul.menu li:focus-within>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
ul.menu .sub-menu li a{display:block;padding:11px 14px;border-radius:9px;font-size:.92rem;font-weight:500}
ul.menu .sub-menu li a:hover{background:#EEF2F8;color:var(--brand)}
.nav-cta{background:var(--brand)!important;color:#fff!important;padding:11px 20px;border-radius:11px;font-weight:700;font-size:.9rem}
.nav-cta:hover{background:var(--brand-strong)!important}
.navtools{display:flex;align-items:center;gap:14px}
.burger{display:none;background:none;border:0;cursor:pointer;width:46px;height:46px;flex-direction:column;justify-content:center;gap:5px;align-items:center}
.burger span{width:25px;height:2px;background:var(--navy);transition:.25s;display:block}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile{display:none;position:fixed;inset:80px 0 0 0;background:var(--paper);z-index:90;overflow-y:auto;padding:14px 24px 40px;transform:translateX(100%);transition:transform .3s;border-top:1px solid var(--line)}
.mobile.open{transform:translateX(0)}
.mobile ul{list-style:none}
.mobile>ul>li{border-bottom:1px solid var(--line)}
.mobile>ul>li>a{display:block;padding:15px 2px;font-family:var(--display);font-weight:700;font-size:1.05rem}
.mobile .sub-menu{padding:0 0 10px 14px}
.mobile .sub-menu li a{display:block;padding:9px 2px;color:var(--muted);font-weight:500}

/* hero (front page) */
.hero{position:relative;color:#fff;background:var(--navy);overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:62% center}
.hero__bg::before{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(18,30,54,.94) 0%,rgba(18,30,54,.8) 42%,rgba(20,35,63,.46) 100%)}
.hero__bg::after{content:"";position:absolute;inset:0;background:radial-gradient(620px 340px at 88% 10%,rgba(91,131,196,.22),transparent 62%)}
.hero__inner{position:relative;z-index:1;max-width:720px;padding:88px 0 78px}
.hero h1{color:#fff;font-size:clamp(2.6rem,5.6vw,4.1rem);font-weight:800;margin:18px 0 0}
.hero h1 .hl{color:var(--brand-bright)}
.hero__sub{margin-top:20px;font-size:1.16rem;color:#D8E1EF;max-width:42ch}
.hero__markets{display:flex;gap:8px;flex-wrap:wrap;margin-top:22px}
.mk{font-size:.78rem;font-weight:600;color:#DCE5F2;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.06);padding:7px 13px;border-radius:30px;display:inline-flex;align-items:center;gap:6px}
.mk::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--brand-bright)}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}

/* accreditation strip */
.accred{background:#fff;border-bottom:1px solid var(--line)}
.accred__in{display:flex;align-items:center;gap:30px;flex-wrap:wrap;justify-content:center;padding:20px 0}
.accred__lab{font-family:var(--display);font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--steel)}
.accred__in img{height:50px;width:auto;opacity:.9;filter:saturate(.55);transition:.2s}
.accred__in img:hover{filter:saturate(1);opacity:1}

/* sections */
.sec{padding:90px 0}
.sec__h{max-width:660px;margin-bottom:44px}
.sec__h h2{font-size:clamp(1.9rem,3.6vw,2.7rem);margin-top:15px}
.sec__h p{margin-top:15px;color:var(--muted);font-size:1.08rem}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

/* image service cards */
.scard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s,border-color .2s}
.scard:hover{transform:translateY(-5px);box-shadow:0 26px 46px -28px rgba(20,35,63,.34);border-color:#CED6E4}
.scard__img{height:188px;background-size:cover;background-position:center;position:relative}
.scard__img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,35,63,0),rgba(20,35,63,.34))}
.scard__b{padding:24px 26px 26px;display:flex;flex-direction:column;flex-grow:1}
.scard h3{font-size:1.26rem;margin-bottom:9px}
.scard p{color:var(--muted);font-size:.96rem;flex-grow:1}
.scard a.more{display:inline-flex;gap:7px;align-items:center;margin-top:16px;font-weight:700;font-size:.9rem;color:var(--brand)}
.scard:hover a.more .ar{transform:translateX(3px)}

/* about band */
.about{padding:90px 0}
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.about__img{border-radius:20px;overflow:hidden;box-shadow:0 30px 60px -34px rgba(20,35,63,.45);aspect-ratio:3/2;background-size:cover;background-position:center}
.about h2{font-size:clamp(1.8rem,3.4vw,2.5rem);margin-top:14px}
.about .intro{color:var(--muted);font-size:1.06rem;margin-top:16px}
.vlist{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:26px}
.vitem .n{font-family:var(--display);font-weight:800;color:var(--brand-bright);font-size:1.05rem;margin-bottom:5px}
.vitem h4{font-size:1.04rem;margin-bottom:4px}
.vitem p{color:var(--muted);font-size:.9rem}

/* markets */
.markets{background:var(--navy);color:#fff;padding:90px 0}
.markets .sec__h h2{color:#fff}.markets .sec__h p{color:var(--muted-d)}
.mwrap{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center}
.mcards{display:flex;flex-direction:column;gap:16px}
.mcard{background:linear-gradient(180deg,var(--navy-2),rgba(27,46,78,.55));border:1px solid rgba(255,255,255,.13);border-radius:16px;padding:24px 26px}
.mcard__flag{font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--brand-bright);margin-bottom:5px}
.mcard h3{color:#fff;font-size:1.32rem;margin-bottom:10px}
.mcard p{color:var(--muted-d);font-size:.95rem;margin-bottom:14px}
.cities{display:flex;gap:8px;flex-wrap:wrap}
.city{font-size:.82rem;font-weight:600;color:#DCE5F2;background:rgba(91,131,196,.16);border:1px solid rgba(91,131,196,.3);padding:6px 13px;border-radius:30px}
.mfeature{border-radius:20px;overflow:hidden;aspect-ratio:4/5;background-size:cover;background-position:center;position:relative;box-shadow:0 30px 60px -30px rgba(0,0,0,.6)}
.mfeature::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,35,63,.1),rgba(20,35,63,.55))}
.mfeature .cap{position:absolute;left:22px;bottom:20px;z-index:2;font-family:var(--display);font-weight:700;font-size:1.05rem;color:#fff;max-width:80%}

/* training cards */
.tcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.tcard:hover{transform:translateY(-5px);box-shadow:0 24px 44px -26px rgba(20,35,63,.3)}
.tcard__top{padding:24px 26px 0}
.badge{font-family:var(--display);font-size:.7rem;font-weight:700;letter-spacing:.06em;color:var(--brand);background:#EAF0FA;border:1px solid #D5E1F4;padding:5px 10px;border-radius:7px}
.tcard__b{padding:10px 26px 26px;display:flex;flex-direction:column;flex-grow:1}
.tcard h3{font-size:1.24rem;margin-bottom:9px}
.tcard p{color:var(--muted);font-size:.95rem;flex-grow:1}
.tcard a.more{margin-top:16px;font-weight:700;font-size:.9rem;color:var(--brand);display:inline-flex;gap:7px;align-items:center}

/* corporate feature */
.feat{margin-top:30px;display:grid;grid-template-columns:.9fr 1.1fr;gap:0;border:1px solid var(--line);border-radius:20px;overflow:hidden;background:#fff}
.feat__img{background-size:cover;background-position:center;min-height:260px}
.feat__b{padding:38px 40px;display:flex;flex-direction:column;justify-content:center}
.feat__b h3{font-size:1.5rem;margin-bottom:12px}
.feat__b p{color:var(--muted);font-size:1rem;margin-bottom:20px}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;background:linear-gradient(120deg,var(--brand),var(--brand-strong));border-radius:20px;padding:42px 38px;color:#fff}
.stat b{font-family:var(--display);font-weight:800;font-size:clamp(2rem,4vw,2.7rem);display:block;line-height:1}
.stat span{font-size:.82rem;color:#E2EAF7;margin-top:9px;display:block;font-weight:500}

/* testimonials */
.tests{background:#EAEEF5}
.tg{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.tq{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px}
.tq p{font-size:1.04rem;color:var(--ink);line-height:1.62}
.tq p::before{content:"\201C";font-family:var(--display);font-weight:800;font-size:2.4rem;color:var(--brand-bright);line-height:0;vertical-align:-.35em;margin-right:.08em}
.tq .who{display:flex;align-items:center;gap:13px;margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.av{width:42px;height:42px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:700}
.who b{display:block;font-family:var(--display);font-size:.97rem}.who span{font-size:.82rem;color:var(--muted)}

/* CTA */
.cta{background:radial-gradient(620px 280px at 82% 0,rgba(91,131,196,.3),transparent 60%),linear-gradient(180deg,var(--navy),var(--navy-2));border-radius:24px;padding:56px 46px;text-align:center;color:#fff;margin:0 auto}
.cta h2{color:#fff;font-size:clamp(1.8rem,3.6vw,2.4rem)}
.cta p{color:#D5DEEC;margin:14px auto 0;max-width:52ch;font-size:1.04rem}
.cta__row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:26px}
.cta__c{margin-top:24px;font-size:.86rem;color:var(--muted-d)}.cta__c a{color:#fff}
.sec-cta{padding:0 0 90px}

/* footer */
footer.site{background:var(--navy);color:#fff;padding:62px 0 26px;border-top:4px solid var(--brand)}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px}
.fbrand .wm{font-family:var(--display);font-weight:800;font-size:1.35rem;color:#fff}
.fbrand p{color:var(--muted-d);font-size:.92rem;margin-top:13px;max-width:32ch}
.fcol h4{font-size:.72rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--brand-bright);margin-bottom:14px}
.fcol ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.fcol ul li a{color:#C7D1E2;font-size:.91rem}.fcol ul li a:hover{color:#fff}
.fcol address{font-style:normal;color:#C7D1E2;font-size:.91rem;line-height:1.75}.fcol address a{color:#fff}
.fbot{margin-top:42px;padding-top:20px;border-top:1px solid var(--line-d);font-size:.82rem;color:var(--muted-d);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---- inner page ---- */
.phero{position:relative;color:#fff;background:var(--navy);overflow:hidden}
.phero__bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center}
.phero__bg::before{content:"";position:absolute;inset:0;background:linear-gradient(102deg,rgba(18,30,54,.95),rgba(20,35,63,.6))}
.phero.hasimg .phero__bg::before{background:linear-gradient(102deg,rgba(18,30,54,.92) 0%,rgba(18,30,54,.78) 45%,rgba(20,35,63,.5) 100%)}
.phero__in{position:relative;z-index:1;padding:40px 0 56px;max-width:780px}
.crumb{font-size:.8rem;color:var(--muted-d);margin-bottom:18px}.crumb a{color:var(--muted-d)}.crumb a:hover{color:#fff}
.phero h1{color:#fff;font-size:clamp(2rem,4.4vw,3rem);font-weight:800;margin:8px 0 0}
.phero .sub{margin-top:14px;font-size:1.1rem;color:#D8E1EF;max-width:60ch}
.layout{display:grid;grid-template-columns:1fr 330px;gap:52px;padding:64px 0 80px;align-items:start}
.layout.full{grid-template-columns:1fr;max-width:820px;margin:0 auto}
.prose{font-size:1.05rem;color:#39454D}
.prose>*+*{margin-top:18px}
.prose h2{font-family:var(--display);font-size:clamp(1.5rem,2.8vw,2rem);margin-top:42px;color:var(--ink)}
.prose h3{font-family:var(--display);font-size:1.18rem;margin-top:26px;color:var(--ink)}
.prose p{color:#39454D}
.prose strong{color:var(--ink)}
.prose ul,.prose ol{margin-left:1.1em}
.prose li{margin-top:8px}
.prose a{color:var(--brand);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.prose img{border-radius:12px;margin:24px 0}
.prose blockquote{border-left:3px solid var(--brand);background:linear-gradient(120deg,rgba(91,131,196,.1),rgba(64,96,152,.04));padding:18px 22px;border-radius:10px;font-style:normal}
.prose .lede{font-size:1.16rem;color:var(--ink)}
aside.side{position:sticky;top:98px;display:flex;flex-direction:column;gap:18px}
.qcard{background:var(--navy);color:#fff;border-radius:var(--r);padding:26px;position:relative;overflow:hidden}
.qcard::before{content:"";position:absolute;top:0;left:26px;right:26px;height:3px;background:var(--brand-bright)}
.qcard h3{color:#fff;font-size:1.2rem;margin-bottom:8px}
.qcard p{color:var(--muted-d);font-size:.93rem;margin-bottom:16px}
.qcard .tel{display:block;text-align:center;margin-top:12px;font-size:.86rem;color:#fff}
.infocard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px}
.infocard h4{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--brand);margin-bottom:8px}
.infocard ul{list-style:none}
.infocard ul li a{display:flex;justify-content:space-between;align-items:center;font-weight:500;font-size:.95rem;color:var(--ink);padding:10px 0;border-bottom:1px solid var(--line)}
.infocard ul li:last-child a{border-bottom:0}.infocard ul li a:hover{color:var(--brand)}

/* blog */
.bloghero{background:var(--navy);color:#fff;padding:54px 0 48px}
.bloghero h1{color:#fff;font-size:clamp(2rem,4vw,2.8rem)}
.bloghero p{color:var(--muted-d);margin-top:12px}
.postgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:64px 0 80px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.pcard:hover{transform:translateY(-5px);box-shadow:0 24px 44px -26px rgba(20,35,63,.3)}
.pcard__img{height:180px;background-size:cover;background-position:center;background-color:#dfe5ef}
.pcard__b{padding:22px 24px;display:flex;flex-direction:column;flex-grow:1}
.pcard h3{font-size:1.18rem;margin-bottom:8px}
.pcard h3 a:hover{color:var(--brand)}
.pcard .meta{font-size:.78rem;color:var(--steel);margin-bottom:10px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.pcard p{color:var(--muted);font-size:.93rem;flex-grow:1}
.pcard .more{margin-top:14px;font-weight:700;font-size:.88rem;color:var(--brand)}
.single-content{max-width:760px;margin:0 auto;padding:56px 0 40px}
.authorbox{max-width:760px;margin:10px auto 80px;display:flex;gap:18px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px}
.authorbox .ava{flex:0 0 56px;width:56px;height:56px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:1.2rem}
.authorbox h4{font-size:1.05rem;margin-bottom:4px}
.authorbox .role{color:var(--brand);font-weight:600;font-size:.85rem;margin-bottom:6px}
.authorbox p{color:var(--muted);font-size:.92rem;margin:0}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s,transform .7s}
.reveal.vis{opacity:1;transform:none}

@media(max-width:1024px){
  .hero__inner{max-width:none}
  .g3{grid-template-columns:1fr 1fr}.about__grid,.mwrap,.feat{grid-template-columns:1fr}
  .about__img{aspect-ratio:16/9}.mfeature{aspect-ratio:16/9;max-height:340px}
  .stats{grid-template-columns:1fr 1fr}.fgrid{grid-template-columns:1fr 1fr}.feat__img{min-height:220px}
  .postgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  ul.menu,.navtools .nav-cta{display:none}.burger{display:flex}.mobile{display:block}
  .layout{grid-template-columns:1fr;gap:36px}aside.side{position:static;flex-direction:row;flex-wrap:wrap}
  .qcard,.infocard{flex:1 1 280px}
}
@media(max-width:680px){
  .g3,.tg,.vlist,.postgrid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr;padding:32px 24px}
  .sec,.about,.markets{padding:62px 0}.cta{padding:42px 24px}.fgrid{grid-template-columns:1fr}
  aside.side{flex-direction:column}.feat__b{padding:30px 26px}
}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important}.reveal{opacity:1;transform:none;transition:none}}

/* ===== language switch + RTL / Arabic ===== */
.langswitch{font-family:var(--display);font-weight:700;font-size:.85rem;color:var(--brand);padding:8px 12px;border:1px solid var(--line);border-radius:9px;transition:.18s;white-space:nowrap}
.langswitch:hover{background:#E8EDF5;border-color:#CED6E4;color:var(--brand)}
@media(max-width:860px){.navtools .langswitch{display:none}}

html[dir="rtl"] body,
html[dir="rtl"] h1,html[dir="rtl"] h2,html[dir="rtl"] h3,html[dir="rtl"] h4,
html[dir="rtl"] .eyebrow,html[dir="rtl"] .btn,html[dir="rtl"] .badge,html[dir="rtl"] .nav-cta,
html[dir="rtl"] ul.menu li a,html[dir="rtl"] .mcard__flag,html[dir="rtl"] .city,html[dir="rtl"] .mk{font-family:'Cairo',system-ui,sans-serif}
html[dir="rtl"] h1,html[dir="rtl"] h2,html[dir="rtl"] h3,html[dir="rtl"] h4{letter-spacing:0;line-height:1.28}
html[dir="rtl"] .hero h1{line-height:1.2}
html[dir="rtl"] .prose ul,html[dir="rtl"] .prose ol{margin-left:0;margin-right:1.2em}
html[dir="rtl"] .prose a{text-underline-offset:3px}
html[dir="rtl"] .btn .ar{display:inline-block;transform:scaleX(-1)}
html[dir="rtl"] .eyebrow::before{margin-left:.2em}
