/* ============================================================
   تقرير تقييم ليالي عاشوراء ١٤٤٨هـ — الإصدار الثاني (V2)
   Executive dashboard design system
   ------------------------------------------------------------
   Type   : Alexandria (headings/numbers) + Readex Pro (body)
   Theme  : light-first, warm-neutral canvas, brand green/red
            accents; dark mode via <html data-theme="dark">
            (dark tokens scoped to @media screen → print = light)
   Motion : scroll reveals + chart bar growth (app.js adds
            .in-view); disabled under prefers-reduced-motion
   ============================================================ */

* { margin: 0; padding: 0; box-sizing: border-box; }

/* ---------------- Design tokens ---------------- */
:root {
  color-scheme: light;

  /* surfaces */
  --canvas: #f8f7f4;
  --card: #ffffff;
  --card-2: #fbfaf7;
  --border: #e7e4de;
  --border-strong: #d8d3ca;
  --total-bg: #f3f1ec;

  /* text */
  --ink: #1c1917;
  --body-c: #413b36;
  --muted: #7d7568;
  --faint: #aaa295;

  /* brand accents */
  --green: #4a8527;
  --green-strong: #3e7d2b;
  --green-soft: #eaf3e2;
  --green-border: #cfe3c0;
  --red: #c93a2c;
  --red-soft: #fbeae7;
  --red-border: #f0cec8;
  --amber: #a97617;
  --amber-soft: #f9f1dd;
  --amber-border: #ecd9ab;

  /* data / chart palette */
  --chart-base: #877f74;   /* ranking bars */
  --chart-hi: #57a13a;     /* highlighted best performer */
  --chart-dist: #57a13a;   /* distribution bars */
  --slate-strong: #57534e; /* donut A */
  --sat: #57a13a;
  --neu: #dda52f;
  --dis: #d93a2b;

  /* effects */
  --shadow-sm: 0 1px 2px rgba(28, 25, 23, .05);
  --shadow-md: 0 6px 22px -6px rgba(28, 25, 23, .12);
  --nav-bg: rgba(255, 255, 255, .78);
  --ring: rgba(87, 161, 58, .35);

  --nav-h: 64px;
  --radius: 16px;
  --radius-sm: 11px;
  --font-head: 'Alexandria', 'Readex Pro', sans-serif;
  --font-body: 'Readex Pro', 'Segoe UI', Tahoma, sans-serif;
}

@media screen {
  [data-theme="dark"] {
    color-scheme: dark;

    --canvas: #101012;
    --card: #19191c;
    --card-2: #1f1f23;
    --border: #2a2a2f;
    --border-strong: #414147;
    --total-bg: #232327;

    --ink: #f4f4f5;
    --body-c: #d6d3d1;
    --muted: #a29e98;
    --faint: #6e6a64;

    --green: #93cd6e;
    --green-strong: #a5da82;
    --green-soft: #1d2916;
    --green-border: #35512a;
    --red: #ef7061;
    --red-soft: #331f1c;
    --red-border: #55312c;
    --amber: #dcae54;
    --amber-soft: #2f2717;
    --amber-border: #4e4023;

    --chart-base: #7d786f;
    --chart-hi: #67ae45;
    --chart-dist: #67ae45;
    --slate-strong: #b8b1a7;
    --sat: #67ae45;
    --neu: #d3a340;
    --dis: #e05243;

    --shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);
    --shadow-md: 0 8px 26px -8px rgba(0, 0, 0, .55);
    --nav-bg: rgba(16, 16, 18, .72);
    --ring: rgba(103, 174, 69, .4);
  }
}

