/* ============================================================
   PAGE REDESIGN OVERRIDES (loaded LAST — wins cascade)

   Convention: every page redesign uses the `.ed-` prefix
   (editorial). New pages get `.page.ed-spread` as base modifier.

   Universal primitives:
     .ed-spread          → 2-col layout (visual + cream panel)
     .ed-spread--reverse → flip columns
     .ed-eyebrow         → small uppercase eyebrow with bullet
     .ed-title-ar        → big Tajawal display (Arabic)
     .ed-title-en        → small italic Cormorant (English)
     .ed-rule            → 50px gold rule
     .ed-narrative       → 11pt body
     .ed-stats           → 2x2 grid of stat tiles
     .ed-stat            → single stat tile (num + label)
     .ed-callout         → bordered authority callout
     .ed-callout-eyebrow → callout eyebrow
     .ed-pullquote       → italic Cormorant pull-quote
     .ed-visual          → visual half (photo / svg)
     .ed-visual-cap      → caption strip beneath visual
     .ed-panel           → cream narrative panel
   ============================================================ */

/* Base spread layout — overrides .content default for ed-spread pages */
.page.ed-spread .content {
  display: grid;
  grid-template-columns: 1fr 0.95fr;
  grid-template-rows: minmax(0, 1fr);  /* force row to container height; prevents auto-grow */
  gap: 0;
  padding: 0;
  height: calc(210mm - 22mm - 14mm); /* matches base .content top:22mm + footer 14mm */
}
.page.ed-spread.ed-spread--reverse .content {
  grid-template-columns: 0.95fr 1fr;
}

/* Visual half */
.ed-visual {
  position: relative;
  background: var(--navy);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.ed-visual--photo {
  background-size: cover;
  background-position: center;
  background-color: var(--navy-deep, #08172E);
}
.ed-visual--photo::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(11,31,63,0) 45%, rgba(11,31,63,.55) 100%);
  pointer-events: none;
}
.ed-visual--diagram {
  background: var(--paper);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8mm;
}
.ed-visual--navy {
  background: var(--navy);
  color: #fff;
  padding: 12mm;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.ed-visual-cap {
  position: relative;
  z-index: 2;
  padding: 4mm 6mm 5mm;
  color: #fff;
}
.ed-visual-cap-rule {
  display: inline-block;
  width: 28px; height: 1.5px;
  background: var(--gold);
  margin-bottom: 2mm;
}
.ed-visual-cap-eyebrow {
  display: block;
  font-family: "Inter", sans-serif;
  font-size: 7.5pt;
  letter-spacing: .25em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 1mm;
}
.ed-visual-cap-text {
  display: block;
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: 10pt;
  color: rgba(255,255,255,.85);
  line-height: 1.35;
}

/* Cream narrative panel */
.ed-panel {
  background: var(--paper, #F6F0E4);
  padding: 12mm 11mm 10mm;
  display: flex;
  flex-direction: column;
  position: relative;
}
.ed-panel::before {
  /* gold left-edge accent */
  content: "";
  position: absolute;
  inset: 6mm auto 6mm 0;
  width: 1.5px;
  background: var(--gold);
  opacity: .35;
}
.ed-panel--rtl::before { left: auto; right: 0; }

.ed-eyebrow {
  font-family: "Inter", sans-serif;
  font-size: 10pt;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 4mm;
  display: block;
}

.ed-title-ar {
  font-family: "Tajawal", sans-serif;
  font-weight: 800;
  font-size: 22pt;
  line-height: 1.15;
  color: var(--navy);
  margin: 0 0 1.5mm;
  letter-spacing: -.005em;
}

.ed-title-en {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-weight: 400;
  font-size: 12pt;
  color: var(--ink-soft);
  margin: 0 0 3mm;
  display: block;
}

.ed-rule {
  display: block;
  width: 50px;
  height: 2px;
  background: var(--gold);
  margin: 0 0 5mm;
}

.ed-narrative {
  font-family: "Tajawal", sans-serif;
  font-size: 10pt;
  line-height: 1.75;
  color: var(--ink);
  margin: 0 0 4mm;
}
.ed-narrative--en {
  font-family: "Inter", sans-serif;
  font-size: 9pt;
  line-height: 1.65;
  color: var(--ink-soft);
}

/* Stat tiles */
.ed-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4mm;
  margin: 2mm 0 5mm;
}
.ed-stats--3 { grid-template-columns: repeat(3, 1fr); }
.ed-stats--4 { grid-template-columns: repeat(4, 1fr); }

.ed-stat {
  border-top: 1px solid rgba(11,31,63,.2);
  padding: 2.5mm 0 0;
}
.ed-stat-num {
  font-family: "Cormorant Garamond", serif;
  font-weight: 500;
  font-size: 22pt;
  line-height: 1;
  color: var(--navy);
  display: block;
  margin-bottom: 1mm;
}
.ed-stat-unit {
  font-family: "Inter", sans-serif;
  font-size: 7pt;
  letter-spacing: .15em;
  color: var(--gold);
  text-transform: uppercase;
}
.ed-stat-label {
  font-family: "Tajawal", sans-serif;
  font-size: 8.5pt;
  line-height: 1.4;
  color: var(--ink-soft);
  display: block;
}

/* Authority / decision callout */
.ed-callout {
  margin-top: auto;
  border-top: 1.5px solid var(--navy);
  padding-top: 3.5mm;
}
.ed-callout-eyebrow {
  display: block;
  font-family: "Inter", sans-serif;
  font-size: 7pt;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--navy);
  margin-bottom: 2mm;
  font-weight: 600;
}
.ed-callout-line {
  display: block;
  font-family: "Tajawal", sans-serif;
  font-size: 9pt;
  color: var(--ink);
  line-height: 1.55;
  margin-bottom: 1.5mm;
}
.ed-callout-line:last-child { margin-bottom: 0; }
.ed-callout-line strong {
  color: var(--navy);
  font-weight: 700;
}

