/* ============================================
   THE VANDERBILT PORTFOLIO — DESIGN SYSTEM
   National Visions Cluster · OMAN 2040 VISION
   ============================================ */

/* RESET */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* CLUSTER BASE — National Visions (NEVER CHANGES) */
  --salmon: #F5EBDB;
  --salmon-dark: #EADDC8;
  --salmon-deep: #DDD0BA;
  --salmon-border: #CEBEA6;
  --salmon-hover: #FAF0E4;

  /* TYPOGRAPHY */
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body: 'Source Serif 4', Georgia, serif;
  --font-ui: 'DM Sans', 'Helvetica Neue', sans-serif;

  /* NEUTRALS */
  --ink: #1A1108;
  --ink-80: #33261A;
  --ink-60: #5C4A38;
  --ink-40: #8A7560;
  --ink-25: #B3A08A;
  --ink-15: #D4C4B0;
  --white: #FFFFFF;

  /* DOMAIN ACCENT — Oman */
  --accent: #1A5C4B;
  --accent-dark: #0E3D32;
  --accent-mid: #2A8C72;
  --accent-light: #5BB89E;
  --accent-pale: #E8F5F0;

  /* SECONDARY ACCENT */
  --accent2: #C8903A;
  --accent2-dark: #9C6B20;
  --accent2-light: #E8B866;

  /* SECTION ACCENTS */
  --section-economy: #1A5C4B;
  --section-energy: #2D6A4F;
  --section-tourism: #C8903A;
  --section-logistics: #2471A3;
  --section-digital: #7B3FC0;
  --section-governance: #8B0000;

  /* SEMANTIC */
  --positive: #1B7A4A;
  --negative: #C0392B;
  --warning: #D4872A;
}

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
body {
  background: var(--salmon);
  color: var(--ink);
  font-family: var(--font-body);
  line-height: 1.6;
}
a { color: var(--ink); text-decoration: none; }
a:hover { color: var(--accent); }
img { max-width: 100%; display: block; }
ul, ol { list-style: none; }

/* ============================================
   LAYOUT
   ============================================ */
.container { max-width: 1280px; margin: 0 auto; padding: 0 24px; }
.container-narrow { max-width: 740px; margin: 0 auto; padding: 0 24px; }
.container-article { max-width: 680px; margin: 0 auto; padding: 0 24px; }

/* ============================================
   SHARED COMPONENTS
   ============================================ */

/* Section Tags */
.section-tag {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent);
}
.section-tag--economy { color: var(--section-economy); }
.section-tag--energy { color: var(--section-energy); }
.section-tag--tourism { color: var(--section-tourism); }
.section-tag--logistics { color: var(--section-logistics); }
.section-tag--digital { color: var(--section-digital); }
.section-tag--governance { color: var(--section-governance); }

/* Badges */
.badge {
  font-family: var(--font-ui);
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 2px 7px;
  border-radius: 2px;
  display: inline-block;
  line-height: 1.4;
}
.badge--l1 { background: var(--ink-60); color: var(--white); }
.badge--l2 { background: var(--accent); color: var(--white); }
.badge--premium { background: var(--accent2); color: var(--white); }
.badge--on-track { background: var(--positive); color: var(--white); }
.badge--at-risk { background: var(--warning); color: var(--white); }
.badge--off-track { background: var(--negative); color: var(--white); }
.badge--ahead { background: var(--accent-mid); color: var(--white); }
.badge--stable { background: var(--ink-40); color: var(--white); }
.badge--entity { background: var(--salmon-deep); color: var(--ink-60); }
.badge--lens {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.3);
  color: var(--white);
}

/* Thin Rule */
.rule { border: none; border-top: 1px solid var(--salmon-border); margin: 0; }
.rule--dark { border-top-color: var(--ink-15); }

/* Progress Bar */
.progress-bar {
  width: 100%;
  height: 6px;
  background: var(--salmon-deep);
  border-radius: 3px;
  overflow: hidden;
}
.progress-bar__fill {
  height: 100%;
  border-radius: 3px;
}
.progress-bar__fill--positive { background: var(--positive); }
.progress-bar__fill--warning { background: var(--warning); }
.progress-bar__fill--negative { background: var(--negative); }
.progress-bar__fill--accent { background: var(--accent); }

/* Trends */
.trend { font-family: var(--font-ui); font-size: 12px; font-weight: 600; }
.trend--up { color: var(--positive); }
.trend--down { color: var(--negative); }
.trend--flat { color: var(--ink-40); }

/* Updated Tag */
.updated-tag {
  font-family: var(--font-ui);
  font-size: 10px;
  font-weight: 600;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Timestamp */
.timestamp {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-40);
}

/* Pull Quote */
.pull-quote {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.4rem;
  line-height: 1.45;
  color: var(--ink-80);
  border-left: 3px solid var(--accent);
  padding: 16px 0 16px 24px;
  margin: 32px 0;
}

/* Data Callout */
.data-callout {
  border-left: 3px solid var(--accent);
  padding: 16px 20px;
  margin: 24px 0;
}
.data-callout__number {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
  color: var(--accent);
  line-height: 1.1;
}
.data-callout__label {
  font-family: var(--font-ui);
  font-size: 12px;
  color: var(--ink-60);
  margin-top: 4px;
}

/* Buttons */
.btn {
  font-family: var(--font-ui);
  font-size: 13px;
  font-weight: 600;
  padding: 8px 20px;
  border: none;
  border-radius: 2px;
  cursor: pointer;
  display: inline-block;
  text-align: center;
  transition: background 0.2s;
  text-decoration: none;
}
.btn--primary { background: var(--accent); color: var(--white); }
.btn--primary:hover { background: var(--accent-dark); color: var(--white); }
.btn--secondary { background: transparent; color: var(--accent); border: 1px solid var(--accent); }
.btn--secondary:hover { background: var(--accent); color: var(--white); }
.btn--accent2 { background: var(--accent2); color: var(--white); }
.btn--accent2:hover { background: var(--accent2-dark); color: var(--white); }
.btn--dark { background: var(--ink); color: var(--salmon); }
.btn--dark:hover { background: var(--ink-80); color: var(--salmon); }
.btn--large { padding: 12px 32px; font-size: 14px; }

/* Section Header (used in body content) */
.section-header {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--ink);
  padding-bottom: 12px;
  border-bottom: 1px solid var(--salmon-border);
  margin-bottom: 20px;
  margin-top: 36px;
}
.section-header:first-child { margin-top: 0; }

/* Centered Section Label (like "TOP STORIES") */
.section-label {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ink-40);
  text-align: center;
  margin-bottom: 24px;
}

/* ============================================
   MASTHEAD
   ============================================ */
.masthead {
  background: var(--ink);
  padding: 9px 0;
  font-family: var(--font-ui);
  font-size: 11px;
}
.masthead .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.masthead__left {
  color: var(--ink-25);
  font-weight: 400;
  letter-spacing: 0.02em;
  font-size: 11px;
}
.masthead__right {
  display: flex;
  gap: 18px;
  align-items: center;
}
.masthead__right a {
  color: var(--salmon-deep);
  font-size: 11px;
  font-weight: 400;
}
.masthead__right a:hover { color: var(--white); }
.masthead__subscribe {
  background: var(--accent);
  color: var(--white);
  padding: 4px 14px;
  border-radius: 2px;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.masthead__subscribe:hover {
  background: var(--accent-mid);
  color: var(--white);
}

/* ============================================
   BRAND AREA
   ============================================ */
.brand {
  text-align: center;
  padding: 30px 0 22px;
  background: var(--salmon);
}
.brand__name {
  font-family: var(--font-display);
  font-size: 3rem;
  font-weight: 900;
  color: var(--ink);
  letter-spacing: 0.015em;
  line-height: 1.1;
}
.brand__tagline {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 1.15rem;
  color: var(--ink-60);
  margin-top: 6px;
}
.brand__subtitle {
  font-family: var(--font-ui);
  font-size: 9.5px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink-40);
  margin-top: 8px;
}

