/* ============================================================
   style.css — Web Infrastructure Design
   ثيم: لوحة عمليات مركز بيانات (NOC) — سلِيت أزرق بارد + إشارة سماوية
   دلالات الحالة: UP أخضر · WARN كهرماني · DOWN/SPOF أحمر
   ============================================================ */
:root {
  /* أسطح: من الأعمق للأعلى (غرفة خوادم ليلاً) */
  --void: #06090e;
  --deep: #0a0f16;
  --panel: #0e141d;
  --elevated: #131c27;
  --code: #0a1018;
  /* نصوص */
  --fg: #dde7f2;
  --muted: #9fb1c6;
  --dim: #6c8198;
  --faint: #44586e;
  /* خطوط/حدود */
  --line-faint: #18222e;
  --line: #233140;
  --line-strong: #38506a;
  /* لون مهيمن: إشارة (تدفّق الطلب، الروابط، النشِط) */
  --signal: #34d6c6;
  --signal-dim: #18514c;
  --accent2: #5aa2ff;          /* ثانوي: أزرق */
  /* دلالات الحالة */
  --ok: #46d27e;   --ok-dim: #1c5a39;     /* UP / مكرّر / صحّي */
  --warn: #f3b24a; --warn-dim: #6a4d18;   /* WARN / صيانة */
  --danger: #ff5c6a; --danger-dim: #6e2630; /* DOWN / SPOF */
  --info: #5aa2ff; --info-dim: #244468;
  /* خطوط */
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --body: "IBM Plex Sans Arabic", system-ui, "Segoe UI", Tahoma, sans-serif;
  --radius: 2px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--body);
  color: var(--fg);
  background: var(--void);
  line-height: 1.78;
  font-size: 16.5px;
  -webkit-font-smoothing: antialiased;
  /* عمق بطبقات: توهّج شعاعي بارد + شبكة blueprint دقيقة */
  background-image:
    radial-gradient(1100px 540px at 82% -8%, rgba(52, 214, 198, 0.07), transparent 60%),
    radial-gradient(900px 600px at 8% 4%, rgba(90, 162, 255, 0.05), transparent 55%),
    linear-gradient(var(--line-faint) 1px, transparent 1px),
    linear-gradient(90deg, var(--line-faint) 1px, transparent 1px);
  background-size: 100% 100%, 100% 100%, 44px 44px, 44px 44px;
  background-position: 0 0, 0 0, -1px -1px, -1px -1px;
  background-attachment: fixed;
}

/* ===== ثنائية اللغة ===== */
code, pre, pre code, .ascii, .en, .badge, .mono {
  direction: ltr;
  unicode-bidi: isolate;
  font-family: var(--mono);
}
::selection { background: var(--signal); color: #04110f; }

a { color: var(--signal); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 3px; }

/* ===== شريط علوي ===== */
.topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; gap: 16px;
  padding: 0 22px; height: 46px;
  background: rgba(8, 12, 18, 0.86);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
  font-family: var(--mono); font-size: 12.5px;
}
.topbar .brand { color: var(--signal); font-weight: 700; letter-spacing: 0.5px; }
.topbar .meta { display: flex; gap: 16px; color: var(--dim); }
.topbar .meta b { color: var(--fg); }
.topbar .meta b.built { color: var(--ok); }
.topbar .spacer { flex: 1; }
.topbar .kbd-hint { color: var(--faint); cursor: pointer; }
.topbar .kbd-hint:hover { color: var(--muted); }
.topbar .status {
  color: var(--ok); text-transform: uppercase; letter-spacing: 1px;
  display: flex; align-items: center; gap: 7px;
}
.topbar .status::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--ok); box-shadow: 0 0 8px var(--ok);
  animation: pulse 2s infinite;
}
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.35; } }

/* شعاع القراءة */
.beam {
  position: fixed; top: 46px; right: 0; height: 2px; width: 0;
  background: linear-gradient(90deg, var(--accent2), var(--signal));
  z-index: 49; box-shadow: 0 0 10px var(--signal);
}

