/* =========================================================================
   Sajilny v9 — "Reads the room"
   One motif: surface -> the read. Gold appears only on the read (the insight).
   Midnight & Gold. RTL via CSS logical properties (one sheet serves LTR + RTL).
   ========================================================================= */

/* ----------------------------- Fonts ------------------------------------- */
@font-face{font-family:"Bricolage";font-style:normal;font-weight:300 700;font-display:swap;
  src:url("/fonts/bricolage-latin-var.woff2") format("woff2-variations");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212;}

@font-face{font-family:"Plex Sans";font-style:normal;font-weight:400;font-display:swap;
  src:url("/fonts/plex-sans-latin-400.woff2") format("woff2");unicode-range:U+0000-00FF,U+2000-206F,U+2122,U+2191,U+2193;}
@font-face{font-family:"Plex Sans";font-style:normal;font-weight:500;font-display:swap;
  src:url("/fonts/plex-sans-latin-500.woff2") format("woff2");unicode-range:U+0000-00FF,U+2000-206F,U+2122,U+2191,U+2193;}
@font-face{font-family:"Plex Sans";font-style:normal;font-weight:600;font-display:swap;
  src:url("/fonts/plex-sans-latin-600.woff2") format("woff2");unicode-range:U+0000-00FF,U+2000-206F,U+2122,U+2191,U+2193;}

@font-face{font-family:"Plex Arabic";font-style:normal;font-weight:400;font-display:swap;
  src:url("/fonts/plex-arabic-400.woff2") format("woff2");unicode-range:U+0600-06FF,U+0750-077F,U+0870-088E,U+08A0-08FF,U+FB50-FDFF,U+FE70-FEFF,U+200C-200F;}
@font-face{font-family:"Plex Arabic";font-style:normal;font-weight:600;font-display:swap;
  src:url("/fonts/plex-arabic-600.woff2") format("woff2");unicode-range:U+0600-06FF,U+0750-077F,U+FB50-FDFF,U+FE70-FEFF;}
@font-face{font-family:"Plex Arabic";font-style:normal;font-weight:700;font-display:swap;
  src:url("/fonts/plex-arabic-700.woff2") format("woff2");unicode-range:U+0600-06FF,U+0750-077F,U+FB50-FDFF,U+FE70-FEFF;}

@font-face{font-family:"Plex Mono";font-style:normal;font-weight:500;font-display:swap;
  src:url("/fonts/plex-mono-latin-500.woff2") format("woff2");unicode-range:U+0000-00FF,U+2000-206F;}

/* ----------------------------- Tokens ------------------------------------ */
:root{
  --obsidian:#0A1420;
  --ink:#101E33;
  --panel:#11203A;
  --navy:#1B3A5C;
  --navy-lit:#27517C;
  --gold:#BD922F;
  --gold-lit:#E6BE63;
  --porcelain:#EDF1F6;
  --slate:#94A6BF;
  --slate-dim:#7E92AD;
  --line:rgba(237,241,246,.09);
  --line-strong:rgba(237,241,246,.16);

  /* status */
  --s-warm:#E2AB57;
  --s-steady:#84A6CF;
  --s-cool:#8AA6C6;
  --s-crit:#E37B72;

  /* on-porcelain (Tally inset) — AA-safe */
  --on-paper-mute:#5B6B82;
  --on-paper-link:#9A7A26;

  --font-display:"Bricolage","Plex Arabic",sans-serif;
  --font:"Plex Sans","Plex Arabic",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-ar:"Plex Arabic","Plex Sans",sans-serif;
  --font-mono:"Plex Mono",ui-monospace,SFMono-Regular,Menlo,monospace;

  --fs-display:clamp(2.7rem,1.6rem + 4.6vw,4.7rem);
  --fs-h2:clamp(1.9rem,1.4rem + 2.3vw,2.95rem);
  --fs-h3:clamp(1.15rem,1.05rem + .4vw,1.34rem);
  --fs-lede:clamp(1.06rem,1rem + .42vw,1.28rem);
  --fs-body:1.0625rem;
  --fs-eyebrow:.72rem;

  --wrap:1180px;
  --gutter:clamp(1.25rem,.6rem + 2.4vw,2.75rem);
  --pad-section:clamp(5.5rem,3.6rem + 6vw,9.5rem);

  --r:18px; --r-sm:12px; --r-pill:999px;

  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-wipe:cubic-bezier(.77,0,.175,1);
  --ease-soft:cubic-bezier(.22,.61,.36,1);
}

/* ----------------------------- Reset / base ------------------------------ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
html.await-i18n body{visibility:hidden}
body{
  margin:0;position:relative;
  font-family:var(--font);font-size:var(--fs-body);line-height:1.6;
  color:var(--slate);
  background:
    radial-gradient(120% 60% at 50% -10%, rgba(27,58,92,.22), transparent 60%),
    var(--obsidian);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  font-variant-numeric:tabular-nums;
  overflow-x:hidden;
}
h1,h2,h3,p,ul,ol,figure,figcaption{margin:0}
ul,ol{padding:0;list-style:none}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-inline-size:100%}
::selection{background:rgba(230,190,99,.26);color:#fff}

.wrap{inline-size:min(100% - 2*var(--gutter),var(--wrap));margin-inline:auto}
.section{padding-block:var(--pad-section);position:relative}
html[dir="rtl"] body{line-height:1.85}

/* ----------------------------- .edge (elevation primitive) --------------- */
.edge{position:relative;background:linear-gradient(180deg,rgba(27,58,92,.14),rgba(16,30,51,.5));
  box-shadow:inset 0 0 0 1px rgba(237,241,246,.05)}