/* ---------------- Base ---------------- */
html { scroll-behavior: smooth; scroll-padding-top: calc(var(--nav-h) + 24px); }
body {
  font-family: var(--font-body);
  direction: rtl;
  background: var(--canvas);
  color: var(--body-c);
  font-size: 15px;
  line-height: 1.95;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4 { font-family: var(--font-head); color: var(--ink); line-height: 1.5; }
h2 { font-size: 26px; font-weight: 800; margin: 6px 0 4px; }
h3 { font-size: 19px; font-weight: 700; margin: 34px 0 10px; }
h4 { font-size: 16px; font-weight: 600; margin: 20px 0 6px; }
p { margin: 11px 0; }
small { font-size: .8em; color: var(--muted); }
.lead { font-size: 16.5px; color: var(--ink); font-weight: 350; }
strong, b { color: var(--ink); font-weight: 650; }
img { max-width: 100%; }
::selection { background: var(--green-soft); color: var(--ink); }

.eyebrow { color: var(--muted); font-weight: 600; font-size: 12.5px; letter-spacing: 1px; }

/* ---------------- Top navigation ---------------- */
.topnav {
  position: fixed; inset-inline: 0; top: 0; z-index: 50;
  height: var(--nav-h);
  background: var(--nav-bg);
  -webkit-backdrop-filter: saturate(180%) blur(16px);
  backdrop-filter: saturate(180%) blur(16px);
  border-bottom: 1px solid var(--border);
}
.topnav .nav-inner {
  max-width: 1240px; height: 100%; margin: 0 auto; padding: 0 28px;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.brand { display: flex; align-items: center; text-decoration: none; }
.brand img { height: 40px; width: auto; display: block; }
.brand .logo-dark { display: none; }
[data-theme="dark"] .brand .logo-light { display: none; }
[data-theme="dark"] .brand .logo-dark { display: block; }

.nav-actions { display: flex; align-items: center; gap: 8px; }
.icon-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  height: 38px; min-width: 38px; padding: 0 10px;
  border: 1px solid var(--border); border-radius: 10px;
  background: var(--card); color: var(--muted);
  font: 600 13px var(--font-body); cursor: pointer;
  transition: color .18s, border-color .18s, background .18s, transform .18s;
}
.icon-btn:hover { color: var(--ink); border-color: var(--border-strong); }
.icon-btn:active { transform: scale(.96); }
.icon-btn:focus-visible { outline: 3px solid var(--ring); outline-offset: 1px; }
.icon-btn svg { width: 17px; height: 17px; flex: none; }
.icon-btn .lbl { display: inline; }
.theme-toggle .icon-sun { display: none; }
[data-theme="dark"] .theme-toggle .icon-sun { display: block; }
[data-theme="dark"] .theme-toggle .icon-moon { display: none; }

/* reading progress */
.progress {
  position: absolute; bottom: -1px; inset-inline: 0; height: 2px;
  background: transparent; overflow: hidden;
}
.progress i {
  display: block; height: 100%; width: 100%;
  background: linear-gradient(270deg, var(--chart-hi), var(--green-strong));
  transform: scaleX(0); transform-origin: right;
}

/* ---------------- Hero ---------------- */
.hero {
  position: relative; overflow: hidden;
  padding: calc(var(--nav-h) + 64px) 28px 30px;
}
.hero::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(46rem 22rem at 85% -10%, rgba(87, 161, 58, .10), transparent 60%),
    radial-gradient(38rem 20rem at 8% 0%, rgba(217, 58, 43, .07), transparent 55%);
}
[data-theme="dark"] .hero::before {
  background:
    radial-gradient(46rem 22rem at 85% -10%, rgba(103, 174, 69, .12), transparent 60%),
    radial-gradient(38rem 20rem at 8% 0%, rgba(224, 82, 67, .08), transparent 55%);
}
.hero-emblem {
  position: absolute; left: -70px; bottom: -90px; width: 420px; opacity: .07;
  pointer-events: none; user-select: none;
  -webkit-mask-image: linear-gradient(200deg, #000 40%, transparent 85%);
  mask-image: linear-gradient(200deg, #000 40%, transparent 85%);
}
.hero-inner { max-width: 1240px; margin: 0 auto; position: relative; }
.hero .kicker-chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px; border-radius: 999px;
  background: var(--card); border: 1px solid var(--border);
  color: var(--muted); font: 600 12.5px var(--font-body);
  box-shadow: var(--shadow-sm);
}
.hero .kicker-chip::before {
  content: ''; width: 7px; height: 7px; border-radius: 50%;
  background: var(--chart-hi);
}
.hero h1 {
  font-size: clamp(28px, 4.6vw, 46px); font-weight: 800;
  line-height: 1.45; margin: 20px 0 10px; max-width: 21em;
  letter-spacing: -.3px;
}
.hero h1 .thin { font-weight: 300; color: var(--muted); }
.hero .sub { color: var(--muted); font-size: 16.5px; max-width: 620px; line-height: 2; }

/* hero stat band */
.hero-stats {
  margin: 36px 0 8px;
  display: grid; grid-template-columns: repeat(4, 1fr);
  background: var(--card); border: 1px solid var(--border);
  border-radius: 20px; box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.hero-stats > div { padding: 22px 26px; position: relative; }
.hero-stats > div + div { border-inline-start: 1px solid var(--border); }
.hero-stats b {
  display: block; font: 800 30px/1.2 var(--font-head);
  color: var(--ink); letter-spacing: -.5px;
}
.hero-stats span { color: var(--muted); font-size: 13px; }

/* ---------------- Layout: sidebar + content ---------------- */
.layout {
  max-width: 1240px; margin: 0 auto; padding: 8px 28px 40px;
  display: grid; grid-template-columns: 232px minmax(0, 1fr); gap: 56px;
  align-items: start;
}
.sidebar { position: sticky; top: calc(var(--nav-h) + 28px); }
.side-title {
  font: 700 12px var(--font-body); color: var(--faint);
  letter-spacing: 1.5px; margin: 6px 12px 10px;
}
.side-nav { display: flex; flex-direction: column; gap: 2px; }
.side-nav a {
  display: flex; align-items: baseline; gap: 10px;
  padding: 7px 12px; border-radius: 9px;
  color: var(--muted); text-decoration: none;
  font-size: 13px; line-height: 1.7;
  border: 1px solid transparent;
  transition: color .15s, background .15s;
}
.side-nav a .n {
  font: 600 11px var(--font-head); color: var(--faint);
  min-width: 16px; text-align: center;
  transition: color .15s;
}
.side-nav a:hover { color: var(--ink); background: var(--card); }
.side-nav a.active {
  color: var(--green); background: var(--green-soft);
  border-color: var(--green-border); font-weight: 600;
}
.side-nav a.active .n { color: var(--green); }

/* mobile TOC */
.toc-mobile {
  display: none;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); margin: 10px 0 4px;
  box-shadow: var(--shadow-sm);
}
.toc-mobile summary {
  cursor: pointer; list-style: none;
  padding: 14px 18px; font: 700 14px var(--font-head); color: var(--ink);
  display: flex; align-items: center; justify-content: space-between;
}
.toc-mobile summary::-webkit-details-marker { display: none; }
.toc-mobile summary::after {
  content: ''; width: 8px; height: 8px;
  border-left: 2px solid var(--muted); border-bottom: 2px solid var(--muted);
  transform: rotate(-45deg); transition: transform .2s; margin-left: 4px;
}
.toc-mobile[open] summary::after { transform: rotate(135deg); }
.toc-mobile nav { padding: 4px 10px 12px; display: flex; flex-direction: column; }
.toc-mobile nav a {
  padding: 8px 10px; border-radius: 8px; text-decoration: none;
  color: var(--body-c); font-size: 13.5px;
}
.toc-mobile nav a:hover { background: var(--card-2); color: var(--ink); }
.toc-mobile nav a .n { color: var(--faint); font: 600 11px var(--font-head); margin-left: 8px; }

/* ---------------- Sections ---------------- */
.section { padding: 34px 0 10px; }
.section + .section { border-top: 1px solid var(--border); margin-top: 24px; }
.section-head { margin-bottom: 8px; }
.kicker {
  display: inline-flex; align-items: center; gap: 10px;
  color: var(--green); font: 600 12.5px var(--font-body); letter-spacing: .8px;
}
.kicker::before { content: ''; width: 20px; height: 2px; background: var(--chart-hi); border-radius: 2px; }
.divider {
  height: 3px; width: 44px; border: 0; border-radius: 3px;
  background: var(--chart-hi); margin: 10px 0 18px; opacity: .85;
}

/* ---------------- KPI cards ---------------- */
.kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin: 22px 0; }
.kpi {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 20px 18px 16px;
  box-shadow: var(--shadow-sm);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.kpi:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--border-strong); }
