/* ═══════════════════════════════════════════════════════
   TREE / TREE — تصميم شجرة الجذور (مصحح)
   ═══════════════════════════════════════════════════════ */

/* ── HEADER ── */
.thead {
  text-align: center;
  padding: 12px 0 6px;
}
.trw {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 1.6rem;
  font-weight: 900;
  color: var(--txt);
  direction: ltr;
}
.tra {
  font-size: 0.9rem;
  color: var(--sub);
  margin-top: 2px;
}
.trm {
  font-size: 0.5rem;
  color: var(--muted);
  margin-top: 4px;
}

/* ── NAV BAR ── */
.tnbar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 0 10px;
  border-bottom: 1px solid var(--brd);
  margin-bottom: 10px;
}
.tntbtn {
  background: var(--sur);
  border: 1.5px solid var(--brd);
  border-radius: var(--rsm);
  padding: 6px 12px;
  font-size: 0.8rem;
  cursor: pointer;
  color: var(--txt);
  transition: all var(--t);
}
.tntbtn:hover:not(:disabled) {
  background: var(--v-bg);
  border-color: var(--v);
}
.tntbtn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.tdts {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  justify-content: center;
}
.tdot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--brd2);
  cursor: pointer;
  transition: all var(--t);
  display: inline-block;
}
.tdot.c {
  background: var(--v);
  transform: scale(1.25);
}
.tdot.d {
  background: var(--n);
}
.tdot:hover {
  transform: scale(1.4);
}

/* ── PROGRESS BAR ── */
.tpbar {
  background: var(--sur);
  border: 1px solid var(--brd);
  border-radius: var(--rsm);
  padding: 8px 12px;
  margin-bottom: 12px;
}

/* ── BODY ── */
.tbody {
  position: relative;
  overflow-x: auto;
  padding-bottom: 80px;
}
.tbody::-webkit-scrollbar {
  height: 4px;
}
.tbody::-webkit-scrollbar-thumb {
  background: var(--brd2);
  border-radius: 20px;
}

/* ── ROOT NODE ── */
.tree-root-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 6px 0;
}
.cr-ck {
  position: absolute;
  top: -6px;
  right: -6px;
  font-size: 0.7rem;
  background: var(--n);
  color: #fff;
  border-radius: 50%;
  width: 18px;
  height: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cr-bdg {
  font-size: 0.45rem;
  font-weight: 700;
  color: var(--muted);
  letter-spacing: 0.1em;
}
.cr-w {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--txt);
  direction: ltr;
}
.cr-a {
  font-size: 0.75rem;
  color: var(--sub);
}

/* ── SVG CONNECTIONS (قديم — لم يعد مستخدَماً بعد التحويل لـCSS org-chart) ── */
.tr-svg-conn {
  margin: 0 auto;
  max-width: 100%;
}

/* ═══════════════════════════════════════════════════════
   بطاقات الشجرة — تصميم مبسّط واحترافي:
   شريط لوني علوي يدل على نوع الكلمة (بدل شارة نصية تأخذ مساحة)،
   وأي تفاصيل ثانوية (النطق/التكرار/الصعوبة/المرادفات/الخطأ الشائع)
   تُجمَّع بتلميح (title) واحد بدل ازدحام شارات على وجه البطاقة
   ═══════════════════════════════════════════════════════ */
.tr-node, .tr-gnode, .tr-root-node {
  position: relative;
  cursor: pointer;
  text-align: center;
  border-radius: var(--r);
  background: var(--sur);
  box-shadow: var(--sh);
  border: 1.5px solid var(--brd);
  transition: transform var(--t-fast), box-shadow var(--t-fast), border-color var(--t-fast), background var(--t-fast);
}
.tr-node::before, .tr-gnode::before, .tr-root-node::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  border-radius: var(--r) var(--r) 0 0;
  background: var(--brd2);
}
.tr-node.V::before, .tr-gnode.V::before, .tr-root-node.V::before { background: var(--v); }
.tr-node.N::before, .tr-gnode.N::before, .tr-root-node.N::before { background: var(--n); }
.tr-node.A::before, .tr-gnode.A::before, .tr-root-node.A::before { background: var(--a); }
.tr-node.D::before, .tr-gnode.D::before, .tr-root-node.D::before { background: var(--d); }
.tr-node.P::before, .tr-gnode.P::before, .tr-root-node.P::before { background: var(--p); }