/* ============================================
   NAVIGATION
   ============================================ */
.nav {
  background: var(--salmon);
  border-top: 1px solid var(--salmon-border);
  border-bottom: 1px solid var(--salmon-border);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.nav::-webkit-scrollbar { display: none; }
.nav__list {
  display: flex;
  justify-content: center;
  min-width: max-content;
}
.nav__item {
  font-family: var(--font-ui);
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: 0.03em;
  padding: 12px 14px;
  color: var(--ink-60);
  white-space: nowrap;
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  cursor: pointer;
  transition: color 0.15s;
}
.nav__item:hover { color: var(--ink); }
.nav__item--active {
  color: var(--ink);
  font-weight: 600;
}
.nav__item--active::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 14px;
  right: 14px;
  height: 2px;
  background: var(--accent);
}
.nav__badge {
  font-size: 8px;
  background: var(--accent);
  color: var(--white);
  padding: 1px 4px;
  border-radius: 2px;
  font-weight: 700;
  line-height: 1.3;
}

/* ============================================
   KPI TICKER
   ============================================ */
.ticker {
  background: var(--ink);
  padding: 10px 0;
  overflow: hidden;
}
.ticker__track {
  display: flex;
  gap: 32px;
  animation: ticker-scroll 45s linear infinite;
  width: max-content;
}
.ticker__item {
  font-family: var(--font-ui);
  font-size: 12px;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.ticker__label { color: var(--ink-25); }
.ticker__value {
  color: var(--salmon);
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 13px;
}
.ticker__change--up { color: #4ADE80; font-weight: 500; }
.ticker__change--down { color: #F87171; font-weight: 500; }
.ticker__sep { color: var(--ink-60); margin: 0 4px; }

@keyframes ticker-scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ============================================
   FOOTER
   ============================================ */
.footer {
  background: var(--ink);
  color: var(--salmon-deep);
  padding: 48px 0 0;
  margin-top: 48px;
}
.footer__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 32px;
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(245,235,219,0.1);
}
.footer__col-title {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--salmon);
  margin-bottom: 16px;
}
.footer__link {
  display: block;
  font-family: var(--font-ui);
  font-size: 12.5px;
  color: var(--ink-25);
  padding: 4px 0;
  transition: color 0.15s;
}
.footer__link:hover { color: var(--salmon); }
.footer__network-link {
  display: block;
  padding: 5px 0;
}
.footer__network-domain {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 500;
  color: var(--accent-light);
}
.footer__network-desc {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-40);
}
.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 0;
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-40);
}
.footer__disclaimer {
  max-width: 500px;
  text-align: right;
  font-size: 10px;
  color: var(--ink-60);
  line-height: 1.4;
}

/* ============================================
   TEMPLATE A — HOMEPAGE
   ============================================ */
.home-hero {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 0;
  padding: 28px 0 0;
}
.home-hero__main {
  padding-right: 32px;
  border-right: 1px solid var(--salmon-border);
}
.home-hero__sidebar { padding-left: 32px; align-self: start; }

.home-hero__headline {
  font-family: var(--font-display);
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.16;
  color: var(--ink);
  margin: 8px 0 14px;
}
.home-hero__standfirst {
  font-family: var(--font-body);
  font-size: 1.05rem;
  color: var(--ink-60);
  line-height: 1.55;
}
.home-hero__meta {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 12px;
}

/* Secondary Stories */
.secondary-story {
  padding: 20px 0;
  border-top: 1px solid var(--salmon-border);
}
.secondary-story__headline {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 600;
  line-height: 1.3;
  color: var(--ink);
  margin: 6px 0 8px;
}
.secondary-story__excerpt {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--ink-60);
  line-height: 1.5;
}

/* Top Stories Grid */
.top-stories { padding: 32px 0; }
.top-stories__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.top-stories__item {
  padding: 0 20px;
  border-left: 1px solid var(--salmon-border);
}
.top-stories__item:first-child { border-left: none; padding-left: 0; }
.top-stories__item:last-child { padding-right: 0; }
.top-stories__item-headline {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.3;
  color: var(--ink);
  margin: 8px 0;
}
.top-stories__item-desc {
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--ink-60);
  line-height: 1.5;
}

/* KPI Scorecard */
.kpi-scorecard { padding: 32px 0; }
.kpi-scorecard__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.kpi-card {
  padding: 20px;
  border-left: 1px solid var(--salmon-border);
}
.kpi-card:first-child { border-left: none; }
.kpi-card__name {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-40);
  margin-bottom: 8px;
}
.kpi-card__value {
  font-family: var(--font-display);
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.1;
}
.kpi-card__meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 6px;
  font-family: var(--font-ui);
  font-size: 11px;
}
.kpi-card__target { color: var(--ink-40); }
.kpi-card__progress { margin-top: 10px; }

/* Article Stream */
.article-stream { padding: 24px 0; }
.stream-item {
  padding: 20px 0;
  border-top: 1px solid var(--salmon-border);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 20px;
  align-items: start;
}
.stream-item__headline {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 600;
  line-height: 1.3;
  color: var(--ink);
  margin: 4px 0 6px;
}
.stream-item__excerpt {
  font-family: var(--font-body);
  font-size: 0.88rem;
  color: var(--ink-60);
  line-height: 1.5;
}

/* GCC Preview Table */
.gcc-preview { padding: 32px 0; }
.gcc-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-ui);
  font-size: 13px;
}
.gcc-table th {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-40);
  padding: 10px 12px;
  text-align: left;
  border-bottom: 2px solid var(--ink-15);
}
.gcc-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--salmon-border);
  color: var(--ink-80);
}
.gcc-table td:first-child { font-weight: 500; color: var(--ink); }
.gcc-table .highlight-col { background: rgba(26,92,75,0.04); }
.gcc-table .leader { color: var(--accent); font-weight: 700; }

/* Sidebar Widgets */
.sidebar-widget {
  padding: 20px 0;
  border-top: 1px solid var(--salmon-border);
}
.sidebar-widget:first-child { border-top: none; padding-top: 0; }
.sidebar-widget__title {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-40);
  margin-bottom: 14px;
}
.sidebar-indicator {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 7px 0;
  border-bottom: 1px solid var(--salmon-border);
  font-family: var(--font-ui);
  font-size: 12.5px;
}
.sidebar-indicator:last-child { border-bottom: none; }
.sidebar-indicator__name { color: var(--ink-80); }
.sidebar-indicator__value {
  font-family: var(--font-display);
  font-weight: 600;
}

/* L2 Callout Box */
.l2-callout {
  background: var(--accent-dark);
  color: var(--white);
  padding: 24px;
  margin: 20px 0;
}
.l2-callout__title {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 700;
  margin-bottom: 8px;
}
.l2-callout__desc {
  font-family: var(--font-body);
  font-size: 0.88rem;
  color: var(--salmon-deep);
  line-height: 1.5;
  margin-bottom: 14px;
}
.l2-callout .btn { font-size: 11px; padding: 6px 14px; }

/* Network Links */
.network-link {
  display: block;
  padding: 8px 0;
  border-bottom: 1px solid var(--salmon-border);
}
.network-link:last-child { border-bottom: none; }
.network-link__domain {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
}
.network-link__desc {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-40);
}

/* ============================================
   TEMPLATE B — DEEP-DIVE
   ============================================ */
