/* ============================================================
   PROJECT HISTORY — EDITORIAL ARCHETYPES (added 2026-05-01)
   Used by §14 Featured Projects, §15 Key Projects, §16 Image Gallery
   Brief: museum-monograph quality, asymmetric grids, mixed scales,
          fine-line dividers, deep navy + cream + gold.
   ============================================================ */

/* --- Shared project-history typography accents --- */
.proj-eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: 10pt; letter-spacing: 0.32em;
  color: var(--gold); text-transform: uppercase; font-weight: 700;
}
.proj-large-num {
  font-family: var(--font-display);
  font-size: 64pt; font-weight: 300;
  color: var(--navy); line-height: 0.9; letter-spacing: -0.02em;
}
.proj-rule-fine {
  height: 0.4pt; background: var(--gold); opacity: 0.55;
}
.proj-rule-thick {
  height: 1.2pt; background: var(--navy); opacity: 0.85;
}

/* ============ §14.0 LEGACY TIMELINE ============
   Horizontal year band; large year numbers, project names below,
   thin gold rule connecting milestones.
   ================================================ */
.proj-timeline { position: relative; background: var(--paper); }
.proj-timeline .content {
  padding: 8mm 10mm 6mm; display: flex; flex-direction: column; gap: 6mm; overflow: hidden;
}
.proj-timeline .pt-hero { display: flex; flex-direction: column; gap: 1.5mm; text-align: right; }
.proj-timeline .pt-title {
  font-family: 'Tajawal', sans-serif;
  font-weight: 800; font-size: 26pt; color: var(--ink);
  line-height: 1.1; letter-spacing: -0.012em;
}
.proj-timeline .pt-tag {
  font-family: var(--font-display); font-style: italic;
  font-size: 12pt; color: var(--ink-soft);
}
.proj-timeline .pt-band {
  position: relative; flex: 1; min-height: 0;
  display: grid; grid-template-columns: repeat(7, 1fr); gap: 0;
  padding: 12mm 0 4mm;
}
.proj-timeline .pt-axis {
  position: absolute; left: 0; right: 0; top: 50%;
  height: 0.8pt; background: var(--gold); opacity: 0.7;
}
.proj-timeline .pt-milestone {
  position: relative; display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 0 2mm;
}
.proj-timeline .pt-milestone::before {
  content: ""; position: absolute; left: 50%; top: 50%;
  width: 3mm; height: 3mm; margin: -1.5mm 0 0 -1.5mm;
  background: var(--gold); border-radius: 50%; box-shadow: 0 0 0 2pt var(--paper);
  z-index: 2;
}
.proj-timeline .pt-milestone--key::before {
  width: 5mm; height: 5mm; margin: -2.5mm 0 0 -2.5mm;
  background: var(--navy); border: 1pt solid var(--gold);
}
.proj-timeline .pt-year {
  position: absolute; top: -8mm; left: 0; right: 0;
  font-family: var(--font-display); font-size: 22pt; font-weight: 500;
  color: var(--navy); line-height: 1;
}
.proj-timeline .pt-milestone--key .pt-year { color: var(--gold); font-weight: 600; }
.proj-timeline .pt-event {
  position: absolute; top: calc(50% + 6mm); left: 0; right: 0;
  display: flex; flex-direction: column; gap: 0.5mm; padding: 0 1mm;
}
.proj-timeline .pt-event-ar {
  font-family: 'Tajawal', sans-serif; font-weight: 700; font-size: 7.5pt;
  color: var(--ink); line-height: 1.2;
}
.proj-timeline .pt-event-en {
  font-family: 'Inter', sans-serif; font-size: 6pt;
  color: var(--muted); letter-spacing: 0.04em; line-height: 1.3;
}
.proj-timeline .pt-stats-strip {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 4mm;
  padding-top: 4mm; border-top: 0.4pt solid var(--hairline);
}
.proj-timeline .pt-stat { display: flex; flex-direction: column; gap: 0.5mm; text-align: right; }
.proj-timeline .pt-stat-num {
  font-family: var(--font-display); font-size: 20pt; font-weight: 500;
  color: var(--navy); line-height: 1;
}
.proj-timeline .pt-stat-unit { font-family: 'Inter', sans-serif; font-size: 7pt; color: var(--gold); letter-spacing: 0.1em; }
.proj-timeline .pt-stat-label { font-family: 'Tajawal', sans-serif; font-size: 7.5pt; color: var(--ink-soft); }