.edge::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;
  background:linear-gradient(155deg,rgba(237,241,246,.30),rgba(237,241,246,.04) 44%,rgba(189,146,47,.16));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude}

/* ----------------------------- Type -------------------------------------- */
.display{font-family:var(--font-display);font-weight:600;font-size:var(--fs-display);
  font-optical-sizing:auto;line-height:1.02;letter-spacing:-.026em;color:var(--porcelain);text-wrap:balance}
html[dir="rtl"] .display{font-family:var(--font-ar);font-weight:700;line-height:1.26;letter-spacing:0}
.section-h{font-family:var(--font-display);font-weight:600;font-size:var(--fs-h2);font-optical-sizing:auto;
  line-height:1.07;letter-spacing:-.02em;color:var(--porcelain);max-inline-size:20ch;text-wrap:balance}
html[dir="rtl"] .section-h{font-family:var(--font-ar);line-height:1.34;letter-spacing:0}
.lede{font-size:var(--fs-lede);line-height:1.55;color:var(--slate);max-inline-size:46ch}

.eyebrow{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--font-mono);font-weight:500;
  font-size:var(--fs-eyebrow);text-transform:uppercase;letter-spacing:.2em;color:var(--slate);margin-block-end:1.3rem}
.eyebrow::before{content:"";inline-size:1.7rem;block-size:1px;flex:0 0 auto;
  background:linear-gradient(90deg,var(--gold-lit),transparent)}
html[dir="rtl"] .eyebrow{font-family:var(--font-ar);text-transform:none;letter-spacing:0;font-weight:600;font-size:.92rem}
html[dir="rtl"] .eyebrow::before{background:linear-gradient(270deg,var(--gold-lit),transparent)}
.sec-head{max-inline-size:54ch;margin-block-end:clamp(2.6rem,1.6rem + 3vw,4rem)}
.sec-head .lede{margin-block-start:1.2rem}

/* ----------------------------- The read (the motif) ---------------------- */
.read{position:relative;margin-block-start:1.5rem;padding-block-start:1.25rem}
.read-rule{position:absolute;inset-block-start:0;inset-inline-start:0;inline-size:clamp(3rem,40%,5.5rem);block-size:1px;
  transform-origin:inline-start;background:linear-gradient(90deg,var(--gold-lit),var(--gold) 70%,transparent)}
html[dir="rtl"] .read-rule{background:linear-gradient(270deg,var(--gold-lit),var(--gold) 70%,transparent)}
.read-line{display:flex;flex-wrap:wrap;align-items:baseline;gap:.1rem .7rem;line-height:1.5}
.read-label{font-family:var(--font-mono);font-weight:500;font-size:.64rem;text-transform:uppercase;letter-spacing:.14em;
  color:var(--slate-dim)}
html[dir="rtl"] .read-label{font-family:var(--font-ar);text-transform:none;letter-spacing:0;font-size:.82rem}
.read-text{color:var(--gold-lit);font-size:1.1rem;font-weight:500;letter-spacing:-.01em;line-height:1.45}
html[dir="rtl"] .read-text{font-family:var(--font-ar);font-weight:600}

/* ----------------------------- Buttons ----------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-family:var(--font);
  font-weight:600;font-size:1rem;line-height:1;padding:.95rem 1.55rem;border-radius:var(--r-pill);
  cursor:pointer;border:1px solid transparent;position:relative;min-block-size:48px;
  transition:transform .18s var(--ease-soft),box-shadow .22s var(--ease-soft)}
html[dir="rtl"] .btn{font-family:var(--font-ar)}
.btn-primary{background:var(--porcelain);color:var(--ink);box-shadow:0 10px 30px -16px rgba(0,0,0,.8)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 16px 38px -18px rgba(0,0,0,.85),0 0 0 1px rgba(230,190,99,.45),0 0 24px -8px rgba(230,190,99,.4)}
.btn-primary:active{transform:translateY(0)}
.btn-lg{padding:1.05rem 1.9rem;font-size:1.05rem}
.link-quiet{display:inline-flex;align-items:center;gap:.45rem;color:var(--slate);font-weight:500;font-size:.98rem;
  padding-block:.4rem;border-block-end:1px solid transparent;transition:color .2s,border-color .2s}
html[dir="rtl"] .link-quiet{font-family:var(--font-ar)}
.link-quiet:hover{color:var(--porcelain);border-color:var(--line-strong)}
.link-quiet::after{content:"\2192";transition:transform .25s var(--ease-soft)}
.link-quiet:hover::after{transform:translateX(3px)}
html[dir="rtl"] .link-quiet::after{content:"\2190"}
html[dir="rtl"] .link-quiet:hover::after{transform:translateX(-3px)}

/* ----------------------------- Header ------------------------------------ */
.site-header{position:sticky;inset-block-start:0;z-index:60;
  transition:background-color .3s var(--ease-soft),border-color .3s var(--ease-soft)}
