/* ============================================================
   Section 05 — The Market
   Maldives tourism macro context. Cream background, navy text,
   gold accents — designed to read like an institutional
   placement memo data-page.
   ============================================================ */

.market {
  position: relative;
  background: var(--cream);
  color: var(--ocean-deep);
  padding: clamp(72px, 10vh, 120px) 0 clamp(96px, 14vh, 160px);
}

.market__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(24px, 6vw, 72px);
}

.market__header {
  text-align: center;
  margin-bottom: clamp(56px, 8vh, 96px);
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

.market__header .section__eyebrow {
  color: rgba(4, 20, 28, 0.55);
}

.market__title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(48px, 6vw, 92px);
  line-height: 1.05;
  letter-spacing: 0.01em;
  color: var(--ocean-deep);
  margin: 14px 0 18px;
}

.market__lede {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(22px, 2.2vw, 32px);
  line-height: 1.45;
  color: rgba(4, 20, 28, 0.72);
  letter-spacing: 0.005em;
  /* Wider wrapper so the sentence fits in ≤3 lines, not 5 */
  max-width: 56ch;
  margin-left: auto;
  margin-right: auto;
}

/* ---------- Hero stat ---------- */
.market__hero-stat {
  text-align: center;
  margin-bottom: clamp(48px, 7vh, 80px);
  padding: 0 16px;
}

.market__hero-figure {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(96px, 16vw, 220px);
  line-height: 0.92;
  letter-spacing: -0.02em;
  color: var(--ocean-deep);
}

.market__hero-figure sup {
  font-size: 0.32em;
  font-weight: 400;
  letter-spacing: 0;
  vertical-align: top;
  margin-left: 4px;
  color: var(--gold);
  top: 0.45em;
  position: relative;
}

.market__hero-label {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgba(4, 20, 28, 0.55);
  margin-top: 18px;
}

.market__hero-deltas {
  font-family: var(--font-sans);
  font-size: 13px;
  color: rgba(4, 20, 28, 0.7);
  margin-top: 14px;
  letter-spacing: 0.04em;
}

.market__delta {
  font-weight: 500;
  color: var(--ocean-deep);
}

.market__delta--up::before {
  content: "▲";
  color: var(--gold);
  font-size: 9px;
  margin-right: 4px;
  position: relative;
  top: -1px;
}

.market__delta-sep {
  display: inline-block;
  width: 1px;
  height: 12px;
  background: rgba(4, 20, 28, 0.2);
  margin: 0 16px;
  vertical-align: middle;
}

.market__delta-caveat {
  font-size: 11px;
  font-style: italic;
  color: rgba(4, 20, 28, 0.45);
  margin-left: 4px;
}

.market__chart-value--forecast-caveat {
  fill: rgba(4, 20, 28, 0.4);
  font-size: 9px;
  font-style: italic;
  letter-spacing: 0.04em;
  text-anchor: middle;
}

/* ---------- Chart ---------- */
.market__chart {
  margin-bottom: clamp(56px, 9vh, 100px);
  padding: clamp(28px, 4vw, 48px) clamp(20px, 3vw, 36px) clamp(20px, 3vw, 32px);
  border-top: 0.5px solid rgba(4, 20, 28, 0.12);
  border-bottom: 0.5px solid rgba(4, 20, 28, 0.12);
}

.market__chart-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: clamp(20px, 3vh, 32px);
}

.market__chart-title {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgba(4, 20, 28, 0.7);
}

.market__chart-source {
  font-family: var(--font-sans);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(4, 20, 28, 0.4);
}

.market__chart-svg {
  width: 100%;
  height: auto;
  display: block;
  overflow: visible;
}

.market__chart-grid line {
  stroke: rgba(4, 20, 28, 0.08);
  stroke-width: 0.5;
}

.market__chart-yaxis text {
  font-family: var(--font-sans);
  font-size: 10px;
  fill: rgba(4, 20, 28, 0.45);
  letter-spacing: 0.08em;
}

.market__chart-xaxis text {
  font-family: var(--font-sans);
  font-size: 11px;
  fill: rgba(4, 20, 28, 0.6);
  letter-spacing: 0.16em;
  text-anchor: middle;
}

.market__chart-line {
  fill: none;
  stroke: var(--ocean-deep);
  stroke-width: 1.4;
  stroke-linejoin: round;
  stroke-linecap: round;
}

.market__chart-area {
  fill: rgba(11, 46, 64, 0.06);
  stroke: none;
}

.market__chart-dot {
  fill: var(--cream);
  stroke: var(--gold);
  stroke-width: 1.5;
}

.market__chart-dot--latest {
  fill: var(--gold);
  stroke: var(--gold);
}

.market__chart-value {
  font-family: var(--font-sans);
  font-size: 11px;
  fill: var(--ocean-deep);
  font-weight: 500;
  letter-spacing: 0.04em;
  text-anchor: middle;
}

.market__chart-value--muted {
  fill: rgba(4, 20, 28, 0.45);
  font-weight: 400;
}

/* Forecast styling — dashed line, hollow gold dot, gold label */
.market__chart-line--forecast {
  stroke: var(--gold);
  stroke-width: 1.4;
  stroke-dasharray: 4 4;
  fill: none;
}

.market__chart-dot--forecast {
  fill: var(--cream);
  stroke: var(--gold);
  stroke-width: 1.5;
  stroke-dasharray: 2 2;
}

.market__chart-value--forecast {
  fill: var(--gold);
  font-weight: 500;
  font-style: italic;
  letter-spacing: 0.04em;
  text-anchor: middle;
}