/* ============ §14.1-3 FLAGSHIP PROJECT SPREAD ============
   Full-bleed hero on left, cream narrative panel on right with:
   eyebrow + large project number + AR title + EN tag + narrative
   + key facts strip + 1-2 inset detail photos.
   =========================================================== */
.proj-flagship { position: relative; background: var(--paper); }
.proj-flagship .content {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 0; padding: 0; overflow: hidden;
}
/* Left: full-bleed hero (visual right in RTL) */
.proj-flagship .pf-hero {
  position: relative;
  background-size: cover; background-position: center;
  min-height: 0; min-width: 0;
}
.proj-flagship .pf-hero-overlay {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 4mm 6mm 4mm; color: var(--paper);
  background: linear-gradient(to top, rgba(11,31,63,0.85), transparent);
}
.proj-flagship .pf-hero-cap-ar {
  font-family: 'Tajawal', sans-serif; font-weight: 700; font-size: 10pt;
  color: var(--paper); display: block;
}
.proj-flagship .pf-hero-cap-en {
  font-family: 'Inter', sans-serif; font-style: italic; font-size: 8pt;
  color: var(--gold-light); letter-spacing: 0.04em; display: block; margin-top: 0.5mm;
}
/* Right: cream panel */
.proj-flagship .pf-panel {
  background: var(--cream);
  padding: 10mm 8mm 6mm 10mm;
  display: flex; flex-direction: column; gap: 4mm;
  border-inline-end: 0.7pt solid var(--gold);
  min-width: 0; overflow: hidden;
}
.proj-flagship .pf-eyebrow {
  font-family: 'Inter', sans-serif; font-size: 10pt; font-weight: 700;
  letter-spacing: 0.32em; color: var(--gold); text-transform: uppercase;
}
.proj-flagship .pf-num {
  font-family: var(--font-display); font-size: 56pt; font-weight: 300;
  color: var(--navy); line-height: 0.85; letter-spacing: -0.02em;
  margin: 1mm 0 0;
}
.proj-flagship .pf-title-ar {
  font-family: 'Tajawal', sans-serif; font-weight: 800; font-size: 22pt;
  color: var(--ink); line-height: 1.15; margin: 1mm 0 0; text-align: right;
}
.proj-flagship .pf-title-en {
  font-family: var(--font-display); font-style: italic; font-size: 12pt;
  color: var(--ink-soft); margin: 0.5mm 0 0;
}
.proj-flagship .pf-rule {
  height: 0.5pt; background: var(--gold); opacity: 0.55; margin: 1mm 0;
}
.proj-flagship .pf-narrative {
  font-family: 'Tajawal', sans-serif; font-size: 9pt; line-height: 1.55;
  color: var(--ink-soft); text-align: right;
}
.proj-flagship .pf-facts {
  display: grid; grid-template-columns: 1fr 1fr; gap: 2mm 4mm;
  padding-top: 3mm; border-top: 0.4pt solid var(--hairline);
}
.proj-flagship .pf-fact { display: flex; flex-direction: column; gap: 0.3mm; }
.proj-flagship .pf-fact-key {
  font-family: 'Inter', sans-serif; font-size: 6pt; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--muted);
}
.proj-flagship .pf-fact-val {
  font-family: 'Tajawal', sans-serif; font-size: 8pt; font-weight: 700; color: var(--ink);
}
.proj-flagship .pf-details {
  display: grid; grid-template-columns: 1fr 1fr; gap: 2mm; margin-top: auto;
}
.proj-flagship .pf-detail {
  background-size: cover; background-position: center;
  height: 28mm; border: 0.4pt solid var(--hairline);
}
.proj-flagship .pf-detail--single { grid-column: 1 / -1; height: 38mm; }

/* ============ §14.4 REGIONAL EXPANSION MAP ============
   Two-column: SVG map left, region cards right.
   ========================================================= */
