/* ============================================================
   FUTURE TOUCH ELECTRONICS — "Aurora Touch"
   A luminous light interface: porcelain-lavender ground, soft
   aurora glows, glassmorphic cards, purple→gold gradients, and a
   fingertip-ripple motif echoing the "touch" in the name.
   Deliberately unlike a dark circuit board or a flat paper ledger.
   ============================================================ */
:root{
  --plum-ink:#2A0E38;  --plum:#3C1848;     --plum-2:#4A1E5C;
  --purple:#6E2C82;    --purple-2:#8A3FA0; --violet:#A45FC4;
  --gold:#C0A24E;      --gold-2:#E3C178;   --gold-deep:#A87E2C;  --gold-bright:#F2DDA0;  --bronze:#905430;
  --ink:#2A1733;       --muted:#6E5C79;    --muted-2:#9A8AA4;
  --bg:#F6F3FB;        --bg-2:#FBFAFE;     --surface:#FFFFFF;
  --glass:rgba(255,255,255,.6);            --glass-2:rgba(255,255,255,.45);
  --line:rgba(74,30,92,.12);               --line-2:rgba(74,30,92,.07);
  --grad:linear-gradient(120deg,#6E2C82 0%,#8A3FA0 38%,#C0A24E 100%);
  --grad-soft:linear-gradient(120deg,#8A3FA0,#C0A24E);
  --grad-deep:linear-gradient(150deg,#2A0E38,#4A1E5C 55%,#6E2C82);
  --shadow:0 24px 60px -28px rgba(74,30,92,.45);
  --shadow-sm:0 12px 30px -16px rgba(74,30,92,.32);
  --ff-display:"Outfit",system-ui,sans-serif;
  --ff-body:"Plus Jakarta Sans",system-ui,sans-serif;
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
html[dir=rtl]{ --ff-display:"Tajawal",system-ui,sans-serif; --ff-body:"Tajawal",system-ui,sans-serif; }

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:96px}
body{font-family:var(--ff-body);color:var(--ink);background:var(--bg);line-height:1.7;font-size:16.5px;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative}
html[dir=rtl] body{line-height:1.95}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:24px}
.ltr{direction:ltr;unicode-bidi:embed;display:inline-block}

/* ---------- aurora background ---------- */
.aurora{position:fixed;inset:0;z-index:-2;background:var(--bg);overflow:hidden}
.aurora::before,.aurora::after{content:"";position:absolute;border-radius:50%;filter:blur(90px);opacity:.5}
.aurora::before{width:60vw;height:60vw;top:-18vw;inset-inline-start:-12vw;
  background:radial-gradient(circle,rgba(138,63,160,.55),transparent 65%)}
.aurora::after{width:55vw;height:55vw;bottom:-16vw;inset-inline-end:-10vw;
  background:radial-gradient(circle,rgba(227,193,120,.5),transparent 65%)}
.aurora i{position:absolute;width:38vw;height:38vw;border-radius:50%;filter:blur(80px);opacity:.32;
  background:radial-gradient(circle,rgba(110,44,130,.55),transparent 65%);top:42%;inset-inline-start:48%}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--ff-display);color:var(--plum-ink);line-height:1.12;font-weight:600;letter-spacing:-.02em}
html[dir=rtl] h1,html[dir=rtl] h2,html[dir=rtl] h3,html[dir=rtl] h4{letter-spacing:0;line-height:1.4;font-weight:700}
h1 em,h2 em{font-style:normal;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--ff-display);font-weight:600;
  font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--purple);
  background:rgba(138,63,160,.08);border:1px solid var(--line);padding:7px 16px;border-radius:30px}
html[dir=rtl] .eyebrow{letter-spacing:.02em;font-size:.86rem}
.eyebrow::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--grad)}

.sec-head{margin-bottom:54px;max-width:780px}
.sec-head h2{font-size:clamp(2rem,4.4vw,3.2rem);margin:.5em 0 .4em}
.sec-head p{color:var(--muted);max-width:660px;font-size:1.06rem}

section{padding:104px 0;position:relative}
.band-tint{background:linear-gradient(180deg,rgba(138,63,160,.05),rgba(227,193,120,.05))}
.band-deep{background:var(--grad-deep);position:relative;overflow:hidden;color:#EBDDF2}
.band-deep h2,.band-deep h3{color:#fff}
.band-deep .sec-head p{color:#D6C4E0}
.band-deep .eyebrow{color:var(--gold-bright);background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.16)}
.band-deep::before{content:"";position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;
  width:40vw;height:40vw;top:-10vw;inset-inline-end:-8vw;background:radial-gradient(circle,rgba(227,193,120,.5),transparent 65%)}
.band-deep > .wrap{position:relative;z-index:1}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease);transition-delay:var(--rd,0s)}
.reveal.in{opacity:1;transform:none}

/* ---------- topbar ---------- */
.topbar{background:rgba(255,255,255,.5);border-bottom:1px solid var(--line);font-size:.8rem;color:var(--muted);backdrop-filter:blur(8px)}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;min-height:40px;gap:16px;flex-wrap:wrap}
.topbar a{color:var(--purple);font-weight:600}
.topbar .tb-item{display:inline-flex;align-items:center;gap:8px}
.topbar svg{width:14px;height:14px;fill:none;stroke:var(--gold-deep);stroke-width:1.8}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:60;background:rgba(246,243,251,.72);backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;min-height:80px;gap:18px}
.brand{display:flex;align-items:center;gap:13px}
.brand .mark{width:46px;height:46px;filter:drop-shadow(0 6px 14px rgba(110,44,130,.35))}
.brand .b-name{font-family:var(--ff-display);font-weight:700;color:var(--plum-ink);font-size:1.08rem;line-height:1.1;display:block}
html[dir=rtl] .brand .b-name{font-size:1.18rem}
.brand .b-sub{display:block;font-family:var(--ff-display);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold-deep);font-weight:600;margin-top:3px}
html[dir=rtl] .brand .b-sub{letter-spacing:.02em;font-size:.72rem}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{font-family:var(--ff-display);font-weight:500;font-size:.84rem;letter-spacing:.04em;color:var(--ink);
  padding:10px 14px;border-radius:30px;transition:.2s;position:relative}
html[dir=rtl] .nav-links a{font-size:.96rem}
.nav-links a:hover{color:var(--purple);background:rgba(138,63,160,.07)}
.nav-links a.active{color:#fff;background:var(--grad);box-shadow:0 8px 20px -8px rgba(110,44,130,.6)}
.lang-btn{font-family:var(--ff-display);font-weight:700;font-size:.85rem;border:1.5px solid transparent;
  background:linear-gradient(#fff,#fff) padding-box,var(--grad) border-box;color:var(--purple);
  padding:8px 18px;border-radius:30px;cursor:pointer;transition:.22s}
.lang-btn:hover{background:var(--grad);color:#fff}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.burger span{display:block;width:24px;height:2px;background:var(--plum);margin:5px 0;transition:.25s;border-radius:2px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--ff-display);font-weight:600;
  padding:15px 30px;border-radius:40px;font-size:.95rem;cursor:pointer;border:0;transition:.25s var(--ease)}
.btn svg{width:17px;height:17px}
html[dir=rtl] .btn svg.arr{transform:scaleX(-1)}
.btn-grad{background:var(--grad);color:#fff;box-shadow:0 18px 40px -16px rgba(110,44,130,.65)}
.btn-grad:hover{transform:translateY(-3px);box-shadow:0 26px 56px -16px rgba(110,44,130,.8)}
.btn-ghost{background:rgba(255,255,255,.6);color:var(--plum-2);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--purple);color:var(--purple);transform:translateY(-2px)}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden}
#nodes{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;
  min-height:660px;padding-block:80px}
.hero h1{font-size:clamp(2.6rem,5.8vw,4.4rem);margin:22px 0 22px;font-weight:700;letter-spacing:-.03em}
html[dir=rtl] .hero h1{letter-spacing:0}
.hero p.lead{color:var(--muted);font-size:1.18rem;max-width:560px;font-weight:400}
.hero-cta{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap;align-items:center}
.hero-stats{display:flex;margin-top:46px;gap:14px;flex-wrap:wrap}
.hstat{flex:1;min-width:120px;padding:18px 20px;background:var(--glass);border:1px solid var(--line);border-radius:18px;
  backdrop-filter:blur(10px);box-shadow:var(--shadow-sm)}