.deep-header {
  background: linear-gradient(135deg, #0D1B16 0%, var(--accent-dark) 60%, var(--accent) 100%);
  color: var(--white);
  padding: 48px 0 0;
}
.deep-header__breadcrumb {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--accent-light);
  margin-bottom: 16px;
}
.deep-header__breadcrumb a { color: var(--accent-light); }
.deep-header__breadcrumb a:hover { color: var(--white); }
.deep-header__breadcrumb span { color: var(--ink-25); margin: 0 6px; }
.deep-header__badges { display: flex; gap: 8px; margin-bottom: 16px; }
.deep-header__title {
  font-family: var(--font-display);
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.15;
  max-width: 720px;
}
.deep-header__subtitle {
  font-family: var(--font-body);
  font-size: 1.05rem;
  color: var(--salmon-deep);
  margin-top: 10px;
  max-width: 620px;
  line-height: 1.5;
}
.deep-header__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  margin-top: 32px;
  border-top: 1px solid rgba(255,255,255,0.15);
}
.deep-stat {
  padding: 20px;
  border-right: 1px solid rgba(255,255,255,0.1);
}
.deep-stat:last-child { border-right: none; }
.deep-stat__label {
  font-family: var(--font-ui);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--accent-light);
  margin-bottom: 4px;
}
.deep-stat__value {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--white);
}

/* Deep-Dive Body */
.deep-body {
  display: grid;
  grid-template-columns: 1fr 300px;
  padding: 32px 0;
}
.deep-body__main {
  padding-right: 32px;
  border-right: 1px solid var(--salmon-border);
}
.deep-body__sidebar { padding-left: 32px; align-self: start; }

/* Tabs */
.tabs {
  border-bottom: 1px solid var(--salmon-border);
  margin-bottom: 28px;
  display: flex;
}
.tab {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 500;
  padding: 12px 20px;
  color: var(--ink-40);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color 0.15s;
  background: none;
  border-top: none;
  border-left: none;
  border-right: none;
}
.tab:hover { color: var(--ink); }
.tab--active {
  color: var(--ink);
  font-weight: 600;
  border-bottom-color: var(--accent);
}

/* Objectives Grid */
.objectives-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.objective {
  padding: 20px;
  border-bottom: 1px solid var(--salmon-border);
  border-right: 1px solid var(--salmon-border);
}
.objective:nth-child(2n) { border-right: none; }
.objective__number {
  font-family: var(--font-display);
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--accent);
  line-height: 1;
}
.objective__title {
  font-family: var(--font-ui);
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  margin: 8px 0 6px;
}
.objective__desc {
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--ink-60);
  line-height: 1.5;
}

/* Body Prose (Deep-Dive) */
.deep-body__main p {
  font-family: var(--font-body);
  font-size: 1.02rem;
  color: var(--ink-80);
  line-height: 1.7;
  margin-bottom: 18px;
}
.deep-body__main h3 {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--ink);
  margin: 32px 0 14px;
  padding-top: 8px;
}

/* ============================================
   TEMPLATE C — ENTITY PROFILE
   ============================================ */
.entity-header {
  padding: 36px 0;
  border-bottom: 1px solid var(--salmon-border);
}
.entity-header__type { margin-bottom: 12px; }
.entity-header__name {
  font-family: var(--font-display);
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.15;
  color: var(--ink);
}
.entity-header__tagline {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--ink-60);
  margin-top: 8px;
}
.entity-header__metrics {
  display: flex;
  gap: 36px;
  margin-top: 24px;
  flex-wrap: wrap;
}
.entity-metric__label {
  font-family: var(--font-ui);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-40);
}
.entity-metric__value {
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--ink);
  margin-top: 2px;
}

/* Entity Body */
.entity-body {
  display: grid;
  grid-template-columns: 1fr 300px;
  padding: 32px 0;
}
.entity-body__main {
  padding-right: 32px;
  border-right: 1px solid var(--salmon-border);
}
.entity-body__sidebar { padding-left: 32px; align-self: start; }

.entity-body__main p {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--ink-80);
  line-height: 1.65;
  margin-bottom: 14px;
}

/* Timeline */
.timeline { position: relative; padding-left: 28px; }
.timeline::before {
  content: '';
  position: absolute;
  left: 5px;
  top: 6px;
  bottom: 6px;
  width: 1px;
  background: var(--salmon-border);
}
.timeline-item { padding-bottom: 24px; position: relative; }
.timeline-item:last-child { padding-bottom: 0; }
.timeline-item::before {
  content: '';
  position: absolute;
  left: -28px;
  top: 6px;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--accent);
  border: 2px solid var(--salmon);
}
.timeline-item__date {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 600;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.timeline-item__title {
  font-family: var(--font-ui);
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  margin: 4px 0;
}
.timeline-item__desc {
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--ink-60);
  line-height: 1.5;
}

/* SWOT Grid */
.swot-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.swot-cell {
  padding: 20px;
  border-bottom: 1px solid var(--salmon-border);
  border-right: 1px solid var(--salmon-border);
}
.swot-cell:nth-child(2n) { border-right: none; }
.swot-cell__title {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 12px;
}
.swot-cell--s .swot-cell__title { color: var(--positive); }
.swot-cell--w .swot-cell__title { color: var(--negative); }
.swot-cell--o .swot-cell__title { color: var(--accent); }
.swot-cell--t .swot-cell__title { color: var(--warning); }
.swot-cell li {
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--ink-60);
  line-height: 1.5;
  padding: 4px 0 4px 14px;
  position: relative;
}
.swot-cell li::before {
  content: '·';
  position: absolute;
  left: 0;
  color: var(--ink-40);
  font-weight: 700;
}

/* Investment Relevance Box */
.investment-box {
  border-left: 3px solid var(--accent2);
  padding: 20px 24px;
  margin: 24px 0;
}
.investment-box__title {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent2);
  margin-bottom: 10px;
}
.investment-box p {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--ink-80);
  line-height: 1.6;
}

/* ============================================
   TEMPLATE D — DASHBOARD
   ============================================ */
.dash-header {
  background: var(--accent);
  color: var(--white);
  padding: 36px 0;
}
.dash-header__title {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
}
.dash-header__subtitle {
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--accent-pale);
  margin-top: 6px;
}
.dash-header__updated {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--accent-light);
  margin-top: 10px;
}

/* Dashboard Body */
.dash-body {
  display: grid;
  grid-template-columns: 1fr 280px;
  padding: 32px 0;
}
.dash-body__main {
  padding-right: 32px;
  border-right: 1px solid var(--salmon-border);
}
.dash-body__sidebar { padding-left: 32px; align-self: start; }

.dash-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  padding: 28px 0;
}
.dash-kpi {
  padding: 20px;
  border-right: 1px solid var(--salmon-border);
}
.dash-kpi:last-child { border-right: none; }
.dash-kpi__name {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--ink-40);
}
.dash-kpi__value {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
  color: var(--ink);
  margin: 6px 0;
  line-height: 1.1;
}
.dash-kpi__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 4px;
}
.dash-kpi__target {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-40);
}

/* Scorecard Table */
.scorecard {
  width: 100%;
  border-collapse: collapse;
  margin: 16px 0;
}
.scorecard th {
  font-family: var(--font-ui);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-40);
  padding: 10px 12px;
  text-align: left;
  border-bottom: 2px solid var(--ink-15);
  background: var(--salmon);
  position: sticky;
  top: 0;
}
.scorecard td {
  font-family: var(--font-ui);
  font-size: 13px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--salmon-border);
  color: var(--ink-80);
}
.scorecard__group-header td {
  background: var(--salmon-dark);
  font-weight: 700;
  font-size: 12px;
  color: var(--ink);
  letter-spacing: 0.03em;
}
.scorecard .progress-bar {
  width: 80px;
  display: inline-block;
  vertical-align: middle;
}

/* ============================================
   TEMPLATE E — ARTICLE / INTELLIGENCE BRIEF
   ============================================ */
.article-header {
  padding: 44px 0 28px;
  border-bottom: 1px solid var(--salmon-border);
}
.article-header__headline {
  font-family: var(--font-display);
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.15;
  color: var(--ink);
  max-width: 680px;
  margin: 12px 0;
}
.article-header__standfirst {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 1.1rem;
  color: var(--ink-60);
  line-height: 1.55;
  max-width: 640px;
  margin-bottom: 16px;
}
.article-header__byline {
  font-family: var(--font-ui);
  font-size: 12px;
  color: var(--ink-40);
}
.article-header__byline strong {
  color: var(--ink);
  font-weight: 600;
}