.kpi .v {
  font: 800 30px/1.15 var(--font-head); color: var(--ink);
  letter-spacing: -.5px;
}
.kpi.g .v { color: var(--green); }
.kpi.o .v { color: var(--amber); }
.kpi.p .v { color: var(--slate-strong); }
.kpi .l { font-size: 12.5px; color: var(--muted); margin-top: 6px; line-height: 1.7; }
.kpi .x {
  display: inline-block; margin-top: 6px; padding: 1px 9px;
  border-radius: 999px; background: var(--green-soft);
  color: var(--green); font-size: 11px; font-weight: 600;
}

/* ---------------- Tables ---------------- */
.table-wrap {
  width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch;
  margin: 18px 0; border-radius: var(--radius);
  background: var(--card); border: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
}
table { width: 100%; border-collapse: collapse; background: transparent; }

.rt { min-width: 560px; }
.rt th {
  background: var(--card-2); color: var(--muted);
  font: 600 12px var(--font-body); letter-spacing: .3px;
  padding: 12px 10px; text-align: center; line-height: 1.5;
  border-bottom: 1px solid var(--border-strong);
}
.rt td {
  padding: 10px; text-align: center; white-space: nowrap;
  border-bottom: 1px solid var(--border); font-size: 13.5px;
}
.rt tbody tr:last-child td { border-bottom: 0; }
.rt tbody tr { transition: background .15s; }
.rt tbody tr:hover { background: var(--card-2); }
.rt td.lcell {
  text-align: right; font-weight: 600; color: var(--ink);
  white-space: normal; min-width: 170px;
}
.rt tbody tr.total { background: var(--total-bg); font-weight: 700; }
.rt tbody tr.total td { border-top: 1px solid var(--border-strong); }
.rt .csat { color: var(--green); font-weight: 700; }
.rt .cneu { color: var(--amber); font-weight: 600; }
.rt .cdis { color: var(--red); font-weight: 700; }
.rt tr.lowrow td.lcell { box-shadow: inset 3px 0 0 var(--dis); }
.rt tr.hirow td.lcell { box-shadow: inset 3px 0 0 var(--sat); }
table td.msg { text-align: right; font-size: 12.5px; white-space: normal; min-width: 260px; line-height: 1.9; }