.hstat b{font-family:var(--ff-display);font-size:1.9rem;font-weight:700;display:block;line-height:1.05;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hstat span{font-size:.76rem;color:var(--muted);letter-spacing:.04em}

/* hero orb — concentric touch ripples around a glowing node */
.orb-stage{position:relative;display:flex;align-items:center;justify-content:center;min-height:460px}
.orb-glow{position:absolute;width:58%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(138,63,160,.4),rgba(227,193,120,.18) 55%,transparent 72%);filter:blur(10px);
  animation:breathe 6s ease-in-out infinite}
@keyframes breathe{0%,100%{transform:scale(.92);opacity:.7}50%{transform:scale(1.05);opacity:1}}
.orb-svg{width:100%;max-width:480px;position:relative;z-index:2}
.orb-svg .spin{transform-origin:200px 200px;animation:spin 40s linear infinite}
.orb-svg .spin-r{transform-origin:200px 200px;animation:spin 30s linear infinite reverse}
@keyframes spin{to{transform:rotate(360deg)}}
.orb-svg .pingring{transform-origin:200px 200px;animation:ping 3.4s ease-out infinite}
.orb-svg .pingring.d2{animation-delay:1.1s}
.orb-svg .pingring.d3{animation-delay:2.2s}
@keyframes ping{0%{transform:scale(.45);opacity:.9}80%{opacity:0}100%{transform:scale(1.25);opacity:0}}

/* ---------- ticker ---------- */
.ticker{background:rgba(255,255,255,.45);border-block:1px solid var(--line);padding:14px 0;overflow:hidden;position:relative;backdrop-filter:blur(8px)}
.ticker-track{display:flex;width:max-content;animation:tick 44s linear infinite}
html[dir=rtl] .ticker-track{animation-name:tick-rtl}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-track span{font-family:var(--ff-display);font-weight:600;color:var(--plum-2);font-size:.82rem;letter-spacing:.1em;
  text-transform:uppercase;padding-inline:26px;white-space:nowrap;display:inline-flex;align-items:center;gap:26px}
html[dir=rtl] .ticker-track span{letter-spacing:.02em;font-size:.94rem}
.ticker-track span::after{content:"";width:8px;height:8px;border-radius:50%;background:var(--grad);display:inline-block}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes tick-rtl{from{transform:translateX(0)}to{transform:translateX(50%)}}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:58px;align-items:center}
.about-grid h2{font-size:clamp(1.9rem,3.8vw,2.7rem);margin:.4em 0 .5em}
.name-story{position:relative;background:var(--glass);border:1px solid var(--line);border-radius:20px;padding:26px 30px;
  margin-top:26px;font-size:1rem;color:var(--muted);box-shadow:var(--shadow-sm);backdrop-filter:blur(10px)}
.name-story::before{content:"";position:absolute;inset:0 auto 0 0;width:5px;border-radius:5px;background:var(--grad)}
html[dir=rtl] .name-story::before{inset:0 0 0 auto}
.name-story b{color:var(--purple);font-family:var(--ff-display);font-weight:700}
.about-points{margin-top:28px;display:grid;gap:0}
.about-points li{display:flex;gap:14px;align-items:baseline;padding:14px 2px;border-bottom:1px solid var(--line);color:var(--ink)}
.about-points li:first-child{border-top:1px solid var(--line)}
.tick{flex:0 0 22px;width:22px;height:22px;border-radius:50%;background:var(--grad);display:grid;place-items:center;transform:translateY(3px)}
.tick::after{content:"";width:7px;height:4px;border-inline-start:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg) translate(0,-1px)}

/* ---------- expertise: glass capability cards ---------- */
.cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cap{position:relative;background:var(--glass);border:1px solid var(--line);border-radius:24px;padding:32px 28px;
  box-shadow:var(--shadow-sm);backdrop-filter:blur(10px);overflow:hidden;transition:.4s var(--ease)}
.cap::after{content:"";position:absolute;inset:auto -40% -60% auto;width:60%;height:60%;border-radius:50%;
  background:radial-gradient(circle,rgba(227,193,120,.25),transparent 70%);opacity:0;transition:.4s}
