/* ============================================================
   iibdaei — "The Living Signal"
   Shared stylesheet · loaded on every page
   ============================================================ */

:root {
  --ink:        #070D0A;   /* near-black green base */
  --ink-2:      #0A130F;   /* slightly lifted panel */
  --ink-3:      #0C1812;   /* card / elevated */
  --palm:       #0B5C45;   /* palm green primary */
  --palm-deep:  #073A2C;   /* deep palm */
  --emerald:    #1FAE74;   /* bright emerald glow / type accent */
  --emerald-hi: #36E29A;   /* hottest highlight */
  --cream:      #F5EFE3;   /* warm cream — primary text */
  --cream-2:    #EDE6D6;   /* secondary cream */
  --muted:      #8A9A91;   /* desaturated green-grey */
  --muted-2:    #5E6F66;
  --line:       rgba(245,239,227,0.10);
  --line-soft:  rgba(245,239,227,0.06);
  --gold:       #C9A227;   /* RARE spark only */

  --font-display: "Bricolage Grotesque", system-ui, sans-serif;
  --font-edit:    "Fraunces", Georgia, serif;       /* italic editorial */
  --font-body:    "IBM Plex Sans", system-ui, sans-serif;
  --font-ar:      "IBM Plex Sans Arabic", system-ui, sans-serif;

  --ease:    cubic-bezier(0.22, 1, 0.36, 1);
  --ease-io: cubic-bezier(0.65, 0, 0.35, 1);
  --maxw:    1280px;
  --gutter:  clamp(1.25rem, 5vw, 5rem);
}

/* ---------- reset / base ---------- */
* { box-sizing: border-box; }
html, body { overflow-x: hidden; max-width: 100%; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: auto; }

body {
  margin: 0;
  background: var(--ink);
  color: var(--cream);
  font-family: var(--font-body);
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0.005em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* Arabic mode swaps body font + direction */
html[lang="ar"] body { font-family: var(--font-ar); letter-spacing: 0; }
html[lang="ar"] .font-edit-i { font-style: normal; }

img, video, svg { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
input, textarea, select, button { font: inherit; }

:focus-visible {
  outline: 2px solid var(--emerald);
  outline-offset: 4px;
}

::selection { background: var(--emerald); color: var(--ink); }

/* ---------- ambient layers ---------- */
/* fine grain / noise overlay across the whole site */
body::after {
  content: "";
  position: fixed; inset: 0;
  z-index: 9000;
  pointer-events: none;
  opacity: 0.045;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- layout helpers ---------- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.section { position: relative; }
.min-w-0 > * { min-width: 0; }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: fixed; top: 0; inset-inline: 0;
  z-index: 1000;
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem;
  padding: 1.05rem var(--gutter);
  transition: background .5s var(--ease), border-color .5s var(--ease), backdrop-filter .5s var(--ease);
  border-bottom: 1px solid transparent;
}
.nav.is-stuck {
  background: rgba(7,13,10,0.72);
  backdrop-filter: blur(18px) saturate(1.1);
  -webkit-backdrop-filter: blur(18px) saturate(1.1);
  border-bottom: 1px solid var(--line-soft);
}

.brand {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(1.15rem, 2.4vw, 1.4rem);
  letter-spacing: -0.02em;
  color: var(--cream);
  display: inline-flex; align-items: baseline; gap: 0.12em;
  white-space: nowrap;
}
.brand .spark { color: var(--emerald); }
.brand .ar { font-family: var(--font-ar); font-weight: 700; font-size: 0.78em; color: var(--muted); margin-inline-start: 0.5em; }

.nav-links {
  display: flex; align-items: center; gap: clamp(1rem, 2.4vw, 2.1rem);
  list-style: none; margin: 0; padding: 0;
  font-size: 0.82rem; font-weight: 500;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.nav-links a { color: var(--cream-2); opacity: 0.78; transition: opacity .3s var(--ease), color .3s var(--ease); position: relative; }
.nav-links a::after {
  content: ""; position: absolute; left: 0; bottom: -5px; height: 1px; width: 0;
  background: var(--emerald); transition: width .35s var(--ease);
}
html[dir="rtl"] .nav-links a::after { left: auto; right: 0; }
.nav-links a:hover { opacity: 1; color: var(--cream); }
.nav-links a:hover::after, .nav-links a[aria-current="page"]::after { width: 100%; }
.nav-links a[aria-current="page"] { opacity: 1; color: var(--cream); }

.nav-right { display: flex; align-items: center; gap: clamp(0.75rem, 1.8vw, 1.4rem); }

/* language switcher */
.lang-toggle {
  display: inline-flex; align-items: center; gap: 0.5ch;
  background: transparent; border: 1px solid var(--line);
  color: var(--cream-2);
  border-radius: 999px;
  padding: 0.42rem 0.85rem;
  font-family: var(--font-body);
  font-size: 0.74rem; font-weight: 600; letter-spacing: 0.08em;
  transition: border-color .3s var(--ease), color .3s var(--ease), background .3s var(--ease);
  min-height: 36px;
}
html[lang="ar"] .lang-toggle { font-family: var(--font-ar); letter-spacing: 0; }
.lang-toggle:hover { border-color: var(--emerald); color: var(--cream); background: rgba(31,174,116,0.08); }
.lang-toggle .globe { width: 14px; height: 14px; stroke: currentColor; fill: none; opacity: 0.8; }
.lang-toggle .lang-on  { color: var(--emerald); }
.lang-toggle .lang-sep { opacity: 0.4; }
.lang-toggle .lang-off { opacity: 0.55; }

.btn-touch {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5ch;
  font-size: 0.78rem; font-weight: 600; letter-spacing: 0.04em;
  padding: 0.62rem 1.25rem; border-radius: 999px;
  background: var(--emerald); color: var(--ink);
  border: 1px solid var(--emerald);
  min-height: 44px;
  transition: transform .3s var(--ease), box-shadow .4s var(--ease), background .3s var(--ease);
  box-shadow: 0 0 0 rgba(31,174,116,0);
}
.btn-touch:hover { transform: translateY(-2px); box-shadow: 0 12px 36px -10px rgba(31,174,116,0.55); background: var(--emerald-hi); }
.btn-touch.ghost { background: transparent; color: var(--cream); border-color: var(--line); }
.btn-touch.ghost:hover { border-color: var(--cream); box-shadow: none; background: rgba(245,239,227,0.05); }

/* hamburger (mobile) */
.nav-burger { display: none; background: none; border: 0; width: 44px; height: 44px; position: relative; }
.nav-burger span { position: absolute; left: 9px; right: 9px; height: 1.5px; background: var(--cream); transition: transform .35s var(--ease), opacity .25s var(--ease); }
.nav-burger span:nth-child(1) { top: 16px; }
.nav-burger span:nth-child(2) { top: 22px; }
.nav-burger span:nth-child(3) { top: 28px; }
.nav-burger.open span:nth-child(1) { top: 22px; transform: rotate(45deg); }
.nav-burger.open span:nth-child(2) { opacity: 0; }
.nav-burger.open span:nth-child(3) { top: 22px; transform: rotate(-45deg); }

/* mobile menu sheet */
.mobile-menu {
  position: fixed; inset: 0; z-index: 990;
  background: rgba(7,13,10,0.97);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  display: flex; flex-direction: column; justify-content: center;
  gap: 0.35rem;
  padding: var(--gutter);
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity .45s var(--ease), visibility .45s var(--ease);
}
.mobile-menu.open { opacity: 1; visibility: visible; pointer-events: auto; }
.mobile-menu a {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(2rem, 9vw, 3.2rem); letter-spacing: -0.02em;
  color: var(--cream); line-height: 1.15;
  opacity: 0; transform: translateY(18px);
  transition: opacity .5s var(--ease), transform .5s var(--ease);
}
.mobile-menu.open a { opacity: 1; transform: translateY(0); }
.mobile-menu.open a:nth-child(1){ transition-delay:.06s } .mobile-menu.open a:nth-child(2){ transition-delay:.12s }
.mobile-menu.open a:nth-child(3){ transition-delay:.18s } .mobile-menu.open a:nth-child(4){ transition-delay:.24s }
.mobile-menu a .idx { font-family: var(--font-body); font-size: 0.9rem; color: var(--emerald); margin-inline-end: 0.8rem; vertical-align: super; }
.mobile-menu .mm-foot { margin-top: 2rem; font-family: var(--font-body); font-size: 0.85rem; color: var(--muted); letter-spacing: 0.04em; }

/* ============================================================
   TYPOGRAPHY PRIMITIVES
   ============================================================ */
.eyebrow {
  font-family: var(--font-body);
  font-size: 0.74rem; font-weight: 600;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--emerald);
  display: inline-flex; align-items: center; gap: 0.7rem;
}
html[lang="ar"] .eyebrow { letter-spacing: 0.06em; }
.eyebrow::before { content: ""; width: 26px; height: 1px; background: linear-gradient(90deg, var(--emerald), transparent); display: inline-block; }
html[dir="rtl"] .eyebrow::before { background: linear-gradient(270deg, var(--emerald), transparent); }

.display {
  font-family: var(--font-display);
  font-weight: 800;
  line-height: 0.96;
  letter-spacing: -0.035em;
  color: var(--cream);
  margin: 0;
  overflow-wrap: anywhere;
}
html[lang="ar"] .display { font-family: var(--font-ar); font-weight: 700; line-height: 1.15; letter-spacing: 0; }

.edit-line {
  font-family: var(--font-edit);
  font-style: italic;
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.01em;
  color: var(--cream);
}
html[lang="ar"] .edit-line { font-family: var(--font-ar); font-style: normal; font-weight: 500; line-height: 1.4; }

.lead { font-size: clamp(1.05rem, 1.8vw, 1.3rem); color: var(--cream-2); line-height: 1.55; max-width: 56ch; }
.body-muted { color: var(--muted); }

.grad-emerald {
  background: linear-gradient(120deg, var(--emerald-hi) 0%, var(--emerald) 45%, var(--palm) 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}

/* ============================================================
   HERO (index)
   ============================================================ */
.hero { position: relative; min-height: 100svh; display: flex; align-items: center; overflow: hidden; }
.hero-media { position: absolute; inset: 0; z-index: 0; }
.hero-media img { width: 100%; height: 100%; object-fit: cover; opacity: 0.9; }
.hero-media::after {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(120% 90% at 70% 30%, rgba(31,174,116,0.10), transparent 55%),
    linear-gradient(to bottom, rgba(7,13,10,0.55) 0%, rgba(7,13,10,0.35) 40%, rgba(7,13,10,0.92) 100%);
}
.hero-glow {
  position: absolute; z-index: 1; width: 60vw; height: 60vw; max-width: 760px; max-height: 760px;
  top: 8%; inset-inline-end: -8%;
  background: radial-gradient(circle, rgba(31,174,116,0.22), transparent 65%);
  filter: blur(40px); pointer-events: none;
}
.hero-inner { position: relative; z-index: 2; padding-block: 8rem 4rem; }
.hero-title {
  font-size: clamp(2.6rem, 11vw, 8.4rem);
  max-width: 11ch;
}
.hero-title .line { display: block; overflow: hidden; }
.hero-title .line > span { display: inline-block; will-change: transform; }

/* scroll cue */
.scroll-cue {
  position: absolute; z-index: 3; bottom: 2.2rem; inset-inline-start: var(--gutter);
  display: inline-flex; align-items: center; gap: 0.8rem;
  font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted);
}
.scroll-cue .track { width: 1px; height: 42px; background: var(--line); position: relative; overflow: hidden; }
.scroll-cue .track::after { content: ""; position: absolute; top: -50%; left: 0; width: 100%; height: 50%; background: var(--emerald); animation: cue 2.4s var(--ease-io) infinite; }
@keyframes cue { 0%{ transform: translateY(0) } 100%{ transform: translateY(300%) } }

/* ============================================================
   CHAPTERS (the 5 verbs) — index
   ============================================================ */
.chapter { position: relative; min-height: 92svh; display: flex; align-items: center; padding-block: 8vh; overflow: hidden; }
.chapter-grid {
  display: grid; gap: clamp(1.5rem, 4vw, 4rem); align-items: center;
  grid-template-columns: 1.05fr 0.95fr;
}
.chapter > .wrap { position: relative; z-index: 1; }
.chapter-shape .chapter-grid { grid-template-columns: 1.08fr 0.82fr; gap: clamp(2.5rem, 7vw, 7rem); }
.chapter-shape .chapter-visual { width: min(100%, 520px); justify-self: end; aspect-ratio: 5/4; }
.chapter-shape .verb { font-size: clamp(2.7rem, 10.2vw, 9.1rem); }
.chapter-endure .chapter-grid { grid-template-columns: 0.9fr minmax(0, 1fr); gap: clamp(2.4rem, 6vw, 6.5rem); }
.chapter-endure .min-w-0:last-child { padding-inline-start: clamp(1rem, 4vw, 3rem); }
.chapter-endure .verb { font-size: clamp(2.6rem, 9.3vw, 8.8rem); max-width: 100%; }
.chapter-num {
  font-family: var(--font-body); font-weight: 600;
  font-size: 0.8rem; letter-spacing: 0.3em; color: var(--emerald);
}
.verb {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(2.8rem, 11.5vw, 10rem);
  line-height: 0.86; letter-spacing: -0.01em;
  color: transparent;
  -webkit-text-stroke: 1.4px rgba(245,239,227,0.16);
  position: relative;
  margin: 0.1em 0 0.15em;
  overflow-wrap: normal;
  word-break: keep-all;
}
html[lang="ar"] .verb { font-family: var(--font-ar); font-weight: 700; -webkit-text-stroke: 1px rgba(245,239,227,0.2); font-size: clamp(2.8rem, 12vw, 9rem); line-height: 1.05; }
/* the green "fill" that wipes in on scroll */
.verb .fill {
  position: absolute; inset: 0;
  color: transparent;
  -webkit-text-stroke: 0;
  background: linear-gradient(115deg, var(--emerald-hi), var(--emerald) 50%, var(--palm));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  clip-path: inset(0 100% 0 0);
  will-change: clip-path;
}
html[dir="rtl"] .verb .fill { clip-path: inset(0 0 0 100%); }
.verb[data-filled] .fill { clip-path: inset(0 0 0 0); }

.chapter-statement { font-size: clamp(1.5rem, 3.6vw, 2.9rem); margin: 0.2em 0 0.6em; max-width: 18ch; }
.chapter-support { color: var(--muted); max-width: 44ch; font-size: clamp(1rem, 1.5vw, 1.18rem); }
.chapter-tag {
  margin-top: 1.6rem; font-size: 0.74rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--cream-2); opacity: 0.75; display: inline-flex; align-items: center; gap: 0.7rem;
}
.chapter-tag .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--emerald); box-shadow: 0 0 12px var(--emerald); }

/* the liquid motif visual that reacts per chapter */
.chapter-visual {
  position: relative; aspect-ratio: 4/3; border-radius: 18px; overflow: hidden;
  border: 1px solid var(--line-soft);
  background: var(--ink-2);
  box-shadow: 0 28px 80px -52px rgba(31,174,116,0.38);
}
.chapter-visual img { width: 100%; height: 100%; object-fit: cover; will-change: transform; transform: scale(1.06); opacity: 0.94; }
.chapter-visual::after {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(80% 80% at 50% 40%, transparent, rgba(7,13,10,0.55));
}
.chapter-visual .visual-label {
  position: absolute; inset-inline-start: 1.1rem; bottom: 1rem; z-index: 2;
  font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--cream-2);
  display: flex; align-items: center; gap: 0.6rem;
}
.chapter-visual .visual-label b { color: var(--emerald); font-weight: 600; }

/* a continuous vertical "signal" line that threads chapters */
.signal-thread {
  position: absolute; inset-inline-start: 50%; top: 0; bottom: 0; width: 1px;
  background: var(--line-soft); z-index: 0; pointer-events: none;
}
.signal-thread::before {
  content: ""; position: absolute; top: 0; left: -1px; width: 3px; height: 30vh;
  background: linear-gradient(to bottom, transparent, var(--emerald), transparent);
  filter: blur(1px);
  animation: thread 7s linear infinite;
}
@keyframes thread { 0%{ top: -30vh } 100%{ top: 100% } }

/* ============================================================
   STAT MOMENT — industrial delivery signals
   ============================================================ */
.statband { position: relative; padding-block: clamp(5rem, 12vh, 9rem); background: var(--ink-2); border-block: 1px solid var(--line-soft); overflow: hidden; }
.statband .softbg { position: absolute; inset: 0; z-index: 0; opacity: 0.5; }
.statband .softbg img { width: 100%; height: 100%; object-fit: cover; }
.statband .softbg::after { content:""; position:absolute; inset:0; background: linear-gradient(to bottom, var(--ink-2), rgba(10,19,15,0.4), var(--ink-2)); }
.statgrid { position: relative; z-index: 1; display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.5rem, 4vw, 3rem) clamp(1rem,3vw,2.5rem); }
.stat { border-top: 1px solid var(--line); padding-top: 1.1rem; }
.stat .num {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(2.2rem, 5.5vw, 4rem); line-height: 1;
  letter-spacing: -0.03em; color: var(--cream);
}
.stat .num .grad-emerald { display: inline; }
.stat .lbl { margin-top: 0.5rem; font-size: 0.82rem; color: var(--muted); letter-spacing: 0.03em; }

/* ============================================================
   ARABIC LINE MOMENT
   ============================================================ */
.ar-moment {
  text-align: center;
  padding-block: clamp(4.5rem, 10vh, 7rem);
  position: relative;
  overflow: hidden;
  border-block: 1px solid var(--line-soft);
  isolation: isolate;
}
.ar-moment::after {
  content: "";
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(45% 60% at 50% 50%, rgba(31,174,116,0.16), transparent 68%),
    linear-gradient(to bottom, rgba(7,13,10,0.92), rgba(7,13,10,0.72), rgba(7,13,10,0.94));
}
.ar-motion {
  position: absolute; inset: -8% 0; z-index: -3;
  width: 100%; height: 116%;
  object-fit: cover;
  opacity: 0.18;
  filter: saturate(1.2) contrast(1.08);
  animation: ar-drift 14s var(--ease-io) infinite alternate;
}
.ar-gridline {
  position: absolute; inset: 0; z-index: -2; opacity: 0.22;
  background-image:
    linear-gradient(rgba(245,239,227,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245,239,227,0.04) 1px, transparent 1px);
  background-size: 54px 54px;
  mask-image: radial-gradient(circle at 50% 50%, black, transparent 72%);
}
@keyframes ar-drift { from { transform: scale(1.04) translate3d(-1.5%, -1%, 0); } to { transform: scale(1.12) translate3d(1.5%, 1%, 0); } }
.ar-moment .ar-big {
  font-family: var(--font-ar); font-weight: 700;
  font-size: clamp(3.5rem, 16vw, 10rem); line-height: 1; color: transparent;
  margin: 0;
  background: linear-gradient(120deg, var(--emerald-hi), var(--palm)); -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.ar-moment .ar-trans { margin: 0.65rem 0 0; font-family: var(--font-edit); font-style: italic; font-size: clamp(1.2rem, 3vw, 2rem); color: var(--cream-2); }
html[lang="ar"] .ar-moment .ar-trans { font-family: var(--font-ar); font-style: normal; }

/* ============================================================
   CTA BLOCK
   ============================================================ */
.cta { position: relative; padding-block: clamp(6rem, 15vh, 10rem); text-align: center; overflow: hidden; }
.cta-title { font-size: clamp(2.4rem, 8vw, 6rem); }
.cta .actions { display: inline-flex; flex-wrap: wrap; gap: 1rem; justify-content: center; margin-top: 2.4rem; }

/* ============================================================
   EDITORIAL SECTIONS (capabilities / about)
   ============================================================ */
.section-pad { padding-block: clamp(4.5rem, 11vh, 8rem); }
.page-hero { position: relative; padding-block: clamp(8rem, 20vh, 13rem) clamp(2rem,6vh,4rem); overflow: hidden; }
.page-hero .glow { position: absolute; z-index: 0; width: 50vw; height: 50vw; max-width: 620px; max-height: 620px; top: -10%; inset-inline-end: -6%; background: radial-gradient(circle, rgba(31,174,116,0.16), transparent 65%); filter: blur(30px); }
.page-hero-title { font-size: clamp(2.6rem, 9vw, 6.5rem); position: relative; z-index: 1; }

/* capability editorial row */
.cap {
  display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(1.5rem, 5vw, 4.5rem);
  align-items: start;
  padding-block: clamp(3rem, 8vh, 6rem);
  border-top: 1px solid var(--line-soft);
  position: relative;
}
.cap:first-of-type { border-top: 0; }
.cap-index {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(3rem, 8vw, 6rem); line-height: 0.9;
  color: transparent; -webkit-text-stroke: 1px rgba(31,174,116,0.4);
}
.cap-verb { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.7rem, 4vw, 2.8rem); letter-spacing: -0.02em; color: var(--cream); margin: 0.2em 0 0.1em; }
html[lang="ar"] .cap-verb { font-family: var(--font-ar); font-weight: 700; }
.cap-name { font-family: var(--font-edit); font-style: italic; font-size: clamp(1.05rem, 2vw, 1.4rem); color: var(--emerald); }
html[lang="ar"] .cap-name { font-family: var(--font-ar); font-style: normal; }
.cap-body p { color: var(--cream-2); margin: 0 0 1.2rem; max-width: 56ch; }
.cap-deliver { list-style: none; margin: 1.5rem 0 0; padding: 0; display: grid; gap: 0.85rem; }
.cap-deliver li { display: flex; align-items: baseline; gap: 0.85rem; color: var(--cream-2); font-size: 0.98rem; }
.cap-deliver li::before { content: ""; flex: none; width: 7px; height: 7px; border-radius: 50%; margin-top: 0.45em; background: var(--emerald); box-shadow: 0 0 10px rgba(31,174,116,0.7); }
html[dir="rtl"] .cap-deliver li { text-align: start; }