.tr-node:hover, .tr-gnode:hover, .tr-root-node:hover {
  transform: translateY(-3px);
  box-shadow: var(--sh2);
}
.tr-node.sn, .tr-gnode.sn { background: var(--n-bg); border-color: var(--n); }
.tr-node.du, .tr-gnode.du { background: var(--gold-bg); border-color: var(--gold); }

/* ── الجذر الرئيسي: أكبر وأبرز ── */
.tr-root-node {
  padding: 16px 22px 12px;
  min-width: 130px;
  max-width: 230px;
  border-width: 2.5px;
}
.tr-root-node.sn { background: var(--n-bg); border-color: var(--n); }

/* ── بطاقة عادية (الجيل المباشر) ── */
.tr-node {
  width: 104px;
  padding: 12px 6px 8px;
}
/* ── بطاقة الأحفاد (أصغر وأخف) ── */
.tr-gnode {
  width: 84px;
  padding: 10px 5px 6px;
  background: var(--sur2);
}

@media (min-width: 768px) {
  .tr-node { width: 128px; padding: 13px 8px 9px; }
  .tr-gnode { width: 100px; padding: 11px 6px 7px; }
}
@media (min-width: 1024px) {
  .tr-node { width: 148px; padding: 14px 10px 10px; }
  .tr-gnode { width: 112px; padding: 12px 7px 8px; }
}

/* ── محتوى البطاقة الموحّد ── */
.tr-pos {
  position: absolute;
  top: 6px;
  right: 6px;
  font-size: 0.42rem;
  font-weight: 800;
  width: 13px;
  height: 13px;
  line-height: 13px;
  border-radius: 50%;
  opacity: .85;
}
.tr-word {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.76rem;
  font-weight: 700;
  color: var(--txt);
  direction: ltr;
  overflow-wrap: break-word;
}
.tr-gnode .tr-word { font-size: 0.62rem; }
.tr-root-node .tr-word { font-size: 1.4rem; }
.tr-ar {
  font-size: 0.55rem;
  color: var(--sub);
  margin-top: 1px;
}
.tr-gnode .tr-ar { font-size: 0.46rem; }
.tr-root-node .tr-ar { font-size: 0.85rem; margin-top: 3px; }

.tr-badges {
  display: flex;
  gap: 2px;
  justify-content: center;
  margin-top: 4px;
  min-height: 11px;
}
.tr-b {
  font-size: 0.6rem;
  line-height: 1;
}

/* ── محتويات لم تعد تُطبع على وجه البطاقة (منقولة لتلميح title موحّد) ── */
.tr-dtag, .tr-tap { display: none; }

/* ── PREFIXES ── */
.tr-pfx-wrap {
  margin-top: 14px;
  padding: 10px;
  background: var(--sur2);
  border: 1px solid var(--brd);
  border-radius: var(--r);
  width: 100%;
}
.tr-pfx-label {
  font-size: 0.5rem;
  font-weight: 700;
  color: var(--sub);
  margin-bottom: 6px;
}
.tr-pfx-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.tr-pfx-node {
  position: relative;
  background: var(--sur);
  border: 1px solid var(--brd);
  border-radius: var(--rsm);
  padding: 10px 8px 7px;
  text-align: center;
  cursor: pointer;
  transition: transform var(--t-fast), box-shadow var(--t-fast);
  flex: 0 0 auto;
  min-width: 70px;
  box-shadow: var(--sh);
}
.tr-pfx-node:hover {
  transform: translateY(-2px);
  box-shadow: var(--sh2);
  border-color: var(--p);
}
.tr-pfx-node.sn {
  border-color: var(--n);
  background: var(--n-bg);
}
.tr-pfx-node.du {
  border-color: var(--gold);
  background: var(--gold-bg);
}
.tr-pfx-node .tr-word {
  font-size: 0.6rem;
}

