/* ===========================================================================
   actual. — Platform Spec doc styles (one-page scroll, dev handoff)
   RTL Arabic headings + English implementation notes. Token-driven.
   =========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--bg-void); color: var(--text-primary); font: var(--type-body); font-family: var(--font-sans); -webkit-font-smoothing: antialiased; }
::selection { background: var(--accent-soft); color: var(--warm-white); }
a { color: inherit; text-decoration: none; }
::-webkit-scrollbar { width: 12px; height: 12px; }
::-webkit-scrollbar-track { background: var(--ink-950); }
::-webkit-scrollbar-thumb { background: var(--ink-600); border-radius: 999px; border: 3px solid var(--ink-950); }

.shell { display: flex; min-height: 100vh; }

/* side index */
.sidenav { position: sticky; top: 0; align-self: flex-start; width: 270px; flex: none; height: 100vh; overflow-y: auto;
  padding: var(--space-7) var(--space-5); border-inline-start: 1px solid var(--line);
  background: linear-gradient(180deg, var(--ink-900), var(--ink-950)); display: flex; flex-direction: column; gap: var(--space-5); z-index: 40; }
.sidenav .brandrow { display: flex; align-items: center; gap: 10px; }
.sidenav .brandrow img { width: 32px; height: 32px; border-radius: 8px; }
.sidenav .brandrow .wm { font-family: var(--font-latin); font-weight: 700; font-size: 19px; letter-spacing: -0.03em; }
.sidenav .brandrow .wm .dot { color: var(--accent); }
.toc { display: flex; flex-direction: column; gap: 1px; }
.toc .eyebrow { font: var(--type-caption); letter-spacing: var(--ls-caps); text-transform: uppercase; color: var(--text-faint); font-family: var(--font-latin); margin: 0 0 8px; }
.toc a { display: flex; align-items: center; gap: 10px; padding: 7px 11px; border-radius: var(--radius-sm); color: var(--text-secondary); font-size: var(--text-md); font-weight: var(--fw-medium); transition: all var(--dur-fast) var(--ease-out); }
.toc a .num { font-family: var(--font-mono); font-size: 10px; color: var(--text-faint); width: 16px; }
.toc a:hover { background: var(--ink-800); color: var(--text-primary); }
.toc a.active { background: var(--accent-soft); color: var(--accent); }
.toc a.active .num { color: var(--accent); }
.sidenav .foot { margin-top: auto; font: var(--type-caption); color: var(--text-faint); line-height: 1.7; }

.content { flex: 1 1 auto; min-width: 0; }

/* cover */
.cover { min-height: 88vh; display: flex; flex-direction: column; justify-content: center; padding: var(--space-9);
  background: radial-gradient(60% 50% at 50% 25%, rgba(255,158,87,0.10), transparent 70%), var(--grad-night); border-bottom: 1px solid var(--line); position: relative; overflow: hidden; }
.cover .bloom { position: absolute; inset-inline-start: 50%; top: 12%; width: 560px; height: 480px; transform: translateX(50%);
  background: radial-gradient(circle, rgba(255,122,89,0.20), transparent 62%); filter: blur(40px); pointer-events: none; }
.cover .inner { position: relative; max-width: 1080px; margin: 0 auto; width: 100%; }
.cover .mark { width: 104px; height: 104px; border-radius: 22px; box-shadow: var(--glow-spark); margin-bottom: var(--space-6); }
.cover h1 { font: var(--type-hero); font-size: clamp(2.6rem, 6vw, 4rem); margin: 0 0 16px; line-height: 1.08; }
.cover h1 .two { background: var(--grad-twotone); -webkit-background-clip: text; background-clip: text; color: transparent; }
.cover .sub { font-size: var(--text-2xl); color: var(--text-secondary); max-width: 40ch; line-height: var(--lh-snug); }
.cover .handoff { margin-top: var(--space-7); display: inline-flex; align-items: center; gap: 12px; padding: 14px 20px; border-radius: var(--radius-lg);
  background: var(--bg-card); border: 1px solid var(--accent-line); max-width: 560px; }
.cover .handoff .ic { color: var(--accent); flex: none; }
.cover .handoff .t { font: var(--type-label); color: var(--text-secondary); line-height: 1.6; }
.cover .meta { margin-top: var(--space-8); display: flex; gap: var(--space-8); flex-wrap: wrap; border-top: 1px solid var(--line); padding-top: var(--space-6); }
.cover .meta .k { font: var(--type-caption); letter-spacing: var(--ls-caps); text-transform: uppercase; color: var(--text-faint); font-family: var(--font-latin); margin-bottom: 4px; }
.cover .meta .v { font-size: var(--text-lg); color: var(--text-primary); font-weight: var(--fw-medium); }