/* about prose */
.prose-lg p { font-size: clamp(1.1rem, 1.9vw, 1.45rem); line-height: 1.65; color: var(--cream-2); max-width: 62ch; margin: 0 0 1.6rem; }
.prose-lg p .hl { color: var(--cream); }
.ethos-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.5rem, 4vw, 3rem); margin-top: 1rem; }
.ethos { border-top: 1px solid var(--line); padding-top: 1.2rem; }
.ethos h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; margin: 0 0 0.5rem; color: var(--cream); }
html[lang="ar"] .ethos h3 { font-family: var(--font-ar); }
.ethos p { color: var(--muted); font-size: 0.95rem; margin: 0; }

.partner-card {
  border: 1px solid var(--line); border-radius: 20px; padding: clamp(1.6rem, 4vw, 2.6rem);
  background: linear-gradient(160deg, var(--ink-3), var(--ink-2));
  position: relative; overflow: hidden;
}
.partner-card::before { content:""; position:absolute; top:-40%; inset-inline-end:-20%; width: 60%; height: 120%; background: radial-gradient(circle, rgba(31,174,116,0.12), transparent 70%); }
.partner-stat { font-family: var(--font-display); font-weight: 800; font-size: clamp(2.6rem,7vw,4.5rem); line-height: 1; color: var(--cream); }

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 6vw, 5rem); align-items: start; }
.field { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 1.4rem; }
.field label { font-size: 0.76rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); }
.field input, .field textarea, .field select {
  background: var(--ink-2); border: 1px solid var(--line); border-radius: 12px;
  color: var(--cream); font-family: inherit; font-size: 1rem;
  padding: 0.95rem 1.1rem; width: 100%;
  transition: border-color .3s var(--ease), box-shadow .3s var(--ease), background .3s var(--ease);
  min-height: 48px;
}
html[lang="ar"] .field input, html[lang="ar"] .field textarea, html[lang="ar"] .field select { font-family: var(--font-ar); }
.field textarea { resize: vertical; min-height: 130px; }
.field input::placeholder, .field textarea::placeholder { color: var(--muted-2); }
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--emerald); box-shadow: 0 0 0 4px rgba(31,174,116,0.12); background: var(--ink-3); }
.contact-detail { display: flex; flex-direction: column; gap: 0.3rem; padding-block: 1.3rem; border-top: 1px solid var(--line-soft); }
.contact-detail .k { font-size: 0.74rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--emerald); }
.contact-detail .v { font-size: clamp(1.1rem, 2.5vw, 1.5rem); color: var(--cream); font-family: var(--font-display); font-weight: 600; }
html[lang="ar"] .contact-detail .v { font-family: var(--font-ar); }
.contact-trust-panel {
  position: relative;
  margin-top: 2rem;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(245,239,227,0.12);
  background: var(--ink-2);
  box-shadow: 0 34px 92px -58px rgba(31,174,116,0.5);
}
.contact-trust-panel img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.05); }
.contact-trust-panel::after {
  content: "";
  position: absolute; inset: 0;
  background:
    linear-gradient(135deg, rgba(7,13,10,0.72), transparent 42%),
    radial-gradient(60% 40% at 75% 18%, rgba(54,226,154,0.18), transparent 65%);
}
.trust-scan {
  position: absolute; inset: 0; z-index: 2;
  background: linear-gradient(180deg, transparent, rgba(54,226,154,0.18), transparent);
  height: 34%;
  transform: translateY(-120%);
  animation: trust-scan 5.8s linear infinite;
  mix-blend-mode: screen;
}
.trust-card {
  position: absolute; z-index: 3;
  min-width: min(210px, 64%);
  padding: 0.85rem 1rem;
  border: 1px solid rgba(245,239,227,0.14);
  border-radius: 14px;
  background: rgba(7,13,10,0.68);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.trust-card span {
  display: block;
  color: var(--muted);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.trust-card b {
  display: block;
  margin-top: 0.2rem;
  color: var(--cream);
  font-family: var(--font-display);
  font-size: 1.05rem;
}
.trust-card-a { top: 1rem; inset-inline-start: 1rem; }
.trust-card-b { bottom: 1rem; inset-inline-end: 1rem; }
@keyframes trust-scan { 0% { transform: translateY(-120%); opacity: 0; } 12%, 76% { opacity: 1; } 100% { transform: translateY(320%); opacity: 0; } }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { position: relative; border-top: 1px solid var(--line-soft); padding-block: clamp(4rem, 9vh, 6rem) 2.5rem; overflow: hidden; background: var(--ink); }
.footer-word {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(4rem, 24vw, 22rem); line-height: 0.8; letter-spacing: -0.04em;
  color: transparent; -webkit-text-stroke: 1px rgba(245,239,227,0.10);
  background: linear-gradient(100deg, transparent 0%, rgba(31,174,116,0.10) 28%, rgba(54,226,154,0.62) 48%, rgba(201,162,39,0.22) 58%, transparent 78%);
  background-size: 260% 100%;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: footer-signal 8.5s linear infinite;
  margin-block: 0 1.5rem; user-select: none;
  display: flex; align-items: baseline; gap: 0.08em;
  max-width: 100%;
  overflow: hidden;
}
.footer-word .spark { -webkit-text-stroke: 0; color: transparent; -webkit-text-fill-color: transparent; }
@keyframes footer-signal { from { background-position: 140% 50%; } to { background-position: -140% 50%; } }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 2.5rem; padding-top: 2.5rem; border-top: 1px solid var(--line-soft); }
.footer-grid h4 { font-size: 0.74rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); margin: 0 0 1.1rem; }
.footer-grid ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.7rem; }
.footer-grid a { color: var(--cream-2); opacity: 0.78; transition: opacity .3s, color .3s; font-size: 0.95rem; }
.footer-grid a:hover { opacity: 1; color: var(--emerald); }
.footer-bottom { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: space-between; align-items: center; margin-top: 3rem; padding-top: 1.6rem; border-top: 1px solid var(--line-soft); font-size: 0.82rem; color: var(--muted); }
.footer-bottom .ar { font-family: var(--font-ar); }