/* Article Layout */
.article-layout {
  display: grid;
  grid-template-columns: 1fr 260px;
  padding: 32px 0;
}
.article-layout__body {
  padding-right: 40px;
  border-right: 1px solid var(--salmon-border);
}
.article-layout__sidebar { padding-left: 28px; align-self: start; }

.article-layout__body p {
  font-family: var(--font-body);
  font-size: 1.06rem;
  line-height: 1.78;
  color: var(--ink-80);
  margin-bottom: 20px;
}
.article-layout__body h3 {
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--ink);
  margin: 36px 0 16px;
  padding-top: 12px;
  border-top: 1px solid var(--salmon-border);
}
.article-break {
  text-align: center;
  color: var(--ink-25);
  margin: 32px 0;
  letter-spacing: 8px;
  font-size: 14px;
}

/* Article Tags */
.article-tags { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 24px; padding-top: 24px; border-top: 1px solid var(--salmon-border); }
.article-tag {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-60);
  border: 1px solid var(--salmon-border);
  padding: 3px 10px;
  border-radius: 2px;
}

/* TOC */
.toc { position: sticky; top: 24px; }
.toc--static { position: static; }
.toc__title {
  font-family: var(--font-ui);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-40);
  margin-bottom: 12px;
}
.toc__item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-ui);
  font-size: 12px;
  color: var(--ink-60);
  padding: 6px 0;
}
.toc__item::before {
  content: '';
  width: 6px;
  height: 6px;
  min-width: 6px;
  border-radius: 50%;
  background: var(--salmon-border);
  transition: background 0.15s;
}
.toc__item:hover { color: var(--ink); }
.toc__item:hover::before { background: var(--ink-40); }
.toc__item--active {
  color: var(--ink);
  font-weight: 600;
}
.toc__item--active::before {
  background: var(--accent);
}

/* Subscribe CTA (article footer) */
.subscribe-cta {
  border-top: 1px solid var(--salmon-border);
  padding: 28px 0;
  margin-top: 32px;
}
.subscribe-cta__title {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 6px;
}
.subscribe-cta__desc {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--ink-60);
  margin-bottom: 14px;
}

/* ============================================
   TEMPLATE F — UTILITY / REFERENCE
   ============================================ */
.utility-header {
  padding: 48px 0 28px;
  text-align: center;
}
.utility-header__title {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
  color: var(--ink);
}
.utility-header__subtitle {
  font-family: var(--font-body);
  font-size: 1.05rem;
  color: var(--ink-60);
  margin-top: 8px;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}

.utility-body { padding: 32px 0 48px; }
.utility-body p {
  font-family: var(--font-body);
  font-size: 1.02rem;
  line-height: 1.75;
  color: var(--ink-80);
  margin-bottom: 18px;
}
.utility-body h3 {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--ink);
  margin: 32px 0 12px;
}
.utility-body ol {
  list-style: none;
  counter-reset: lens-counter;
  margin: 20px 0;
}
.utility-body ol li {
  counter-increment: lens-counter;
  padding: 16px 0;
  border-bottom: 1px solid var(--salmon-border);
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--ink-80);
  line-height: 1.6;
  padding-left: 48px;
  position: relative;
}
.utility-body ol li::before {
  content: counter(lens-counter);
  position: absolute;
  left: 0;
  top: 16px;
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--accent);
}
.utility-body ol li strong {
  display: block;
  font-family: var(--font-ui);
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 4px;
}

/* ============================================
   TEMPLATE G — COMPARISON TABLE
   ============================================ */
.comparison-header {
  padding: 36px 0 24px;
  border-bottom: 1px solid var(--salmon-border);
}
.comparison-header__title {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
  color: var(--ink);
  margin: 8px 0;
}
.comparison-header__subtitle {
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--ink-60);
  line-height: 1.5;
  max-width: 640px;
}

.comparison-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  padding: 32px 0;
}
.comparison-layout__main {
  padding-right: 32px;
  border-right: 1px solid var(--salmon-border);
}
.comparison-layout__sidebar { padding-left: 32px; align-self: start; }

.comparison-table {
  width: 100%;
  border-collapse: collapse;
  margin: 0 0 32px;
}
.comparison-table th {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 12px 16px;
  text-align: left;
  border-bottom: 2px solid var(--ink-15);
  color: var(--ink-40);
}
.comparison-table th.highlight {
  background: rgba(26,92,75,0.06);
  color: var(--accent);
}
.comparison-table td {
  font-family: var(--font-ui);
  font-size: 13.5px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--salmon-border);
  color: var(--ink-80);
}
.comparison-table td.highlight { background: rgba(26,92,75,0.04); }
.comparison-table td.metric-name {
  font-weight: 600;
  color: var(--ink);
}
.comparison-table .rank {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: 9px;
  font-weight: 700;
  background: var(--accent);
  color: var(--white);
  width: 18px;
  height: 18px;
  line-height: 18px;
  text-align: center;
  border-radius: 50%;
  margin-left: 6px;
}
.comparison-table .rank--2 { background: var(--ink-40); }
.comparison-table .rank--3 { background: var(--ink-25); }
.comparison-table .rank--4 { background: var(--ink-15); color: var(--ink-60); }

/* Analysis Sections */
.analysis-section {
  padding: 24px 0;
  border-top: 1px solid var(--salmon-border);
}
.analysis-section__title {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 10px;
}
.analysis-section p {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--ink-80);
  line-height: 1.65;
}

/* Cross-Domain Links */
.cross-domain {
  padding: 24px 0;
  border-top: 1px solid var(--salmon-border);
}
.cross-domain__title {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-40);
  margin-bottom: 14px;
}
.cross-domain__item {
  display: block;
  padding: 10px 0;
  border-bottom: 1px solid var(--salmon-border);
}
.cross-domain__item:last-child { border-bottom: none; }
.cross-domain__item-domain {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
}
.cross-domain__item-title {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--ink-60);
  margin-top: 2px;
}

/* ============================================
   TEMPLATE H — ENCYCLOPEDIA
   ============================================ */
.ency-header {
  padding: 36px 0 24px;
  border-bottom: 1px solid var(--salmon-border);
}
.ency-header__name {
  font-family: var(--font-display);
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--ink);
  margin: 8px 0 6px;
}
.ency-header__def {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 1rem;
  color: var(--ink-60);
}
.ency-header__facts {
  display: flex;
  gap: 28px;
  margin-top: 16px;
  flex-wrap: wrap;
}
.ency-fact__label {
  font-family: var(--font-ui);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-40);
}
.ency-fact__value {
  font-family: var(--font-ui);
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  margin-top: 2px;
}

.ency-body {
  display: grid;
  grid-template-columns: 1fr 260px;
  padding: 28px 0;
}
.ency-body__main {
  padding-right: 32px;
  border-right: 1px solid var(--salmon-border);
}
.ency-body__sidebar { padding-left: 28px; align-self: start; }

.ency-body__main h3 {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--ink);
  margin: 28px 0 12px;
}
.ency-body__main h3:first-child { margin-top: 0; }
.ency-body__main p {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--ink-80);
  line-height: 1.65;
  margin-bottom: 14px;
}
.ency-body__main ul { margin: 12px 0; }
.ency-body__main ul li {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--ink-80);
  line-height: 1.6;
  padding: 4px 0 4px 16px;
  position: relative;
}
.ency-body__main ul li::before {
  content: '—';
  position: absolute;
  left: 0;
  color: var(--ink-25);
}

/* Related Entities Bar */
.related-bar {
  padding: 28px 0;
  border-top: 1px solid var(--salmon-border);
}
.related-bar__title {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-40);
  margin-bottom: 16px;
}
.related-bar__items {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  padding-bottom: 8px;
}
.related-bar__item {
  min-width: 200px;
  padding: 16px;
  border: 1px solid var(--salmon-border);
  flex-shrink: 0;
}
.related-bar__item-type {
  font-family: var(--font-ui);
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-40);
}
.related-bar__item-name {
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--ink);
  margin-top: 4px;
}