/* ── RESPONSIVE (عناصر لم تُعَد تصميمها أعلاه) ── */
@media (max-width: 768px) {
  .trw { font-size: 1.2rem; }
  .tra { font-size: 0.7rem; }
  .cr-w { font-size: 0.9rem; }
  .cr-a { font-size: 0.65rem; }
  .tr-pfx-node { min-width: 50px; padding: 3px 6px 5px; }
  .tr-pfx-node .tr-word { font-size: 0.45rem; }
  .tdot { width: 6px; height: 6px; }
  .tntbtn { padding: 4px 8px; font-size: 0.6rem; }
}

@media (max-width: 480px) {
  .trw { font-size: 1rem; }
  .cr-w { font-size: 0.75rem; }
  .cr-a { font-size: 0.55rem; }
  .tr-pfx-node .tr-word { font-size: 0.4rem; }
  .tdot { width: 5px; height: 5px; }
}
/* ═══════════════════════════════════════════════════════
   عقدة الشجرة الفعلية الحالية (.tnode-card) — تستبدل
   onmouseenter/onmouseleave المضمّنة بـJS بانتقال CSS حقيقي:
   أخف على الأداء، ويحترم تلقائياً prefers-reduced-motion
   ═══════════════════════════════════════════════════════ */
.tnode-card {
  transition: transform var(--t-fast), box-shadow var(--t-fast);
  will-change: transform;
}
.tnode-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--sh2);
}
.tnode-card:active {
  transform: translateY(0);
  transition-duration: 60ms;
}

/* ═══════════════════════════════════════════════════════
   TCHART — مخطط شجري عضوي: الهيكل بـ<ul><li> (متين دائماً،
   لا ينكسر مهما كان عدد الكلمات)، والأغصان بمنحنيات SVG
   ناعمة تُرسم بعد القياس الفعلي للعناصر — تنمو كشجرة حقيقية
   بدل خطوط قائمة الزوايا
   ═══════════════════════════════════════════════════════ */
.tchart, .tchart ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
}
.tchart {
  padding: 8px 10px 16px;
  position: relative;
}
.tchart ul {
  padding-top: 26px;
  position: relative;
}
.tchart li {
  position: relative;
  padding: 26px 10px 0;
  text-align: center;
  flex-shrink: 0;
}
.tchart > li {
  padding-top: 0;
}
.tree-branches {
  position: absolute;
  top: 0;
  left: 0;
  overflow: visible;
  pointer-events: none;
}
.tchart .tgen-label {
  font-size: .32rem;
  color: var(--muted);
  opacity: .8;
  margin-top: 3px;
  white-space: nowrap;
}
@media (max-width: 767px) {
  .tchart ul, .tchart li { padding-top: 18px; }
}

/* ── تلوين خفيف لكل جيل — يميّز العمق بصرياً دون إخفاء حالة البطاقة (sn/du) ── */
.tchart li.tgen-1 > .tr-node,
.tchart li.tgen-1 > .tr-gnode {
  box-shadow: inset 0 0 0 999px color-mix(in srgb, var(--v) 4%, transparent);
}
.tchart li.tgen-2 > .tr-node,
.tchart li.tgen-2 > .tr-gnode {
  box-shadow: inset 0 0 0 999px color-mix(in srgb, var(--p) 5%, transparent);
}
.tchart li.tgen-3 > .tr-node,
.tchart li.tgen-3 > .tr-gnode {
  box-shadow: inset 0 0 0 999px color-mix(in srgb, var(--muted) 6%, transparent);
}
/* حالات sn/du تبقى أوضح من التلوين العام */
.tchart li[class*="tgen-"] > .tr-node.sn,
.tchart li[class*="tgen-"] > .tr-node.du,
.tchart li[class*="tgen-"] > .tr-gnode.sn,
.tchart li[class*="tgen-"] > .tr-gnode.du {
  box-shadow: none;
}

/* ═══════════════════════════════════════════════════════
   التنقّل جيلاً بجيل — مسار الأجداد، معادلة الاشتقاق،
   رقائق النوع/المستوى، ومؤشر التعمّق
   ═══════════════════════════════════════════════════════ */