.site-header::after{content:"";position:absolute;inset-block-end:0;inset-inline:0;block-size:1px;background:var(--line);opacity:0;transition:opacity .3s}
.site-header.stuck{background:rgba(10,20,32,.7);backdrop-filter:saturate(150%) blur(14px)}
.site-header.stuck::after{opacity:1}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:1.05rem}
/* align the header to the hero frame (full width minus the hero's side padding), not the narrower content wrap */
.site-header .wrap{inline-size:100%;padding-inline:clamp(1.1rem,.7rem + 1.1vw,2.4rem)}
.wordmark{display:inline-flex;align-items:center;gap:.6rem}
.wordmark-mark{inline-size:.62rem;block-size:.62rem;border-radius:2px;flex:0 0 auto;transform:rotate(45deg);
  background:linear-gradient(150deg,var(--gold-lit),var(--gold));box-shadow:0 0 10px -1px rgba(230,190,99,.5)}
.wordmark-latin{font-family:var(--font-display);font-weight:700;font-size:1.3rem;letter-spacing:-.02em;color:var(--porcelain)}
.header-actions{display:flex;align-items:center;gap:clamp(.6rem,.3rem + 1vw,1.1rem)}
.lang-switch{display:inline-flex;align-items:center;background:rgba(237,241,246,.05);border:1px solid var(--line);border-radius:var(--r-pill);padding:.2rem}
.lang-opt{font-family:var(--font);font-size:.85rem;font-weight:600;color:var(--slate);background:none;border:0;cursor:pointer;
  border-radius:var(--r-pill);padding:.45rem .75rem;min-block-size:34px;min-inline-size:40px;line-height:1;transition:color .15s,background-color .15s}
.lang-opt[aria-pressed="true"]{background:var(--porcelain);color:var(--ink)}
.lang-opt:hover:not([aria-pressed="true"]){color:var(--porcelain)}
.lang-opt[lang="ar"]{font-family:var(--font-ar);font-size:.96rem}
@media (max-width:600px){.header-cta{display:none}}

/* ----------------------------- Hero (overlaid scene frame) --------------- */
.hero{padding-inline:clamp(1.1rem,.7rem + 1.1vw,2.4rem);padding-block:clamp(.5rem,.35rem + .4vw,.85rem) clamp(.85rem,.6rem + .5vw,1.4rem)}
.hero-frame{position:relative;overflow:hidden;isolation:isolate;inline-size:100%;
  border-radius:clamp(16px,.7rem + 1.2vw,28px);min-block-size:clamp(27rem,23rem + 32vh,43rem);
  background:linear-gradient(160deg,#FCFDFF 0%,#EDF2F9 100%);
  box-shadow:0 50px 120px -40px rgba(0,0,0,.7),0 3px 14px -5px rgba(0,0,0,.45),inset 0 0 0 1px rgba(16,30,51,.06)}

/* product image slot (looping video) + ambient: a gold glow behind it and a faint grid */
.hero-scene{position:absolute;inset:0;z-index:0;overflow:hidden}
.scene-blobs{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(44% 50% at 14% 20%,rgba(39,81,124,.12),transparent 70%),
            radial-gradient(40% 46% at 90% 24%,rgba(27,58,92,.09),transparent 72%),
            radial-gradient(50% 56% at 62% 98%,rgba(39,81,124,.09),transparent 72%);
  animation:blobsDrift 24s ease-in-out infinite alternate}
html[dir="rtl"] .scene-blobs{background:radial-gradient(44% 50% at 86% 20%,rgba(39,81,124,.12),transparent 70%),
            radial-gradient(40% 46% at 10% 24%,rgba(27,58,92,.09),transparent 72%),
            radial-gradient(50% 56% at 38% 98%,rgba(39,81,124,.09),transparent 72%)}
@keyframes blobsDrift{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(-2.5%,2%,0) scale(1.05)}}
/* floating meeting-platform icons around the figure */
.float-icons{position:absolute;inset-block:0;inset-inline-end:0;inline-size:min(52%,40rem);pointer-events:none;z-index:1}
.float-icon{position:absolute;inline-size:clamp(3.4rem,2.7rem + 1.6vw,4.9rem);block-size:clamp(3.4rem,2.7rem + 1.6vw,4.9rem);
  display:grid;place-items:center;filter:drop-shadow(0 10px 16px rgba(16,30,51,.22));
  animation:floaty 5s ease-in-out infinite;animation-delay:var(--d,0s);will-change:transform}
.float-icon img{inline-size:100%;block-size:100%;object-fit:contain;display:block}
.fi-zoom{inset-block-start:7%;inset-inline-start:9%}
.fi-teams{inset-block-start:29%;inset-inline-start:84%}
.fi-meet{inset-block-start:77%;inset-inline-start:14%}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.hero-media{position:absolute;inset-block:0;inset-inline-end:0;inline-size:min(53%,42rem);
  display:flex;align-items:center;justify-content:center;padding:clamp(.6rem,.3rem + 1.4vw,1.8rem)}
.media-disc{position:absolute;top:46%;left:50%;transform:translate(-50%,-50%);
  inline-size:min(88%,32rem);aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle at 50% 36%,rgba(230,190,99,.46) 0%,rgba(189,146,47,.28) 52%,rgba(189,146,47,.08) 100%);
  box-shadow:inset 0 0 0 1.5px rgba(189,146,47,.3),0 26px 60px -32px rgba(189,146,47,.4)}
.media-disc::after{content:"";position:absolute;inset:-14%;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(230,190,99,.30),rgba(189,146,47,.10) 54%,transparent 72%);
  animation:radiate 5s ease-in-out infinite}
@keyframes radiate{0%,100%{opacity:.42;transform:scale(1)}50%{opacity:.9;transform:scale(1.12)}}
.hero-figure{position:relative;z-index:1;inline-size:100%;block-size:96%;display:flex;align-items:flex-end;justify-content:center;opacity:0}
.hero-media.has-media .hero-figure{opacity:1}
html.anim .hero-figure{transform:translateY(28px) scale(.985)}
html.anim .hero-media.has-media .hero-figure{transform:none;transition:opacity .85s var(--ease-out) .14s,transform 1s var(--ease-out) .14s}
.hero-img{block-size:100%;inline-size:auto;max-inline-size:100%;object-fit:contain;object-position:center bottom;
  filter:drop-shadow(0 24px 34px rgba(16,30,51,.18));animation:breathe 6.5s ease-in-out infinite;will-change:transform}
@keyframes breathe{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-1.4%) scale(1.012)}}
.media-placeholder{position:absolute;inset:10%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.85rem;padding:1rem;text-align:center;border:1.5px dashed rgba(16,30,51,.16);border-radius:18px;background:rgba(16,30,51,.012)}
.hero-media.has-media .media-placeholder{display:none}
.mp-icon{inline-size:2.7rem;block-size:2.7rem;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(150deg,var(--gold-lit),var(--gold));color:var(--ink);font-size:.9rem;padding-inline-start:.15rem}
.mp-label{font-family:var(--font-display);font-weight:600;color:var(--ink);font-size:1.05rem}
.mp-sub{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.03em;color:var(--on-paper-mute);line-height:1.7}

/* legibility scrim + copy overlay (bottom inline-start) */
.hero-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(to right,rgba(248,250,253,.82),rgba(248,250,253,.2) 38%,transparent 52%),
            linear-gradient(to top,rgba(248,250,253,.5),transparent 32%)}
html[dir="rtl"] .hero-scrim{background:linear-gradient(to left,rgba(248,250,253,.82),rgba(248,250,253,.2) 38%,transparent 52%),
            linear-gradient(to top,rgba(248,250,253,.5),transparent 32%)}
.hero-overlay{position:absolute;z-index:2;inset-block-end:0;inset-inline-start:0;max-inline-size:52rem;
  padding:clamp(1.6rem,1rem + 3vw,4rem)}
.hero-title{max-inline-size:20ch;font-size:clamp(2.8rem,1.9rem + 3.7vw,4.8rem);line-height:1.02}
.hl-gold{color:var(--gold)}
.hero-sub{margin-block-start:1.4rem;max-inline-size:40rem;color:#46566e;
  font-size:clamp(1.05rem,.97rem + .42vw,1.28rem);line-height:1.55}
html[dir="rtl"] .hero-sub{font-family:var(--font-ar);line-height:1.8;max-inline-size:42rem}
.hero-actions{margin-block-start:1.7rem;display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap}
.hero-link{color:var(--porcelain)}
.hero-link:hover{color:#fff}
/* hero copy is above the fold: animate on load, not on scroll */
html.anim .hero-overlay>*{opacity:0;animation:heroIn .85s var(--ease-out) both}
html.anim .hero-overlay .hero-sub{animation-delay:.16s}
html.anim .hero-overlay .hero-actions{animation-delay:.32s}
@keyframes heroIn{from{opacity:0;transform:translateY(28px);filter:blur(6px)}to{opacity:1;transform:none;filter:blur(0)}}

/* live dot (shared: scene status + dossier meta) */
.live{inline-size:.46rem;block-size:.46rem;border-radius:50%;flex:0 0 auto;background:var(--s-steady);
  box-shadow:0 0 0 0 rgba(132,166,207,.5);animation:pulse 2.4s ease-out infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(132,166,207,.5)}70%{box-shadow:0 0 0 6px rgba(132,166,207,0)}100%{box-shadow:0 0 0 0 rgba(132,166,207,0)}}

@media (max-width:760px){
  .scene-feedwrap{inline-size:100%;justify-content:flex-start;padding-block-start:2.2rem;gap:.8rem}
  .feed{max-block-size:11rem}
  .fl{font-size:.9rem;max-inline-size:26ch}
}
@media (max-width:600px){.hero-actions{flex-direction:column;align-items:stretch;gap:.9rem}.hero-actions .btn-primary{inline-size:100%}.hero-actions .hero-link{align-self:center}}