/* ============================================
   TEMPLATE I — LANDING / LEAD GEN
   ============================================ */
.landing-hero {
  padding: 64px 0 48px;
  text-align: center;
}
.landing-hero__headline {
  font-family: var(--font-display);
  font-size: 2.6rem;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.15;
}
.landing-hero__subtitle {
  font-family: var(--font-body);
  font-size: 1.15rem;
  color: var(--ink-60);
  margin-top: 14px;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.55;
}

.value-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  padding: 40px 0;
  border-top: 1px solid var(--salmon-border);
  border-bottom: 1px solid var(--salmon-border);
}
.value-item {
  padding: 24px 20px;
  border-right: 1px solid var(--salmon-border);
  text-align: center;
}
.value-item:last-child { border-right: none; }
.value-item__icon {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 12px;
}
.value-item__title {
  font-family: var(--font-ui);
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 8px;
}
.value-item__desc {
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--ink-60);
  line-height: 1.5;
}

/* Pricing */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  padding: 48px 0;
}
.pricing-tier {
  padding: 32px 28px;
  border: 1px solid var(--salmon-border);
  border-right: none;
  text-align: center;
}
.pricing-tier:last-child { border-right: 1px solid var(--salmon-border); }
.pricing-tier--featured {
  border-color: var(--accent);
  border-right: 1px solid var(--accent);
}
.pricing-tier--featured + .pricing-tier { border-left: none; }
.pricing-tier__label {
  font-family: var(--font-ui);
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--accent);
  margin-bottom: 4px;
}
.pricing-tier__name {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-40);
}
.pricing-tier__price {
  font-family: var(--font-display);
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--ink);
  margin: 12px 0 4px;
}
.pricing-tier__period {
  font-family: var(--font-ui);
  font-size: 12px;
  color: var(--ink-40);
  margin-bottom: 20px;
}
.pricing-tier__features { text-align: left; margin: 20px 0; }
.pricing-tier__feature {
  font-family: var(--font-ui);
  font-size: 12.5px;
  color: var(--ink-80);
  padding: 6px 0;
  border-bottom: 1px solid var(--salmon-border);
}
.pricing-tier__feature:last-child { border-bottom: none; }

/* Email Capture */
.email-capture {
  padding: 48px 0;
  text-align: center;
}
.email-capture__title {
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 6px;
}
.email-capture__desc {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--ink-60);
}
.email-capture__form {
  display: flex;
  max-width: 440px;
  margin: 20px auto 0;
}
.email-capture__input {
  flex: 1;
  font-family: var(--font-ui);
  font-size: 13px;
  padding: 12px 16px;
  border: 1px solid var(--salmon-border);
  border-right: none;
  background: var(--white);
  color: var(--ink);
  outline: none;
}
.email-capture__input:focus { border-color: var(--accent); }
.email-capture__btn {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 600;
  padding: 12px 24px;
  background: var(--accent);
  color: var(--white);
  border: 1px solid var(--accent);
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.email-capture__btn:hover { background: var(--accent-dark); }

/* Social Proof */
.social-proof {
  padding: 36px 0;
  text-align: center;
  border-top: 1px solid var(--salmon-border);
}
.social-proof__label {
  font-family: var(--font-ui);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-40);
  margin-bottom: 20px;
}
.social-proof__logos {
  display: flex;
  justify-content: center;
  gap: 40px;
  align-items: center;
  flex-wrap: wrap;
}
.social-proof__logo {
  font-family: var(--font-ui);
  font-size: 14px;
  font-weight: 600;
  color: var(--ink-25);
  letter-spacing: 0.02em;
}

/* FAQ */
.faq-section { padding: 40px 0; }
.faq-item {
  padding: 20px 0;
  border-bottom: 1px solid var(--salmon-border);
}
.faq-item__q {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 8px;
}
.faq-item__a {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--ink-60);
  line-height: 1.6;
}

/* ============================================
   BREADCRUMBS
   ============================================ */
.breadcrumbs {
  padding: 12px 0;
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-40);
}
.breadcrumbs ol {
  display: flex;
  align-items: center;
  gap: 0;
  list-style: none;
}
.breadcrumbs li { display: flex; align-items: center; }
.breadcrumbs li + li::before {
  content: '›';
  margin: 0 8px;
  color: var(--ink-25);
  font-size: 12px;
}
.breadcrumbs a {
  color: var(--ink-40);
  text-decoration: none;
}
.breadcrumbs a:hover { color: var(--accent); }
.breadcrumbs li:last-child span { color: var(--ink-60); }

/* ============================================
   TEMPLATE J — SECTION INDEX / VERTICAL LANDING
   ============================================ */

/* Section Index Header */
.section-index-header {
  padding: 36px 0 0;
}
.section-index-header__name {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 800;
  color: var(--ink);
  line-height: 1.1;
}
.section-index-header__rule {
  width: 80px;
  height: 3px;
  margin: 12px 0;
}
.section-index-header__rule--energy { background: var(--section-energy); }
.section-index-header__rule--tourism { background: var(--section-tourism); }
.section-index-header__rule--economy { background: var(--section-economy); }
.section-index-header__rule--logistics { background: var(--section-logistics); }
.section-index-header__rule--digital { background: var(--section-digital); }
.section-index-header__rule--governance { background: var(--section-governance); }
.section-index-header__rule--investment { background: var(--accent2); }
.section-index-header__desc {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 1.02rem;
  color: var(--ink-40);
  max-width: 600px;
}
.section-index-header__subnav {
  display: flex;
  gap: 0;
  margin-top: 20px;
  border-bottom: 1px solid var(--salmon-border);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.section-index-header__subnav::-webkit-scrollbar { display: none; }
.subnav__item {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 500;
  color: var(--ink-40);
  padding: 10px 16px;
  white-space: nowrap;
  position: relative;
  cursor: pointer;
  transition: color 0.15s;
  text-decoration: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.subnav__item:first-child { padding-left: 0; }
.subnav__item:hover { color: var(--ink); }
.subnav__item--active {
  color: var(--ink);
  font-weight: 600;
}
.subnav__item--active-energy { border-bottom-color: var(--section-energy); }
.subnav__item--active-tourism { border-bottom-color: var(--section-tourism); }
.subnav__item--active-economy { border-bottom-color: var(--section-economy); }
.subnav__item--active-logistics { border-bottom-color: var(--section-logistics); }
.subnav__item--active-digital { border-bottom-color: var(--section-digital); }
.subnav__item--active-investment { border-bottom-color: var(--accent2); }

/* Section Lead Story */
.section-lead {
  padding: 28px 0;
  border-bottom: 1px solid var(--salmon-border);
}
.section-lead__headline {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.25;
  color: var(--ink);
  margin: 8px 0 12px;
  max-width: 720px;
}
.section-lead__standfirst {
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--ink-60);
  line-height: 1.55;
  max-width: 640px;
}
.section-lead__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
}

/* Section KPI Strip */
.section-kpi-strip {
  display: flex;
  padding: 20px 0;
  border-bottom: 1px solid var(--salmon-border);
}
.section-kpi {
  flex: 1;
  padding: 0 20px;
  border-right: 1px solid var(--salmon-border);
  cursor: pointer;
  transition: background 0.15s;
}
.section-kpi:first-child { padding-left: 0; }
.section-kpi:last-child { border-right: none; padding-right: 0; }
.section-kpi:hover { background: var(--salmon-hover); }
.section-kpi__label {
  font-family: var(--font-ui);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-40);
}
.section-kpi__value {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.2;
  margin-top: 2px;
}
.section-kpi__trend {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 600;
  margin-top: 2px;
}

/* Section Layout (two column) */
.section-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  padding: 28px 0;
}
.section-layout__main {
  padding-right: 32px;
  border-right: 1px solid var(--salmon-border);
}
.section-layout__sidebar { padding-left: 32px; align-self: start; }