.proj-map { position: relative; background: var(--paper); }
.proj-map .content {
  padding: 6mm 8mm; display: grid; grid-template-columns: 1.3fr 0.85fr;
  gap: 6mm; overflow: hidden;
}
.proj-map .pm-left { display: flex; flex-direction: column; gap: 3mm; min-width: 0; }
.proj-map .pm-hero { display: flex; flex-direction: column; gap: 1mm; }
.proj-map .pm-title {
  font-family: 'Tajawal', sans-serif; font-weight: 800; font-size: 24pt;
  color: var(--ink); line-height: 1.1;
}
.proj-map .pm-tag {
  font-family: var(--font-display); font-style: italic; font-size: 11pt;
  color: var(--ink-soft);
}
.proj-map .pm-mapwrap {
  flex: 1; min-height: 0; background: var(--cream);
  border: 0.4pt solid var(--hairline); padding: 4mm;
  display: grid; place-items: center;
}
.proj-map .pm-svg { width: 100%; height: 100%; }
.proj-map .pm-pin { fill: var(--gold); stroke: var(--navy); stroke-width: 0.5; }
.proj-map .pm-pin--hub { fill: var(--navy); stroke: var(--gold); stroke-width: 0.8; r: 2.5; }
.proj-map .pm-region-line { fill: none; stroke: var(--ink-soft); stroke-width: 0.4; opacity: 0.5; }
.proj-map .pm-coast { fill: var(--paper); stroke: var(--navy-soft); stroke-width: 0.6; }
.proj-map .pm-label-city { font-family: 'Inter', sans-serif; font-size: 5.5pt; fill: var(--ink); font-weight: 600; }
.proj-map .pm-label-country { font-family: 'Inter', sans-serif; font-size: 4.5pt; fill: var(--muted); letter-spacing: 0.1em; text-transform: uppercase; }
/* Right column: legend + region cards */
.proj-map .pm-right { display: flex; flex-direction: column; gap: 3mm; min-width: 0; }
.proj-map .pm-legend {
  display: flex; flex-direction: column; gap: 1.5mm;
  padding: 3mm; background: var(--gold-pale); border-inline-start: 1pt solid var(--gold);
}
.proj-map .pm-legend-title {
  font-family: 'Inter', sans-serif; font-size: 6.5pt; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--navy); font-weight: 700;
}
.proj-map .pm-legend-row { display: flex; align-items: center; gap: 2mm; }
.proj-map .pm-legend-dot { width: 2.5mm; height: 2.5mm; border-radius: 50%; flex-shrink: 0; }
.proj-map .pm-legend-text { font-family: 'Tajawal', sans-serif; font-size: 7pt; color: var(--ink); }
.proj-map .pm-region {
  display: flex; flex-direction: column; gap: 0.5mm;
  padding-bottom: 2mm; border-bottom: 0.3pt dashed var(--hairline);
}
.proj-map .pm-region-name {
  font-family: 'Tajawal', sans-serif; font-weight: 700; font-size: 9pt; color: var(--ink);
}
.proj-map .pm-region-en {
  font-family: 'Inter', sans-serif; font-size: 6.5pt; color: var(--muted);
  letter-spacing: 0.04em;
}
.proj-map .pm-region-stat {
  font-family: var(--font-display); font-size: 14pt; color: var(--gold); font-weight: 500;
}

/* ============ §15 SECTORIAL INDEX (3-column) ============
   Replaces old 3-page list. Each column = one sector.
   ========================================================= */
.proj-sectorial { position: relative; background: var(--paper); }
.proj-sectorial .content {
  padding: 6mm 8mm; display: flex; flex-direction: column; gap: 4mm; overflow: hidden;
}
.proj-sectorial .ps-hero { display: flex; flex-direction: column; gap: 1mm; }
.proj-sectorial .ps-title {
  font-family: 'Tajawal', sans-serif; font-weight: 800; font-size: 22pt;
  color: var(--ink); line-height: 1.15;
}
.proj-sectorial .ps-tag {
  font-family: var(--font-display); font-style: italic; font-size: 11pt;
  color: var(--ink-soft);
}
.proj-sectorial .ps-cols {
  flex: 1; display: grid; grid-template-columns: repeat(3, 1fr); gap: 5mm;
  min-height: 0;
}
.proj-sectorial .ps-col {
  display: flex; flex-direction: column; gap: 2mm; min-height: 0; min-width: 0;
}
.proj-sectorial .ps-col-header {
  display: flex; flex-direction: column; gap: 0.5mm;
  padding-bottom: 2mm; border-bottom: 1.2pt solid var(--navy);
}
.proj-sectorial .ps-col-num {
  font-family: var(--font-display); font-size: 28pt; font-weight: 300;
  color: var(--gold); line-height: 1; letter-spacing: -0.02em;
}
.proj-sectorial .ps-col-name-ar {
  font-family: 'Tajawal', sans-serif; font-weight: 800; font-size: 11pt; color: var(--ink);
}
.proj-sectorial .ps-col-name-en {
  font-family: 'Inter', sans-serif; font-size: 7pt; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--muted);
}
.proj-sectorial .ps-cards { display: flex; flex-direction: column; gap: 1mm; flex: 1; min-height: 0; overflow: hidden; }
.proj-sectorial .ps-card {
  display: grid; grid-template-columns: 12mm 1fr; gap: 2mm;
  padding: 0.4mm 0; border-bottom: 0.3pt dashed var(--hairline);
}
.proj-sectorial .ps-card-img {
  width: 12mm; height: 8mm;
  background-size: cover; background-position: center;
  border: 0.3pt solid var(--hairline);
}
.proj-sectorial .ps-card-body { display: flex; flex-direction: column; gap: 0.3mm; min-width: 0; overflow: hidden; }
.proj-sectorial .ps-card-name {
  font-family: 'Tajawal', sans-serif; font-weight: 700; font-size: 7.5pt; color: var(--ink);
  line-height: 1.2; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.proj-sectorial .ps-card-meta {
  font-family: 'Inter', sans-serif; font-size: 6pt; color: var(--muted);
  letter-spacing: 0.04em;
}

/* ============ §16.1 LANDMARK DELIVERIES (asymmetric mosaic) ============
   1 hero + 6 supporting at varying sizes.
   ====================================================================== */
.proj-landmark { position: relative; background: var(--paper); }
.proj-landmark .content {
  padding: 5mm 6mm; display: flex; flex-direction: column; gap: 3mm; overflow: hidden;
}
.proj-landmark .pl-hero-row { display: flex; flex-direction: column; gap: 1mm; }
.proj-landmark .pl-title {
  font-family: 'Tajawal', sans-serif; font-weight: 800; font-size: 20pt;
  color: var(--ink); line-height: 1.15;
}
.proj-landmark .pl-tag {
  font-family: var(--font-display); font-style: italic; font-size: 10pt; color: var(--ink-soft);
}
.proj-landmark .pl-mosaic {
  flex: 1; min-height: 0;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: 1fr 1fr 1fr;
  gap: 2mm;
}
.proj-landmark .pl-tile {
  background-size: cover; background-position: center;
  border: 0.4pt solid var(--hairline);
  position: relative;
  overflow: hidden;
}
.proj-landmark .pl-tile--hero { grid-column: 1 / 2; grid-row: 1 / 4; }
.proj-landmark .pl-tile-cap {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 1.5mm 2mm;
  background: linear-gradient(to top, rgba(11,31,63,0.85), transparent);
  font-family: 'Inter', sans-serif; font-size: 6pt;
  color: var(--paper); letter-spacing: 0.04em;
}
.proj-landmark .pl-tile--hero .pl-tile-cap {
  font-size: 8pt; padding: 3mm;
}

/* ============ §16.2 MATERIALITY & CRAFT ============
   Macro-detail counterpoint. Tight grid of closeups, captions tagging
   technique or material.
   ===================================================== */
.proj-materiality { position: relative; background: var(--paper); }
.proj-materiality .content {
  padding: 5mm 6mm; display: flex; flex-direction: column; gap: 3mm; overflow: hidden;
}
.proj-materiality .pmat-hero { display: flex; flex-direction: column; gap: 1mm; }
.proj-materiality .pmat-title {
  font-family: 'Tajawal', sans-serif; font-weight: 800; font-size: 20pt;
  color: var(--ink); line-height: 1.15;
}
.proj-materiality .pmat-tag {
  font-family: var(--font-display); font-style: italic; font-size: 10pt; color: var(--ink-soft);
}
.proj-materiality .pmat-grid {
  flex: 1; min-height: 0;
  display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 1fr;
  gap: 2mm;
}
.proj-materiality .pmat-cell { display: flex; flex-direction: column; gap: 0.5mm; min-height: 0; }
.proj-materiality .pmat-cell-img {
  flex: 1; background-size: cover; background-position: center;
  border: 0.4pt solid var(--hairline); min-height: 0;
}
.proj-materiality .pmat-cell-cap {
  font-family: 'Inter', sans-serif; font-size: 6pt; color: var(--ink-soft);
  letter-spacing: 0.04em; padding-top: 0.5mm;
}
.proj-materiality .pmat-cell-cap strong {
  font-family: 'Tajawal', sans-serif; font-weight: 700; color: var(--ink);
  font-size: 7pt; display: block;
}

/* End project-history archetypes */