/* ===== الهيكل ===== */
.shell { display: grid; grid-template-columns: 320px 1fr; align-items: start; }

/* ===== الشريط الجانبي ===== */
.sidebar {
  position: sticky; top: 46px; align-self: start;
  height: calc(100vh - 46px); overflow-y: auto;
  padding: 22px 16px 60px;
  border-left: 1px solid var(--line);
  background: linear-gradient(180deg, var(--deep), var(--void));
  font-family: var(--mono); font-size: 13px;
}
.sb-title { color: var(--faint); font-size: 11px; letter-spacing: 1.5px; margin: 20px 8px 8px; }
.sb-title:first-child { margin-top: 0; }
.sidebar a {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 10px; color: var(--muted); border: 1px solid transparent;
  border-radius: var(--radius);
}
.sidebar a:hover { background: var(--panel); color: var(--fg); text-decoration: none; border-color: var(--line); }
.sidebar a .num {
  color: var(--dim); font-size: 11px; min-width: 26px; text-align: center;
  border: 1px solid var(--line); padding: 1px 0; border-radius: var(--radius);
}
.sidebar a.active { background: var(--panel); color: var(--fg); border-color: var(--signal-dim); }
.sidebar a.active .num { color: var(--signal); border-color: var(--signal); }
.sidebar a.active::before { content: "▸"; color: var(--signal); margin-left: -4px; }
.sidebar a.done .num { color: var(--ok); border-color: var(--ok-dim); }
.sidebar a.done .num::after { content: " ✓"; }
.sidebar a.locked { opacity: 0.5; }
.cheat {
  margin: 8px; padding: 12px; font-size: 11.5px; line-height: 2;
  color: var(--dim); background: var(--code);
  border: 1px solid var(--line-faint); border-radius: var(--radius);
}
.cheat b { color: var(--signal); }
.cheat .w { color: var(--warn); }
.cheat .c { color: var(--accent2); }
.cheat .d { color: var(--danger); }

/* ===== المحتوى ===== */
.main { max-width: 1080px; padding: 52px 64px 120px; min-width: 0; }
.main-index { max-width: 1160px; }