.simple { min-width: 420px; }
.simple th {
  background: var(--card-2); color: var(--muted);
  font: 600 12px var(--font-body); padding: 11px;
  border-bottom: 1px solid var(--border-strong); text-align: center;
}
.simple td { padding: 10px 12px; border-bottom: 1px solid var(--border); font-size: 13.5px; }
.simple tbody tr:last-child td { border-bottom: 0; }
.simple tbody tr:hover { background: var(--card-2); }
.simple td.r { text-align: right; }

/* mini stacked distribution bar */
.ministack {
  display: inline-flex; width: 96px; height: 9px; border-radius: 99px;
  overflow: hidden; vertical-align: middle; background: var(--total-bg);
}
.ministack span { display: block; height: 100%; }
.ministack .sat { background: var(--sat); }
.ministack .neu { background: var(--neu); }
.ministack .dis { background: var(--dis); }

.scorebar {
  height: 8px; background: var(--total-bg); border-radius: 99px;
  overflow: hidden; display: inline-block; width: 120px; vertical-align: middle;
}
.scorebar i { display: block; height: 100%; border-radius: 99px; background: var(--chart-hi); }

.pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 2px 10px; border-radius: 999px;
  font-size: 11.5px; font-weight: 600; white-space: nowrap;
}
.pill::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.pill.hi { background: var(--green-soft); color: var(--green); }
.pill.mid { background: var(--amber-soft); color: var(--amber); }
.pill.lo { background: var(--red-soft); color: var(--red); }