.market__chart-xaxis-forecast {
  fill: var(--gold) !important;
  font-style: italic;
}

/* ---------- Regional RevPAR bars ---------- */
.market__bars {
  margin: 0 auto clamp(56px, 8vh, 96px);
  padding: clamp(28px, 4vw, 48px) clamp(20px, 3vw, 36px) clamp(28px, 4vw, 40px);
  border-top: 0.5px solid rgba(4, 20, 28, 0.12);
  border-bottom: 0.5px solid rgba(4, 20, 28, 0.12);
}

.market__bars-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 8px;
}

.market__bar {
  display: grid;
  grid-template-columns: 200px 1fr 80px;
  align-items: center;
  gap: 18px;
}

.market__bar-label {
  font-family: var(--font-sans);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: rgba(4, 20, 28, 0.75);
  text-align: right;
}

.market__bar-label span {
  display: block;
  font-size: 9px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(4, 20, 28, 0.45);
  margin-top: 3px;
  font-weight: 500;
}

.market__bar-track {
  position: relative;
  height: 18px;
  background: rgba(4, 20, 28, 0.04);
}

.market__bar-fill {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  background: rgba(4, 20, 28, 0.55);
  transition: width 1200ms cubic-bezier(0.22, 1, 0.36, 1);
}

.market__bar--hero .market__bar-fill {
  background: var(--ocean-deep);
}

.market__bar--hero .market__bar-label {
  font-weight: 500;
  color: var(--ocean-deep);
}

.market__bar--secondary .market__bar-fill {
  background: rgba(11, 46, 64, 0.85);
}

.market__bar--secondary .market__bar-label {
  font-weight: 500;
  color: var(--ocean-deep);
}

.market__bar-value {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 400;
  letter-spacing: 0.01em;
  color: var(--ocean-deep);
  text-align: left;
}

.market__bar--hero .market__bar-value {
  color: var(--gold);
  font-weight: 500;
  font-size: 22px;
}

.market__bars-footnote {
  margin-top: 28px;
  padding-top: 22px;
  border-top: 0.5px dashed rgba(4, 20, 28, 0.18);
  font-family: var(--font-sans);
  font-size: 12px;
  line-height: 1.65;
  color: rgba(4, 20, 28, 0.6);
  letter-spacing: 0.01em;
}

.market__bars-footnote strong {
  color: var(--ocean-deep);
  font-weight: 500;
}

.market__bars-avg-marker {
  display: inline-block;
  width: 12px;
  height: 1px;
  background: rgba(4, 20, 28, 0.4);
  vertical-align: middle;
  margin-right: 8px;
  position: relative;
  top: -2px;
}

/* ---------- Stat tiles ---------- */
.market__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 0.5px solid rgba(4, 20, 28, 0.12);
  border-bottom: 0.5px solid rgba(4, 20, 28, 0.12);
  margin-bottom: clamp(48px, 7vh, 80px);
}

.market__stat {
  padding: clamp(28px, 4vw, 44px) clamp(16px, 2.5vw, 28px);
  text-align: left;
  border-left: 0.5px solid rgba(4, 20, 28, 0.12);
}

.market__stat:first-child {
  border-left: none;
}

.market__stat-eyebrow {
  font-family: var(--font-sans);
  font-size: 9px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 14px;
}

.market__stat-figure {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(38px, 4.4vw, 56px);
  line-height: 1;
  letter-spacing: -0.01em;
  color: var(--ocean-deep);
  margin-bottom: 12px;
}

.market__stat-label {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(4, 20, 28, 0.75);
  margin-bottom: 8px;
}

.market__stat-sub {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.02em;
  color: rgba(4, 20, 28, 0.5);
  line-height: 1.5;
}

/* ---------- Closing statement ---------- */
.market__closing {
  text-align: center;
  max-width: 780px;
  margin: 0 auto;
  padding: 0 16px;
}

.market__closing-lede {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(24px, 3vw, 36px);
  line-height: 1.35;
  color: var(--ocean-deep);
  letter-spacing: 0.005em;
}

.market__closing-sub {
  font-family: var(--font-sans);
  font-size: 13px;
  letter-spacing: 0.04em;
  color: rgba(4, 20, 28, 0.6);
  line-height: 1.65;
  margin-top: 18px;
}

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .market__stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .market__stat {
    border-left: 0.5px solid rgba(4, 20, 28, 0.12);
  }

  .market__stat:nth-child(2n+1) {
    border-left: none;
  }

  .market__stat:nth-child(n+3) {
    border-top: 0.5px solid rgba(4, 20, 28, 0.12);
  }
}

@media (max-width: 720px) {
  .market__bar {
    grid-template-columns: 110px 1fr 64px;
    gap: 12px;
  }

  .market__bar-label {
    font-size: 11px;
    letter-spacing: 0.04em;
  }

  .market__bar-label span {
    font-size: 8px;
    letter-spacing: 0.18em;
  }

  .market__bar-value {
    font-size: 14px;
  }

  .market__bar--hero .market__bar-value {
    font-size: 16px;
  }
}

@media (max-width: 560px) {
  .market__stats {
    grid-template-columns: 1fr;
  }

  .market__stat {
    border-left: none !important;
  }

  .market__stat:not(:first-child) {
    border-top: 0.5px solid rgba(4, 20, 28, 0.12);
  }

  .market__chart-xaxis text {
    font-size: 9px;
    letter-spacing: 0.08em;
  }

  .market__delta-sep {
    display: