/* shared.css — Kawini International, all pages */

:root{
  color-scheme:light;
  --blue: #2E7BB7;          /* primary — pulled from logo's mid-blue */
  --blue-deep: #1F5680;     /* emphasis */
  --blue-light: #5BA4CF;    /* accent */
  --blue-soft: #E8F2F9;     /* tint backgrounds */
  --blue-softer: #F4F9FC;
  --ink: #16243A;           /* primary text */
  --ink-soft: #5B6A7E;
  --ink-mute: #9AA6B5;
  --rule: #E5EEF6;
  --rule-soft: #F0F6FB;
  --bg: #FFFFFF;
  --red: #C0392B;

  --maxw: 1240px;
  --pad: clamp(20px, 4vw, 64px);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);overflow-x:hidden;
  font-family:'Inter',ui-sans-serif,system-ui,sans-serif;font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body[data-lang="ar"]{font-family:'Noto Kufi Arabic','Inter',sans-serif;direction:rtl}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}

/* ───── Type ───── */
.h-display{font-family:'Bebas Neue',Impact,sans-serif;font-weight:400;letter-spacing:-.03em;
  line-height:.94;text-transform:uppercase}
body[data-lang="ar"] .h-display{font-family:'Noto Kufi Arabic',sans-serif;line-height:1.18;letter-spacing:-.01em;font-weight:700;text-transform:none}
.eyebrow{font:600 11px/1.2 'Inter';letter-spacing:.18em;text-transform:uppercase;color:var(--blue-deep)}
.eyebrow .dot{display:inline-block;width:5px;height:5px;background:var(--blue);margin-inline-end:8px;vertical-align:2px;border-radius:50%}

/* ───── Layout ───── */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
section{padding-block:128px}
.sec-tint{background:var(--blue-softer)}
.sec-tint-soft{background:#FBFCFE}

.sec-head{max-width:64ch}
.sec-head h2{font-family:'Bebas Neue';font-size:clamp(40px,5.4vw,80px);line-height:.96;margin:18px 0 0;color:var(--ink);font-weight:400;text-wrap:balance}
body[data-lang="ar"] .sec-head h2{font-family:'Noto Kufi Arabic';font-weight:700;font-size:clamp(28px,3.8vw,52px);line-height:1.18}
.sec-head h2 .em{color:var(--blue)}
.sec-head p{font:400 18px/1.65 'Inter';color:var(--ink-soft);margin:24px 0 0;max-width:54ch}

/* ───── Nav ───── */
.nav{position:fixed;inset:0 0 auto 0;z-index:50;
  transition:background .25s ease, border-color .25s ease, box-shadow .25s ease;}
.nav.scrolled{background:rgba(255,255,255,.92);backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--rule)}
.nav-row{display:flex;align-items:center;gap:32px;height:80px;color:var(--ink)}
.nav-logo{display:flex;align-items:center;line-height:1;color:var(--ink);text-decoration:none}
.nav-logo img{height:44px;width:auto;display:block}
.nav-logo .wm{font-family:'Bebas Neue';font-size:24px;letter-spacing:.04em;color:var(--ink);margin-inline-start:0}
.nav-logo .wm small{display:block;font:600 8px/1 'Inter';letter-spacing:.28em;color:var(--ink-mute);margin-top:4px}
.nav-links{display:flex;gap:32px;font:500 14px/1 'Inter';color:var(--ink-soft)}
.nav-links a{position:relative;padding:6px 0;transition:color .15s ease}
.nav-links a:hover{color:var(--ink)}
.nav-links a.is-current{color:var(--ink)}
.nav-links a.is-current::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--blue)}

.nav-cta{margin-inline-start:auto;display:flex;align-items:center;gap:16px}
.lang{display:inline-flex;align-items:center;font:600 11px/1 'Inter';letter-spacing:.14em;color:var(--ink-mute);
  background:var(--blue-softer);border:1px solid var(--rule);padding:4px;border-radius:999px}
.lang button{background:transparent;border:0;color:inherit;padding:7px 10px;text-transform:uppercase;letter-spacing:.14em;border-radius:999px}
.lang button.active{color:var(--ink);background:#fff;box-shadow:0 1px 2px rgba(22,36,58,.08)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 22px;font:600 13px/1 'Inter';
  letter-spacing:.02em;border-radius:999px;border:1.5px solid transparent;transition:all .18s cubic-bezier(.16,1,.3,1);white-space:nowrap}
.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 6px 18px -8px rgba(46,123,183,.7)}
.btn-primary:hover{background:var(--blue-deep);border-color:var(--blue-deep);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--rule)}
.btn-ghost:hover{background:var(--blue-softer);border-color:var(--blue)}
.btn-arr::after{content:"→";font-family:'Inter';margin-inline-start:4px}
body[data-lang="ar"] .btn-arr::after{content:"←";margin-inline-end:4px;margin-inline-start:0}

/* ───── Hero (light, airy) ───── */
.hero{position:relative;overflow:hidden;background:var(--bg);padding-top:clamp(120px,14vh,200px);padding-bottom:128px}
.hero-bg{position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle, rgba(46,123,183,.16) 1.2px, transparent 1.4px);
  background-size:32px 32px;
  mask-image:radial-gradient(ellipse 70% 60% at 70% 40%, black 20%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 70% 40%, black 20%, transparent 75%);}
.hero .wrap{position:relative;z-index:2}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:96px;align-items:center}
.hero h1{font-size:clamp(56px, 8.5vw, 120px);margin:28px 0 28px;color:var(--ink);max-width:13ch;text-wrap:balance}
body[data-lang="ar"] .hero h1{font-size:clamp(40px,5.5vw,76px);max-width:14ch}
.hero h1 .em{color:var(--blue)}
.hero .sub{font:400 19px/1.6 'Inter';color:var(--ink-soft);max-width:46ch;margin:0 0 40px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.hero-tag{display:inline-flex;align-items:center;gap:10px;font:600 11px/1 'Inter';letter-spacing:.18em;text-transform:uppercase;
  color:var(--blue-deep);background:var(--blue-soft);padding:9px 16px;border-radius:999px}
.hero-tag .pulse{width:6px;height:6px;background:var(--blue);border-radius:50%;position:relative}
.hero-tag .pulse::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:2px solid var(--blue);
  opacity:.5;animation:pulse 1.8s ease-out infinite}
@keyframes pulse{0%{transform:scale(.4);opacity:.6}100%{transform:scale(1.4);opacity:0}}
.hero-mini{display:inline-flex;align-items:center;gap:16px;margin-top:40px;font:500 13px/1.4 'Inter';color:var(--ink-soft);flex-wrap:wrap}
.hero-mini b{color:var(--ink);font-weight:600}
.hero-mini .sep{color:var(--rule)}

/* Smaller hero variant for inner pages */
.hero-inner{padding-top:160px;padding-bottom:80px;background:var(--bg);position:relative;overflow:hidden}
.hero-inner .hero-bg{mask-image:linear-gradient(to bottom, black, transparent);
  -webkit-mask-image:linear-gradient(to bottom, black, transparent)}
.hero-inner h1{font-family:'Bebas Neue';font-weight:400;font-size:clamp(48px,6.5vw,96px);line-height:.95;
  margin:20px 0 24px;color:var(--ink);max-width:18ch;text-wrap:balance}
body[data-lang="ar"] .hero-inner h1{font-family:'Noto Kufi Arabic';font-weight:700;font-size:clamp(36px,4.6vw,64px);line-height:1.15;text-transform:none}
.hero-inner h1 .em{color:var(--blue)}
.hero-inner .sub{font:400 19px/1.6 'Inter';color:var(--ink-soft);max-width:60ch;margin:0 0 8px}
.hero-inner .breadcrumbs{font:600 11px/1 'Inter';letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute)}
.hero-inner .breadcrumbs a:hover{color:var(--blue-deep)}

/* Quiet stat row */
/* ── Scroll reveal ────────────────────────────── */
.rv{opacity:0;transform:translateY(26px);will-change:transform;
  transition:opacity .72s cubic-bezier(.16,1,.3,1),transform .72s cubic-bezier(.16,1,.3,1)}
.rv.vis{opacity:1;transform:none;will-change:auto}
.rv[data-d="1"]{transition-delay:.08s}
.rv[data-d="2"]{transition-delay:.17s}
.rv[data-d="3"]{transition-delay:.27s}
.rv[data-d="4"]{transition-delay:.38s}
@media(prefers-reduced-motion:reduce){.rv{opacity:1!important;transform:none!important;transition:none!important}}

/* ── Hero page-load entrance ─────────────────── */
@keyframes slideUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
.he1{animation:slideUp .65s cubic-bezier(.16,1,.3,1) both}
.he2{animation:slideUp .65s cubic-bezier(.16,1,.3,1) .12s both}
.he3{animation:slideUp .65s cubic-bezier(.16,1,.3,1) .26s both}
.he4{animation:slideUp .65s cubic-bezier(.16,1,.3,1) .4s both}
.he5{animation:slideUp .65s cubic-bezier(.16,1,.3,1) .55s both}

/* ── Dark stat band ──────────────────────────── */
.stat-dark{background:var(--ink)!important}
.stat-dark .stat-num{color:#fff}
.stat-dark .stat-num .suf{color:var(--blue-light)}
.stat-dark .stat-lbl{color:rgba(255,255,255,.45)}
.stat-dark .stat-sep{background:rgba(255,255,255,.1)!important}

.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:48px;padding:64px 0;
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.stat-cell{display:flex;flex-direction:column;gap:8px}
.stat-num{font-family:'Bebas Neue';font-size:64px;line-height:.9;color:var(--ink);letter-spacing:0;font-weight:400}
body[data-lang="ar"] .stat-num{font-family:'Noto Kufi Arabic';font-weight:700;font-size:44px}
.stat-num .suf{color:var(--blue);margin-inline-start:2px}
.stat-lbl{font:500 13px/1.5 'Inter';color:var(--ink-soft);max-width:22ch}

/* Why — comparison layout */
.why-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.why-h2{font-family:'Bebas Neue';font-size:clamp(36px,4.6vw,68px);line-height:.96;margin:18px 0 0;color:var(--ink);font-weight:400;text-wrap:balance}
body[data-lang="ar"] .why-h2{font-family:'Noto Kufi Arabic';font-weight:700;font-size:clamp(26px,3.4vw,48px);line-height:1.18}
.why-h2 .em{color:var(--blue)}
.why-p{font:400 17px/1.65 'Inter';color:var(--ink-soft);margin:20px 0 0;max-width:46ch}
.why-bullets{list-style:none;padding:0;margin:32px 0 0;display:flex;flex-direction:column;gap:14px}
.why-bullets li{font:500 15px/1.5 'Inter';color:var(--ink);display:flex;gap:12px;align-items:flex-start}
.why-check{color:var(--blue);font-weight:700;flex-shrink:0;margin-top:1px}

/* Comparison table card */
.why-cmp{background:#fff;border-radius:20px;border:1px solid var(--rule);overflow:hidden;
  box-shadow:0 4px 32px rgba(22,36,58,.08);position:relative}

/* ── Scanner frame ── */
.cmp-frame{position:absolute;inset:0;pointer-events:none;z-index:6;border-radius:20px;overflow:hidden}
.cmp-corner{position:absolute;width:18px;height:18px;border-style:solid;border-color:var(--cmp-accent);opacity:.7;transition:opacity .3s,border-color .3s}
.cmp-corner.tl{top:10px;left:10px;border-width:2px 0 0 2px;border-radius:3px 0 0 0}
.cmp-corner.tr{top:10px;right:10px;border-width:2px 2px 0 0;border-radius:0 3px 0 0}
.cmp-corner.bl{bottom:10px;left:10px;border-width:0 0 2px 2px;border-radius:0 0 0 3px}
.cmp-corner.br{bottom:10px;right:10px;border-width:0 2px 2px 0;border-radius:0 0 3px 0}
.why-cmp:hover .cmp-corner{opacity:1}
.cmp-beam{
  position:absolute;left:0;right:0;height:2px;top:56px;
  background:linear-gradient(90deg,transparent 0%,var(--cmp-accent) 20%,rgba(255,255,255,.95) 50%,var(--cmp-accent) 80%,transparent 100%);
  box-shadow:0 0 22px 8px var(--cmp-accent);
  animation:cmpScan 1.5s cubic-bezier(.25,.46,.45,.94) both;
  opacity:.9;
}
@keyframes cmpScan{
  0%{top:56px;opacity:.9}
  70%{opacity:.9}
  100%{top:calc(100% - 56px);opacity:0}
}

/* ── Row reveal animation ── */
.cmp-row-anim{
  animation:cmpRowIn .55s cubic-bezier(.16,1,.3,1) both;
  opacity:0;
}
@keyframes cmpRowIn{
  from{opacity:0;transform:translateX(-8px)}
  to{opacity:1;transform:none}
}
.cmp-tabs{display:flex;gap:8px;padding:14px;background:#f4f7fa}
.cmp-tab{flex:1;padding:12px 16px;border-radius:10px;border:none;font:600 14px/1 'Inter';
  cursor:pointer;background:none;color:var(--ink-mute);transition:all .2s ease}
.cmp-tab.kawini-on{background:var(--blue);color:#fff;box-shadow:0 3px 14px rgba(46,123,183,.35)}
.cmp-tab.trad-on{background:#1a1a2e;color:#fff}
.cmp-head{display:grid;grid-template-columns:1.15fr 1fr;border-bottom:3px solid var(--blue);transition:border-color .2s}
.cmp-head span{padding:13px 18px;font:700 11px/1 'Inter';letter-spacing:.13em;text-transform:uppercase;color:var(--ink-mute)}
.cmp-head span:last-child{transition:color .2s}
.cmp-row{display:grid;grid-template-columns:1.15fr 1fr;border-bottom:1px solid var(--rule-soft)}
.cmp-row:nth-child(even){background:var(--blue-softer)}
.cmp-label{padding:14px 18px;font:400 13.5px/1.4 'Inter';color:var(--ink-soft)}
.cmp-val{padding:14px 18px;font:600 13.5px/1.4 'Inter';transition:color .2s}
.cmp-good{color:var(--blue-deep)}
.cmp-bad{color:#b91c1c}
.cmp-total{display:grid;grid-template-columns:1.15fr 1fr;background:var(--blue-softer);border-top:2px solid var(--rule)}
.cmp-total-label{padding:20px 18px;font:700 11px/1 'Inter';letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-mute);align-self:center}
.cmp-total-val{padding:20px 18px;font-family:'Bebas Neue';font-size:36px;font-weight:400;line-height:1;transition:color .2s}
body[data-lang="ar"] .cmp-total-val{font-family:'Noto Kufi Arabic';font-weight:700;font-size:26px;line-height:1.2}

/* Why cards (kept for compat) */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:64px}
.why-card{background:#fff;border:1px solid var(--rule);border-radius:20px;padding:36px 32px;display:flex;flex-direction:column;gap:14px}
.why-card.us{background:var(--blue);color:#fff;border-color:var(--blue)}
.why-card h4{font:600 19px/1.3 'Inter';margin:0;color:var(--ink)}
.why-card.us h4{color:#fff}
.why-card .lede{font:500 11px/1.2 'Inter';color:var(--ink-mute);letter-spacing:.14em;text-transform:uppercase}
.why-card ul{list-style:none;padding:0;margin:8px 0 0;display:flex;flex-direction:column;gap:12px}
.why-card li{display:flex;gap:12px;font:400 14.5px/1.5 'Inter';color:var(--ink-soft);align-items:baseline}
.why-card .mark{font-weight:700;font-size:12px;flex:0 0 14px;color:var(--ink-mute)}

/* Results */
.results-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:64px}
.res{background:#fff;border:1px solid var(--rule);border-radius:20px;padding:32px;display:flex;flex-direction:column;gap:16px;
  transition:transform .25s ease, box-shadow .25s ease}
.res:hover{transform:translateY(-3px);box-shadow:0 16px 40px -16px rgba(22,36,58,.12)}
.res .pill{align-self:flex-start;background:var(--blue-soft);color:var(--blue-deep);font:600 11px/1 'Inter';
  letter-spacing:.14em;text-transform:uppercase;padding:8px 12px;border-radius:999px}
.res .big{font-family:'Bebas Neue';font-size:38px;line-height:1;color:var(--ink);font-weight:400}
body[data-lang="ar"] .res .big{font-family:'Noto Kufi Arabic';font-weight:700;font-size:26px;line-height:1.2}
.res .det{font:500 14px/1.55 'Inter';color:var(--ink-soft)}

/* CTA Band */
.cta-band{padding-block:120px;background:var(--blue-soft);position:relative;overflow:hidden}
.cta-band .wrap{display:grid;grid-template-columns:1.5fr 1fr;gap:48px;align-items:center;position:relative;z-index:2}
.cta-band h2{font-family:'Bebas Neue';font-size:clamp(44px,5.4vw,80px);line-height:.96;margin:18px 0 0;color:var(--ink);font-weight:400;text-wrap:balance}
body[data-lang="ar"] .cta-band h2{font-family:'Noto Kufi Arabic';font-weight:700;font-size:clamp(28px,3.6vw,48px);line-height:1.18}
.cta-band p{font:400 17px/1.65 'Inter';color:var(--ink-soft);margin:20px 0 0;max-width:46ch}
.cta-band-top{grid-template-columns:1fr!important}
.cta-band-btn{display:inline-flex;margin-top:28px}
.cta-direct-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:36px;padding-top:36px;
  border-top:1px solid rgba(0,0,0,.07);position:relative;z-index:2;grid-column:1/-1}
.cta-ch{display:flex;align-items:center;gap:14px;padding:16px 18px;background:#fff;border-radius:14px;
  border:1px solid var(--rule);color:var(--ink);text-decoration:none;transition:border-color .2s,transform .2s,box-shadow .2s}
.cta-ch:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:0 6px 20px rgba(46,123,183,.1)}
.cta-ch-icon{color:var(--blue);width:38px;height:38px;display:grid;place-items:center;
  background:var(--blue-soft);border-radius:10px;flex-shrink:0}
.cta-ch-body{display:flex;flex-direction:column;gap:3px;flex:1}
.cta-ch-label{font:600 10px/1 'Inter';letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}
.cta-ch-val{font:600 14px/1.3 'Inter';color:var(--ink)}
.cta-ch-arrow{color:var(--blue);font-size:16px;flex-shrink:0}
body[data-lang="ar"] .cta-ch-arrow{transform:scaleX(-1)}
.cta-band-shape{position:absolute;right:-160px;top:-100px;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(46,123,183,.18), transparent 60%);pointer-events:none}

/* Footer */
footer{background:#fff;color:var(--ink);padding:88px 0 0;border-top:1px solid var(--rule)}
.ft-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:56px}
.ft-col h5{font:600 11px/1 'Inter';letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);margin:0 0 22px}
.ft-col a, .ft-col li{display:block;font:500 14px/1.8 'Inter';color:var(--ink-soft);text-decoration:none;list-style:none}
.ft-col a:hover{color:var(--blue-deep)}
.ft-col p{font:400 14px/1.65 'Inter';color:var(--ink-soft);margin:0 0 14px;max-width:38ch}
.ft-bottom{margin-top:88px;padding:24px 0;border-top:1px solid var(--rule);
  display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
  font:500 12px/1 'Inter';color:var(--ink-mute);letter-spacing:.04em}
.ft-logo{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.ft-logo img{height:56px;width:auto}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease, transform .8s ease}
.reveal.is-in{opacity:1;transform:none}

/* ─────────── Flow visual — interactive ─────────── */
/* Per-step animated scenes */
.scene{position:relative;width:100%;aspect-ratio:16/7;background:#fff;border:1px solid var(--rule);border-radius:24px;overflow:hidden}
.scene-inner{position:absolute;inset:0;opacity:0;will-change:opacity,transform;
  transition:opacity .4s cubic-bezier(.16,1,.3,1),transform .5s cubic-bezier(.16,1,.3,1);
  transform:translateY(8px);pointer-events:none}
.scene-inner.is-on{opacity:1;transform:none;pointer-events:auto}
.scene-grid{position:absolute;inset:0;
  background-image:radial-gradient(circle, rgba(46,123,183,.12) 1px, transparent 1.2px);
  background-size:24px 24px;
  mask-image:radial-gradient(ellipse 80% 70% at 50% 60%, black 30%, transparent 80%)}

/* drag affordance */
.flow-pkg{cursor:grab;will-change:left;touch-action:none}
.flow-pkg:active{cursor:grabbing}
.flow-pkg-hint{position:absolute;top:-24px;left:50%;transform:translateX(-50%);
  font:600 9px/1 'Inter';letter-spacing:.16em;text-transform:uppercase;color:var(--blue-deep);
  background:#fff;border:1px solid var(--rule);padding:5px 8px;border-radius:999px;white-space:nowrap;
  opacity:0;transition:opacity .25s ease;pointer-events:none}
.flow-pkg:hover .flow-pkg-hint, .flow-stage.is-dragging .flow-pkg-hint{opacity:1}

/* Station hover tooltip */
.flow-station .tip{position:absolute;top:-44px;left:50%;transform:translateX(-50%) translateY(4px);
  background:var(--ink);color:#fff;font:600 10px/1 'Inter';letter-spacing:.14em;text-transform:uppercase;
  padding:8px 12px;border-radius:8px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease, transform .2s ease;z-index:8}
.flow-station .tip::after{content:"";position:absolute;left:50%;bottom:-4px;transform:translateX(-50%) rotate(45deg);
  width:8px;height:8px;background:var(--ink)}
.flow-station:hover .tip{opacity:1;transform:translateX(-50%) translateY(0)}

/* Scenes — animated parts */
@keyframes typeIn { from{width:0} to{width:100%} }
@keyframes fadeUp { 0%{opacity:0;transform:translateY(12px)} 100%{opacity:1;transform:none} }
@keyframes drift  { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }
@keyframes scanX  { 0%{transform:translateX(-50px)} 100%{transform:translateX(110px)} }
@keyframes shipGo { 0%{transform:translateX(-160px)} 100%{transform:translateX(160px)} }
@keyframes truckIn{ 0%{transform:translateX(-200px)} 80%{transform:translateX(0)} 100%{transform:translateX(0)} }
@keyframes pop    { 0%{transform:scale(.6);opacity:0} 60%{transform:scale(1.12);opacity:1} 100%{transform:scale(1);opacity:1} }
@keyframes glow   { 0%,100%{opacity:.35} 50%{opacity:.85} }
@keyframes blink  { 0%,40%,60%,100%{opacity:.2} 50%{opacity:1} }
@keyframes spin   { from{transform:rotate(0)} to{transform:rotate(360deg)} }
@keyframes wave   { 0%,100%{transform:translateX(0)} 50%{transform:translateX(-12px)} }
@keyframes lift   { 0%{transform:translateY(0)} 50%{transform:translateY(-3px)} 100%{transform:translateY(0)} }
@keyframes dash   { from{stroke-dashoffset:0} to{stroke-dashoffset:-32} }
@keyframes flash  { 0%,100%{filter:drop-shadow(0 0 0 rgba(46,123,183,0))} 50%{filter:drop-shadow(0 0 12px rgba(46,123,183,.7))} }
@keyframes shake  { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-1px)} 75%{transform:translateX(1px)} }