.tr-crumbs {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 4px;
  padding: 6px 10px 10px;
  font-family: 'IBM Plex Mono', monospace;
}
.tr-crumb {
  font-size: 0.58rem;
  font-weight: 700;
  color: var(--sub);
  background: var(--sur2);
  border: 1px solid var(--brd);
  border-radius: 20px;
  padding: 2px 10px;
  cursor: pointer;
  direction: ltr;
  transition: color var(--t-fast), border-color var(--t-fast);
}
.tr-crumb:hover { color: var(--v); border-color: var(--v); }
.tr-crumb.cur {
  color: var(--txt);
  background: var(--sur);
  border-color: var(--v);
  cursor: default;
}
.tr-crumb-sep { font-size: 0.5rem; color: var(--muted); }

.tr-formula {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.48rem;
  color: var(--muted);
  margin-top: 2px;
}
.tr-root-node .tr-formula { font-size: 0.55rem; margin-top: 4px; }

.tr-meta {
  display: flex;
  gap: 3px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 5px;
}
.tr-mchip {
  font-size: 0.42rem;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 9px;
  line-height: 1.5;
}

.tr-drill {
  margin-top: 6px;
  padding-top: 5px;
  border-top: 1px dashed var(--brd);
  font-size: 0.46rem;
  font-weight: 700;
  color: var(--v);
}
.tr-node.drillable { cursor: pointer; }
.tr-node.drillable:hover { border-color: var(--v); }
.tr-info {
  position: absolute;
  top: 4px;
  left: 5px;
  font-size: 0.55rem;
  opacity: 0.55;
  cursor: pointer;
}
.tr-info:hover { opacity: 1; }

/* بطاقات الجيل بالتنقّل الجديد أوسع قليلاً لاستيعاب المعادلة والرقائق */
.tchart li.tgen-1 .tr-node { width: 118px; padding: 12px 7px 9px; }
@media (min-width: 768px) {
  .tchart li.tgen-1 .tr-node { width: 140px; }
}
@media (min-width: 1024px) {
  .tchart li.tgen-1 .tr-node { width: 158px; }
}

/* ═══════════════════════════════════════════════════════
   طورا العرض: مبدّل (مخطط ⇄ قائمة) + طور القائمة المنسدلة
   ═══════════════════════════════════════════════════════ */
.tvm {
  display: flex;
  gap: 0;
  border: 1px solid var(--brd);
  border-radius: var(--rsm);
  overflow: hidden;
}
.tvm-btn {
  background: var(--sur2);
  border: none;
  padding: 5px 12px;
  cursor: pointer;
  font-size: 0.58rem;
  font-weight: 700;
  color: var(--sub);
  transition: background var(--t-fast), color var(--t-fast);
}
.tvm-btn.on {
  background: var(--v);
  color: #fff;
}
.tvm-btn:not(.on):hover { color: var(--txt); }