/* ===== العناوين ===== */
h1 {
  font-size: clamp(30px, 4vw, 46px); line-height: 1.2; margin: 0 0 18px;
  font-weight: 700; letter-spacing: -0.3px; text-wrap: balance;
}
h1 .accent { color: var(--signal); }
h2 {
  font-size: clamp(22px, 2.6vw, 30px); margin: 64px 0 18px; padding-top: 24px;
  border-top: 1px solid var(--line); display: flex; align-items: baseline; gap: 14px;
  text-wrap: balance; font-weight: 700;
}
h2[data-num]::before {
  content: attr(data-num); font-family: var(--mono); font-size: 14px;
  color: var(--signal); border: 1px solid var(--signal-dim); border-radius: var(--radius);
  padding: 3px 9px; flex: none; background: var(--code);
}
h3 {
  font-size: 19px; margin: 36px 0 12px; color: var(--accent2); font-weight: 700;
}
h3::before { content: "// "; color: var(--faint); font-family: var(--mono); font-weight: 400; }
h4 {
  font-family: var(--mono); font-size: 15px; color: var(--warn);
  margin: 26px 0 10px; font-weight: 500;
}
p { margin: 14px 0; text-wrap: pretty; }
strong { color: #fff; font-weight: 700; }
em { color: var(--signal); font-style: normal; }
hr { border: 0; border-top: 1px solid var(--line); margin: 40px 0; }

/* قوائم RTL */
ul, ol { padding-right: 24px; padding-left: 0; margin: 14px 0; }
li { margin: 8px 0; }
li::marker { color: var(--signal); }
.chk {
  display: inline-block; width: 15px; height: 15px; margin-left: 8px;
  vertical-align: -2px; border: 1px solid var(--line-strong);
  border-radius: var(--radius); background: var(--code);
}
li.has-chk { list-style: none; margin-right: -18px; }

/* ===== الكود ===== */
code {
  background: var(--code); border: 1px solid var(--line-faint);
  padding: 1px 6px; border-radius: var(--radius); font-size: 0.86em; color: #b9e9e2;
}
a code { color: var(--signal); }
pre {
  background: var(--code); border: 1px solid var(--line); border-radius: var(--radius);
  margin: 18px 0; overflow: hidden;
}
.term-head {
  display: flex; align-items: center; gap: 8px; padding: 7px 12px;
  background: var(--panel); border-bottom: 1px solid var(--line);
  font-family: var(--mono); font-size: 11px; color: var(--dim);
}
.term-head::before {
  content: "● ● ●"; color: var(--line-strong); letter-spacing: 2px; font-size: 9px;
}
.term-head .tt { text-transform: uppercase; letter-spacing: 1px; }
.term-head .copy {
  margin-right: auto; background: none; border: 1px solid var(--line);
  color: var(--dim); font-family: var(--mono); font-size: 10.5px;
  padding: 2px 9px; border-radius: var(--radius); cursor: pointer;
}
.term-head .copy:hover { color: var(--signal); border-color: var(--signal-dim); }
pre code { display: block; padding: 14px 16px; background: none; border: 0; color: #cde0d8; font-size: 13px; line-height: 1.7; text-align: left; overflow-x: auto; }
pre code .cmt { color: var(--faint); }
pre code .pmt { color: var(--ok); }
pre code .kw { color: var(--accent2); }
pre code .str { color: var(--warn); }
pre code .num { color: var(--signal); }

/* ===== الحاويات الدلالية ===== */
.callout {
  margin: 20px 0; padding: 14px 16px 14px 16px;
  border: 1px solid var(--line); border-right: 3px solid var(--info);
  background: linear-gradient(90deg, rgba(90, 162, 255, 0.05), transparent);
  border-radius: var(--radius);
}
.callout .label {
  font-family: var(--mono); font-size: 11px; letter-spacing: 1px;
  text-transform: uppercase; color: var(--info); margin-bottom: 6px;
}
.callout p:first-of-type, .callout p:last-child { margin-bottom: 0; }
.callout p:first-of-type { margin-top: 0; }
.callout.info { border-right-color: var(--info); }
.callout.info .label { color: var(--info); }
.callout.warn { border-right-color: var(--warn); background: linear-gradient(90deg, rgba(243, 178, 74, 0.06), transparent); }
.callout.warn .label { color: var(--warn); }
.callout.danger { border-right-color: var(--danger); background: linear-gradient(90deg, rgba(255, 92, 106, 0.07), transparent); }
.callout.danger .label { color: var(--danger); }

.panel {
  margin: 22px 0; padding: 20px 22px; background: var(--deep);
  border: 1px solid var(--line); border-radius: var(--radius);
}
.panel.bracket { position: relative; }
.panel.bracket::before, .panel.bracket::after {
  content: ""; position: absolute; width: 14px; height: 14px;
  border: 2px solid var(--signal);
}
.panel.bracket::before { top: -1px; right: -1px; border-bottom: 0; border-left: 0; }
.panel.bracket::after { bottom: -1px; left: -1px; border-top: 0; border-right: 0; }

/* صندوق اللغز (عنوان طافٍ على الحدّ) */
.box {
  position: relative; margin: 30px 0; padding: 22px 20px 18px;
  border: 1px solid var(--warn-dim); border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(243, 178, 74, 0.04), transparent 60%);
}
.box[data-label]::before {
  content: attr(data-label); position: absolute; top: -11px; right: 16px;
  background: var(--deep); padding: 2px 12px; font-family: var(--mono);
  font-size: 12px; letter-spacing: 1px; color: var(--warn);
  border: 1px solid var(--warn-dim); border-radius: var(--radius);
}
.box .box-title { font-weight: 700; color: var(--fg); margin-bottom: 6px; font-size: 17px; }
.box.cyan { border-color: var(--signal-dim); background: linear-gradient(180deg, rgba(52, 214, 198, 0.05), transparent 60%); }
.box.cyan[data-label]::before { color: var(--signal); border-color: var(--signal-dim); }
/* صندوق "على السبورة" = الإجابة المُسلَّمة (أخضر، LTR للإنجليزية) */
.box.ok { border-color: var(--ok-dim); background: linear-gradient(180deg, rgba(70, 210, 126, 0.05), transparent 60%); }
.box.ok[data-label]::before { content: "🎤 على السبورة"; color: var(--ok); border-color: var(--ok-dim); }
.box.ok .callout { direction: ltr; text-align: left; border-right: 0; border-left: 3px solid var(--ok-dim); background: var(--code); }
.box.ok .callout p { font-family: var(--mono); font-size: 13.5px; line-height: 1.85; color: #cfe9da; }
.box .callout { margin: 12px 0 0; }

/* بلوك "الكلام المنطوق" بالإنجليزية (LTR) */
.speak {
  direction: ltr; text-align: left; margin: 14px 0 0;
  padding: 14px 16px; background: var(--code);
  border: 1px solid var(--line); border-left: 3px solid var(--ok-dim);
  border-radius: var(--radius);
}
.box.ok .speak { border-left-color: var(--ok); }
.speak p { font-family: var(--mono); font-size: 13px; line-height: 1.85; color: #cfe9da; margin: 8px 0; }
.speak p:first-child { margin-top: 0; }
.speak p:last-child { margin-bottom: 0; }
.speak ol, .speak ul { padding-left: 22px; padding-right: 0; }
.speak li { color: #cfe9da; font-family: var(--mono); font-size: 13px; }
.speak strong { color: var(--ok); }
.speak code { color: #b9e9e2; }

/* ===== الجداول ===== */
table { width: 100%; border-collapse: collapse; margin: 22px 0; font-size: 14.5px; }
th, td { border: 1px solid var(--line); padding: 9px 13px; text-align: right; vertical-align: top; }
th { background: var(--panel); color: var(--signal); font-family: var(--mono); font-size: 12.5px; letter-spacing: 0.5px; font-weight: 500; }
tbody tr:nth-child(even) { background: rgba(255, 255, 255, 0.012); }
tbody tr:hover { background: rgba(52, 214, 198, 0.04); }

/* ===== badges ===== */
.badge {
  display: inline-block; font-size: 11px; padding: 1px 8px; border-radius: var(--radius);
  border: 1px solid var(--line); color: var(--dim); margin: 0 2px;
}
.badge.ok { color: var(--ok); border-color: var(--ok-dim); }
.badge.bad { color: var(--danger); border-color: var(--danger-dim); }
.badge.warn { color: var(--warn); border-color: var(--warn-dim); }
.badge.info { color: var(--info); border-color: var(--info-dim); }

/* ===== TOC ===== */
.toc {
  float: left; width: 230px; margin: 0 28px 18px 0; padding: 14px 16px;
  background: var(--deep); border: 1px solid var(--line); border-radius: var(--radius);
  font-size: 13px;
}
.toc-h { font-family: var(--mono); font-size: 11px; letter-spacing: 1.5px; color: var(--faint); margin-bottom: 8px; }
.toc ol { padding-right: 18px; margin: 0; }
.toc li { margin: 3px 0; }
.toc a { color: var(--muted); }
.toc a.active { color: var(--signal); }

/* ===== pager ===== */
.pager { display: flex; justify-content: space-between; gap: 16px; margin: 56px 0 0; border-top: 1px solid var(--line); padding-top: 24px; }
.pager a {
  flex: 1; max-width: 48%; padding: 14px 18px; border: 1px solid var(--line);
  border-radius: var(--radius); background: var(--deep); transition: 0.14s;
}
.pager a:hover { border-color: var(--signal-dim); transform: translateY(-2px); text-decoration: none; background: var(--panel); }
.pager .next { text-align: left; margin-right: auto; }
.pager .prev { text-align: right; }
.pager .label { font-family: var(--mono); font-size: 11px; color: var(--faint); letter-spacing: 1px; }
.pager .title { color: var(--fg); margin-top: 3px; }

/* ===== hero ===== */
.hero { padding: 18px 0 30px; border-bottom: 1px solid var(--line); margin-bottom: 36px; }
.hero-meta { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 22px; }
.tag {
  font-family: var(--mono); font-size: 11.5px; padding: 4px 11px; border-radius: var(--radius);
  border: 1px solid var(--line); color: var(--dim); letter-spacing: 0.5px;
}
.tag.live { color: var(--signal); border-color: var(--signal-dim); }
.tag.cls { color: var(--accent2); border-color: var(--info-dim); }
.hero h1 { font-size: clamp(34px, 5.2vw, 58px); }
.lede { font-size: 18px; color: var(--muted); max-width: 760px; line-height: 1.85; }

/* ===== لوحة الحالة (stack board) في الرئيسية ===== */
.idx-body { display: block; }
.tower-wrap { margin: 8px 0 30px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--deep); overflow: hidden; }
.tower-head { padding: 12px 18px; font-family: var(--mono); font-size: 13px; color: var(--muted); border-bottom: 1px solid var(--line); background: var(--panel); }
.tower-head b { color: var(--signal); }
.tower { display: flex; flex-direction: column; }
.layer {
  display: grid; grid-template-columns: 56px 1fr auto auto; gap: 14px; align-items: center;
  padding: 11px 18px; border-bottom: 1px solid var(--line-faint); font-family: var(--mono); font-size: 13px;
  position: relative;
}
.layer::before {
  content: ""; width: 9px; height: 9px; border-radius: 50%; position: absolute; right: 6px;
  background: var(--line-strong);
}
.layer.lit::before { background: var(--ok); box-shadow: 0 0 8px var(--ok); }
.layer .ln { color: var(--signal); font-weight: 700; padding-right: 8px; }
.layer .lname { color: var(--fg); }
.layer .lwhat { color: var(--dim); font-size: 11.5px; }
.layer .lreg { color: var(--faint); font-size: 11px; }
.layer:hover { background: var(--panel); }
.tower-foot { padding: 11px 18px; font-family: var(--mono); font-size: 12px; color: var(--dim); border-top: 1px solid var(--line); }
.tower-foot b { color: var(--ok); }

/* ===== شبكة الوحدات ===== */
.modgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(258px, 1fr)); gap: 14px; margin: 22px 0; }
.modcard {
  display: flex; flex-direction: column; padding: 16px 18px; min-height: 150px;
  border: 1px solid var(--line); border-radius: var(--radius); background: var(--deep);
  transition: 0.14s; position: relative; overflow: hidden;
}
.modcard::after {
  content: ""; position: absolute; inset: 0 auto 0 0; width: 3px; background: var(--signal-dim); opacity: 0;
}
.modcard:hover { border-color: var(--signal-dim); transform: translateY(-3px); text-decoration: none; background: var(--panel); }
.modcard:hover::after { opacity: 1; }
.mc-num { font-family: var(--mono); font-size: 11px; color: var(--faint); letter-spacing: 1.5px; }
.mc-title { font-weight: 700; color: var(--fg); font-size: 17px; margin: 7px 0 8px; }
.mc-desc { color: var(--muted); font-size: 13.5px; line-height: 1.7; flex: 1; }
.mc-foot { display: flex; justify-content: space-between; align-items: center; margin-top: 12px; font-family: var(--mono); font-size: 12px; color: var(--signal); }
.modcard.done .mc-num::after { content: " ✓"; color: var(--ok); }
.modcard.appx { background: var(--code); border-style: dashed; }
.modcard.appx .mc-foot { color: var(--accent2); }

/* ===== figure / ascii ===== */
figure { margin: 24px 0; border: 1px solid var(--line); border-radius: var(--radius); background: var(--code); overflow: hidden; }
.fig-head { padding: 8px 14px; font-family: var(--mono); font-size: 11.5px; color: var(--dim); border-bottom: 1px solid var(--line); background: var(--panel); }
.fig-head .id { color: var(--signal); margin-left: 8px; }
.fig-body { padding: 18px; overflow-x: auto; }
figcaption { padding: 8px 14px; font-size: 12.5px; color: var(--faint); border-top: 1px solid var(--line); }
.ascii {
  display: block; padding: 16px; background: var(--code); border: 1px solid var(--line);
  border-radius: var(--radius); margin: 18px 0; font-size: 12.5px; line-height: 1.5;
  color: var(--muted); white-space: pre; overflow-x: auto; text-align: left;
}

/* ===== footer ===== */
.foot {
  display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  padding: 26px 64px; border-top: 1px solid var(--line); color: var(--faint);
  font-family: var(--mono); font-size: 12px; background: var(--deep);
}
.foot .sig { color: var(--dim); }

/* ===== command palette + help ===== */
.cmdk-back {
  position: fixed; inset: 0; z-index: 100; display: none;
  background: rgba(3, 6, 10, 0.7); backdrop-filter: blur(3px);
  align-items: flex-start; justify-content: center; padding-top: 14vh;
}
.cmdk-back.open { display: flex; }
.cmdk { width: min(560px, 92vw); background: var(--elevated); border: 1px solid var(--line-strong); border-radius: var(--radius); overflow: hidden; box-shadow: 0 24px 70px rgba(0,0,0,0.6); }
.cmdk-in input { width: 100%; padding: 16px 18px; background: var(--code); border: 0; border-bottom: 1px solid var(--line); color: var(--fg); font-family: var(--body); font-size: 15px; outline: none; }
.cmdk-list { max-height: 320px; overflow-y: auto; }
.cmdk-item { display: flex; align-items: center; gap: 12px; padding: 11px 18px; cursor: pointer; font-size: 14px; color: var(--muted); }
.cmdk-item .ci-num { font-family: var(--mono); font-size: 11px; color: var(--dim); border: 1px solid var(--line); padding: 1px 7px; border-radius: var(--radius); min-width: 30px; text-align: center; }
.cmdk-item.sel, .cmdk-item:hover { background: var(--panel); color: var(--fg); }
.cmdk-item.sel .ci-num { color: var(--signal); border-color: var(--signal); }
.cmdk-hint { display: flex; gap: 18px; padding: 9px 18px; border-top: 1px solid var(--line); font-family: var(--mono); font-size: 11px; color: var(--faint); }
.khelp { width: min(380px, 90vw); background: var(--elevated); border: 1px solid var(--line-strong); border-radius: var(--radius); padding: 20px 22px; }
.khelp h4 { margin: 0 0 14px; color: var(--signal); }
.khelp .row { display: flex; justify-content: space-between; padding: 7px 0; border-bottom: 1px solid var(--line-faint); font-size: 13.5px; color: var(--muted); }
kbd { font-family: var(--mono); font-size: 11px; background: var(--code); border: 1px solid var(--line-strong); border-bottom-width: 2px; border-radius: 3px; padding: 1px 7px; color: var(--fg); }

/* ===== responsive ===== */
@media (max-width: 1000px) {
  .shell { grid-template-columns: 1fr; }
  .sidebar { position: static; height: auto; border-left: 0; border-bottom: 1px solid var(--line); }
  .main { padding: 36px 26px 90px; }
  .toc { float: none; width: auto; margin: 0 0 18px; }
  .foot { padding: 22px 26px; }
  .layer { grid-template-columns: 44px 1fr; }
  .layer .lwhat, .layer .lreg { display: none; }
}
