/* ═══════════════════════════════════════════════════════════════
   SFP-Europa — style-elections.css
   Stili specifici hub Élections CDP.
   Richiede style.css + style-doc.css caricati prima.
   ═══════════════════════════════════════════════════════════════ */

/* ── HUB STRIP — riuso .statut-annexes-strip con piccole varianti ── */
.elections-hub-strip {
  position: sticky;
  top: var(--nav-h);
  z-index: 90;
  padding: .5rem 2rem;
}

.elections-hub-strip .annexe-tab {
  min-width: auto;
  padding: .35rem .9rem;
  font-size: .82rem;
}

/* ── SECTIONS ── */
.elections-section {
  scroll-margin-top: calc(var(--nav-h) + 44px);
}

.elections-section .doc-layout {
  padding-top: 2.5rem;
}
section#programme {
  padding-top: 0;
}

/* ── PROGRAMME CONTENT ──
   I 12 engagements vengono dal markdown → h2 stilizzati come articoli numerati
   La numerazione è applicata via CSS counter, così resta coerente con la sidebar
*/
.elections-content {
  counter-reset: engagement;
}

/* Primo h2 = claim/intro: NON conta, NON numerato */
.elections-content > h2:first-of-type {
  font-family: var(--serif);
  font-size: clamp(1.4rem, 2.2vw, 1.8rem);
  font-weight: 400;
  color: var(--blue-deep);
  text-align: center;
  margin: 0 0 1rem;
  padding: 0;
  border: none;
  font-style: italic;
}

.elections-content > h2:first-of-type::before { content: none; }

/* Paragrafo subito dopo il primo h2 = sottotitolo manifesto */
.elections-content > h2:first-of-type + p {
  text-align: center;
  font-size: 1rem;
  color: var(--text-mid);
  max-width: 640px;
  margin: 0 auto 3rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid var(--border);
}

/* Tutti gli altri h2 = engagements numerati */
.elections-content h2 {
  counter-increment: engagement;
  font-family: var(--serif);
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--blue-deep);
  margin: 2.5rem 0 1rem;
  padding: 0 0 .5rem 3.5rem;
  border-bottom: none;
  position: relative;
  scroll-margin-top: calc(var(--nav-h) + 44px + 1rem);
  line-height: 1.3;
}

.elections-content h2::before {
  content: counter(engagement, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: -.15rem;
  font-family: var(--serif);
  font-size: 1.6rem;
  font-weight: 300;
  color: var(--gold);
  line-height: 1;
  letter-spacing: -.02em;
}

/* Reset counter su primo h2 escluso */
.elections-content > h2:first-of-type {
  counter-increment: none;
}

.elections-content p {
  font-size: .935rem;
  line-height: 1.8;
  color: var(--text-mid);
  margin-bottom: .85rem;
}

.elections-content strong { color: var(--text-dark); font-weight: 600; }
.elections-content em { color: var(--text-light); font-style: italic; }

/* ── RESULTATS SECTION ── */
.elections-resultats-section {
  background: var(--bg);
  padding: 3rem 0 5rem;
  margin-top: 4rem;
  border-top: 1px solid var(--border);
}

.elections-resultats-section .main-content {
  padding-top: 0;
  padding-bottom: 0;
}

.scrutin-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.25rem;
  margin-top: 2rem;
}

.scrutin-card {
  display: flex;
  flex-direction: column;
  position: relative;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 1.5rem 1.75rem 1.5rem 1.5rem;
  text-decoration: none;
  color: inherit;
  transition: box-shadow .2s, border-color .2s, transform .2s;
  overflow: hidden;
}

.scrutin-card:hover {
  box-shadow: 0 8px 24px rgba(0,30,100,.09);
  border-color: var(--blue-mid);
  transform: translateY(-2px);
}

.scrutin-card::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: var(--blue-deep);
}

.scrutin-year {
  font-family: var(--serif);
  font-size: 2rem;
  font-weight: 600;
  color: var(--blue-deep);
  line-height: 1;
  margin-bottom: .75rem;
  letter-spacing: -.01em;
}

.scrutin-body { flex: 1; }

.scrutin-title {
  font-size: .9rem;
  font-weight: 600;
  color: var(--text-dark);
  margin-bottom: .5rem;
}

.scrutin-summary {
  font-size: .85rem;
  color: var(--text-mid);
  line-height: 1.5;
  margin-bottom: .75rem;
}

.scrutin-meta {
  font-size: .82rem;
  color: var(--text-mid);
  padding-top: .5rem;
  border-top: 1px solid var(--border);
}

.scrutin-meta strong {
  color: var(--blue-deep);
  font-size: 1rem;
}

.scrutin-arrow {
  position: absolute;
  right: 1.25rem;
  top: 1.5rem;
  font-size: 1.1rem;
  color: var(--blue-mid);
  opacity: .5;
  transition: opacity .15s, transform .15s;
}

.scrutin-card:hover .scrutin-arrow {
  opacity: 1;
  transform: translateX(3px);
}

.elections-empty {
  text-align: center;
  padding: 3rem 1rem;
  color: var(--text-light);
  font-style: italic;
  font-size: .9rem;
  background: var(--white);
  border: 1px dashed var(--border);
  border-radius: 8px;
}

/* ── SIDEBAR TOC: highlight scrollspy ── */
#programme-toc a.current {
  background: var(--blue-deep);
  color: var(--white);
  border-color: var(--blue-deep);
  font-weight: 600;
}

#programme-toc a.current .annexe-num {
  background: rgba(255,255,255,.2);
  color: var(--white);
}

/* ── HUB TABS: stato attivo via scrollspy ── */
.elections-hub-strip .annexe-tab[data-hub-tab].active {
  background: var(--blue-deep);
  border-color: var(--blue-deep);
  color: var(--white);
}

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  .elections-hub-strip {
    position: static;
  }

  .elections-content h2 {
    padding-left: 2.75rem;
    font-size: 1.1rem;
  }

  .elections-content h2::before {
    font-size: 1.3rem;
  }
}

@media (max-width: 640px) {
  .scrutin-grid { grid-template-columns: 1fr; }
  .elections-content > h2:first-of-type + p { margin-bottom: 2rem; }
  .elections-content h2 { padding-left: 2.25rem; }
  .elections-content h2::before { font-size: 1.15rem; }
}