/* Pull-quote */
.ed-pullquote {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-weight: 400;
  font-size: 14pt;
  line-height: 1.45;
  color: var(--navy);
  border-right: 2px solid var(--gold);
  padding: 1mm 4mm 1mm 0;
  margin: 4mm 0 5mm;
}
[dir="ltr"] .ed-pullquote {
  border-right: 0;
  border-left: 2px solid var(--gold);
  padding: 1mm 0 1mm 4mm;
}

/* Tag chips (e.g. for compliance lists) */
.ed-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 2mm;
  margin: 2mm 0 4mm;
}
.ed-chip {
  font-family: "Inter", sans-serif;
  font-size: 7.5pt;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--navy);
  border: 1px solid rgba(11,31,63,.25);
  padding: 1.2mm 2.8mm;
  border-radius: 50px;
  background: rgba(255,255,255,.5);
}

/* Numbered milestone list (for methodology / process pages) */
.ed-steps {
  display: flex;
  flex-direction: column;
  gap: 3mm;
  margin: 2mm 0 4mm;
}
.ed-step {
  display: grid;
  grid-template-columns: 14mm 1fr;
  gap: 3mm;
  align-items: start;
}
.ed-step-num {
  font-family: "Cormorant Garamond", serif;
  font-weight: 500;
  font-size: 18pt;
  line-height: 1;
  color: var(--gold);
}
.ed-step-body {
  border-top: 1px solid rgba(11,31,63,.15);
  padding-top: 1.5mm;
}
.ed-step-title {
  display: block;
  font-family: "Tajawal", sans-serif;
  font-weight: 700;
  font-size: 10pt;
  color: var(--navy);
  margin-bottom: 1mm;
}
.ed-step-desc {
  display: block;
  font-family: "Inter", sans-serif;
  font-size: 8.5pt;
  color: var(--ink-soft);
  line-height: 1.5;
}

/* Photo grid for visual half (when not single bg image) */
.ed-photo-grid {
  position: absolute;
  inset: 0;
  display: grid;
  gap: 1px;
  background: var(--navy);
}
.ed-photo-grid--2 { grid-template-rows: 1fr 1fr; }
.ed-photo-grid--3 { grid-template-rows: 1.4fr 1fr 1fr; }
.ed-photo-grid > div {
  background-size: cover;
  background-position: center;
  background-color: #1a2a4a;
}

/* Diagram panel (used by p21 governance, p18 BIM, etc.) */
.ed-diagram {
  width: 100%;
  height: auto;
  max-height: 100%;
}
.ed-diagram .ed-d-node-rect {
  fill: var(--paper);
  stroke: var(--navy);
  stroke-width: 1;
}
.ed-diagram .ed-d-node-rect--accent {
  fill: var(--navy);
  stroke: var(--navy);
}
.ed-diagram .ed-d-node-rect--gold {
  fill: var(--gold);
  stroke: var(--gold);
}
.ed-diagram .ed-d-edge {
  stroke: var(--navy);
  stroke-width: 1;
  fill: none;
}
.ed-diagram .ed-d-lbl-ar {
  font-family: "Tajawal", sans-serif;
  font-weight: 600;
  font-size: 9px;
  fill: var(--navy);
}
.ed-diagram .ed-d-lbl-ar--accent { fill: #fff; }
.ed-diagram .ed-d-lbl-en {
  font-family: "Inter", sans-serif;
  font-size: 7px;
  letter-spacing: .12em;
  text-transform: uppercase;
  fill: var(--ink-soft);
}
.ed-diagram .ed-d-lbl-en--accent { fill: var(--gold); }
.ed-diagram .ed-d-lbl-en--gold { fill: var(--navy); }

/* Plate caption (small italic caption for any visual) */
.ed-plate-cap {
  position: absolute;
  bottom: 4mm; right: 5mm;
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: 8pt;
  color: rgba(255,255,255,.75);
  letter-spacing: .05em;
}