.cap:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:rgba(138,63,160,.28)}
.cap:hover::after{opacity:1}
.cap-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.cap .num{font-family:var(--ff-display);font-weight:700;font-size:1.05rem;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.cap .ico{width:56px;height:56px;border-radius:16px;background:var(--grad);display:grid;place-items:center;
  box-shadow:0 12px 26px -12px rgba(110,44,130,.6)}
.cap .ico svg{width:28px;height:28px;fill:none;stroke:#fff;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.cap h3{font-size:1.26rem;color:var(--plum-ink);margin-bottom:10px;position:relative;z-index:1}
.cap p{color:var(--muted);font-size:.95rem;position:relative;z-index:1}
.cap .chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;position:relative;z-index:1}
.cap .chips i{font-style:normal;font-family:var(--ff-display);font-size:.72rem;font-weight:600;letter-spacing:.02em;
  color:var(--purple);border:1px solid var(--line);border-radius:30px;padding:5px 12px;background:rgba(255,255,255,.5)}
html[dir=rtl] .cap .chips i{font-size:.84rem}
.cap-note{margin-top:28px;font-size:.88rem;color:var(--muted);display:flex;gap:10px;align-items:baseline}
.cap-note .tick{flex:0 0 18px;width:18px;height:18px;transform:translateY(2px)}
.cap-note .tick::after{width:6px;height:3px}

/* ---------- trade (deep band) ---------- */
.trade-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.trade-grid h2{font-size:clamp(1.9rem,3.8vw,2.7rem);margin:.4em 0 .5em}
.route-list{display:grid;margin-top:26px;border-top:1px solid rgba(255,255,255,.15)}
.route-list li{display:flex;gap:14px;align-items:baseline;color:#D6C4E0;padding:15px 2px;border-bottom:1px solid rgba(255,255,255,.15)}
.route-list .tick{background:var(--grad-soft)}
.route-list b{color:#fff}
.counters{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:34px}
.counter{padding:24px 22px;border:1px solid rgba(255,255,255,.16);border-radius:18px;background:rgba(255,255,255,.06)}
.counter b{font-family:var(--ff-display);font-size:2.4rem;font-weight:700;display:block;line-height:1.05;
  background:linear-gradient(120deg,#E3C178,#F2DDA0);-webkit-background-clip:text;background-clip:text;color:transparent}
.counter span{font-size:.78rem;color:#C9B6D4;letter-spacing:.04em}
.fineprint{font-size:.76rem;color:#A88FB6;margin-top:14px}

/* ---------- why: glass pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.pillar{background:var(--glass);border:1px solid var(--line);border-radius:22px;padding:32px 26px;box-shadow:var(--shadow-sm);
  backdrop-filter:blur(10px);transition:.3s var(--ease)}
.pillar:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:rgba(138,63,160,.28)}
.pillar .p-num{width:48px;height:48px;border-radius:50%;background:var(--grad);display:grid;place-items:center;
  font-family:var(--ff-display);color:#fff;font-size:1.05rem;font-weight:700;margin-bottom:18px;box-shadow:0 10px 22px -10px rgba(110,44,130,.6)}
.pillar h3{font-size:1.14rem;color:var(--plum-ink);margin-bottom:9px}
.pillar p{font-size:.92rem;color:var(--muted)}

/* ---------- contact (no form — email is the action) ---------- */
.contact-card{max-width:760px;margin-inline:auto;text-align:center;background:var(--glass);border:1px solid var(--line);
  border-radius:30px;padding:56px 40px;box-shadow:var(--shadow);backdrop-filter:blur(12px);position:relative;overflow:hidden}
.contact-card::before{content:"";position:absolute;inset:auto auto -50% 50%;transform:translateX(-50%);
  width:80%;height:80%;border-radius:50%;background:radial-gradient(circle,rgba(227,193,120,.22),transparent 70%)}
.contact-card > *{position:relative;z-index:1}
.contact-card .eyebrow{margin-bottom:18px}
.contact-card h2{font-size:clamp(1.8rem,3.6vw,2.6rem);margin-bottom:14px}
.contact-card p.lead{color:var(--muted);max-width:520px;margin:0 auto 30px}
.email-btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--ff-display);font-weight:700;font-size:1.12rem;
  background:var(--grad);color:#fff;padding:18px 34px;border-radius:44px;box-shadow:0 20px 44px -16px rgba(110,44,130,.7);
  transition:.25s var(--ease);direction:ltr}
.email-btn:hover{transform:translateY(-3px);box-shadow:0 28px 60px -16px rgba(110,44,130,.85)}
.email-btn svg{width:20px;height:20px;fill:none;stroke:#fff;stroke-width:1.8}
.c-meta{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin-top:32px}
.c-meta .chip{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.6);border:1px solid var(--line);
  border-radius:30px;padding:10px 18px;font-size:.9rem;color:var(--ink)}
.c-meta .chip svg{width:16px;height:16px;fill:none;stroke:var(--gold-deep);stroke-width:1.8}
.c-meta .chip a{color:var(--purple);font-weight:600}

/* ---------- footer ---------- */
footer{background:var(--grad-deep);color:#C9B6D4;position:relative;overflow:hidden}
footer::before{content:"";position:absolute;border-radius:50%;filter:blur(80px);opacity:.35;
  width:34vw;height:34vw;bottom:-14vw;inset-inline-start:-8vw;background:radial-gradient(circle,rgba(138,63,160,.6),transparent 65%)}
.ft-top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:44px;padding:64px 0 44px;position:relative;z-index:1}
.ft-brand{display:flex;align-items:center;gap:13px;margin-bottom:16px}
.ft-brand .mark{width:48px;height:48px}
.ft-brand .b-name{font-family:var(--ff-display);font-weight:700;color:#fff;font-size:1.08rem;line-height:1.1}
.ft-brand .b-sub{font-family:var(--ff-display);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-bright)}
html[dir=rtl] .ft-brand .b-sub{letter-spacing:.02em;font-size:.72rem}
.ft-top p{font-size:.92rem;color:#C9B6D4;max-width:330px}
.ft-top h4{color:#fff;font-size:1rem;margin-bottom:16px}
.ft-top a{display:block;padding:5px 0;font-size:.92rem;color:#C9B6D4;transition:.2s}
.ft-top a:hover{color:var(--gold-bright)}
.ft-bottom{border-top:1px solid rgba(255,255,255,.14);padding:22px 0;font-size:.82rem;color:#A88FB6;
  display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;position:relative;z-index:1}

/* ---------- media slots ---------- */
.media{position:relative;overflow:hidden;background:var(--glass);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow-sm)}
.media.ratio-43{aspect-ratio:4/3}
.media.ratio-169{aspect-ratio:16/9}
.media .bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity .6s}
.media.loaded .bg{opacity:1}
.media .ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  border:1.5px dashed rgba(138,63,160,.3);margin:14px;border-radius:16px;text-align:center;padding:16px;color:var(--purple);font-size:.8rem}
.media.loaded .ph{display:none}
.media .ph svg{width:32px;height:32px;fill:none;stroke:var(--purple);stroke-width:1.5}
.media .ph b{font-family:var(--ff-display);font-size:.86rem;color:var(--plum-2);direction:ltr;unicode-bidi:embed}
.media .ph span{color:var(--muted-2);max-width:240px}

/* ============================================================
   MOTION — intro (touch ripple) → journey rail
   ============================================================ */
#intro{position:fixed;inset:0;z-index:200;background:var(--bg);display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:30px;animation:introLift .7s cubic-bezier(.7,0,.3,1) 2.1s forwards}
#intro.skip{animation:none;opacity:0;visibility:hidden;transition:opacity .25s}
body.intro-lock{overflow:hidden}
.touch{position:relative;width:200px;height:200px;display:grid;place-items:center}
.touch .ring{position:absolute;inset:0;margin:auto;border-radius:50%;border:2px solid transparent;
  background:var(--grad) border-box;-webkit-mask:linear-gradient(#000 0 0) padding-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;width:0;height:0;opacity:0;
  animation:ripple 1.8s var(--ease) forwards}
.touch .r2{animation-delay:.25s}.touch .r3{animation-delay:.5s}
.touch .dot{width:26px;height:26px;border-radius:50%;background:var(--grad);box-shadow:0 0 0 0 rgba(138,63,160,.5);
  opacity:0;animation:dotIn .5s ease .2s forwards,dotPulse 1.6s ease .7s infinite}
@keyframes ripple{0%{width:30px;height:30px;opacity:.9}100%{width:200px;height:200px;opacity:0}}
@keyframes dotIn{to{opacity:1}}
@keyframes dotPulse{0%{box-shadow:0 0 0 0 rgba(138,63,160,.5)}70%{box-shadow:0 0 0 22px rgba(138,63,160,0)}100%{box-shadow:0 0 0 0 rgba(138,63,160,0)}}
#intro .in-name{font-family:var(--ff-display);font-weight:700;color:var(--plum-ink);font-size:1.6rem;text-align:center;
  opacity:0;animation:fadeUp .6s ease 1.05s forwards}
#intro .in-name span{display:block;font-family:var(--ff-display);font-size:.64rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold-deep);margin-top:10px;font-weight:600}
html[dir=rtl] #intro .in-name span{letter-spacing:.04em;font-size:.8rem}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes introLift{to{transform:translateY(-100%);visibility:hidden}}

body.has-intro .hero-copy > *,body.has-intro .orb-stage{opacity:0;animation:fadeUp .8s var(--ease) forwards}
body.has-intro .hero-copy > :nth-child(1){animation-delay:2.0s}
body.has-intro .hero-copy > :nth-child(2){animation-delay:2.12s}
body.has-intro .hero-copy > :nth-child(3){animation-delay:2.24s}
body.has-intro .hero-copy > :nth-child(4){animation-delay:2.36s}
body.has-intro .hero-copy > :nth-child(5){animation-delay:2.48s}
body.has-intro .orb-stage{animation-delay:2.3s}

/* journey rail */
.journey{position:fixed;inset-inline-end:24px;top:50%;transform:translateY(-50%);z-index:70;
  display:flex;flex-direction:column;align-items:center;gap:24px}
.journey .j-line{position:absolute;top:10px;bottom:10px;width:2px;background:var(--line);overflow:hidden;border-radius:2px}
.journey .j-line i{position:absolute;top:0;left:0;width:100%;height:0;background:var(--grad);display:block;transition:height .25s ease-out}
.journey a{position:relative;z-index:1;width:11px;height:11px;background:var(--surface);border:1.5px solid var(--muted-2);
  border-radius:50%;transition:.3s;outline-offset:4px}
.journey a:hover{border-color:var(--purple)}
.journey a.active{border-color:transparent;background:var(--grad);transform:scale(1.4);box-shadow:0 0 0 5px rgba(138,63,160,.16)}
.journey a.j-mail{width:32px;height:32px;transform:none;border-radius:50%;background:var(--surface);border:1px solid var(--line);display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.journey a.j-mail svg{width:15px;height:15px;fill:none;stroke:var(--muted);stroke-width:1.8;transition:.3s}
.journey a.j-mail:hover svg,.journey a.j-mail.active svg{stroke:var(--purple)}
.journey a.j-mail.active{border-color:var(--purple);transform:scale(1.1)}
@media(max-width:1080px){.journey{display:none}}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .hero .wrap{grid-template-columns:1fr;min-height:0;gap:36px}
  .orb-stage{order:-1;min-height:320px}
  .about-grid,.trade-grid{grid-template-columns:1fr;gap:40px}
  .cap-grid{grid-template-columns:1fr 1fr}
  .pillars{grid-template-columns:1fr 1fr}
  .ft-top{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  .burger{display:block}
  .nav-links{position:fixed;inset:80px 0 auto 0;background:rgba(246,243,251,.97);backdrop-filter:blur(16px);
    flex-direction:column;align-items:stretch;padding:18px 24px 26px;gap:6px;border-bottom:1px solid var(--line);
    box-shadow:0 24px 50px rgba(74,30,92,.18);transform:translateY(-130%);transition:transform .3s;z-index:55}
  .nav-links.open{transform:none}
  .nav-links a{padding:13px 16px;font-size:.98rem}
}
@media(max-width:640px){
  section{padding:74px 0}
  .cap-grid,.pillars{grid-template-columns:1fr}
  .topbar .tb-tag{display:none}
  .hero-stats{flex-direction:column}
  .ft-top{grid-template-columns:1fr;gap:30px}
  .contact-card{padding:40px 22px}
}

/* ---------- motion safety ---------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
  #intro{display:none}
  body.has-intro .hero-copy > *,body.has-intro .orb-stage{opacity:1;animation:none}
}