/* ── القائمة المنسدلة ── */
.tlist {
  background: var(--sur);
  border: 1px solid var(--brd);
  border-radius: var(--r);
  overflow: hidden;
}
.tl-branch summary { list-style: none; }
.tl-branch summary::-webkit-details-marker { display: none; }
.tl-row {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 8px 10px;
  padding-right: calc(10px + var(--tl-d, 0) * 18px);
  border-bottom: 1px solid var(--brd);
  cursor: pointer;
  transition: background var(--t-fast);
}
.tl-row:hover { background: var(--sur2); }
.tl-branch[open] > summary.tl-row {
  background: color-mix(in srgb, var(--v) 5%, var(--sur));
}
.tl-dot {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  line-height: 16px;
  border-radius: 50%;
  text-align: center;
  font-size: 0.45rem;
  font-weight: 800;
}
.tl-word {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.68rem;
  font-weight: 700;
  color: var(--txt);
  direction: ltr;
}
.tl-formula {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.46rem;
  color: var(--muted);
  direction: ltr;
}
.tl-ar {
  font-size: 0.55rem;
  color: var(--sub);
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.tl-chips {
  display: flex;
  align-items: center;
  gap: 3px;
  flex-shrink: 0;
  font-size: 0.55rem;
}
.tl-count {
  flex-shrink: 0;
  font-size: 0.5rem;
  font-weight: 700;
  color: var(--v);
  font-family: 'IBM Plex Mono', monospace;
}
.tl-branch[open] > summary .tl-count { color: var(--muted); }
.tl-info {
  flex-shrink: 0;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 0.6rem;
  opacity: 0.5;
  padding: 0 2px;
}
.tl-info:hover { opacity: 1; }
.tl-tier {
  font-size: 0.44rem;
  font-weight: 700;
  color: var(--muted);
  padding: 5px 10px 3px;
  padding-right: calc(10px + (var(--tl-d, 0) + 1) * 18px);
  background: var(--sur2);
  border-bottom: 1px solid var(--brd);
}
@media (max-width: 480px) {
  .tl-formula { display: none; }
  .tl-row { padding-right: calc(8px + var(--tl-d, 0) * 12px); }
}

/* ── 💡 نافذة المعلومة المفاجئة ── */
.sfact {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.35);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 999;
  padding: 20px;
  animation: sfIn .18s ease;
}
@keyframes sfIn { from { opacity: 0; } to { opacity: 1; } }
.sfact-card {
  position: relative;
  background: var(--sur);
  border: 1.5px solid var(--v-brd);
  border-radius: var(--r);
  box-shadow: var(--sh2);
  padding: 22px 18px 16px;
  max-width: 340px;
  width: 100%;
  text-align: center;
  animation: sfPop .22s cubic-bezier(.34,1.56,.64,1);
}
@keyframes sfPop { from { transform: scale(.85); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.sfact-x {
  position: absolute;
  top: 8px;
  left: 10px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: .7rem;
  color: var(--muted);
}
.sfact-ic { font-size: 2rem; }
.sfact-t { font-size: .75rem; font-weight: 800; color: var(--v); margin-top: 6px; }
.sfact-b { font-size: .62rem; color: var(--txt); line-height: 1.7; margin-top: 8px; }
.sfact-more {
  margin-top: 14px;
  background: var(--v);
  color: #fff;
  border: none;
  border-radius: var(--rsm);
  padding: 7px 16px;
  font-size: .6rem;
  font-weight: 700;
  cursor: pointer;
}
.sfact-more:hover { opacity: .9; }

/* ═══ 🧠 جذور قريبة ═══ */
.trel {
  margin-top: 14px;
  padding: 12px;
  background: var(--sur);
  border: 1px solid var(--brd);
  border-radius: var(--r);
}
.trel-t { font-size: .58rem; font-weight: 800; color: var(--sub); margin-bottom: 8px; }
.trel-row { display: flex; gap: 6px; flex-wrap: wrap; }
.trel-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--sur2);
  border: 1px solid var(--brd);
  border-radius: 20px;
  padding: 4px 11px;
  font-size: .58rem;
  cursor: pointer;
  transition: border-color .15s, transform .15s;
}
.trel-chip:hover { border-color: var(--v); transform: translateY(-2px); }
.trel-chip.dn { border-color: var(--n-brd); background: var(--n-bg); }
.trel-why { font-size: .4rem; color: var(--muted); }

/* ═══ 🛤️ المسارات الموضوعية ═══ */
.tpaths { margin-bottom: 14px; }
.tpaths-t { font-size: .58rem; font-weight: 800; color: var(--sub); margin-bottom: 8px; }
.tpaths-row {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 6px;
  -webkit-overflow-scrolling: touch;
}
.tpath {
  flex: 0 0 auto;
  width: 96px;
  background: var(--sur);
  border: 1.5px solid var(--brd);
  border-radius: var(--r);
  padding: 10px 8px 8px;
  text-align: center;
  cursor: pointer;
  transition: border-color .15s, transform .15s;
}
.tpath:hover { transform: translateY(-2px); border-color: var(--v); }
.tpath.on { border-color: var(--v); background: var(--v-bg); }
.tpath-ic { font-size: 1.3rem; }
.tpath-l { font-size: .55rem; font-weight: 800; color: var(--txt); margin-top: 3px; }
.tpath-m { font-size: .42rem; color: var(--muted); margin-top: 2px; }
.tpath-bar { height: 4px; background: var(--brd); border-radius: 4px; margin-top: 6px; overflow: hidden; }
.tpath-fill { height: 100%; background: var(--v); border-radius: 4px; }