/* ---------------- Charts ---------------- */
.chartbox {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 20px 20px 16px; margin: 18px 0;
  box-shadow: var(--shadow-sm);
}
.chartbox .ct { font: 700 14.5px var(--font-head); color: var(--ink); margin-bottom: 10px; }
.chart { width: 100%; height: auto; }
.chart-note { font-size: 12.5px; color: var(--muted); margin-top: 8px; }
.barlbl { font: 500 12.5px 'Readex Pro', sans-serif; fill: var(--body-c); }
.barnum { font: 600 11px 'Alexandria', sans-serif; fill: #fff; direction: ltr; }
.axislbl { font: 10.5px 'Alexandria', sans-serif; fill: var(--faint); text-anchor: middle; }
.instack { font: 600 10.5px 'Alexandria', sans-serif; fill: #fff; text-anchor: middle; }
.minival { font: 600 10px 'Alexandria', sans-serif; fill: var(--muted); text-anchor: middle; }
.distchart { width: 340px; max-width: 100%; }
.donut { width: 150px; }
.donutc { font: 800 19px 'Alexandria', sans-serif; fill: var(--ink); text-anchor: middle; }

/* map the SVG presentation colors onto the V2 palette */
svg line[stroke="#ece2dd"] { stroke: var(--border); }
svg rect[fill="#7a2420"]  { fill: var(--chart-base); }
svg rect[fill="#b58a3e"]  { fill: var(--chart-hi); }
svg rect[fill="#9e5b2e"]  { fill: var(--chart-dist); }
svg rect[fill="#b0322b"]  { fill: var(--dis); }
svg rect[fill="#4e7f33"]  { fill: var(--sat); }
svg rect[fill="#c79a3e"]  { fill: var(--neu); }
svg circle[stroke="#7a2420"] { stroke: var(--slate-strong); }
svg circle[stroke="#b0322b"] { stroke: var(--dis); }
svg circle[stroke="#4e7f33"] { stroke: var(--sat); }
svg circle[stroke="#c79a3e"] { stroke: var(--neu); }

.legend { display: flex; gap: 16px; flex-wrap: wrap; margin: 10px 2px; font-size: 12.5px; color: var(--muted); }
.legend .lg { display: inline-flex; align-items: center; gap: 6px; }
.legend i { width: 10px; height: 10px; border-radius: 3px; display: inline-block; }
.legend i.sw-sat { background: var(--sat); }
.legend i.sw-neu { background: var(--neu); }
.legend i.sw-dis { background: var(--dis); }
.legend i.sw-bar { background: var(--slate-strong); }

.flexrow { display: flex; gap: 22px; align-items: flex-start; flex-wrap: wrap; }
.flexrow > div { flex: 1; min-width: 240px; }

/* chart bar growth animation */
@media (prefers-reduced-motion: no-preference) {
  .chartbox svg.chart rect,
  .chartbox svg.distchart rect {
    transform: scaleX(0);
    transform-box: fill-box; transform-origin: 100% 50%;
    transition: transform .9s cubic-bezier(.22, .8, .3, 1);
  }
  .chartbox svg.distchart rect { transform: scaleY(0); transform-origin: 50% 100%; }
  .chartbox svg .barnum, .chartbox svg .minival { opacity: 0; transition: opacity .5s ease .55s; }
  .chartbox.in-view svg.chart rect { transform: scaleX(1); }
  .chartbox.in-view svg.distchart rect { transform: scaleY(1); }
  .chartbox.in-view svg .barnum, .chartbox.in-view svg .minival { opacity: 1; }
  .chartbox svg rect:nth-of-type(2) { transition-delay: .06s; }
  .chartbox svg rect:nth-of-type(3) { transition-delay: .12s; }
  .chartbox svg rect:nth-of-type(4) { transition-delay: .18s; }
  .chartbox svg rect:nth-of-type(5) { transition-delay: .24s; }
  .chartbox svg rect:nth-of-type(6) { transition-delay: .3s; }
  .chartbox svg rect:nth-of-type(7) { transition-delay: .36s; }
  .chartbox svg rect:nth-of-type(8) { transition-delay: .42s; }
  .chartbox svg rect:nth-of-type(9) { transition-delay: .48s; }
  .chartbox svg rect:nth-of-type(10) { transition-delay: .54s; }
}

/* ---------------- Callouts ---------------- */
.callout {
  border-radius: 14px; padding: 16px 18px; margin: 16px 0;
  font-size: 14px; line-height: 1.95; border: 1px solid var(--border);
  background: var(--card-2);
}
.callout .ti {
  font: 700 14px var(--font-head); display: flex; align-items: center; gap: 8px;
  margin-bottom: 6px;
}
.callout .ti::before {
  content: ''; width: 16px; height: 16px; flex: none; background: currentColor;
  -webkit-mask: var(--co-icon) center / contain no-repeat;
  mask: var(--co-icon) center / contain no-repeat;
}
.insight { background: var(--green-soft); border-color: var(--green-border); }
.insight .ti { color: var(--green); --co-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 18h6M10 22h4M12 2a7 7 0 0 0-4 12.7c.6.5 1 1.4 1 2.3h6c0-.9.4-1.8 1-2.3A7 7 0 0 0 12 2z'/%3E%3C/svg%3E"); }
.warn { background: var(--red-soft); border-color: var(--red-border); }
.warn .ti { color: var(--red); --co-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M10.3 3.9 1.8 18a2 2 0 0 0 1.7 3h17a2 2 0 0 0 1.7-3L13.7 3.9a2 2 0 0 0-3.4 0z'/%3E%3Cpath d='M12 9v4M12 17h.01'/%3E%3C/svg%3E"); }
.note { background: var(--amber-soft); border-color: var(--amber-border); }
.note .ti { color: var(--amber); --co-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M12 16v-4M12 8h.01'/%3E%3C/svg%3E"); }

.quote {
  background: var(--card); border: 1px solid var(--border);
  border-inline-start: 3px solid var(--chart-hi);
  padding: 12px 18px; margin: 12px 0; border-radius: var(--radius-sm);
  font-size: 14px; color: var(--body-c); line-height: 2;
  box-shadow: var(--shadow-sm);
}
.quote:before {
  content: '\201D'; color: var(--chart-hi); font: 700 28px var(--font-head);
  line-height: 0; vertical-align: -10px; margin-left: 8px; opacity: .8;
}

/* ---------------- Lists ---------------- */
ul, ol { margin: 10px 26px 10px 0; }
li { margin: 8px 0; }
li::marker { color: var(--chart-hi); }

.rank-list { counter-reset: r; list-style: none; margin: 16px 0; }
.rank-list li {
  counter-increment: r; position: relative;
  padding: 12px 56px 12px 16px; margin: 8px 0;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-sm); line-height: 1.9;
  box-shadow: var(--shadow-sm);
  transition: transform .18s ease, box-shadow .18s ease;
}
.rank-list li:hover { transform: translateX(-3px); box-shadow: var(--shadow-md); }
.rank-list li:before {
  content: counter(r); position: absolute; right: 13px; top: 50%; transform: translateY(-50%);
  width: 30px; height: 30px; border-radius: 10px;
  background: var(--total-bg); color: var(--ink);
  display: flex; align-items: center; justify-content: center;
  font: 700 13px var(--font-head);
}
.rank-list.green li:before { background: var(--green-soft); color: var(--green); }
.rank-list.red li:before { background: var(--red-soft); color: var(--red); }
.rank-list.gold li:before { background: var(--amber-soft); color: var(--amber); }
.tagn { color: var(--faint); font-weight: 600; font-size: 11.5px; margin-right: 6px; }

/* ---------------- Recommendations timeline ---------------- */
.rec {
  position: relative;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); margin: 0 26px 18px 0;
  box-shadow: var(--shadow-sm);
}
.rec::before {
  content: ''; position: absolute; right: -26px; top: 34px; bottom: -26px;
  width: 2px; background: var(--border);
}
.rec:last-of-type::before { display: none; }
.rec::after {
  content: ''; position: absolute; right: -31.5px; top: 20px;
  width: 13px; height: 13px; border-radius: 50%;
  background: var(--canvas); border: 3.5px solid var(--rec-c, var(--muted));
}
.rec .rh {
  padding: 14px 18px; display: flex; justify-content: space-between;
  align-items: center; gap: 10px; border-bottom: 1px solid var(--border);
  font: 700 14.5px var(--font-head); color: var(--ink);
}
.rec .rh span:last-child:not(:only-child) {
  font: 600 11.5px var(--font-body); color: var(--rec-c, var(--muted));
  background: var(--rec-soft, var(--card-2));
  padding: 3px 11px; border-radius: 999px; white-space: nowrap; flex: none;
}
.rec.urgent { --rec-c: var(--red); --rec-soft: var(--red-soft); }
.rec.short  { --rec-c: var(--amber); --rec-soft: var(--amber-soft); }
.rec.mid    { --rec-c: var(--slate-strong); --rec-soft: var(--total-bg); }
.rec.long   { --rec-c: var(--green); --rec-soft: var(--green-soft); }
.rec ul { margin: 12px 30px 14px 16px; }
.rec li { margin: 9px 0; font-size: 14px; }
.rec li::marker { color: var(--rec-c, var(--chart-hi)); }

/* ---------------- Footer ---------------- */
.foot {
  border-top: 1px solid var(--border); margin-top: 40px;
  padding: 44px 20px 36px; text-align: center;
  color: var(--muted); font-size: 12.5px; line-height: 2.1;
}
.foot img { height: 52px; margin-bottom: 12px; }

/* ---------------- Scroll reveal ---------------- */
@media (prefers-reduced-motion: no-preference) {
  .rv { opacity: 0; transform: translateY(18px); transition: opacity .7s ease, transform .7s cubic-bezier(.22, .8, .3, 1); }
  .rv.in-view { opacity: 1; transform: none; }
}

/* ---------------- Print ---------------- */
@media print {
  body { background: #fff; font-size: 12px; }
  .topnav, .sidebar, .toc-mobile, .hero::before, .hero-emblem { display: none; }
  .hero { padding: 10px 0 0; }
  .layout { display: block; padding: 0; }
  .section { border: 0; padding: 18px 0; }
  .kpi, .chartbox, .table-wrap, .callout, .rec, .rank-list li, .quote { box-shadow: none; page-break-inside: avoid; }
  h3 { page-break-after: avoid; }
  .rv { opacity: 1 !important; transform: none !important; }
  .chartbox svg rect { transform: none !important; }
  .chartbox svg .barnum, .chartbox svg .minival { opacity: 1 !important; }
}

/* ---------------- Responsive ---------------- */
@media (max-width: 1080px) {
  .layout { grid-template-columns: minmax(0, 1fr); gap: 8px; }
  .sidebar { display: none; }
  .toc-mobile { display: block; }
}
@media (max-width: 760px) {
  .hero { padding: calc(var(--nav-h) + 40px) 20px 20px; }
  .hero-stats { grid-template-columns: 1fr 1fr; }
  .hero-stats > div { padding: 16px 18px; }
  .hero-stats > div:nth-child(3), .hero-stats > div:nth-child(4) { border-top: 1px solid var(--border); }
  .hero-stats > div:nth-child(3) { border-inline-start: 0; }
  .hero-stats b { font-size: 24px; }
  .hero-emblem { width: 260px; left: -60px; bottom: -60px; }
  .layout { padding: 8px 20px 30px; }
  .kpis { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .kpi .v { font-size: 25px; }
  h2 { font-size: 21.5px; }
  h3 { font-size: 17.5px; }
  .brand img { height: 33px; }
  .icon-btn .lbl { display: none; }
  .icon-btn { padding: 0; width: 38px; }
  .topnav .nav-inner { padding: 0 20px; }
  .rec { margin-right: 20px; }
  .rec::before { right: -20px; }
  .rec::after { right: -25.5px; }
  ul, ol { margin: 10px 20px 10px 0; }
}
@media (max-width: 420px) {
  .kpis { grid-template-columns: 1fr 1fr; gap: 8px; }
  .hero h1 { font-size: 26px; }
}