/* Scene-specific helpers */
.s-chat .bubble{background:#fff;border:1.5px solid var(--rule);border-radius:14px 14px 14px 2px;padding:12px 14px;
  font:500 13px/1.4 'Inter';color:var(--ink);box-shadow:0 6px 16px -10px rgba(46,123,183,.4);
  animation:fadeUp .55s ease both}
.s-chat .bubble.them{background:var(--blue);color:#fff;border-color:var(--blue);border-radius:14px 14px 2px 14px;align-self:flex-end}
.s-chat .typing{display:inline-flex;gap:3px}
.s-chat .typing span{width:5px;height:5px;background:var(--blue);border-radius:50%;animation:blink 1.2s infinite}
.s-chat .typing span:nth-child(2){animation-delay:.2s}
.s-chat .typing span:nth-child(3){animation-delay:.4s}

.s-source .fcard{background:#fff;border:1.5px solid var(--rule);border-radius:12px;padding:14px 12px;display:flex;flex-direction:column;gap:6px;
  position:relative;transition:all .25s ease}
.s-source .fcard .row{display:flex;justify-content:space-between;font:500 10px/1 'Inter';color:var(--ink-mute);letter-spacing:.08em;text-transform:uppercase}
.s-source .fcard .name{font:600 12.5px/1.2 'Inter';color:var(--ink)}
.s-source .fcard .bar{height:4px;background:var(--rule-soft);border-radius:2px;overflow:hidden}
.s-source .fcard .bar i{display:block;height:100%;background:var(--blue);border-radius:2px;width:0;transition:width 1s ease}
.s-source .fcard.x{opacity:.55}
.s-source .fcard.x::after{content:"\D7";position:absolute;top:8px;right:10px;color:var(--red);font-weight:700;font-size:14px;
  animation:pop .35s ease both}
.s-source .fcard.ok{border-color:var(--blue);box-shadow:0 8px 24px -10px rgba(46,123,183,.4);transform:translateY(-3px)}
.s-source .fcard.ok::after{content:"\2713";position:absolute;top:8px;right:10px;color:var(--blue);font-weight:700;font-size:14px;animation:pop .4s ease both}

.s-qc .product{width:140px;height:140px;background:var(--blue-softer);border:1.5px solid var(--rule);border-radius:14px;
  display:grid;place-items:center;position:relative;overflow:hidden}
.s-qc .scan{position:absolute;top:0;bottom:0;width:2px;background:var(--blue);box-shadow:0 0 16px rgba(46,123,183,.6);
  animation:scanX 1.6s ease-in-out infinite alternate;left:0}
.s-qc .lens{width:54px;height:54px;border-radius:50%;border:2.5px solid var(--blue);position:relative;background:rgba(255,255,255,.4)}
.s-qc .lens::after{content:"";position:absolute;right:-12px;bottom:-12px;width:18px;height:3px;background:var(--blue);transform:rotate(45deg);border-radius:2px}
.s-qc .badge{background:#fff;border:1.5px solid var(--blue);border-radius:14px;padding:14px 16px;
  display:flex;flex-direction:column;gap:4px;animation:fadeUp .55s ease both}
.s-qc .badge .num{font:400 36px/.85 'Bebas Neue';color:var(--blue)}
.s-qc .badge .lbl{font:600 10px/1 'Inter';letter-spacing:.12em;color:var(--ink-mute);text-transform:uppercase}

.s-ship .water{position:absolute;left:0;right:0;bottom:0;height:64px;background:repeating-linear-gradient(90deg, transparent, transparent 12px, rgba(46,123,183,.15) 12px, rgba(46,123,183,.15) 14px);
  animation:wave 2.4s ease-in-out infinite}
.s-ship .ship{position:absolute;bottom:36px;left:50%;transform-origin:center;animation:shipGo 6s ease-in-out infinite alternate}
.s-ship .cloud{position:absolute;animation:drift 3.4s ease-in-out infinite}
.s-ship .cloud.a{top:30px;left:20%;animation-delay:0s}
.s-ship .cloud.b{top:50px;left:60%;animation-delay:.8s}
.s-ship .cloud.c{top:18px;left:78%;animation-delay:1.6s}
.s-ship .route{stroke:var(--blue);stroke-width:1.6;stroke-dasharray:8 6;fill:none;animation:dash 1.8s linear infinite}

.s-deliver .house{position:absolute;right:14%;bottom:60px}
.s-deliver .door{fill:var(--blue)}
.s-deliver .truck{position:absolute;bottom:64px;left:0;animation:truckIn 1.6s cubic-bezier(.16,.84,.4,1) both;animation-delay:.1s}
.s-deliver .pkg{position:absolute;right:30%;bottom:56px;animation:pop .5s ease both;animation-delay:1.6s;transform-origin:center;opacity:0}
.s-deliver .pkg.shown{opacity:1}
.s-deliver .ring{position:absolute;right:18%;bottom:96px;width:36px;height:36px;border:2px solid var(--blue);border-radius:50%;
  animation:pop .4s ease both, glow 1.8s ease-in-out infinite;animation-delay:2.2s, 2.2s;opacity:0}
.s-deliver .ring.shown{opacity:1}
.s-deliver .road{position:absolute;left:0;right:0;bottom:50px;height:2px;background:repeating-linear-gradient(90deg, var(--rule) 0 10px, transparent 10px 20px)}

/* Scene title + body row beneath */
.flow-scene-wrap{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;align-items:stretch;margin-top:12px}
.flow-scene-meta{display:flex;flex-direction:column;gap:16px;padding:24px 28px;background:#fff;border:1px solid var(--rule);border-radius:20px}
.flow-scene-meta .num{font:400 56px/.9 'Bebas Neue';color:var(--blue);letter-spacing:0}
.flow-scene-meta h3{font:600 20px/1.25 'Inter';margin:0;color:var(--ink)}
.flow-scene-meta p{font:400 14px/1.6 'Inter';color:var(--ink-soft);margin:0}
.flow-scene-meta .ctrls{display:flex;gap:6px;align-items:center;margin-top:auto;padding-top:14px;border-top:1px solid var(--rule)}
.flow-scene-meta .ctrls button{display:inline-grid;place-items:center;width:36px;height:36px;border-radius:50%;
  background:#fff;border:1.5px solid var(--rule);color:var(--ink-soft);transition:all .15s ease}
.flow-scene-meta .ctrls button:hover{border-color:var(--blue);color:var(--blue-deep)}
.flow-scene-meta .ctrls .play{background:var(--blue);color:#fff;border-color:var(--blue);width:auto;padding:0 16px;border-radius:999px;font:600 10px/1 'Inter';letter-spacing:.14em;text-transform:uppercase;height:36px}
.flow-scene-meta .ctrls .play:hover{background:var(--blue-deep);color:#fff;border-color:var(--blue-deep)}
.flow-scene-meta .speed{margin-inline-start:auto;font:600 10px/1 'Inter';letter-spacing:.14em;color:var(--ink-mute);display:flex;gap:3px;text-transform:uppercase;align-items:center}
.flow-scene-meta .speed button{font:600 10px/1 'Inter';padding:6px 9px;background:#fff;border:1px solid var(--rule);border-radius:8px;color:var(--ink-mute);width:auto;height:auto}
.flow-scene-meta .speed button.on{background:var(--ink);color:#fff;border-color:var(--ink)}

@media (max-width:1000px){
  .flow-scene-wrap{grid-template-columns:1fr;gap:14px}
  .scene{aspect-ratio:16/9}
  .flow-scene-meta{padding:20px 22px}
  .flow-scene-meta .num{font-size:48px}
}

/* ─────────── Flow visual ─────────── */
.flow-outer{background:var(--bg);position:relative}
.flow-sticky{
  position:relative;display:flex;align-items:center;padding-block:64px;
  opacity:0;transform:translateY(44px);
  transition:opacity .85s cubic-bezier(.16,1,.3,1), transform .85s cubic-bezier(.16,1,.3,1);
}
.flow-sticky.is-entered{opacity:1;transform:none}
.flow-sticky>.wrap{width:100%}
.flow-sticky .sec-head{margin-bottom:0}
.flow-sticky .sec-head p{display:none}
.flow-scroll-hint{display:none}
.flow-personas{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
.flow-persona{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:999px;
  border:1.5px solid var(--rule);background:#fff;cursor:pointer;color:var(--ink-soft);
  font:600 12px/1 'Inter';transition:all .2s ease}
.flow-persona:hover{border-color:var(--blue)}
.flow-persona.active{background:var(--blue);border-color:var(--blue);color:#fff;
  box-shadow:0 6px 20px -10px rgba(46,123,183,.55)}
.flow-persona .ic{display:inline-grid;place-items:center;width:18px;height:18px}

/* ── Step indicator — clean pill strip ── */
.flow-crumbs{display:flex;align-items:center;gap:0;margin-top:14px;height:36px;
  background:var(--blue-softer);border:1px solid var(--rule);border-radius:999px;padding:4px;width:fit-content}
.flow-crumb{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border:none;cursor:pointer;
  background:transparent;color:var(--ink-mute);font-family:'Inter',sans-serif;
  transition:background .25s,color .25s;border-radius:999px;white-space:nowrap}
.flow-crumb.is-past{color:var(--blue-deep)}
.flow-crumb.is-active{background:#fff;color:var(--ink);box-shadow:0 1px 4px rgba(22,36,58,.1)}
.flow-crumb-num{font:700 10px/1 'Inter';letter-spacing:.1em;color:var(--blue);opacity:.7}
.flow-crumb.is-active .flow-crumb-num{opacity:1}
.flow-crumb-lbl{font:600 11px/1 'Inter';text-transform:uppercase;letter-spacing:.07em}
@media(max-width:640px){
  .flow-crumbs{overflow-x:auto;width:100%;max-width:100%}
  .flow-crumb-num{display:none}
  .flow-crumb-lbl{font-size:10px}
  .flow-crumb{padding:6px 10px}
}

.flow-stage{position:relative;margin-top:72px;padding:80px 32px 56px;
  background:linear-gradient(180deg, var(--blue-softer) 0%, #fff 100%);
  border:1px solid var(--rule);border-radius:24px;overflow:hidden}
.flow-stage::before{content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle, rgba(46,123,183,.14) 1px, transparent 1.2px);
  background-size:28px 28px;
  mask-image:linear-gradient(180deg, black, transparent 60%);
  -webkit-mask-image:linear-gradient(180deg, black, transparent 60%);
  pointer-events:none}
.flow-track{position:relative;height:220px}
.flow-stations{position:absolute;inset:0;display:flex;justify-content:space-between;align-items:center}
.flow-station{position:relative;display:flex;flex-direction:column;align-items:center;gap:14px;cursor:pointer;flex:1;min-width:0;background:transparent;border:0;padding:0}
.flow-node{width:72px;height:72px;border-radius:50%;background:#fff;border:1.5px solid var(--rule);
  display:grid;place-items:center;color:var(--ink-soft);transition:all .35s ease;position:relative;z-index:3}
.flow-station.is-passed .flow-node{background:var(--blue);border-color:var(--blue);color:#fff}
.flow-station.is-active .flow-node{background:#fff;border-color:var(--blue);color:var(--blue);transform:scale(1.18);
  box-shadow:0 0 0 8px rgba(46,123,183,.16), 0 14px 32px -10px rgba(46,123,183,.45)}
.flow-station .lbl{font:600 11px/1.2 'Inter';letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);text-align:center;
  transition:color .25s ease;max-width:13ch}
.flow-station.is-active .lbl, .flow-station.is-passed .lbl{color:var(--ink)}
.flow-rail{position:absolute;top:36px;inset-inline:64px;height:2px;background:var(--rule);border-radius:2px;z-index:1}
.flow-rail-fill{position:absolute;inset:0;background:var(--blue);transform-origin:left center;
  transform:scaleX(var(--p,0));transition:transform .9s cubic-bezier(.6,.05,.2,1)}
body[data-lang="ar"] .flow-rail-fill{transform-origin:right center}
.flow-pkg{position:absolute;top:6px;width:60px;height:60px;
  transition:left .9s cubic-bezier(.6,.05,.2,1);z-index:4;pointer-events:none}
body[data-lang="ar"] .flow-pkg{transition:right .9s cubic-bezier(.6,.05,.2,1)}

.flow-info{margin-top:56px;display:grid;grid-template-columns:auto 1fr auto;gap:32px;align-items:end}
.flow-info .num{font-family:'Bebas Neue';font-size:112px;line-height:.85;color:var(--blue);font-weight:400;letter-spacing:0}
.flow-info .body h3{font:600 26px/1.25 'Inter';margin:0 0 8px;color:var(--ink)}
body[data-lang="ar"] .flow-info .body h3{font-size:23px}
.flow-info .body p{font:400 16px/1.6 'Inter';color:var(--ink-soft);margin:0;max-width:58ch}
.flow-info .ctrls{display:flex;gap:8px;align-items:center;color:var(--ink-mute);font:500 12px/1 'Inter';letter-spacing:.08em;text-transform:uppercase}
.flow-info .ctrls button{display:inline-grid;place-items:center;width:40px;height:40px;border-radius:50%;
  background:#fff;border:1.5px solid var(--rule);color:var(--ink-soft)}
.flow-info .ctrls button:hover{border-color:var(--blue);color:var(--blue-deep)}

.flow-progress{display:flex;align-items:center;gap:16px;margin-top:14px;font:500 11px/1.2 'Inter';color:var(--ink-mute);letter-spacing:.1em;text-transform:uppercase}
.flow-prog-track{flex:1;height:2px;background:var(--rule);border-radius:99px;overflow:hidden}
.flow-prog-fill{height:100%;background:var(--blue);border-radius:99px;transition:width .7s cubic-bezier(.6,.05,.2,1)}

/* ───── Service cards (Services page) ───── */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:64px}
.svc{background:#fff;border:1px solid var(--rule);border-radius:24px;padding:40px 36px;display:flex;flex-direction:column;gap:18px;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease}
.svc:hover{transform:translateY(-3px);box-shadow:0 20px 50px -20px rgba(46,123,183,.25);border-color:var(--blue)}
.svc .num{font:700 11px/1 'Inter';letter-spacing:.18em;color:var(--blue);text-transform:uppercase}
.svc .ic{color:var(--blue);width:48px;height:48px;display:grid;place-items:center;background:var(--blue-soft);border-radius:14px}
.svc h3{font-family:'Bebas Neue';font-size:36px;line-height:1;color:var(--ink);font-weight:400;margin:0}
body[data-lang="ar"] .svc h3{font-family:'Noto Kufi Arabic';font-weight:700;font-size:26px;line-height:1.2}
.svc p{font:400 15px/1.6 'Inter';color:var(--ink-soft);margin:0}
.svc ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.svc li{display:flex;gap:10px;font:400 14px/1.5 'Inter';color:var(--ink-soft)}
.svc li::before{content:"";flex:0 0 6px;height:6px;border-radius:50%;background:var(--blue);margin-top:8px}
.svc .meta{font:600 11px/1.4 'Inter';color:var(--ink-mute);letter-spacing:.12em;text-transform:uppercase;
  border-top:1px solid var(--rule);padding-top:14px;margin-top:auto}

/* Industries strip */
.industries{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule);border-radius:24px;overflow:hidden;margin-top:48px}
.indu{background:#fff;padding:32px 24px;display:flex;flex-direction:column;align-items:flex-start;gap:14px;color:var(--ink);
  font:500 14px/1.4 'Inter';transition:background .2s ease}
.indu:hover{background:var(--blue-softer)}
.indu .ic{color:var(--blue);width:40px;height:40px;display:grid;place-items:center;background:var(--blue-soft);border-radius:12px}
.indu small{font:600 10px/1 'Inter';letter-spacing:.14em;color:var(--ink-mute);text-transform:uppercase}

/* Industry Cards (redesigned) */
.indu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:48px}
.indu-card{background:var(--ink);color:#fff;border-radius:16px;padding:40px;position:relative;overflow:hidden;display:flex;flex-direction:column}
.indu-card::before{content:attr(data-num);position:absolute;inset-block-start:-18px;inset-inline-end:20px;
  font-family:'Bebas Neue';font-size:130px;line-height:1;color:rgba(255,255,255,.04);pointer-events:none;user-select:none}
.indu-card .ic{background:rgba(255,255,255,.1);color:var(--blue-light);width:48px;height:48px;
  border-radius:14px;display:grid;place-items:center;flex-shrink:0}
.indu-card h3{font-family:'Bebas Neue';font-size:1.75rem;font-weight:400;letter-spacing:.03em;color:#fff;margin:20px 0 10px;line-height:1.05}
body[data-lang="ar"] .indu-card h3{font-family:'Noto Kufi Arabic';font-weight:700;font-size:1.3rem;letter-spacing:0;line-height:1.3}
.indu-card > p{font:400 14px/1.7 'Inter';color:rgba(255,255,255,.55);margin:0 0 20px}
.indu-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px;margin-top:auto}
.indu-card li{font:500 13px/1.4 'Inter';color:rgba(255,255,255,.8);padding-inline-start:18px;position:relative}
.indu-card li::before{content:"→";position:absolute;inset-inline-start:0;color:var(--blue-light);font-style:normal}
body[data-lang="ar"] .indu-card li::before{content:"←"}
.indu-cta{margin-top:20px;background:var(--blue-soft);border-radius:16px;padding:36px 40px;
  display:flex;align-items:center;justify-content:space-between;gap:32px}
.indu-cta h3{font-family:'Bebas Neue';font-size:1.625rem;font-weight:400;color:var(--ink);margin:0 0 8px;line-height:1.05}
body[data-lang="ar"] .indu-cta h3{font-family:'Noto Kufi Arabic';font-weight:700;font-size:1.25rem;letter-spacing:0;line-height:1.3}
.indu-cta p{font:400 15px/1.6 'Inter';color:var(--ink-soft);margin:0;max-width:52ch}

/* About / Values */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;margin-top:64px}
.value h4{font-family:'Bebas Neue';font-size:28px;font-weight:400;line-height:1;margin:18px 0 10px;color:var(--ink)}
body[data-lang="ar"] .value h4{font-family:'Noto Kufi Arabic';font-weight:700;font-size:22px;line-height:1.2}
.value p{font:400 14.5px/1.6 'Inter';color:var(--ink-soft);margin:0}
.value .ic{color:var(--blue);width:48px;height:48px;display:grid;place-items:center;background:var(--blue-soft);border-radius:14px}

.story{display:grid;grid-template-columns:.95fr 1.05fr;gap:80px;align-items:center}
.story-text p{font:400 17px/1.75 'Inter';color:var(--ink-soft);margin:0 0 20px;max-width:60ch}
.story-text p strong{color:var(--ink);font-weight:600}
.story-card{background:linear-gradient(180deg, var(--blue-softer), #fff);border:1px solid var(--rule);border-radius:24px;padding:48px;display:flex;flex-direction:column;gap:20px}
.story-card .pill{align-self:flex-start;background:var(--blue);color:#fff;font:600 11px/1 'Inter';letter-spacing:.14em;text-transform:uppercase;padding:8px 12px;border-radius:999px}
.story-card .num{font-family:'Bebas Neue';font-size:96px;line-height:.85;color:var(--blue);font-weight:400}
.story-card p{font:500 14px/1.5 'Inter';color:var(--ink);margin:0}
.story-card hr{border:0;border-top:1px solid var(--rule);margin:8px 0}
.story-card .small{font:500 12px/1.4 'Inter';color:var(--ink-mute);letter-spacing:.04em;text-transform:uppercase}

/* Timeline */
.timeline{margin-top:64px;background:#fff;border:1px solid var(--rule);border-radius:24px;padding:48px}
.tl-row{display:grid;grid-template-columns:repeat(8,1fr);gap:8px;position:relative}
.tl-step{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;position:relative;padding-top:20px}
.tl-step::before{content:"";position:absolute;top:8px;left:50%;width:10px;height:10px;border-radius:50%;background:var(--blue);transform:translateX(-50%);z-index:2}
.tl-rail{position:absolute;top:13px;left:24px;right:24px;height:2px;background:var(--rule);z-index:1}
.tl-step .name{font:600 12px/1.3 'Inter';color:var(--ink);max-width:14ch}
.tl-step .when{font:600 10px/1 'Inter';letter-spacing:.1em;color:var(--ink-mute);text-transform:uppercase}

/* Contact form */
.form-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;margin-top:48px;align-items:flex-start}
.form{background:#fff;border:1px solid var(--rule);border-radius:24px;padding:40px;display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form .full{grid-column:1/-1}
.form label{display:flex;flex-direction:column;gap:8px;font:600 11px/1 'Inter';letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}
.form input, .form select, .form textarea{font:400 15px/1.4 'Inter';color:var(--ink);background:var(--blue-softer);
  border:1.5px solid var(--rule);border-radius:12px;padding:14px 16px;outline:none;transition:border-color .15s ease, background .15s ease}
.form input:focus, .form select:focus, .form textarea:focus{border-color:var(--blue);background:#fff}
.form textarea{min-height:120px;resize:vertical}
.form .check-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px}
.form .chip{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border:1.5px solid var(--rule);border-radius:999px;
  background:var(--blue-softer);font:500 13px/1 'Inter';color:var(--ink-soft);cursor:pointer;transition:all .2s ease;text-transform:none;letter-spacing:0}
.form .chip:hover{border-color:var(--blue)}
.form .chip.on{background:var(--blue);color:#fff;border-color:var(--blue)}
.form .submit-row{grid-column:1/-1;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.form .note{font:500 12px/1.4 'Inter';color:var(--ink-mute)}

.contact-side h3{font-family:'Bebas Neue';font-size:32px;font-weight:400;margin:0 0 14px;color:var(--ink)}
body[data-lang="ar"] .contact-side h3{font-family:'Noto Kufi Arabic';font-weight:700;font-size:24px;line-height:1.2}
.contact-side .channels{display:flex;flex-direction:column;gap:8px;margin-top:24px}
.contact-side .ch{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;
  background:#fff;border:1px solid var(--rule);border-radius:16px;transition:all .2s ease;color:var(--ink)}
.contact-side .ch:hover{border-color:var(--blue);transform:translateY(-1px)}
.contact-side .ch .label{font:600 13px/1 'Inter';color:var(--ink)}
.contact-side .ch .val{font:500 13px/1 'Inter';color:var(--ink-soft)}
.contact-side .faq{margin-top:48px;display:flex;flex-direction:column;gap:8px}
.contact-side .faq details{background:#fff;border:1px solid var(--rule);border-radius:14px;padding:0;overflow:hidden}
.contact-side .faq summary{font:600 14px/1.4 'Inter';color:var(--ink);padding:18px 22px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.contact-side .faq summary::after{content:"+";color:var(--blue);font-weight:400;font-size:22px;transition:transform .2s ease}
.contact-side .faq details[open] summary::after{transform:rotate(45deg)}
.contact-side .faq details > div{padding:0 22px 18px;font:400 14px/1.55 'Inter';color:var(--ink-soft);border-top:1px solid var(--rule)}

/* ───── Responsive ───── */
@media (max-width:1000px){
  .hero-grid{grid-template-columns:1fr;gap:56px}
  .stat-row{grid-template-columns:repeat(2,1fr);gap:32px}
  .why-grid,.results-row,.svc-grid,.values{grid-template-columns:1fr;gap:18px}
  .industries{grid-template-columns:repeat(2,1fr)}
  .indu-grid{grid-template-columns:1fr}
  .indu-cta{flex-direction:column;align-items:flex-start}
  .ft-grid{grid-template-columns:1fr 1fr;gap:32px}
  .nav-links{display:none}
  .cta-band .wrap{grid-template-columns:1fr}
  .cta-band-ctas{justify-self:start}
  .cta-direct-row{grid-template-columns:1fr}
  .flow-info{grid-template-columns:1fr;gap:18px}
  .flow-info .num{font-size:72px}
  .flow-station .lbl{font-size:9px}
  .flow-node{width:54px;height:54px}
  .flow-rail{inset-inline:32px;top:27px}
  .flow-pkg{width:42px;height:42px;top:6px}
  .story{grid-template-columns:1fr;gap:48px}
  .tl-row{grid-template-columns:repeat(4,1fr);row-gap:32px}
  .form-grid{grid-template-columns:1fr;gap:32px}
  .form{grid-template-columns:1fr;padding:28px}
  section{padding-block:88px}
}
@media (max-width:560px){
  .stat-row{grid-template-columns:1fr;gap:24px;padding:40px 0}
  .ft-grid{grid-template-columns:1fr}
  .hero{padding-top:140px;padding-bottom:80px}
  section{padding-block:64px}
  .flow-station .lbl{display:none}
  .flow-info .num{font-size:56px}
  .tl-row{grid-template-columns:repeat(2,1fr)}
  .nav-row{height:68px}
  .nav-logo img{height:36px}
}

/* ── Mobile hamburger button ────────────────────── */
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;
  width:40px;height:40px;padding:9px;background:none;border:none;cursor:pointer;border-radius:8px;flex-shrink:0}
.nav-burger span{display:block;width:100%;height:2px;background:var(--ink);border-radius:2px}
.nav-burger:hover span{background:var(--blue)}

/* ── Mobile nav overlay + drawer ───────────────── */
.nav-overlay{position:fixed;inset:0;background:rgba(22,36,58,.5);z-index:998;
  -webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:nav-fade .2s ease}
@keyframes nav-fade{from{opacity:0}to{opacity:1}}
.nav-drawer{position:absolute;inset-block:0;inset-inline-end:0;width:min(300px,84vw);
  background:#fff;padding:20px 28px 40px;display:flex;flex-direction:column;
  box-shadow:-12px 0 48px rgba(22,36,58,.18);animation:nav-slide .25s ease}
body[data-lang="ar"] .nav-drawer{inset-inline-end:auto;inset-inline-start:0;
  box-shadow:12px 0 48px rgba(22,36,58,.18);animation:nav-slide-rtl .25s ease}
@keyframes nav-slide{from{transform:translateX(100%)}to{transform:translateX(0)}}
@keyframes nav-slide-rtl{from{transform:translateX(-100%)}to{transform:translateX(0)}}
.nav-drawer-close{align-self:flex-end;background:none;border:none;font-size:18px;
  color:var(--ink-mute);cursor:pointer;padding:4px 8px;margin-bottom:16px;border-radius:6px;line-height:1}
.nav-drawer-close:hover{color:var(--ink);background:var(--blue-softer)}
.nav-drawer-links{display:flex;flex-direction:column;border-top:1px solid var(--rule);margin-bottom:28px}
.nav-drawer-links a{font:600 17px/1 'Inter';color:var(--ink);text-decoration:none;
  padding:18px 0;border-bottom:1px solid var(--rule);transition:color .15s ease}
.nav-drawer-links a.is-current{color:var(--blue)}
.nav-drawer-links a:hover{color:var(--blue)}
body[data-lang="ar"] .nav-drawer-links a{font-family:'Noto Kufi Arabic'}
.nav-drawer-cta{justify-content:center;text-align:center;margin-top:auto}
.nav-drawer-langs{display:flex;gap:8px;margin-top:20px}
.nav-drawer-langs button{flex:1;font:600 11px/1 'Inter';letter-spacing:.14em;padding:10px 0;
  border-radius:999px;border:1.5px solid var(--rule);background:none;color:var(--ink-mute);cursor:pointer;transition:all .15s}
.nav-drawer-langs button.active{background:var(--blue);color:#fff;border-color:var(--blue)}

@media(max-width:1000px){
  .nav-desk-cta{display:none}
  .nav-burger{display:flex}
}

/* ── Industry List (editorial rows) ────────────── */
.indu-list{border-top:1px solid var(--rule);margin-top:56px}
.indu-row{display:grid;grid-template-columns:72px 1fr 1fr;gap:32px 48px;
  padding:40px 0;border-bottom:1px solid var(--rule);align-items:start}
.indu-row-num{font-family:'Bebas Neue';font-size:72px;color:var(--blue);line-height:1;font-weight:400}
body[data-lang="ar"] .indu-row-num{font-family:'Noto Kufi Arabic';font-size:48px;font-weight:700;line-height:1.1}
.indu-row-main .ic{width:44px;height:44px;background:var(--blue-soft);color:var(--blue);
  border-radius:12px;display:grid;place-items:center;margin-bottom:16px}
.indu-row-main h3{font-family:'Bebas Neue';font-size:26px;color:var(--ink);margin:0 0 10px;
  font-weight:400;line-height:1.05;letter-spacing:.02em}
body[data-lang="ar"] .indu-row-main h3{font-family:'Noto Kufi Arabic';font-weight:700;font-size:20px;letter-spacing:0;line-height:1.3}
.indu-row-main p{font:400 14px/1.65 'Inter';color:var(--ink-soft);margin:0}
.indu-row-items{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;padding-top:64px}
.indu-row-items li{font:500 13.5px/1.45 'Inter';color:var(--ink);padding-inline-start:20px;position:relative}
.indu-row-items li::before{content:"–";position:absolute;inset-inline-start:0;color:var(--blue)}

@media(max-width:900px){
  .indu-row{grid-template-columns:56px 1fr;grid-template-areas:"num main" ". items";gap:14px 24px}
  .indu-row-num{grid-area:num;font-size:48px}
  .indu-row-main{grid-area:main}
  .indu-row-items{grid-area:items;padding-top:0;margin-top:4px}
  .why-layout{grid-template-columns:1fr;gap:48px}
}
@media(max-width:480px){
  .indu-row{grid-template-columns:44px 1fr}
  .indu-row-num{font-size:38px}
  .cmp-label,.cmp-val{padding:12px 14px;font-size:13px}
  .cmp-head span{padding:11px 14px;font-size:10px}
  .cmp-total-label,.cmp-total-val{padding:16px 14px}
  .cmp-total-val{font-size:28px}
}