/* --- the hero frame is a LIGHT panel: recolor its copy for the white surface --- */
.hero-overlay .eyebrow{color:var(--on-paper-mute)}
.hero-title{color:var(--ink);text-shadow:none}
.hero-overlay .btn-primary{background:var(--ink);color:var(--porcelain);box-shadow:0 12px 30px -16px rgba(16,30,51,.55)}
.hero-overlay .btn-primary:hover{transform:translateY(-1px);box-shadow:0 16px 40px -18px rgba(16,30,51,.6),0 0 0 1px rgba(189,146,47,.55),0 0 22px -8px rgba(189,146,47,.4)}
.hero-link{color:var(--navy)}
.hero-link:hover{color:var(--ink);border-color:rgba(16,30,51,.22)}

/* Hero on small screens: stack (image banner on top, copy below) so nothing overlaps */
@media (max-width:760px){
  .hero-frame{display:flex;flex-direction:column;min-block-size:0}
  .hero-scene{position:relative;inset:auto;order:1;flex:0 0 auto;block-size:clamp(18rem,63vw,23rem)}
  /* fade the disc, figure and ambient into the panel; icons stay crisp so they can spread out */
  .hero-media,.scene-blobs{
    -webkit-mask-image:linear-gradient(to bottom,#000 46%,transparent);
            mask-image:linear-gradient(to bottom,#000 46%,transparent)}
  .hero-media{inline-size:100%;inset-inline:0}
  /* smaller, slightly higher disc so its soft edge stays inside the banner (no clipped top) */
  .media-disc{inline-size:min(52%,13rem);top:41%}
  .hero-figure{block-size:82%}
  .hero-scrim{display:none}
  /* platform icons spread around the banner (top corners + lower-right), not bunched */
  .float-icons{inline-size:100%;inset-inline:0}
  .float-icon{inline-size:3rem;block-size:3rem}
  .fi-zoom{inset-block-start:8%;inset-inline-start:6%}
  .fi-teams{inset-block-start:8%;inset-inline-start:82%}
  .fi-meet{inset-block-start:77%;inset-inline-start:57%}
  .hero-overlay{position:relative;inset:auto;order:2;max-inline-size:none;
    padding:clamp(1.2rem,1rem + 2vw,2.2rem) clamp(1.5rem,1rem + 3vw,2.2rem) clamp(1.6rem,1.2rem + 3vw,2.4rem)}
  .hero-title{max-inline-size:none;font-size:clamp(2.2rem,1.4rem + 5.2vw,3.1rem)}
  .hero-sub{max-inline-size:none}
  /* shrink the flow-card graphic on mobile — full-width cards make the 60% version too big */
  .flow .flow-fx{inline-size:min(43%,11rem)}
}

/* ----------------------------- How it works (the flow) ------------------- */
.flow .sec-head{max-inline-size:none}
.flow .section-h{max-inline-size:40ch;text-wrap:wrap}
.flow-grid{display:grid;gap:clamp(1rem,.7rem + 1vw,1.4rem);grid-template-columns:1fr}
@media (min-width:760px){.flow-grid{grid-template-columns:repeat(2,1fr);align-items:stretch}}
/* lighter, neutral card surface so it reads clearly against the dark navy page */
.flow-card{position:relative;border-radius:var(--r);padding:clamp(1.5rem,1.15rem + 1.4vw,2.1rem);
  display:flex;flex-direction:column;min-block-size:clamp(17rem,14rem + 8vw,21rem);overflow:hidden;
  background:linear-gradient(180deg,rgba(237,241,246,.075),rgba(237,241,246,.03));
  box-shadow:inset 0 0 0 1px var(--line-strong),0 24px 46px -34px rgba(0,0,0,.7)}
.flow-head{display:flex;align-items:baseline;gap:.7rem;margin-block-end:.8rem}
.flow-num{font-family:var(--font-display);font-weight:600;font-size:clamp(1.5rem,1.25rem + .9vw,2rem);
  line-height:1;letter-spacing:-.03em;color:var(--gold-lit)}
.flow-step{font-family:var(--font-mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.18em;color:var(--gold)}
html[dir="rtl"] .flow-step{font-family:var(--font-ar);text-transform:none;letter-spacing:0;font-weight:600;font-size:.9rem}
.flow-card h3{font-family:var(--font-display);font-size:clamp(1.3rem,1.1rem + .7vw,1.6rem);font-weight:600;
  color:var(--porcelain);line-height:1.16;margin-block-end:.4rem}
html[dir="rtl"] .flow-card h3{font-family:var(--font-ar);line-height:1.3}
.flow-lede{color:var(--slate);max-inline-size:29ch;font-size:1rem;line-height:1.5;position:relative;z-index:1}
html[dir="rtl"] .flow-lede{font-family:var(--font-ar)}

/* keep the card text above the graphic + its ambient field */
.flow-card > :not(.flow-fx){position:relative;z-index:1}
/* dimensional gold icon, large, anchored to the bottom-right of the card */
.flow-fx{position:absolute;z-index:0;inset-block-end:-1.4rem;inset-inline-end:-1.4rem;
  inline-size:min(60%,17rem);aspect-ratio:1;display:grid;place-items:center;pointer-events:none}
/* ambient field: soft gold bloom + faint gold dot-grid, spreading beyond the icon to fill space */
.flow-fx::before{content:"";position:absolute;inset:-42%;pointer-events:none;z-index:0;
  background-image:radial-gradient(closest-side,rgba(230,190,99,.2),rgba(189,146,47,.06) 46%,transparent 72%),radial-gradient(rgba(230,190,99,.15) 1.1px,transparent 1.4px);
  background-size:100% 100%,15px 15px;background-position:center;
  -webkit-mask:radial-gradient(72% 72% at 56% 56%,#000 18%,transparent 78%);mask:radial-gradient(72% 72% at 56% 56%,#000 18%,transparent 78%)}
.fx-ic{position:relative;z-index:1;inline-size:86%;block-size:auto;overflow:visible;
  filter:drop-shadow(0 0 22px rgba(230,190,99,.32)) drop-shadow(0 14px 20px rgba(0,0,0,.5));will-change:transform}
html.anim .fx-join.in .fx-ic{animation:floaty2 6s ease-in-out infinite}
html.anim .fx-transcribe.in .fx-ic{animation:floaty2 6.6s ease-in-out -.6s infinite}
html.anim .fx-insights.in .fx-ic{animation:floaty2 6.2s ease-in-out -1.2s infinite}
html.anim .fx-prep.in .fx-ic{animation:floaty2 7s ease-in-out -1.8s infinite}

/* join: concentric rings pulse outward behind the orb */
.ic-ring{transform-box:fill-box;transform-origin:center}
html.anim .fx-join .ic-ring-a,html.anim .fx-join .ic-ring-b{opacity:0}
html.anim .fx-join.in .ic-ring-a{animation:ripple2 3.2s ease-out infinite}
html.anim .fx-join.in .ic-ring-b{animation:ripple2 3.2s ease-out 1.6s infinite}

/* insights: the spark gently twinkles */
.ic-spark-main{transform-box:fill-box;transform-origin:center}
html.anim .fx-insights.in .ic-spark-main{animation:twinkle 3.2s ease-in-out infinite}

@keyframes floaty2{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@keyframes ripple2{0%{transform:scale(.5);opacity:.6}70%{opacity:.1}100%{transform:scale(1.18);opacity:0}}
@keyframes twinkle{0%,100%{transform:scale(.94);opacity:.85}50%{transform:scale(1.06);opacity:1}}
@keyframes blink{0%,55%{opacity:1}56%,100%{opacity:.15}}

/* ----------------------------- Features (horizontal scroller) ------------ */
.feat-head{text-align:center;margin-block-end:clamp(2.6rem,1.6rem + 3vw,4rem)}
.feat-head .sec-head{margin-block-end:0;max-inline-size:none;margin-inline:auto}
.feat-head .section-h{max-inline-size:none}

/* scroll arrows: centered under the cards */
.feat-controls{display:flex;gap:.7rem;justify-content:center;
  margin-block-start:clamp(1.6rem,1rem + 2vw,2.4rem)}
.feat-nav{inline-size:2.6rem;block-size:2.6rem;border:0;border-radius:var(--r-pill);cursor:pointer;
  background:rgba(237,241,246,.04);box-shadow:inset 0 0 0 1px var(--line-strong);
  color:var(--porcelain);font-size:1.35rem;line-height:1;display:grid;place-items:center;
  transition:transform .2s var(--ease-soft),opacity .2s,box-shadow .2s}
@media (hover:hover){.feat-nav:hover:not(:disabled){transform:translateY(-2px);box-shadow:inset 0 0 0 1px var(--line-strong),0 10px 24px -14px rgba(0,0,0,.8)}}
.feat-nav:focus-visible{outline:2px solid var(--gold-lit);outline-offset:3px}
.feat-nav:disabled{opacity:.32;cursor:default}
.feat-nav span{display:block;margin-block-start:-2px}
/* the ‹ › glyphs are auto-mirrored by the browser in RTL, so no manual flip needed */

.feat-scroller{overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  scroll-padding-inline:var(--gutter);
  scrollbar-width:none;
  -webkit-mask-image:linear-gradient(90deg,#000 calc(100% - 3.5rem),transparent);
          mask-image:linear-gradient(90deg,#000 calc(100% - 3.5rem),transparent)}
html[dir="rtl"] .feat-scroller{
  -webkit-mask-image:linear-gradient(270deg,#000 calc(100% - 3.5rem),transparent);
          mask-image:linear-gradient(270deg,#000 calc(100% - 3.5rem),transparent)}
.feat-scroller::-webkit-scrollbar{display:none}
.feat-scroller:focus-visible{outline:2px solid var(--gold-lit);outline-offset:-4px}
.feat-track{display:flex;gap:clamp(1rem,.7rem + 1vw,1.4rem);list-style:none;margin:0;
  justify-content:safe center;
  padding-block:.75rem 2.25rem;
  padding-inline:var(--gutter)}

/* white card: a real border wraps the whole card, image included; blue lettering on light */
.feat-card{flex:0 0 clamp(260px,78vw,360px);scroll-snap-align:start;border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;
  background:linear-gradient(180deg,#FCFDFF,#EDF2F9);
  border:1px solid rgba(237,241,246,.22);
  box-shadow:0 24px 46px -34px rgba(0,0,0,.7);
  transition:transform .25s var(--ease-out),box-shadow .25s var(--ease-out)}
@media (hover:hover){.feat-card:hover{transform:translateY(-3px);box-shadow:0 30px 58px -30px rgba(0,0,0,.78)}}
.feat-art{position:relative;aspect-ratio:4 / 3;overflow:hidden;
  background:linear-gradient(160deg,var(--navy),var(--obsidian))}
.feat-art img{inline-size:100%;block-size:100%;object-fit:cover}
.feat-body{padding:clamp(1.3rem,1rem + 1vw,1.85rem);display:flex;flex-direction:column;gap:.45rem}
.feat-body h3{font-family:var(--font-display);font-size:var(--fs-h3);font-weight:700;color:var(--on-paper-link);
  line-height:1.2;letter-spacing:-.01em;white-space:nowrap}
html[dir="rtl"] .feat-body h3{font-family:var(--font-ar);line-height:1.34;letter-spacing:0}
.feat-body>p{color:#46566E;font-size:1rem;line-height:1.5}
html[dir="rtl"] .feat-body>p{font-family:var(--font-ar)}

/* ----------------------------- Cohort carousel --------------------------- */
.cohort{padding-block:clamp(1.1rem,.8rem + 1vw,1.9rem) clamp(2.6rem,1.8rem + 2.4vw,4rem);overflow:hidden}
.cohort-cap{text-align:center;font-family:var(--font-mono);font-size:.66rem;text-transform:uppercase;
  letter-spacing:.18em;color:var(--slate-dim);margin-block-end:1.5rem}
html[dir="rtl"] .cohort-cap{font-family:var(--font-ar);text-transform:none;letter-spacing:0;font-size:.86rem}
.marquee{position:relative;overflow:hidden;
  -webkit-mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.marquee-track{display:flex;align-items:center;inline-size:max-content;animation:marquee 38s linear infinite;will-change:transform}
.marquee-track li{display:inline-flex;align-items:center;white-space:nowrap;color:var(--slate);
  font-family:var(--font-display);font-weight:500;letter-spacing:-.01em;font-size:clamp(1.1rem,.95rem + .7vw,1.55rem);
  margin-inline-end:clamp(2.8rem,2.2rem + 1.8vw,4.4rem)}
html[dir="rtl"] .marquee-track li{font-family:var(--font-ar);font-weight:600;letter-spacing:0}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
html[dir="rtl"] .marquee-track{animation-direction:reverse}
@media (hover:hover){.marquee:hover .marquee-track{animation-play-state:paused}}

/* ----------------------------- Join -------------------------------------- */
.join-card{position:relative;max-inline-size:680px;margin-inline:auto;border-radius:calc(var(--r) + 4px);
  padding:clamp(1.8rem,1.2rem + 3vw,3.2rem);text-align:center}
.join-head .eyebrow{justify-content:center}
.join-head .section-h{margin-inline:auto;max-inline-size:18ch}
.join-sub{margin-block-start:1rem;color:var(--slate);max-inline-size:44ch;margin-inline:auto}
.section-h:focus-visible{outline:none}
.tally-wrap{margin-block-start:2rem;text-align:start}
.tally-inset{background:var(--porcelain);border-radius:var(--r-sm);padding:clamp(.5rem,.4rem + .6vw,1rem);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8),0 14px 30px -18px rgba(0,0,0,.7),0 0 0 1px rgba(20,34,58,.06);overflow:hidden}
.tally-inset iframe{inline-size:100%;border:0;display:block;color-scheme:light}
.form-skeleton{display:grid;gap:.9rem;padding:1.4rem .4rem}
.sk-bar{height:2.6rem;border-radius:8px;background:linear-gradient(90deg,#E3E6EC 0%,#EDEFF3 40%,#E3E6EC 80%);background-size:200% 100%;animation:skeleton 1.4s linear infinite}
.sk-bar.s3{height:5rem}
@keyframes skeleton{to{background-position:-200% 0}}
.form-fallback{text-align:center;color:var(--on-paper-mute);font-size:.92rem;padding-block-start:.6rem}
.form-fallback a{color:var(--on-paper-link);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.trust-ticks{margin-block-start:1.2rem;display:flex;gap:.6rem;justify-content:center;color:var(--slate-dim);
  font-family:var(--font-mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase}
html[dir="rtl"] .trust-ticks{font-family:var(--font-ar);text-transform:none;letter-spacing:0;font-size:.82rem}
.consent{margin-block-start:1.5rem;font-size:.82rem;color:var(--slate-dim);line-height:1.55;max-inline-size:52ch;margin-inline:auto}
.consent a{color:var(--gold-lit);font-weight:600;text-decoration:underline;text-underline-offset:3px}

/* ----------------------------- Footer ------------------------------------ */
.site-footer{border-block-start:1px solid var(--line);padding-block:3.4rem;margin-block-start:2rem}
.footer-inner{display:flex;flex-wrap:wrap;gap:1.4rem 2rem;align-items:center;justify-content:space-between}
.footer-brand{display:flex;align-items:baseline;gap:.85rem}
.footer-brand .wordmark-latin{color:var(--porcelain);font-size:1.2rem}
.wordmark-ar{font-family:var(--font-ar);font-weight:700;color:var(--gold-lit);font-size:1.24rem;line-height:1}
.footer-nav{display:flex;gap:1.5rem;align-items:center}
.footer-nav a{color:var(--slate);font-size:.92rem;transition:color .2s}
html[dir="rtl"] .footer-nav a{font-family:var(--font-ar)}
.footer-nav a:hover{color:var(--porcelain)}
.footer-legal{flex-basis:100%;color:var(--slate-dim);font-size:.85rem;border-block-start:1px solid var(--line);padding-block-start:1.3rem;margin-block-start:.5rem}

/* ----------------------------- Sub-pages --------------------------------- */
html[lang="ar"] .lang-en{display:none}
html[lang="en"] .lang-ar{display:none}
.page-main{padding-block:clamp(2.5rem,1.5rem + 4vw,5rem) clamp(3rem,2rem + 5vw,6rem)}
.prose{max-inline-size:64ch;margin-inline:auto}
.prose h1{font-family:var(--font-display);font-size:var(--fs-h2);font-weight:700;color:var(--porcelain);letter-spacing:-.015em;line-height:1.12}
html[dir="rtl"] .prose h1{font-family:var(--font-ar)}
.prose .updated{color:var(--slate-dim);font-size:.9rem;margin-block:.6rem 2.2rem}
.prose h2{font-size:1.18rem;font-weight:600;color:var(--porcelain);margin-block:2rem .5rem}
.prose p{color:var(--slate);margin-block-end:.9rem}
.prose ul{margin-block-end:1rem;display:grid;gap:.4rem}
.prose li{position:relative;padding-inline-start:1.2rem;color:var(--slate)}
.prose li::before{content:"";position:absolute;inset-inline-start:0;inset-block-start:.7em;inline-size:.4rem;block-size:.4rem;border-radius:50%;background:var(--gold)}
.prose a{color:var(--gold-lit);font-weight:600;text-underline-offset:2px}
.prose strong{color:var(--porcelain)}
.back-link{display:inline-flex;align-items:center;gap:.4rem;color:var(--gold-lit);font-weight:600;margin-block-end:1.6rem}
.back-link:hover{text-decoration:underline;text-underline-offset:2px}
.error-wrap{min-block-size:56vh;display:grid;place-content:center;text-align:center;gap:1rem;padding-block:4rem}
.error-code{font-family:var(--font-mono);font-size:clamp(3rem,2rem + 6vw,5rem);color:var(--gold-lit);line-height:1}
.error-wrap .section-h{margin-inline:auto}.error-wrap .lede{margin-inline:auto}.u-mt{margin-block-start:1.6rem}

/* ----------------------------- a11y -------------------------------------- */
.skip-link{position:absolute;inset-inline-start:1rem;inset-block-start:-4rem;z-index:100;background:var(--porcelain);
  color:var(--ink);padding:.6rem 1rem;border-radius:0 0 10px 10px;font-weight:600;transition:inset-block-start .15s var(--ease-soft)}
.skip-link:focus{inset-block-start:0}
:focus-visible{outline:2px solid var(--gold-lit);outline-offset:3px;border-radius:6px}
.tally-inset :focus-visible{outline-color:var(--navy)}
:target,[id]{scroll-margin-block-start:5.5rem}

/* ============================================================================
   MOTION — gated on html.anim (set pre-paint). Defaults below = final state,
   so reduced-motion and a JS failure both show the complete design.
   ============================================================================ */

/* generic reveal */
html.anim [data-reveal]{opacity:0;transform:translateY(16px)}
html.anim [data-reveal].in{opacity:1;transform:none;
  transition:opacity .6s var(--ease-out) calc(var(--i,0)*70ms),transform .6s var(--ease-out) calc(var(--i,0)*70ms)}

/* the read: rule draws, text surfaces */
html.anim .read-rule{transform:scaleX(0)}
html.anim .read .read-text{opacity:0;transform:translateY(4px)}
html.anim .read.in .read-rule{transform:scaleX(1);transition:transform .7s var(--ease-wipe) .05s}
html.anim .read.in .read-text{opacity:1;transform:none;transition:opacity .55s var(--ease-out) .28s,transform .55s var(--ease-out) .28s}

/* (flow card icons animate via ambient loops defined in the flow block above) */

/* roster rail draws */
html.anim .roster::before{transform:scaleY(0)}
html.anim .roster.in::before{transform:scaleY(1);transition:transform .8s var(--ease-out)}

/* ----------------------------- Reduced motion ---------------------------- */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .live,.scene-blobs,.marquee-track,.hero-img,.float-icon,.media-disc::after,.fx-ic,.ic-ring,.ic-spark-main{animation:none}
  .btn,.feat-card,.feat-nav,.rrow::before,.link-quiet::after{transition:none}
}