/* Featured Deep Dive */
.featured-deep {
  border-left: 4px solid var(--section-energy);
  padding: 20px 24px;
  margin: 28px 0;
}
.featured-deep--tourism { border-left-color: var(--section-tourism); }
.featured-deep--economy { border-left-color: var(--section-economy); }
.featured-deep--logistics { border-left-color: var(--section-logistics); }
.featured-deep--digital { border-left-color: var(--section-digital); }
.featured-deep--investment { border-left-color: var(--accent2); }
.featured-deep__headline {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--ink);
  margin: 4px 0 8px;
}
.featured-deep__excerpt {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--ink-60);
  line-height: 1.55;
}
.featured-deep__link {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
  display: inline-block;
  margin-top: 10px;
}

/* Entity Cards (compact, horizontal) */
.entity-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  padding: 28px 0;
  border-top: 1px solid var(--salmon-border);
}
.entity-card {
  padding: 16px 20px;
  border-right: 1px solid var(--salmon-border);
}
.entity-card:last-child { border-right: none; }
.entity-card__type {
  font-family: var(--font-ui);
  font-size: 8px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-40);
}
.entity-card__name {
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--ink);
  margin: 4px 0;
}
.entity-card__metric {
  font-family: var(--font-display);
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--accent);
}

/* Cross-Domain Callout (Section Index) */
.cross-domain-callout {
  padding: 20px 24px;
  border: 1px solid var(--salmon-border);
  margin: 28px 0;
  text-align: center;
}
.cross-domain-callout__text {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--accent);
}
.cross-domain-callout__sub {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-40);
  margin-top: 4px;
}

/* ============================================
   TEMPLATE K — PREMIUM GATE / PAYWALL
   ============================================ */

/* Fade Overlay */
.premium-fade {
  position: relative;
}
.premium-fade::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 180px;
  background: linear-gradient(to bottom, rgba(245,235,219,0) 0%, var(--salmon) 100%);
  pointer-events: none;
}

/* Hidden text below fade */
.premium-hidden {
  display: none;
}

/* Premium Gate Container */
.premium-gate {
  text-align: center;
  padding: 48px 0 56px;
  max-width: 540px;
  margin: 0 auto;
}
.premium-gate__rule {
  width: 60px;
  height: 2px;
  background: var(--accent);
  margin: 0 auto 32px;
}
.premium-gate__headline {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.3;
}
.premium-gate__subtext {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--ink-40);
  line-height: 1.55;
  max-width: 500px;
  margin: 14px auto 0;
}
.premium-gate__counter {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-40);
  margin-top: 20px;
}
.premium-gate__progress {
  width: 200px;
  height: 4px;
  background: var(--salmon-deep);
  border-radius: 2px;
  margin: 8px auto 28px;
  overflow: hidden;
}
.premium-gate__progress-fill {
  height: 100%;
  background: var(--accent);
  border-radius: 2px;
}
.premium-cta {
  font-family: var(--font-ui);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
  background: var(--accent);
  color: var(--white);
  border: none;
  padding: 14px 48px;
  border-radius: 2px;
  cursor: pointer;
  display: inline-block;
  text-decoration: none;
  transition: background 0.2s;
}
.premium-cta:hover { background: var(--accent-dark); color: var(--white); }
.premium-gate__signin {
  font-family: var(--font-ui);
  font-size: 12px;
  color: var(--accent);
  display: block;
  margin-top: 14px;
}
.premium-gate__signin:hover { color: var(--accent-dark); }
.premium-gate__features {
  display: flex;
  justify-content: center;
  gap: 32px;
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--salmon-border);
}
.premium-gate__feature {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-40);
  line-height: 1.4;
  max-width: 180px;
  text-align: center;
}
.premium-gate__feature strong {
  display: block;
  color: var(--ink-60);
  font-weight: 600;
  margin-bottom: 2px;
}
.premium-gate__rule-bottom {
  width: 60px;
  height: 2px;
  background: var(--accent);
  margin: 32px auto 0;
}

/* ============================================
   TEMPLATE L — SEARCH RESULTS
   ============================================ */

/* Search Header */
.search-header {
  padding: 36px 0 0;
}
.search-input-large {
  width: 100%;
  font-family: var(--font-ui);
  font-size: 16px;
  padding: 14px 20px;
  border: 1px solid var(--salmon-border);
  background: var(--white);
  color: var(--ink);
  outline: none;
  border-radius: 2px;
}
.search-input-large:focus { border-color: var(--accent); }
.search-input-large::placeholder { color: var(--ink-25); }

.search-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 0;
  border-bottom: 1px solid var(--salmon-border);
}
.search-meta__count {
  font-family: var(--font-ui);
  font-size: 14px;
  color: var(--ink-60);
}
.search-meta__sort {
  display: flex;
  gap: 12px;
}
.search-meta__sort-item {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-40);
  cursor: pointer;
  text-decoration: none;
}
.search-meta__sort-item:hover { color: var(--ink); }
.search-meta__sort-item--active { color: var(--ink); font-weight: 600; }

/* Search Filters */
.search-filters {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  padding: 14px 0;
  border-bottom: 1px solid var(--salmon-border);
}
.search-filter-group {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}
.search-filter-group__label {
  font-family: var(--font-ui);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-40);
  margin-right: 4px;
}
.search-chip {
  font-family: var(--font-ui);
  font-size: 10px;
  font-weight: 500;
  color: var(--ink-60);
  background: var(--salmon-dark);
  padding: 4px 10px;
  border-radius: 2px;
  cursor: pointer;
  border: 1px solid transparent;
  text-decoration: none;
  transition: all 0.15s;
}
.search-chip:hover { border-color: var(--salmon-border); color: var(--ink); }
.search-chip--active {
  border-color: var(--accent);
  color: var(--accent);
  font-weight: 600;
  background: var(--salmon-hover);
}

/* Search Layout */
.search-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  padding: 0 0 32px;
}
.search-layout__main {
  padding-right: 32px;
  border-right: 1px solid var(--salmon-border);
}
.search-layout__sidebar { padding-left: 32px; padding-top: 20px; align-self: start; }

/* Search Result */
.search-result {
  padding: 18px 0;
  border-bottom: 1px solid var(--salmon-border);
}
.search-result__badges {
  display: flex;
  gap: 6px;
  align-items: center;
  margin-bottom: 6px;
}
.search-result-badge {
  font-family: var(--font-ui);
  font-size: 8px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 2px 6px;
  border-radius: 2px;
}
.search-result-badge--article { background: var(--salmon-deep); color: var(--ink-60); }
.search-result-badge--dashboard { background: var(--accent-pale); color: var(--accent); }
.search-result-badge--entity { background: #F0E6D8; color: var(--accent2-dark); }
.search-result-badge--comparison { background: #E8EDF5; color: var(--section-logistics); }
.search-result-badge--encyclopedia { background: var(--salmon-dark); color: var(--ink-60); }
.search-result-badge--deep-dive { background: var(--ink-15); color: var(--ink-60); }
.search-result__title {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.3;
  text-decoration: none;
}
.search-result__title:hover { color: var(--accent); }
.search-result__excerpt {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--ink-60);
  line-height: 1.5;
  margin-top: 4px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.search-result__meta {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-40);
  margin-top: 6px;
  display: flex;
  gap: 8px;
  align-items: center;
}

/* Search Pagination */
.search-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4px;
  padding: 28px 0;
  font-family: var(--font-ui);
  font-size: 12px;
}
.search-pagination__item {
  padding: 6px 10px;
  color: var(--ink-60);
  cursor: pointer;
  text-decoration: none;
  border-radius: 2px;
  transition: all 0.15s;
}
.search-pagination__item:hover { background: var(--salmon-dark); color: var(--ink); }
.search-pagination__item--active {
  background: var(--accent);
  color: var(--white);
  font-weight: 600;
}
.search-pagination__item--disabled {
  color: var(--ink-25);
  cursor: default;
}