/* ── نقاط التنقّل: أكبر وألمس-صديقة + مؤشر "المزيد" ── */
.tdot { width: 9px; height: 9px; }
.tdot-more {
  font-size: .55rem;
  color: var(--muted);
  cursor: pointer;
  padding: 0 3px;
  line-height: 1;
}
@media (max-width: 480px) {
  .tdot { width: 8px; height: 8px; }
}

/* ═══ 🛤️ صفحة المسارات المستقلة ═══ */
.pp-sec { font-size: .72rem; font-weight: 900; color: var(--txt); margin: 14px 2px 8px; }
.pp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 10px;
}
.pp-card {
  background: var(--sur);
  border: 1.5px solid var(--brd);
  border-radius: var(--r);
  padding: 14px 10px 10px;
  text-align: center;
  cursor: pointer;
  box-shadow: var(--sh);
  transition: transform .15s, border-color .15s, box-shadow .15s;
}
.pp-card:hover { transform: translateY(-3px); border-color: var(--pc); box-shadow: var(--sh2); }
.pp-ic { font-size: 1.8rem; }
.pp-t { font-size: .68rem; font-weight: 900; color: var(--txt); margin-top: 5px; }
.pp-s { font-size: .48rem; color: var(--muted); margin-top: 2px; min-height: 2em; }
.pp-bar { height: 5px; background: var(--brd); border-radius: 5px; margin-top: 8px; overflow: hidden; }
.pp-fill { height: 100%; background: var(--pc); border-radius: 5px; transition: width .4s ease; }
.pp-m { font-family: 'IBM Plex Mono', monospace; font-size: .46rem; color: var(--sub); margin-top: 5px; }

/* ═══ 🎒 صفحة مسار الكلمات ═══ */
.wp-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: 8px; }
.wp-word {
  position: relative;
  background: var(--sur);
  border: 1.5px solid var(--brd);
  border-radius: var(--r);
  padding: 12px 6px 8px;
  text-align: center;
  cursor: pointer;
  box-shadow: var(--sh);
  transition: transform .15s, border-color .15s;
}
.wp-word:hover { transform: translateY(-2px); border-color: var(--v); }
.wp-word.sn { background: var(--n-bg); border-color: var(--n); }
.wp-word.du { background: var(--gold-bg); border-color: var(--gold); }
.wp-w { font-family: 'IBM Plex Mono', monospace; font-size: .68rem; font-weight: 800; color: var(--txt); direction: ltr; }
.wp-a { font-size: .52rem; color: var(--sub); margin-top: 2px; }
.wp-r { font-size: .42rem; color: var(--muted); margin-top: 4px; direction: ltr; }
.wp-ck { position: absolute; top: 4px; left: 6px; font-size: .55rem; }

/* ═══ 📖 قصة الجذر المولَّدة آلياً ═══ */
.rstory { margin-top: 14px; border-radius: var(--r); padding: 14px; box-shadow: var(--sh); }
.rstory.locked { background: var(--sur2); border: 1.5px dashed var(--brd2); text-align: center; }
.rstory.open { background: linear-gradient(135deg, var(--v-bg), var(--sur)); border: 1.5px solid var(--v-brd); }
.rstory-ic { font-size: 1.6rem; }
.rstory-t { font-size: .78rem; font-weight: 900; color: var(--txt); }
.rstory-d { font-size: .5rem; color: var(--muted); margin-top: 2px; }
.rstory-m { font-family: 'IBM Plex Mono', monospace; font-size: .5rem; color: var(--sub); margin-top: 5px; }
.rstory-hd { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.rstory-body { font-size: .72rem; line-height: 2.1; color: var(--txt); background: var(--sur); border: 1px solid var(--brd); border-radius: var(--rsm); padding: 12px; }
.rstory-w { color: var(--v); cursor: pointer; border-bottom: 1.5px dashed var(--v-brd); }
.rstory-ar { display: inline-block; font-size: .5rem; color: var(--muted); direction: rtl; margin: 0 4px; }
.rstory-ftr { font-size: .48rem; color: var(--sub); margin-top: 8px; text-align: center; }