/* ============================================================
   SCROLL REVEAL primitives (JS toggles .in)
   ============================================================ */
.reveal { opacity: 0; transform: translateY(34px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal-d1 { transition-delay: .08s; } .reveal-d2 { transition-delay: .16s; }
.reveal-d3 { transition-delay: .24s; } .reveal-d4 { transition-delay: .32s; }
.clip-up { clip-path: inset(0 0 100% 0); transition: clip-path 1.1s var(--ease); will-change: clip-path; }
.clip-up.in { clip-path: inset(0 0 0% 0); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .footer-word { font-size: clamp(3.5rem, 26vw, 14rem); }
}

@media (max-width: 880px) {
  .nav-links { display: none; }
  .nav-cta-desktop { display: none; }
  .nav-burger { display: block; }
  .nav-right { gap: 0.5rem; }

  .chapter-grid { grid-template-columns: 1fr; gap: 2rem; }
  .signal-thread { inset-inline-start: 0.45rem; opacity: 0.48; }
  .chapter { min-height: auto; padding-block: 12vh; }
  .chapter-shape .chapter-grid,
  .chapter-endure .chapter-grid { grid-template-columns: 1fr; gap: 2rem; }
  .chapter-shape .chapter-visual { width: 100%; justify-self: stretch; }
  .chapter-endure .min-w-0:last-child { padding-inline-start: 0; }
  .chapter-visual { aspect-ratio: 16/10; }

  .statgrid { grid-template-columns: repeat(2, 1fr); }
  .cap { grid-template-columns: 1fr; gap: 1.5rem; }
  .cap-head { display: flex; align-items: baseline; gap: 1.2rem; }
  .ethos-grid { grid-template-columns: 1fr; gap: 1.5rem; }
  .contact-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
  .partner-layout { grid-template-columns: 1fr !important; }
}

@media (max-width: 640px) {
  .nav { padding-block: 0.85rem; }
  .brand .ar { display: none; }
  .lang-toggle { padding-inline: 0.7rem; min-height: 42px; }
  .hero-title { font-size: clamp(2.35rem, 14vw, 4.6rem); max-width: 9ch; }
  .page-hero-title { font-size: clamp(2.35rem, 13vw, 4.8rem); }
  .verb { font-size: clamp(2.25rem, 15vw, 5.4rem); line-height: 0.9; }
  .chapter-endure .verb { font-size: clamp(2.05rem, 13.2vw, 5rem); }
  html[lang="ar"] .verb { font-size: clamp(2.15rem, 13vw, 4.8rem); }
  .chapter-statement { max-width: 100%; }
  .chapter-visual .visual-label { letter-spacing: 0.1em; }
  .cap-head { align-items: flex-start; }
  .cap-index { font-size: clamp(2.6rem, 18vw, 4.5rem); }
}

@media (max-width: 480px) {
  :root { --gutter: 1.25rem; }
  .statgrid { grid-template-columns: 1fr 1fr; gap: 1.4rem 1rem; }
  .hero-inner { padding-block: 7rem 3rem; }
  .scroll-cue { display: none; }
  .btn-touch { width: 100%; }
  .lang-toggle .globe { display: none; }
  .trust-card { min-width: auto; max-width: calc(100% - 2rem); }
  .trust-card b { font-size: 0.95rem; }
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; scroll-behavior: auto !important; }
  .reveal, .clip-up { opacity: 1 !important; transform: none !important; clip-path: none !important; }
  .verb .fill { clip-path: inset(0 0 0 0) !important; }
  .signal-thread::before, .scroll-cue .track::after, .ar-motion, .trust-scan, .footer-word { animation: none !important; }
}
