/* ===========================================================
   NoLimitDigital — shared styles (styles.css)
   Design system + premium animations (motion-with-purpose)
   =========================================================== */
:root{
  --bg:#08070f;--bg-2:#0c0a1c;--surface:rgba(255,255,255,.035);--surface-2:rgba(255,255,255,.06);
  --line:rgba(255,255,255,.09);--line-strong:rgba(255,255,255,.16);
  --txt:#f4f2ff;--muted:#a09cc4;--muted-2:#6f6b91;
  --violet:#8b5cf6;--indigo:#6366f1;--cyan:#22d3ee;--teal:#06d6ce;--fuchsia:#e879f9;
  --grad:linear-gradient(115deg,#8b5cf6 0%,#6366f1 38%,#22d3ee 100%);
  --grad-soft:linear-gradient(115deg,rgba(139,92,246,.18),rgba(34,211,238,.12));
  --display:"Bricolage Grotesque",serif;--body:"Manrope",system-ui,sans-serif;
  --r:18px;--maxw:1180px;
  --ease:cubic-bezier(.2,.7,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%;overflow-x:clip}
body{background:var(--bg);color:var(--txt);font-family:var(--body);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:clip;position:relative}
body::before{content:"";position:fixed;inset:0;z-index:-2;background:
  radial-gradient(60% 50% at 78% -5%,rgba(139,92,246,.22),transparent 60%),
  radial-gradient(55% 45% at 8% 12%,rgba(34,211,238,.14),transparent 55%),
  radial-gradient(70% 60% at 50% 110%,rgba(99,102,241,.16),transparent 60%),var(--bg);
  animation:bgdrift 20s ease-in-out infinite alternate}
@keyframes bgdrift{to{background-position:6% -3%,-4% 5%,3% -4%,0 0}}
body::after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:56px 56px;-webkit-mask-image:radial-gradient(circle at 50% 22%,#000 0%,transparent 78%);mask-image:radial-gradient(circle at 50% 22%,#000 0%,transparent 78%)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:rgba(139,92,246,.4);color:#fff}

/* scroll progress */
#prog{position:fixed;top:0;left:0;height:3px;width:0;z-index:120;background:var(--grad);box-shadow:0 0 12px rgba(139,92,246,.7)}
/* page-transition loader */
#pageload{position:fixed;inset:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;background:#08070f;opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility .35s}
#pageload.show{opacity:1;visibility:visible}
#pageload .pl-mark{width:54px;height:54px;border-radius:15px;background:#0b0a18;display:grid;place-items:center;animation:plpulse 1.1s ease-in-out infinite}
#pageload .pl-mark svg{width:34px;height:34px}
@keyframes plpulse{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.08);opacity:1}}
#pageload .pl-bar{width:140px;height:3px;border-radius:100px;background:rgba(255,255,255,.1);overflow:hidden}
#pageload .pl-bar span{display:block;width:40%;height:100%;border-radius:100px;background:var(--grad);animation:plslide 1s var(--ease) infinite}
@keyframes plslide{0%{transform:translateX(-120%)}100%{transform:translateX(320%)}}
@media(prefers-reduced-motion:reduce){#pageload .pl-mark,#pageload .pl-bar span{animation:none}}

/* language */
/* language (BS default; EN and AR hidden until toggled) */
.en,.ar{display:none}
body.lang-en .bs,body.lang-en .ar{display:none}
body.lang-en .en{display:inline}
body.lang-en .en.block{display:block}
body.lang-ar .bs,body.lang-ar .en{display:none}
body.lang-ar .ar{display:inline}
body.lang-ar .ar.block{display:block}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--body);font-weight:700;font-size:.97rem;padding:.92em 1.5em;border-radius:100px;border:1px solid transparent;cursor:pointer;transition:.25s var(--ease);white-space:nowrap;will-change:transform}
.btn-primary{background:var(--grad);color:#0a0815;box-shadow:0 8px 30px -8px rgba(139,92,246,.6);background-size:160% 160%;animation:gradshift 6s ease infinite}
@keyframes gradshift{50%{background-position:100% 50%}}
.btn-primary:hover{box-shadow:0 16px 44px -10px rgba(139,92,246,.8)}
.btn-ghost{background:var(--surface);color:var(--txt);border-color:var(--line-strong)}
.btn-ghost:hover{background:var(--surface-2);border-color:var(--violet)}
.btn-lg{padding:1.05em 1.8em;font-size:1.02rem}

/* ===== HEADER ===== */
header{position:sticky;top:0;z-index:100;transition:.3s}
header.scrolled{background:rgba(8,7,15,.72);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-weight:800;font-size:1.18rem;letter-spacing:-.02em}
.brand .mark{width:34px;height:34px;border-radius:10px;background:#0b0a18;display:grid;place-items:center;flex:0 0 auto;transition:.3s}
.brand:hover .mark{transform:rotate(-8deg) scale(1.05)}
.brand .mark svg{width:22px;height:22px}
.brand b{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.nav-links{display:flex;align-items:center;gap:1.7rem;font-weight:600;font-size:.95rem}
.nav-row{display:flex;align-items:center;gap:1.7rem}
.nav-main{display:flex;align-items:center;gap:1.7rem}
.nav-feature,.nav-contact{display:none}
.nav-links a{color:var(--muted);transition:.2s;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:2px;background:var(--grad);transition:width .25s var(--ease)}
.nav-links a:hover{color:var(--txt)}.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--txt)}.nav-links a.active::after{width:100%}
.nav-right{display:flex;align-items:center;gap:1rem}
.nav-cta-desktop{padding:.66em 1.2em;font-size:.9rem}
.nav-links .nav-cta-mobile{display:none!important}
/* related services / read-more cards */
.rel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px}
.rel-card{display:flex;align-items:center;justify-content:space-between;gap:.8rem;padding:1rem 1.2rem;border:1px solid var(--line);border-radius:14px;background:var(--surface);color:var(--txt);font-weight:600;font-size:.98rem;transition:transform .25s var(--ease),border-color .25s,background .25s,box-shadow .25s}
.rel-card:hover{transform:translateY(-3px);border-color:var(--violet);background:rgba(139,92,246,.08);box-shadow:0 14px 32px -16px rgba(139,92,246,.5)}
.rel-card .rel-arrow{color:var(--teal);font-size:1.1em;flex:0 0 auto;transition:transform .25s var(--ease)}
.rel-card:hover .rel-arrow{transform:translateX(5px)}
html[dir="rtl"] .rel-card .rel-arrow{transform:scaleX(-1)}
html[dir="rtl"] .rel-card:hover .rel-arrow{transform:scaleX(-1) translateX(5px)}
/* system list rows (homepage) — slide right on hover */
.sys-row{display:flex;align-items:center;gap:.8rem;padding:.85rem 1rem;border:1px solid var(--line);border-radius:13px;background:rgba(10,9,24,.7);font-weight:600;font-size:.93rem;color:var(--txt);transition:transform .25s var(--ease),border-color .25s,background .25s}
.sys-row:hover{transform:translateX(7px);border-color:var(--violet);background:rgba(139,92,246,.12)}
html[dir="rtl"] .sys-row:hover{transform:translateX(-7px)}
.sys-total{transition:transform .25s var(--ease),box-shadow .25s,filter .25s;box-shadow:0 8px 26px -10px rgba(139,92,246,.5)}
.sys-total:hover{transform:translateY(-2px);box-shadow:0 14px 36px -10px rgba(139,92,246,.75);filter:brightness(1.05)}
.lang-toggle{display:flex;border:1px solid var(--line-strong);border-radius:100px;overflow:hidden;font-weight:700;font-size:.8rem}
.lang-toggle button{background:none;border:none;color:var(--muted);padding:.45em .8em;cursor:pointer;transition:.2s}
.lang-toggle button.active{background:var(--grad);color:#0a0815}
.burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.burger span{width:24px;height:2px;background:var(--txt);border-radius:2px;transition:.3s}
.burger.x span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.x span:nth-child(2){opacity:0}
.burger.x span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== generic section ===== */
section{padding:92px 0;position:relative}
.sec-head{max-width:680px;margin-bottom:52px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.tag{font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal)}
.sec-head h2{font-family:var(--display);font-weight:700;font-size:clamp(1.9rem,4vw,3rem);letter-spacing:-.025em;line-height:1.08;margin:.8rem 0 1rem}
.sec-head p{color:var(--muted);font-size:1.08rem}

/* page hero (inner pages) */
.phero{padding:70px 0 30px;text-align:center}
.phero .tag{display:inline-block}
.phero h1{font-family:var(--display);font-weight:800;font-size:clamp(2.2rem,5.2vw,3.8rem);letter-spacing:-.03em;line-height:1.04;margin:1rem auto 1.1rem;max-width:13ch}
.phero h1 em{font-style:normal;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.phero p{color:var(--muted);font-size:clamp(1.05rem,2vw,1.25rem);max-width:680px;margin:0 auto}
.crumbs{font-size:.84rem;color:var(--muted-2);margin-bottom:6px}
.crumbs a:hover{color:var(--teal)}

/* ===== eyebrow / hero shared ===== */
.eyebrow{display:inline-flex;align-items:center;gap:.6em;font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:.5em 1.1em;border:1px solid var(--line);border-radius:100px;background:var(--surface)}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 12px var(--teal);animation:pulse 2s ease infinite}
@keyframes pulse{50%{opacity:.4;box-shadow:0 0 4px var(--teal)}}

/* ===== cards / services ===== */
.grid-svc{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{position:relative;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);padding:30px;transition:transform .3s var(--ease),background .3s;overflow:hidden}
.card::before{content:"";position:absolute;width:320px;height:320px;background:radial-gradient(circle,rgba(139,92,246,.18),transparent 60%);left:var(--mx,50%);top:var(--my,50%);transform:translate(-50%,-50%);opacity:0;transition:opacity .3s;pointer-events:none}
.card:hover::before{opacity:1}
.card::after{content:"";position:absolute;inset:0;border-radius:var(--r);padding:1px;background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:.3s}
.card:hover{transform:translateY(-5px);background:var(--surface-2)}.card:hover::after{opacity:1}
.card .ic{width:50px;height:50px;border-radius:13px;background:var(--grad-soft);border:1px solid var(--line);display:grid;place-items:center;margin-bottom:1.1rem;position:relative}
.card .ic svg{width:25px;height:25px;stroke:var(--teal);fill:none;stroke-width:1.7}
.card h3{font-family:var(--display);font-weight:700;font-size:1.14rem;margin-bottom:.5rem;letter-spacing:-.01em;position:relative}
.card p{color:var(--muted);font-size:.95rem;position:relative}
.card .lnk{position:relative;margin-top:.9rem;font-weight:700;font-size:.88rem;color:var(--teal);display:inline-flex;gap:.4em;align-items:center;opacity:0;transform:translateX(-6px);transition:.3s}
.card:hover .lnk{opacity:1;transform:none}
.card.feat{background:var(--grad-soft);border-color:var(--line-strong)}
.card.feat .ic{background:var(--grad)}.card.feat .ic svg{stroke:#0a0815}
a.card{display:block}

/* trust bar */
.trustbar{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--surface);padding:22px 0}
.trustbar .row{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 2.4rem;align-items:center}
.trustbar .it{display:flex;align-items:center;gap:.6rem;font-weight:600;font-size:.95rem;color:var(--muted)}
.trustbar .it svg{width:20px;height:20px;stroke:var(--teal);fill:none;stroke-width:2;flex:0 0 auto}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.stat{background:var(--bg-2);padding:1.7rem 1.2rem;text-align:center}
.stat .num{font-family:var(--display);font-weight:800;font-size:clamp(1.7rem,3vw,2.4rem);background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1;text-align:center;display:block}
.stat .lbl{font-size:.86rem;color:var(--muted);margin-top:.5rem}

/* ===== FAQ ===== */
.faq{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.qa{border:1px solid var(--line);border-radius:14px;background:var(--surface);overflow:hidden}
.qa-q{width:100%;text-align:left;background:none;border:none;color:var(--txt);font-family:var(--body);font-weight:700;font-size:1.04rem;padding:20px 22px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.qa-q .pl{flex:0 0 auto;width:22px;height:22px;position:relative;transition:.3s}
.qa-q .pl::before,.qa-q .pl::after{content:"";position:absolute;background:var(--teal);border-radius:2px;top:50%;left:50%;transform:translate(-50%,-50%)}
.qa-q .pl::before{width:14px;height:2px}.qa-q .pl::after{width:2px;height:14px;transition:.3s}
.qa.open .pl::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.qa-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.qa-a p{padding:0 22px 20px;color:var(--muted);font-size:.97rem}

/* ===== reviews marquee ===== */
.marquee{display:flex;gap:18px;width:max-content;animation:scroll 55s linear infinite}
.marquee-wrap{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.marquee-wrap:hover .marquee{animation-play-state:paused}
@keyframes scroll{to{transform:translateX(calc(-50% - 9px))}}
.review{flex:0 0 360px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);padding:26px;display:flex;flex-direction:column}
.stars{color:#fbbf24;font-size:.95rem;letter-spacing:2px;margin-bottom:.9rem}
.review p{color:var(--txt);font-size:.97rem;line-height:1.55;margin-bottom:1.2rem;flex:1}
.review .who{display:flex;align-items:center;gap:.8rem}
.avatar{width:42px;height:42px;border-radius:50%;background:var(--grad);display:grid;place-items:center;font-family:var(--display);font-weight:800;color:#0a0815;flex:0 0 auto;font-size:1rem}
.review .who b{font-family:var(--display);font-weight:700;font-size:.98rem;display:block;line-height:1.2}
.review .who span{font-size:.82rem;color:var(--muted)}

/* ===== CTA + form ===== */
.cta-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:stretch}
.cta-copy{border:1px solid var(--line);border-radius:24px;background:linear-gradient(150deg,rgba(139,92,246,.16),rgba(34,211,238,.08));padding:40px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center}
.cta-copy::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 100% at 0 0,rgba(139,92,246,.25),transparent 70%)}
.cta-copy h2{font-family:var(--display);font-weight:800;font-size:clamp(1.7rem,3.5vw,2.5rem);letter-spacing:-.025em;position:relative;margin-bottom:.8rem}
.cta-copy p{color:var(--muted);position:relative;margin-bottom:1.4rem}
.cta-copy .phone{font-family:var(--display);font-weight:700;font-size:1.2rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;position:relative}
.cta-copy .reassure{position:relative;display:flex;flex-direction:column;gap:.6rem;margin-top:1.2rem}
.cta-copy .reassure div{display:flex;gap:.6rem;align-items:center;font-size:.92rem;color:var(--muted)}
.cta-copy .reassure svg{width:18px;height:18px;stroke:var(--teal);fill:none;stroke-width:2.2;flex:0 0 auto}
.form{border:1px solid var(--line);border-radius:24px;background:var(--surface);padding:34px}
.form h3{font-family:var(--display);font-weight:700;font-size:1.3rem;margin-bottom:1.3rem}
.field{margin-bottom:14px}
.field label{display:block;font-size:.82rem;font-weight:600;color:var(--muted);margin-bottom:.4rem}
.field input,.field textarea,.field select{width:100%;background:rgba(10,9,24,.6);border:1px solid var(--line-strong);border-radius:12px;padding:.8em 1em;color:var(--txt);font-family:var(--body);font-size:.98rem;transition:.2s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px rgba(139,92,246,.18)}
.field textarea{resize:vertical;min-height:90px}
/* custom select: brand chevron, dark dropdown list */
.field select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:2.8em;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a09cc4' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1.05em center}
.field select:hover{border-color:var(--violet)}
.field select option{background:#0c0a1c;color:var(--txt);padding:10px}
.field select option:checked{background:#1a1730;color:#fff}
html[dir="rtl"] .field select{padding-right:1em;padding-left:2.8em;background-position:left 1.05em center}
/* custom dropdown (JS-enhanced select) — full brand control */
.nld-select{position:relative}
.nld-select>select{position:absolute;opacity:0;width:100%;height:100%;top:0;left:0;pointer-events:none;margin:0}
.nld-select .ns-btn{width:100%;background:rgba(10,9,24,.6);border:1px solid var(--line-strong);border-radius:12px;padding:.8em 1em;color:var(--txt);font-family:var(--body);font-size:.98rem;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:.6rem;transition:border-color .2s,box-shadow .2s;text-align:left}
.nld-select .ns-btn:hover{border-color:var(--violet)}
.nld-select.open .ns-btn{border-color:var(--violet);box-shadow:0 0 0 3px rgba(139,92,246,.18)}
.nld-select .ns-chev{flex:0 0 auto;width:16px;height:16px;stroke:var(--muted);fill:none;stroke-width:2.5;transition:transform .25s var(--ease)}
.nld-select.open .ns-chev{transform:rotate(180deg)}
.nld-select .ns-list{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:60;background:#0c0a1c;border:1px solid var(--line-strong);border-radius:12px;padding:6px;box-shadow:0 24px 60px -20px rgba(0,0,0,.75);max-height:288px;overflow-y:auto;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .2s,transform .2s,visibility .2s}
.nld-select.open .ns-list{opacity:1;visibility:visible;transform:none}
.nld-select .ns-opt{padding:.62em .8em;border-radius:8px;cursor:pointer;font-size:.95rem;color:var(--txt);transition:background .15s,color .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nld-select .ns-opt:hover,.nld-select .ns-opt.active{background:rgba(139,92,246,.16)}
.nld-select .ns-opt[aria-selected="true"]{background:rgba(139,92,246,.24);color:#fff}
.nld-select .ns-list::-webkit-scrollbar{width:8px}
.nld-select .ns-list::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:8px}
.field.consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.84rem;color:var(--muted)}
.field.consent input[type="checkbox"]{appearance:none;-webkit-appearance:none;outline:none;-webkit-tap-highlight-color:transparent;box-sizing:border-box;flex:0 0 auto;width:16px!important;height:16px;min-width:16px;padding:0!important;margin:.18rem 0 0;border:1px solid var(--line-strong);border-radius:5px;background:rgba(10,9,24,.6);cursor:pointer;position:relative;transition:border-color .2s,background .2s;display:inline-block}
.field.consent input[type="checkbox"]:hover{border-color:var(--violet)}
.field.consent input[type="checkbox"]:checked{background:var(--grad);border-color:transparent}
.field.consent input[type="checkbox"]:checked::after{content:"";position:absolute;left:50%;top:50%;width:4px;height:8px;border:solid #0a0815;border-width:0 2px 2px 0;transform:translate(-50%,-58%) rotate(45deg)}
.field.consent input[type="checkbox"]:focus-visible{box-shadow:0 0 0 3px rgba(139,92,246,.25)}
.field.consent a{color:var(--teal);text-decoration:underline}
.form .btn-primary{width:100%;justify-content:center;margin-top:6px}
.form .note{font-size:.78rem;color:var(--muted-2);margin-top:.9rem;text-align:center}
.form-msg{display:none;padding:14px 16px;border-radius:12px;font-size:.92rem;font-weight:600;margin-top:12px}
.form-msg.ok{display:block;background:rgba(6,214,206,.12);color:var(--teal);border:1px solid rgba(6,214,206,.3)}
.form-msg.err{display:block;background:rgba(244,63,94,.12);color:#fb7185;border:1px solid rgba(244,63,94,.3)}

/* ===== footer ===== */
footer{border-top:1px solid var(--line);padding:60px 0 36px;margin-top:40px}
.foot{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
.foot .brand{margin-bottom:1rem}
.foot p.tg{color:var(--muted);font-size:.94rem;max-width:280px}
.foot h5{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-2);margin-bottom:1.1rem;font-weight:700}
.foot ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.foot ul a{color:var(--muted);font-size:.94rem;transition:.2s}.foot ul a:hover{color:var(--txt)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-top:48px;padding-top:24px;border-top:1px solid var(--line);color:var(--muted-2);font-size:.86rem}
.foot-bottom a:hover{color:var(--teal)}
.socials{display:flex;gap:.6rem}
.socials a{width:38px;height:38px;border:1px solid var(--line);border-radius:10px;display:grid;place-items:center;transition:.25s}
.socials a:hover{border-color:var(--violet);background:var(--surface)}
.socials svg{width:17px;height:17px;fill:var(--muted)}.socials a:hover svg{fill:var(--txt)}

/* ===== GDPR cookie banner ===== */
#cookie{position:fixed;left:18px;right:18px;bottom:18px;z-index:200;max-width:560px;margin:0 auto;background:rgba(14,13,26,.96);backdrop-filter:blur(16px);border:1px solid var(--line-strong);border-radius:18px;padding:22px 24px;box-shadow:0 24px 60px -20px rgba(0,0,0,.7);transform:translateY(140%);transition:transform .5s var(--ease)}
#cookie.show{transform:none}
#cookie h4{font-family:var(--display);font-weight:700;font-size:1.05rem;margin-bottom:.4rem}
#cookie p{font-size:.88rem;color:var(--muted);margin-bottom:1rem}
#cookie p a{color:var(--teal);text-decoration:underline}
#cookie .ck-actions{display:flex;gap:.6rem;flex-wrap:wrap}
#cookie .ck-actions .btn{padding:.7em 1.2em;font-size:.88rem}
.ck-pref{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}
.ck-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:.88rem;padding:.5rem .2rem;border-bottom:1px solid var(--line)}
.ck-row b{font-weight:700}
.ck-row span{color:var(--muted-2);font-size:.78rem;display:block}
.switch{position:relative;width:42px;height:24px;flex:0 0 auto}
.switch input{opacity:0;width:0;height:0}
.switch .sl{position:absolute;inset:0;background:rgba(255,255,255,.12);border-radius:100px;cursor:pointer;transition:.25s}
.switch .sl::before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.25s}
.switch input:checked+.sl{background:var(--grad)}
.switch input:checked+.sl::before{transform:translateX(18px)}
.switch input:disabled+.sl{opacity:.6;cursor:not-allowed}

/* ===== ANIMATIONS (research-based: purposeful, staggered, GPU-friendly) ===== */
/* reveal on scroll */
.reveal{opacity:0;transform:translateY(24px);transition:.7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal-l{opacity:0;transform:translateX(-28px);transition:.7s var(--ease)}
.reveal-l.in{opacity:1;transform:none}
.reveal-r{opacity:0;transform:translateX(28px);transition:.7s var(--ease)}
.reveal-r.in{opacity:1;transform:none}
.reveal-sc{opacity:0;transform:scale(.94);transition:.7s var(--ease)}
.reveal-sc.in{opacity:1;transform:none}
/* word-by-word headline */
.word{display:inline-block;opacity:0;transform:translateY(24px) rotate(2deg);animation:wordin .7s var(--ease) forwards}
@keyframes wordin{to{opacity:1;transform:none}}
/* float */
@keyframes float{50%{transform:translateY(-10px)}}

/* reduced motion: kill all non-essential motion */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal,.reveal-l,.reveal-r,.reveal-sc,.word{opacity:1!important;transform:none!important}
  .nav-links a{opacity:1!important;transform:none!important}
  body::before{animation:none}
}

/* ===== responsive — full device coverage ===== */

/* tablets / small laptops */
@media(max-width:1024px){
  :root{--maxw:960px}
  .nav-links{gap:1.3rem}
  .nav-right{gap:.7rem}
}

/* ≤900px: mobile nav (burger), 2-col grids */
@media(max-width:900px){
  .nav-links{display:flex;position:fixed;top:64px;left:0;right:0;flex-direction:column;align-items:stretch;background:#0a0813;padding:26px 24px 30px;gap:1.5rem;z-index:99;max-height:calc(100dvh - 64px);overflow-y:auto;opacity:0;visibility:hidden;transform:translateY(-14px);transition:opacity .38s var(--ease),transform .38s var(--ease),visibility .38s;pointer-events:none;box-shadow:0 26px 50px -22px rgba(0,0,0,.8)}
  .nav-links.open{opacity:1;visibility:visible;transform:none;pointer-events:auto}
  /* top row: nav links (left) + blog card (right) */
  .nav-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;align-items:start}
  .nav-main{display:flex;flex-direction:column;align-items:flex-start;gap:1.2rem}
  .nav-main a{font-size:1rem;color:var(--muted);position:relative;opacity:0;transform:translateY(-10px);transition:opacity .35s var(--ease),transform .35s var(--ease),color .22s var(--ease)}
  .nav-main a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--grad);transition:width .28s var(--ease)}
  .nav-main a:hover{color:var(--txt)}.nav-main a:hover::after{width:100%}
  .nav-main a.active{color:var(--teal)}.nav-main a.active::after{width:100%}
  .nav-links.open .nav-main a{opacity:1;transform:none}
  .nav-links.open .nav-main a:nth-child(1){transition-delay:.05s}
  .nav-links.open .nav-main a:nth-child(2){transition-delay:.10s}
  .nav-links.open .nav-main a:nth-child(3){transition-delay:.15s}
  .nav-links.open .nav-main a:nth-child(4){transition-delay:.20s}
  .nav-links.open .nav-main a:nth-child(5){transition-delay:.25s}
  .burger{display:flex}
  nav{height:64px}
  .nav-cta-desktop{display:none}
  /* CTA — uniform hover; text stays dark (no nav-link color leak); entrance delay only on opacity */
  .nav-links .nav-cta-mobile{color:#0a0815!important;box-shadow:0 8px 30px -8px rgba(139,92,246,.6);opacity:0;transition:transform .28s ease,box-shadow .28s ease,filter .28s ease,opacity .28s ease .3s}
  .nav-links .nav-cta-mobile::after{display:none}
  .nav-links.open .nav-cta-mobile{display:inline-flex!important;width:100%;justify-content:center;opacity:1}
  .nav-links.open .nav-cta-mobile:hover{transform:translateY(-2px);box-shadow:0 16px 42px -10px rgba(139,92,246,.85);filter:brightness(1.06)}
  /* blog card (right column) — animated hover */
  .nav-feature{display:flex;flex-direction:column;align-items:flex-start;gap:.7rem;padding:14px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.03);align-self:start;overflow:hidden;opacity:0;transition:opacity .4s var(--ease) .2s,transform .28s var(--ease),border-color .25s,background .25s,box-shadow .25s}
  .nav-links.open .nav-feature{opacity:1}
  .nav-feature::after{display:none}
  .nav-feature:hover{transform:translateY(-3px);border-color:var(--violet);background:rgba(139,92,246,.1);box-shadow:0 16px 34px -16px rgba(139,92,246,.55)}
  .nav-feature img{width:100%;height:84px;object-fit:cover;border-radius:10px;transition:transform .45s var(--ease)}
  .nav-feature:hover img{transform:scale(1.06)}
  .nav-feature .nf-text{display:flex;flex-direction:column;gap:4px;min-width:0}
  .nav-feature .nf-eyebrow{font-size:.64rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal)}
  .nav-feature .nf-title{font-size:.9rem;font-weight:600;color:var(--txt);line-height:1.25;font-family:var(--display)}
  /* contact row */
  .nav-contact{display:flex;flex-direction:column;gap:.6rem;border-top:1px solid var(--line);padding-top:1.1rem;margin-top:.3rem;opacity:0;transform:translateY(-8px);transition:opacity .4s var(--ease) .36s,transform .4s var(--ease) .36s}
  .nav-links.open .nav-contact{opacity:1;transform:none}
  .nav-contact a{display:flex;align-items:center;gap:.6rem;font-size:.95rem;color:var(--muted);transition:color .2s}
  .nav-contact a::after{display:none}
  .nav-contact a:hover{color:var(--teal)}
  .nav-contact svg{width:17px;height:17px;stroke:var(--teal);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:0 0 auto}
  .cta-grid{grid-template-columns:1fr;gap:28px}
  .grid-svc{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .foot{grid-template-columns:1fr 1fr;gap:32px}.foot .brand-col{grid-column:1/-1}
  .marquee{animation-duration:40s}
  /* 3-col content grids → 2-col on tablet */
  .pf3,.bl3,.blgrid{grid-template-columns:repeat(2,1fr)!important}
}

/* ≤600px: phones — single column everything */
@media(max-width:600px){
  body{font-size:16px}
  .wrap{padding:0 18px}
  section{padding:60px 0}
  .hero{padding-top:30px!important;padding-bottom:44px!important}
  .hero-line{max-width:260px!important}
  .sec-head{margin-bottom:38px}
  .grid-svc{grid-template-columns:1fr}
  .foot{grid-template-columns:1fr}
  .pf3,.bl3,.blgrid,.vals,.incl,.grid-work,.sysgrid{grid-template-columns:1fr!important}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:.8rem}
  .review{flex-basis:280px}
  .cta-copy,.form{padding:24px}
  #cookie{padding:16px 16px 14px;left:8px;right:8px;bottom:8px;border-radius:14px}
  #cookie h4{font-size:.96rem;margin-bottom:.3rem}
  #cookie p{font-size:.8rem;margin-bottom:.75rem;line-height:1.45}
  #cookie .ck-actions{flex-direction:column;gap:.45rem}
  #cookie .ck-actions .btn{width:100%;justify-content:center;padding:.72em 1em;font-size:.85rem}
  .ck-row{font-size:.82rem}.ck-row span{font-size:.72rem}
  .phero{padding:54px 0 24px}
  .btn{font-size:.95rem;padding:.9em 1.4em}
  .brand{font-size:1.05rem}
  .brand .mark{width:30px;height:30px}.brand .mark svg{width:20px;height:20px}
  /* footer has room — keep its logo + headers comfortably larger than the header bar */
  .foot .brand{font-size:1.32rem;gap:.6rem}
  .foot .brand .mark{width:40px;height:40px}.foot .brand .mark svg{width:25px;height:25px}
  .foot h5{font-size:.92rem}
  .foot p.tg{font-size:1rem}
}

/* ≤400px: small phones — tighten further, keep header from overflowing */
@media(max-width:400px){
  .wrap{padding:0 14px}
  .lang-toggle button{padding:.4em .6em;font-size:.72rem}
  .brand{font-size:.98rem;gap:.45rem}
  .foot .brand{font-size:1.24rem;gap:.55rem}
  .foot .brand .mark{width:38px;height:38px}.foot .brand .mark svg{width:24px;height:24px}
  .stats{grid-template-columns:1fr 1fr}
  .stat{padding:1.3rem .8rem}
  .stat .num{font-size:clamp(1.2rem,5.2vw,1.7rem);word-break:break-word}
  .sec-head h2{font-size:clamp(1.6rem,7vw,2rem)}
  .phero h1{font-size:clamp(1.9rem,8.5vw,2.6rem)}
  #cookie{padding:14px 14px 12px}
  #cookie h4{font-size:.92rem}
  #cookie p{font-size:.76rem;margin-bottom:.65rem}
  #cookie .ck-actions .btn{padding:.66em 1em;font-size:.82rem}
}

/* ===========================================================
   ARABIC + RTL  (applied only when <body class="lang-ar"> / dir=rtl)
   Arabic display & headings use "Cairo"; layout mirrors cleanly.
   =========================================================== */
:root{--arabic:"Cairo","Noto Kufi Arabic",var(--body)}

/* Arabic typography: switch font + relax letter-spacing (Arabic must not be tracked) */
body.lang-ar{font-family:var(--arabic);letter-spacing:0}
body.lang-ar .ar{font-family:var(--arabic)}
body.lang-ar h1,body.lang-ar h2,body.lang-ar h3,body.lang-ar h4,body.lang-ar h5,
body.lang-ar .brand,body.lang-ar .sec-head h2,body.lang-ar .phero h1,
body.lang-ar .stat .num,body.lang-ar .cta-copy h2{font-family:var(--arabic);letter-spacing:0;line-height:1.3}
body.lang-ar .stat .num,body.lang-ar .cta-copy .phone{direction:ltr;unicode-bidi:plaintext}

/* RTL mirroring */
html[dir="rtl"] body{direction:rtl}
html[dir="rtl"] .sec-head:not(.center),
html[dir="rtl"] .article-body,
html[dir="rtl"] .legal,
html[dir="rtl"] .cta-copy,
html[dir="rtl"] .form,
html[dir="rtl"] .qa-q{text-align:right}
html[dir="rtl"] .phero{text-align:center}

/* keep brand/logo mark on the right, latin lockups LTR */
html[dir="rtl"] .brand{flex-direction:row}
html[dir="rtl"] .brand b,html[dir="rtl"] .brand{unicode-bidi:plaintext}

/* lists: indent from the right */
html[dir="rtl"] .article-body ul,html[dir="rtl"] .article-body ol,
html[dir="rtl"] .legal ul{margin:0 1.3rem 1.1rem 0}
html[dir="rtl"] .faq{text-align:right}

/* callout border flips to the right edge */
html[dir="rtl"] .article-body .callout{border-left:none;border-right:3px solid var(--teal);border-radius:12px 0 0 12px}

/* tables align right */
html[dir="rtl"] .article-body .tbl th,html[dir="rtl"] .article-body .tbl td{text-align:right}

/* nav underline + link arrows: keep readable */
html[dir="rtl"] .nav-links a::after{left:auto;right:0}
html[dir="rtl"] .crumbs{direction:rtl}

/* form fields read right-to-left */
html[dir="rtl"] .field input,html[dir="rtl"] .field textarea,html[dir="rtl"] .field select{text-align:right}
html[dir="rtl"] .field.consent{flex-direction:row-reverse}

/* reveal-l / reveal-r come from the correct side in RTL */
html[dir="rtl"] .reveal-l{transform:translateX(28px)}
html[dir="rtl"] .reveal-r{transform:translateX(-28px)}
html[dir="rtl"] .reveal-l.in,html[dir="rtl"] .reveal-r.in{transform:none}

/* phone / numbers / emails / latin brand names stay LTR inside Arabic text */
html[dir="rtl"] a[href^="tel:"],html[dir="rtl"] a[href^="mailto:"]{direction:ltr;unicode-bidi:embed;display:inline-block}

/* marquee keeps its direction (visual only) */
html[dir="rtl"] .marquee{direction:ltr}
html[dir="rtl"] .review{text-align:right;direction:rtl}

/* footer columns align right */
html[dir="rtl"] .foot,html[dir="rtl"] .foot ul{text-align:right}
html[dir="rtl"] .socials{direction:ltr}

/* language toggle stays LTR (BS · EN · AR labels) */
html[dir="rtl"] .lang-toggle{direction:ltr}