/* sections */
.sec { padding: var(--space-10) var(--space-8); border-bottom: 1px solid var(--line-soft); scroll-margin-top: 12px; }
.sec-head { display: flex; align-items: baseline; gap: 14px; margin-bottom: 8px; flex-wrap: wrap; }
.sec-head .idx { font-family: var(--font-mono); font-size: var(--text-md); color: var(--accent); }
.sec-head h2 { margin: 0; font: var(--type-title); font-size: var(--text-3xl); }
.sec-head .en { font-family: var(--font-latin); font-size: var(--text-lg); color: var(--text-faint); font-weight: 500; letter-spacing: -0.01em; }
.sec .intro { font-size: var(--text-lg); color: var(--text-secondary); line-height: var(--lh-relaxed); max-width: 70ch; margin: 0 0 var(--space-6); }

/* the screen + spec layout */
.screen-wrap { display: grid; grid-template-columns: 1fr 320px; gap: var(--space-6); align-items: start; }
.screen-wrap.wide { grid-template-columns: 1fr; }
.shot-frame { border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--line); box-shadow: var(--shadow-lg); background: var(--ink-900); }
.shot-cap { display: flex; align-items: center; gap: 8px; margin-top: 10px; font: var(--type-caption); color: var(--text-faint); font-family: var(--font-latin); letter-spacing: 0.02em; }
.shot-cap .route { color: var(--accent); }

.mobrow { display: flex; gap: var(--space-5); flex-wrap: wrap; }
.mobrow .mobcap { text-align: center; margin-top: 8px; font: var(--type-caption); color: var(--text-muted); }

/* dev spec panel (LTR English) */
.spec { direction: ltr; text-align: left; background: var(--bg-card); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: var(--space-5); position: sticky; top: 18px; }
.spec h4 { margin: 0 0 12px; font-family: var(--font-latin); font-size: var(--text-md); font-weight: 700; color: var(--text-primary); display: flex; align-items: center; gap: 8px; }
.spec h4::before { content: "</>"; font-family: var(--font-mono); font-size: 12px; color: var(--accent); }
.spec .grp { margin-bottom: 16px; }
.spec .grp:last-child { margin-bottom: 0; }
.spec .lbl { font-family: var(--font-latin); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-faint); margin-bottom: 7px; }
.spec ul { margin: 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 6px; }
.spec li { display: flex; gap: 8px; font-family: var(--font-latin); font-size: 12.5px; color: var(--text-secondary); line-height: 1.5; }
.spec li::before { content: "▸"; color: var(--accent); flex: none; }
.spec code, .spec .mono { font-family: var(--font-mono); font-size: 11.5px; color: var(--accent); background: var(--accent-soft); padding: 1px 6px; border-radius: 5px; }
/* full-width spec band (under the screen) */
.spec.band { position: static; margin-top: var(--space-5); }
.spec.band .cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 22px 28px; }
.screen-wrap.stack { display: block; }
.spec .chips { display: flex; flex-wrap: wrap; gap: 6px; }
.spec .chip { font-family: var(--font-mono); font-size: 11px; color: var(--text-secondary); background: var(--bg-elevated); border: 1px solid var(--line); border-radius: 6px; padding: 3px 8px; }

/* generic two-tone callout */
.note { display: flex; gap: 12px; padding: 16px 18px; border-radius: var(--radius-md); background: var(--accent-soft); border: 1px solid var(--accent-line); margin-top: var(--space-5); }
.note .ic { color: var(--accent); flex: none; }
.note .t { font: var(--type-body); color: var(--text-secondary); line-height: 1.6; }

.closing { text-align: center; background: var(--grad-night); padding: var(--space-10) var(--space-8); }
.closing img { width: 56px; height: 56px; margin: 0 auto var(--space-5); filter: drop-shadow(var(--glow-spark-lg)); }
.closing h2 { font: var(--type-display); margin: 0 0 12px; }
.closing p { color: var(--text-muted); }

@media (max-width: 1100px) {
  .screen-wrap { grid-template-columns: 1fr; }
  .spec { position: static; }
}
@media (max-width: 880px) { .sidenav { display: none; } .sec { padding: var(--space-8) var(--space-5); } }
