/* =========================================================
   pages.css — Estils per a analisi.html
   ========================================================= */

:root {
  --color-paper: #F5EFE4;
  --color-paper-dark: #EDE5D3;
  --color-paper-deep: #2A2520;
  --color-ink: #1F1A15;
  --color-ink-soft: #4A4239;
  --color-ink-mute: #8A8073;

  --color-resort: #C04A30;
  --color-resort-soft: #E8B5A8;
  --color-city: #2E5077;
  --color-city-soft: #B5C5D6;

  --color-gold: #C4915C;
  --color-rule: #D8CFB8;

  --font-display: 'Fraunces', Georgia, serif;
  --font-body:    'Newsreader', Georgia, serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

html { font-size: 17px; -webkit-text-size-adjust: 100%; }

body {
  background: var(--color-paper);
  color: var(--color-ink);
  font-family: var(--font-body);
  font-size: 1.125rem;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "kern", "liga", "onum";
}

.tag {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.78em;
  font-weight: 500;
  padding: 1px 8px;
  border-radius: 2px;
}
.tag-resort { background: var(--color-resort); color: var(--color-paper); }
.tag-city   { background: var(--color-city);   color: var(--color-paper); }

.num {
  font-family: var(--font-mono);
  font-weight: 700;
  background: rgba(196, 145, 92, 0.22);
  padding: 1px 6px;
  border-radius: 2px;
}

code {
  font-family: var(--font-mono);
  font-size: 0.92em;
  background: rgba(31, 26, 21, 0.06);
  padding: 1px 6px;
  border-radius: 2px;
}

a {
  color: var(--color-resort);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  text-decoration-color: rgba(192, 74, 48, 0.4);
}
a:hover { text-decoration-color: var(--color-resort); }

/* ---------------- HEADER (compartit) ---------------- */
.page-header {
  border-bottom: 1px solid var(--color-rule);
  padding: 22px 0;
  background: var(--color-paper);
}
.page-header-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 32px;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 24px;
  flex-wrap: wrap;
}
.page-header-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.2rem;
  letter-spacing: -0.01em;
  font-variation-settings: "opsz" 18;
  margin: 0;
}
.page-header-title .pipe {
  color: var(--color-ink-mute);
  margin: 0 12px;
  font-weight: 200;
}
.page-header-nav {
  display: flex;
  gap: 22px;
}
.page-header-nav a {
  font-family: var(--font-mono);
  font-size: 0.74rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-ink-mute);
  text-decoration: none;
}
.page-header-nav a:hover,
.page-header-nav a.is-current { color: var(--color-ink); }

/* =========================================================
   ANALISI — article layout
   ========================================================= */
.analisi {
  background: var(--color-paper);
  padding: 64px 0 120px;
}
.analisi-wrap {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 32px;
}

.analisi-eyebrow {
  font-family: var(--font-mono);
  font-size: 0.74rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-ink-mute);
  margin-bottom: 22px;
}
.analisi-title {
  font-family: var(--font-display);
  font-size: clamp(44px, 5.5vw, 68px);
  font-weight: 350;
  line-height: 1;
  letter-spacing: -0.03em;
  margin: 0 0 24px;
  font-variation-settings: "opsz" 96, "SOFT" 50;
}
.analisi-title em { font-style: italic; color: var(--color-resort); }

.analisi-deck {
  font-family: var(--font-body);
  font-size: 1.32rem;
  line-height: 1.55;
  font-style: italic;
  color: var(--color-ink-soft);
  margin: 0 0 64px;
  max-width: 620px;
  font-variation-settings: "opsz" 36;
}

.analisi-section {
  margin: 64px 0;
}
.analisi-section h2 {
  font-family: var(--font-display);
  font-size: 1.8rem;
  font-weight: 400;
  letter-spacing: -0.02em;
  margin: 0 0 20px;
  padding-top: 28px;
  border-top: 1px solid var(--color-rule);
  font-variation-settings: "opsz" 36, "SOFT" 30;
}
.analisi-section h2::before {
  content: attr(data-num);
  font-family: var(--font-mono);
  font-size: 0.74rem;
  font-weight: 500;
  color: var(--color-resort);
  display: block;
  letter-spacing: 0.18em;
  margin-bottom: 8px;
}

.analisi-section p {
  font-size: 1.12rem;
  line-height: 1.75;
  color: var(--color-ink);
  margin: 0 0 1.2em;
  font-variation-settings: "opsz" 24;
}

.analisi-section ul {
  padding-left: 0;
  list-style: none;
}
.analisi-section li {
  padding: 8px 0 8px 24px;
  position: relative;
  font-size: 1.06rem;
  color: var(--color-ink-soft);
  line-height: 1.55;
}
.analisi-section li::before {
  content: "→";
  position: absolute;
  left: 0;
  color: var(--color-gold);
  font-family: var(--font-mono);
  font-weight: 500;
}

.callout {
  background: var(--color-paper-dark);
  padding: 28px 32px;
  margin: 32px 0;
  border-left: 3px solid var(--color-resort);
  font-family: var(--font-body);
  font-size: 1.08rem;
  font-style: italic;
  color: var(--color-ink);
}
.callout-num {
  display: block;
  font-family: var(--font-display);
  font-size: 2.4rem;
  font-style: normal;
  font-weight: 350;
  color: var(--color-resort);
  letter-spacing: -0.02em;
  margin-bottom: 4px;
}

.refs {
  border-top: 1px solid var(--color-rule);
  margin-top: 64px;
  padding-top: 36px;
}
.refs li {
  padding-left: 0;
  border-bottom: 1px solid var(--color-rule);
  padding: 16px 0;
  font-size: 0.98rem;
  line-height: 1.55;
  color: var(--color-ink-soft);
}
.refs li::before { content: none; }
.refs li:last-child { border-bottom: 0; }

@media (max-width: 640px) {
  html { font-size: 16px; }
  .analisi-wrap { padding: 0 22px; }
  .analisi-title { font-size: 40px; }
}