/* ============================================
   TEMPLATE M — 404 ERROR
   ============================================ */
.error-page {
  padding: 80px 0 60px;
  text-align: center;
}
.error-page__code {
  font-family: var(--font-display);
  font-size: 6rem;
  font-weight: 900;
  color: var(--ink-15);
  line-height: 1;
  margin-bottom: 16px;
}
.error-page__headline {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--ink);
}
.error-page__subtext {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--ink-40);
  max-width: 460px;
  margin: 12px auto 0;
  line-height: 1.55;
}
.error-page__search {
  max-width: 480px;
  margin: 28px auto;
}
.error-page__search input {
  width: 100%;
  font-family: var(--font-ui);
  font-size: 14px;
  padding: 12px 18px;
  border: 1px solid var(--salmon-border);
  background: var(--white);
  color: var(--ink);
  outline: none;
  border-radius: 2px;
}
.error-page__search input:focus { border-color: var(--accent); }
.error-page__search input::placeholder { color: var(--ink-25); }

.error-recovery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  padding: 36px 0;
  border-top: 1px solid var(--salmon-border);
  text-align: left;
  max-width: 800px;
  margin: 0 auto;
}
.error-recovery__col {
  padding: 0 24px;
  border-right: 1px solid var(--salmon-border);
}
.error-recovery__col:first-child { padding-left: 0; }
.error-recovery__col:last-child { border-right: none; padding-right: 0; }
.error-recovery__title {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-40);
  margin-bottom: 12px;
}
.error-recovery__link {
  display: block;
  font-family: var(--font-display);
  font-size: 14px;
  color: var(--accent);
  padding: 6px 0;
  border-bottom: 1px solid var(--salmon-border);
  text-decoration: none;
}
.error-recovery__link:last-child { border-bottom: none; }
.error-recovery__link:hover { color: var(--accent-dark); }

.error-crossdomain {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-40);
  text-align: center;
  padding: 24px 0 0;
}
.error-crossdomain a { color: var(--accent); }
.error-crossdomain a:hover { color: var(--accent-dark); }

/* ============================================
   TEMPLATE N — TAXONOMY / TAG ARCHIVE
   ============================================ */
.taxonomy-header {
  padding: 36px 0 0;
}
.taxonomy-header__type {
  font-family: var(--font-ui);
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-40);
}
.taxonomy-header__name {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 800;
  color: var(--ink);
  margin: 6px 0;
  line-height: 1.15;
}
.taxonomy-header__desc {
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--ink-40);
  max-width: 600px;
  line-height: 1.55;
}
.taxonomy-header__count {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-40);
  margin-top: 10px;
}
.taxonomy-header__rule {
  width: 60px;
  height: 3px;
  margin-top: 16px;
}
.taxonomy-header__rule--accent { background: var(--accent); }
.taxonomy-header__rule--accent2 { background: var(--accent2); }

/* Taxonomy Layout */
.taxonomy-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  padding: 8px 0 32px;
}
.taxonomy-layout__main {
  padding-right: 32px;
  border-right: 1px solid var(--salmon-border);
}
.taxonomy-layout__sidebar { padding-left: 32px; padding-top: 20px; align-self: start; }

/* Taxonomy Content Grid */
.taxonomy-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
.taxonomy-item {
  padding: 18px 20px;
  border-bottom: 1px solid var(--salmon-border);
  border-right: 1px solid var(--salmon-border);
}
.taxonomy-item:nth-child(2n) { border-right: none; }
.taxonomy-item__badges {
  display: flex;
  gap: 6px;
  align-items: center;
  margin-bottom: 6px;
}
.taxonomy-item__title {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.3;
  text-decoration: none;
  display: block;
}
.taxonomy-item__title:hover { color: var(--accent); }
.taxonomy-item__excerpt {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--ink-60);
  line-height: 1.5;
  margin-top: 4px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.taxonomy-item__meta {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-40);
  margin-top: 6px;
  display: flex;
  gap: 8px;
  align-items: center;
}

/* Taxonomy Sidebar Widgets */
.taxonomy-tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.taxonomy-tag {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-60);
  border: 1px solid var(--salmon-border);
  padding: 4px 10px;
  border-radius: 2px;
  text-decoration: none;
  transition: all 0.15s;
}
.taxonomy-tag:hover { border-color: var(--accent); color: var(--accent); }
.taxonomy-breakdown {
  font-family: var(--font-ui);
  font-size: 12px;
}
.taxonomy-breakdown__row {
  display: flex;
  justify-content: space-between;
  padding: 6px 0;
  border-bottom: 1px solid var(--salmon-border);
  color: var(--ink-80);
}
.taxonomy-breakdown__row:last-child { border-bottom: none; }
.taxonomy-breakdown__count {
  font-family: var(--font-display);
  font-weight: 600;
  color: var(--ink);
}

/* ============================================
   TEMPLATE O — ENCYCLOPEDIA INDEX
   ============================================ */
.ency-index-header {
  padding: 48px 0 28px;
  text-align: center;
}
.ency-index-header__title {
  font-family: var(--font-display);
  font-size: 2.2rem;
  font-weight: 800;
  color: var(--ink);
}
.ency-index-header__subtitle {
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--ink-40);
  margin-top: 8px;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.5;
}
.ency-index-header__search {
  max-width: 480px;
  margin: 24px auto 0;
}
.ency-index-header__search input {
  width: 100%;
  font-family: var(--font-ui);
  font-size: 14px;
  padding: 12px 18px;
  border: 1px solid var(--salmon-border);
  background: var(--white);
  color: var(--ink);
  outline: none;
  border-radius: 2px;
}
.ency-index-header__search input:focus { border-color: var(--accent); }
.ency-index-header__search input::placeholder { color: var(--ink-25); }

/* Ency Filter Bar */
.ency-filter-bar {
  padding: 16px 0;
  border-bottom: 1px solid var(--salmon-border);
}
.ency-filter-types {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.ency-alpha-bar {
  display: flex;
  gap: 2px;
  flex-wrap: wrap;
  justify-content: center;
}
.ency-alpha-bar__letter {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 600;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-60);
  cursor: pointer;
  text-decoration: none;
  border-radius: 2px;
  transition: all 0.15s;
}
.ency-alpha-bar__letter:hover { background: var(--salmon-dark); color: var(--ink); }
.ency-alpha-bar__letter--active { background: var(--accent); color: var(--white); }
.ency-alpha-bar__letter--disabled { color: var(--ink-15); cursor: default; }

/* Ency Index Layout */
.ency-index-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  padding: 0 0 32px;
}
.ency-index-layout__main {
  padding-right: 32px;
  border-right: 1px solid var(--salmon-border);
}
.ency-index-layout__sidebar { padding-left: 32px; padding-top: 20px; align-self: start; }

/* Featured Entities Grid */
.ency-featured {
  padding: 28px 0;
  border-bottom: 1px solid var(--salmon-border);
}
.ency-featured__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}
.ency-featured__item {
  padding: 16px 20px;
  border-right: 1px solid var(--salmon-border);
  border-bottom: 1px solid var(--salmon-border);
}
.ency-featured__item:nth-child(3n) { border-right: none; }
.ency-featured__item-type {
  font-family: var(--font-ui);
  font-size: 8px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 2px 6px;
  border-radius: 2px;
  display: inline-block;
}
.ency-featured__item-type--swf { background: var(--accent-pale); color: var(--accent); }
.ency-featured__item-type--soe { background: #E8F5F0; color: var(--section-energy); }
.ency-featured__item-type--govt { background: #FFF0E0; color: var(--accent2-dark); }
.ency-featured__item-type--fz { background: #E8EDF5; color: var(--section-logistics); }
.ency-featured__item-name {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 600;
  color: var(--ink);
  margin: 6px 0 4px;
  line-height: 1.3;
}
.ency-featured__item-desc {
  font-family: var(--font-body);
  font-size: 12.5px;
  color: var(--ink-60);
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.ency-featured__item-stat {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 700;
  color: var(--accent);
  margin-top: 6px;
}

/* Letter Groups */
.ency-letter-group {
  padding-top: 28px;
}
.ency-letter-group__header {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--ink-15);
  margin-bottom: 0;
}
.ency-letter-group__letter {
  font-family: var(--font-display);
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--ink-15);
}
.ency-letter-group__count {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--ink-25);
}

/* Directory Entry */
.ency-entry {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid var(--salmon-border);
}
.ency-entry__type {
  font-family: var(--font-ui);
  font-size: 8px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 2px 6px;
  border-radius: 2px;
  white-space: nowrap;
}
.ency-entry__type--soe { background: #E8F5F0; color: var(--section-energy); }
.ency-entry__type--company { background: var(--salmon-dark); color: var(--ink-60); }
.ency-entry__type--programme { background: #FFF0E0; color: var(--accent2-dark); }
.ency-entry__type--govt { background: #F5F0E8; color: var(--ink-60); }
.ency-entry__type--fz { background: #E8EDF5; color: var(--section-logistics); }
.ency-entry__type--fi { background: #EDE8F5; color: var(--section-digital); }
.ency-entry__type--concept { background: var(--salmon-deep); color: var(--ink-60); }
.ency-entry__type--infra { background: #F0E8E8; color: var(--section-governance); }
.ency-entry__body { min-width: 0; }
.ency-entry__name {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
}
.ency-entry__name:hover { color: var(--accent-dark); }
.ency-entry__desc {
  font-family: var(--font-body);
  font-size: 12.5px;
  color: var(--ink-40);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ency-entry__metric {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
  white-space: nowrap;
  text-align: right;
}

/* ============================================
   RESPONSIVE — TABLET
   ============================================ */
@media (max-width: 1024px) {
  .home-hero { grid-template-columns: 1fr; }
  .home-hero__main { padding-right: 0; border-right: none; border-bottom: 1px solid var(--salmon-border); padding-bottom: 24px; }
  .home-hero__sidebar { padding-left: 0; padding-top: 24px; }
  .top-stories__grid { grid-template-columns: repeat(2, 1fr); }
  .top-stories__item { border-bottom: 1px solid var(--salmon-border); padding-bottom: 20px; margin-bottom: 20px; }
  .kpi-scorecard__grid, .dash-kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .kpi-card, .dash-kpi { border-bottom: 1px solid var(--salmon-border); }
  .deep-body, .entity-body, .article-layout, .ency-body, .comparison-layout, .dash-body, .section-layout, .search-layout, .taxonomy-layout, .ency-index-layout {
    grid-template-columns: 1fr;
  }
  .deep-body__main, .entity-body__main, .article-layout__body, .ency-body__main, .comparison-layout__main, .dash-body__main, .section-layout__main, .search-layout__main, .taxonomy-layout__main, .ency-index-layout__main {
    padding-right: 0; border-right: none;
    padding-bottom: 24px; border-bottom: 1px solid var(--salmon-border);
  }
  .deep-body__sidebar, .entity-body__sidebar, .article-layout__sidebar, .ency-body__sidebar, .comparison-layout__sidebar, .dash-body__sidebar, .section-layout__sidebar, .search-layout__sidebar, .taxonomy-layout__sidebar, .ency-index-layout__sidebar {
    padding-left: 0; padding-top: 24px;
  }
  .entity-cards { grid-template-columns: repeat(2, 1fr); }
  .ency-featured__grid { grid-template-columns: repeat(2, 1fr); }
  .ency-featured__item { border-right: 1px solid var(--salmon-border); }
  .ency-featured__item:nth-child(2n) { border-right: none; }
  .taxonomy-grid { grid-template-columns: 1fr; }
  .taxonomy-item { border-right: none; }
  .deep-header__stats { grid-template-columns: repeat(2, 1fr); }
  .footer__grid { grid-template-columns: repeat(3, 1fr); }
  .value-grid { grid-template-columns: repeat(2, 1fr); }
  .value-item { border-bottom: 1px solid var(--salmon-border); }
  .pricing-grid { grid-template-columns: 1fr; }
  .pricing-tier { border-right: 1px solid var(--salmon-border); }
  .pricing-tier--featured + .pricing-tier { border-left: 1px solid var(--salmon-border); }
}

/* ============================================
   RESPONSIVE — MOBILE
   ============================================ */
@media (max-width: 640px) {
  .container { padding: 0 16px; }
  .brand__name { font-size: 2.2rem; }
  .brand__tagline { font-size: 1rem; }
  .nav__item { padding: 10px 10px; font-size: 11px; }
  .home-hero__headline { font-size: 1.8rem; }
  .top-stories__grid { grid-template-columns: 1fr; }
  .kpi-scorecard__grid, .dash-kpi-grid { grid-template-columns: 1fr; }
  .deep-header__title { font-size: 1.8rem; }
  .deep-header__stats { grid-template-columns: 1fr; }
  .entity-header__metrics { flex-direction: column; gap: 12px; }
  .objectives-grid { grid-template-columns: 1fr; }
  .objective { border-right: none; }
  .swot-grid { grid-template-columns: 1fr; }
  .swot-cell { border-right: none; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .footer__bottom { flex-direction: column; gap: 12px; text-align: center; }
  .value-grid { grid-template-columns: 1fr; }
  .email-capture__form { flex-direction: column; }
  .email-capture__input { border-right: none; border-bottom: 1px solid var(--salmon-border); }
  .article-header__headline { font-size: 1.8rem; }
  .landing-hero__headline { font-size: 2rem; }
  .social-proof__logos { gap: 20px; }
  .masthead .container { flex-direction: column; gap: 6px; text-align: center; }
  .comparison-table { display: block; overflow-x: auto; }
  .stream-item { grid-template-columns: 1fr; }
  .gcc-table { display: block; overflow-x: auto; }
  .scorecard { display: block; overflow-x: auto; }
  .section-kpi-strip { flex-wrap: wrap; }
  .section-kpi { min-width: 50%; border-bottom: 1px solid var(--salmon-border); border-right: none; }
  .entity-cards { grid-template-columns: 1fr; }
  .entity-card { border-right: none; border-bottom: 1px solid var(--salmon-border); }
  .error-recovery { grid-template-columns: 1fr; }
  .error-recovery__col { padding: 16px 0; border-right: none; border-bottom: 1px solid var(--salmon-border); }
  .error-recovery__col:last-child { border-bottom: none; }
  .error-page__code { font-size: 4rem; }
  .premium-gate__features { flex-direction: column; gap: 16px; align-items: center; }
  .ency-featured__grid { grid-template-columns: 1fr; }
  .ency-featured__item { border-right: none; }
  .ency-entry { grid-template-columns: auto 1fr; }
  .ency-entry__metric { grid-column: 2; padding-left: 0; }
  .cookie-banner {
    flex-direction: column;
    padding: 16px 20px;
    text-align: center;
  }
}

/* ============================================
   COOKIE CONSENT BANNER
   ============================================ */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--ink);
  color: rgba(255,255,255,0.7);
  padding: 16px 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  z-index: 9999;
  border-top: 1px solid rgba(255,255,255,0.08);
  font-family: var(--font-ui);
  font-size: 12px;
  line-height: 1.5;
}
.cookie-banner a {
  color: var(--accent2-light);
  text-decoration: underline;
}
.cookie-banner-buttons {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}
.cookie-accept {
  background: var(--accent2);
  color: var(--white);
  border: none;
  padding: 8px 20px;
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.15s;
}
.cookie-accept:hover { background: var(--accent2-dark); }
.cookie-manage {
  background: transparent;
  color: rgba(255,255,255,0.4);
  border: 1px solid rgba(255,255,255,0.15);
  padding: 8px 16px;
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}
.cookie-manage:hover { color: var(--white); border-color: rgba(255,255,255,0.3); }