/* ============================================================
   LSH — Article page CSS (extracted from WP live)
   Source: https://lifesciencehub.info/en/dietary-fiber-benefits-metabolism-gut-health-prevention/
   Extracted: 2026-05-25 16:18
   Contiene: 3 stylesheet esterni + 15 <style> inline, in ordine di apparizione.
   ============================================================ */


/* ──────────────────────────────────────────────────────
   [EXTERNAL] style.css  (   28710 bytes)
   ────────────────────────────────────────────────────── */

/*
Theme Name: Blog Life Custom
Theme URI: https://example.com/
Author: Custom
Description: Tema custom leggero in stile "Blog Life" basato sugli screenshot (pagine Menu: Chi siamo, Governance, Trasparenza, Metodo scientifico, Disclaimer, Contatti, Collaborazioni, Policy, Form).
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 8.0
Text Domain: bloglife-custom
*/
:root {
  --bg: #ffffff;
  --text: #3b3b3b;
  --muted: #6b6b6b;
  --line: #e7e7e7;

  /* Layout widths */
  --container: 1200px;
  /* max width area articolo (contenitore) */
  --content: 830px;
  /* max width colonna testo */
  --max: var(--container);

  /* UI surfaces (fallback per le classi già presenti nel CSS) */
  --border: var(--line);
  --panel: #ffffff;
  --panel-2: #ffffff;
  --accent: var(--brand);

  --brand: #6f8f6a;
  /* verde soft */
  --brand-dark: #5c7e57;
  --active-bg: #6f8f6a;
  --active-text: #ffffff;

  --shadow: 0 0px 10px rgba(0, 0, 0, .10);
  --radius: 8px;
  --header-h: 72px;
  --verde: #4c5846;
  --verdescuro:#0A5536;
  /* Verde dei titoli — allineato al verde "C_GREEN" del PDF (src/Pdf/pdf_engine.php) */
  --verde-pdf: #2D6A4F;
  --bg-sectionbox: #F2F7F3;
  --text-dx-fs:14px;

  /* ── Scala spaziature articolo (unità base 10px, gestibile) ──────────
     Cambia i valori qui sotto per regolare le distanze in tutto l'articolo. */
  --lsh-sp:   10px;            /* unità base */
  --lsh-sp-1: 10px;
  --lsh-sp-2: 20px;
  --lsh-sp-3: 30px;
  --lsh-sp-4: 40px;
  /* Gap "semantici": riusano la scala, così si regolano in un solo punto. */
  --lsh-heading-gap: var(--lsh-sp-1);  /* titolo H2/H3 → contenuto sottostante */
  --lsh-table-gap:   var(--lsh-sp-1);  /* intro/titolo → tabella */
  --lsh-ref-row-gap: var(--lsh-sp-1);  /* righe nei Riferimenti (meta + DOI/PubMed) */
}

/* Tutti i titoli dell'articolo usano il verde del PDF: h1/h2/h3 corpo,
   titoli sidebar e titoli card (faq, answer box, ecc.). Lo scope è
   `body.page-article` (impostato da ContentController + ReviewController).
   Eccezioni esplicite (devono restare BIANCHI su sfondo verde):
     .brief__head       — "In breve: cosa dice la scienza"
     .h2-reference      — "Riferimenti" (ex Bibliografia correlata) */
.page-article h1,
.page-article h2:not(.brief__head):not(.h2-reference),
.page-article h3,
.page-article .sideTitle,
.page-article .sideTitleArticle,
.page-article .title-faq,
.page-article .section-h2 > h2:not(.brief__head):not(.h2-reference),
.page-article .novita-aggiornamenti > h2 {
  /*color: var(--verde-pdf);*/
  color:#1f5238;
}

/* ── Header icons: Condividi + Cita (pulsanti pill verde PDF) ───────── */
.article-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  
  align-items: center;
}

.article-actions__group {
  position: relative;
}

.article-action-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border: 1.5px solid var(--verde-pdf);
  border-radius: 999px;
  background: #fff;
  color: var(--verde-pdf);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: background .15s ease, color .15s ease, box-shadow .15s ease, transform .15s ease;
}

.article-action-btn:hover,
.article-action-btn:focus-visible {
  background: var(--verde-pdf);
  color: #fff;
  outline: none;
  box-shadow: 0 3px 10px rgba(45, 106, 79, .25);
  transform: translateY(-1px);
}

.article-share-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  z-index: 50;
  min-width: 200px;
  background: #fff;
  border: 1px solid #e6e8ea;
  border-radius: 10px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .12);
  padding: 6px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.article-share-menu[hidden] { display: none; }

.article-share-menu > * {
  display: block;
  padding: 8px 12px;
  font-size: 13px;
  color: #1f2937;
  background: transparent;
  border: 0;
  border-radius: 6px;
  text-align: left;
  text-decoration: none;
  cursor: pointer;
  font: inherit;
  font-weight: 600;
}

.article-share-menu > *:hover,
.article-share-menu > *:focus-visible {
  background: #f1f5f3;
  color: var(--verde-pdf);
  outline: none;
}

/* ── Review notice — DATE INLINE (Pubblicazione · Aggiornamento · Revisione) */
.review__dates--inline {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 18px;
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
}

.review__dates--inline li {
  display: inline-flex;
  gap: 4px;
  font-size: 13px;
  color: #4b5563;
}

.review__dates--inline li strong {
  color: var(--verde-pdf);
  font-weight: 700;
}

/* Mobile: ogni date su una riga propria (Pubblicazione → Aggiornamento →
   Revisione → Storia articolo, stacked verticali).
   Nota: una regola .review__dates { display: grid } più sotto nel file
   sovrascriverebbe flex se non rifacessimo l'override DEL display. */
@media (max-width: 768px) {
  .review__dates,
  .review__dates--inline {
    display: flex !important;
    flex-direction: column !important;
    grid-template-columns: none !important;
    gap: 6px !important;
  }
  .review__dates li,
  .review__dates--inline li {
    display: flex;
    width: 100%;
  }
}

/* ── Citation group: visual brackets condivise su [N,M,O,P] ───────────── */
.ref-cite-group {
  white-space: nowrap;
  color: var(--verde-pdf);
  font-weight: 700;
}

.ref-cite-group .ref-cite {
  color: inherit;
  text-decoration: none;
  font-weight: 700;
}

.ref-cite-group .ref-cite:hover,
.ref-cite-group .ref-cite:focus-visible {
  text-decoration: underline;
}

/* ── Pulsante rettangolare verde (stile "Download rivista") ────────────
   Layout condiviso: pulsanti azione in fondo, bottone Volume del rivista_box.
   Rettangolare con angoli stondati 6px, solid verde-pdf + bianco. */
.rivista-box__volume,
.article-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 16px;
  border: 0;
  border-radius: 6px;
  background: var(--verde-pdf, #2D6A4F);
  color: #fff;
  font-family: inherit;
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(45, 106, 79, .18);
  transition: background-color .18s ease, transform .18s ease, box-shadow .18s ease;
}

/* ── Badges Open Access / Narrative Review — quadrati piatti,
   NON cliccabili, niente angoli stondati né hover. */
.article-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 12px;
  border: 0;
  border-radius: 0;            /* niente stondatura */
  background: var(--verde-pdf, #2D6A4F);
  color: #fff;
  font-family: inherit;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  cursor: default;
  box-shadow: none;
  user-select: none;
}

.rivista-box__volume:hover,
.rivista-box__volume:focus-visible,
.article-pill:hover,
.article-pill:focus-visible {
  background: #1f5238;
  outline: none;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(45, 106, 79, .28);
  color: #fff;
}

/* ── Badges Open Access + Narrative Review (sopra titolo) ────────────
   Allineati A SINISTRA in coerenza col flusso del titolo H1. */
.article-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-start;
  margin: 10px 0 10px;
}

/* Badge "Narrative Review": stesso layout ma sfondo grigio chiaro +
   testo verde (variante non-primary per distinguere il tipo di articolo). */
.article-badge--type {
  background: #e9ecef;
  color: var(--verde-pdf, #2D6A4F);
  box-shadow: none;
}

/* ── Bottom action bar: Video a sinistra, le altre azioni a destra ───
   Il primo .btn-video resta flush-left; il primo .article-pill /
   .article-actions-bottom__group ha margin-left: auto e spinge sé
   + tutti i fratelli successivi verso destra. */
.article-actions-bottom {
  display: flex;
  flex-wrap: nowrap;          /* Storia articolo deve restare in linea con gli altri */
  gap: 10px;
  justify-content: flex-start;
  align-items: center;
  margin: 0px !important;
  padding-top: 0px !important;
  /* Occupa TUTTA la riga del parent: senza questo il bar resta wide=sum-of-children
     e margin-left:auto non ha spazio per spingere a destra. */
  width: 100%;
  flex: 1 1 auto;
}

/* I pulsanti azione non vanno mai a capo né si rimpiccioliscono troppo. */
.article-actions-bottom > .article-pill,
.article-actions-bottom > .article-actions-bottom__group {
  flex: 0 0 auto;
}

/* Video articolo: stessa identica geometria del pulsante .article-pill
   (padding 12/16, font 15/600, border-radius 6px, ombra match). Resta a
   sinistra perché è il primo figlio (justify-content: flex-start). */
.article-actions-bottom > .btn-video {
  background: var(--verde-pdf, #2D6A4F);
  color: #fff;
  padding: 12px 16px;
  border-radius: 6px;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.2;
  box-shadow: 0 2px 6px rgba(45, 106, 79, .18);
}

/* Il primo elemento DOPO il video viene spinto a destra: tutti i
   fratelli successivi (Condividi, Cita, Download PDF) lo seguono
   grazie al gap: 10px e flex-wrap: nowrap del container.
   Regola fallback su :nth-child(2) per coprire shape diverse del
   markup (group wrapper, pill diretto, ecc.). */
.article-actions-bottom > .btn-video + .article-pill,
.article-actions-bottom > .btn-video + .article-actions-bottom__group,
.article-actions-bottom > .btn-video ~ :nth-child(2) {
  margin-left: auto !important;
}

.article-actions-bottom__group {
  position: relative;
}

/* I label dei pulsanti azione non devono andare a capo. */
.article-actions-bottom .article-pill span {
  white-space: nowrap;
}

/* Il menu share del bottom apre verso L'ALTO (siamo a fondo articolo)
   ed è allineato a destra rispetto al pulsante toggle. */
.article-actions-bottom .article-share-menu {
  top: auto;
  bottom: calc(100% + 6px);
  left: auto;
  right: 0;
  min-width: 220px;
  padding: 6px;
  background: #fff;
  border: 1px solid #e6e8ea;
  border-radius: 12px;
  box-shadow: 0 10px 28px rgba(15, 23, 42, .14);
  z-index: 60;
}

.article-actions-bottom .article-share-menu[hidden] { display: none; }

/* Ogni voce: icona a sinistra, label a destra, hover light-gray.
   Stesso stile per <a> link, <button> Web Share API e Copia link. */
.article-share-item {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 8px 12px;
  background: transparent;
  border: 0;
  border-radius: 8px;
  color: #1f2937;
  font: inherit;
  font-size: 14px;
  font-weight: 500;
  text-align: left;
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
}

.article-share-item:hover,
.article-share-item:focus-visible {
  background: #f1f5f3;
  color: var(--verde-pdf, #2D6A4F);
  outline: none;
}

.article-share-item svg {
  flex: 0 0 16px;
  color: #4b5563;
}

.article-share-item:hover svg,
.article-share-item:focus-visible svg {
  color: var(--verde-pdf, #2D6A4F);
}

/* Separatore prima di "Copia link" */
.article-share-sep {
  height: 1px;
  margin: 6px 8px;
  background: #e6e8ea;
}

/* ── Tag estratti dal testo (sotto al DOI nel box review) ────────────
   UPPERCASE bold, fondino verde-pdf 50% opacità, testo bianco. */
.review__tags {
  list-style: none;
  padding: 0;
  margin: 10px 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.review__tag {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 4px;
  background: rgba(45, 106, 79, .5);
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

/* "Storia articolo" → link sottolineato in linea con le date
   (Pubblicazione · Aggiornamento · Revisione · Storia articolo). */
.review__dates-story { margin-left: 0; }
.review__story-link {
  color: var(--verde-pdf, #2D6A4F);
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 2px;
  cursor: pointer;
}
.review__story-link:hover { color: #1f5238; }

/* ── Storia articolo dialog ──────────────────────────────────────────── */
.story-dialog {
  max-width: 560px;
  width: calc(100% - 32px);
  border: 0;
  border-radius: 12px;
  padding: 0;
  background: #fff;
  box-shadow: 0 16px 48px rgba(0, 0, 0, .18);
}

.story-dialog::backdrop {
  background: rgba(15, 23, 42, .45);
}

.story-dialog__form {
  margin: 0;
}

.story-dialog__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 20px;
  border-bottom: 1px solid #e9ecef;
}

.story-dialog__head h3 {
  margin: 0;
  font-size: 18px;
  font-weight: 800;
  color: var(--verde-pdf, #2D6A4F);
}

.story-dialog__close {
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  font-size: 22px;
  line-height: 1;
  color: #4b5563;
  cursor: pointer;
}

.story-dialog__close:hover { background: #f1f5f3; color: var(--verde-pdf); }

.story-dialog__body { padding: 16px 20px 20px; }

.story-dialog__body h4 {
  margin: 14px 0 6px;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #4b5563;
}

.story-dialog__body h4:first-child { margin-top: 0; }

.story-dialog__dates,
.story-dialog__revs {
  margin: 0;
  padding: 0 0 0 18px;
}

.story-dialog__dates {
  list-style: none;
  padding-left: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.story-dialog__dates li strong,
.story-dialog__revs li strong {
  color: var(--verde-pdf, #2D6A4F);
}

.story-dialog__revs li {
  margin: 6px 0;
  font-size: 14px;
  line-height: 1.5;
}

.story-dialog__rev-note {
  display: block;
  color: #4b5563;
  font-size: 13px;
  margin-top: 2px;
}

.story-dialog__note {
  margin: 14px 0 0;
  padding: 10px 12px;
  border-radius: 8px;
  background: #f8f9fa;
  font-size: 12px;
  color: #6b7280;
}

/* ── Cite dialog: tabs (APA/MLA/Chicago/Vancouver/BibTeX) + 2 bottoni big ─ */
.cite-modal {
  max-width: 560px;
  width: calc(100% - 32px);
  border: 0;
  border-radius: 12px;
  padding: 0;
  background: #fff;
  box-shadow: 0 16px 48px rgba(0, 0, 0, .18);
}

.cite-modal::backdrop {
  background: rgba(15, 23, 42, .45);
}

.cite-modal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 20px;
  border-bottom: 1px solid #e9ecef;
}

.cite-modal__head h3 {
  margin: 0;
  font-size: 18px;
  font-weight: 800;
  color: var(--verde-pdf, #2D6A4F);
}

.cite-modal__close {
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  font-size: 22px;
  line-height: 1;
  color: #4b5563;
  cursor: pointer;
}
.cite-modal__close:hover { background: #f1f5f3; color: var(--verde-pdf, #2D6A4F); }

.cite-modal__body { padding: 16px 20px; }

/* Tabs APA / MLA / Chicago / Vancouver / BibTeX in alto */
.cite-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 14px;
}

.cite-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 14px;
  border: 0;
  border-radius: 6px;
  background: #e9ecef;
  color: #4b5563;
  font: inherit;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: background-color .15s ease, color .15s ease;
}

.cite-tab:hover,
.cite-tab:focus-visible {
  background: #d8dde2;
  color: #1f2937;
  outline: none;
}

.cite-tab.is-active {
  background: var(--verde-pdf, #2D6A4F);
  color: #fff;
}

/* Riquadro citazione */
.cite-content {
  padding: 14px 16px;
  border: 1px dashed #c5cdd2;
  border-radius: 8px;
  background: #f8f9fa;
  color: #1f2937;
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size: 13px;
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
  max-height: 220px;
  overflow-y: auto;
}

/* Footer con 2 pulsanti big stile Download rivista */
.cite-modal__foot {
  display: flex;
  gap: 10px;
  padding: 16px 20px 20px;
  border-top: 1px solid #e9ecef;
}

.cite-btn {
  flex: 1 1 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 16px;
  border-radius: 6px;
  font: inherit;
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  text-decoration: none;
  cursor: pointer;
  transition: background-color .15s ease, color .15s ease, box-shadow .15s ease;
}

.cite-btn--primary {
  border: 0;
  background: var(--verde-pdf, #2D6A4F);
  color: #fff;
  box-shadow: 0 2px 6px rgba(45, 106, 79, .18);
}
.cite-btn--primary:hover,
.cite-btn--primary:focus-visible {
  background: #1f5238;
  outline: none;
  box-shadow: 0 4px 12px rgba(45, 106, 79, .28);
}

.cite-btn--outline {
  border: 1.5px solid var(--verde-pdf, #2D6A4F);
  background: transparent;
  color: var(--verde-pdf, #2D6A4F);
}
.cite-btn--outline:hover,
.cite-btn--outline:focus-visible {
  background: var(--verde-pdf, #2D6A4F);
  color: #fff;
  outline: none;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--text);
  background: #fafafa;
}

a {
  color: inherit;
  text-decoration: none;
}

button {
  font: inherit;
}

/* ===== Header ===== */
.site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--bg);
  border-bottom: 1px solid var(--line);
}

.header-inner {
  max-width: var(--container);
  margin: 0 auto;
  height: var(--header-h);
  padding: 0 16px;
  display: flex;
  align-items: center;
  gap: 18px;
}

/* Logo */
.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 160px;
}

.brand-mark {
  width: 0;
  height: 0;
}

.brand-name {
  font-weight: 900;
  letter-spacing: .5px;
  font-size: 28px;
  line-height: 1;
  color: var(--brand);
  text-transform: uppercase;
  white-space: nowrap;
}

/* Desktop nav */
.nav {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 6px;
  overflow: visible;
}

.nav>ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  gap: 2px;
}

.nav-item {
  position: relative;
}

.nav-link,
.nav-trigger {
  height: 44px;
  padding: 0 14px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 16px;
  color: var(--text);
  border: 1px solid transparent;
  background: transparent;
  cursor: pointer;
  white-space: nowrap;
}

.nav-link:hover,
.nav-trigger:hover {
  background: #f4f6f4;
  border-color: #eef1ee;
}



.chev {
  width: 10px;
  height: 10px;
  display: inline-block;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  margin-top: -2px;
  opacity: .85;
}

/* Dropdown 
.dropdown {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: 260px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 6px;
  box-shadow: var(--shadow);
  padding: 8px;
  display: none;
}

.dropdown::before {
  content: "";
  position: absolute;
  top: -7px;
  left: 22px;
  width: 12px;
  height: 12px;
  background: #fff;
  border-left: 1px solid var(--line);
  border-top: 1px solid var(--line);
  transform: rotate(45deg);
}

.dropdown a {
  display: block;
  padding: 10px 10px;
  border-radius: 6px;
  color: var(--text);
}

.dropdown a:hover {
  background: #f4f6f4;
}

.nav-item.is-open>.dropdown {
  display: block;
}
*/
/* Right actions */
.header-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.icon-btn {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  border: 1px solid transparent;
  background: transparent;
  display: grid;
  place-items: center;
  cursor: pointer;
}

.icon-btn:hover {
  background: #f4f6f4;
  border-color: #eef1ee;
}

.mail-icon {
  width: 22px;
  height: 22px;
}

/* Burger (mobile only) */
.burger {
  display: none;
  width: 44px;
  height: 44px;
  border-radius: 8px;
  border: 1px solid transparent;
  background: transparent;
  cursor: pointer;
  place-items: center;
}

.burger:hover {
  background: #f4f6f4;
  border-color: #eef1ee;
}

.burger-lines {
  width: 20px;
  height: 14px;
  position: relative;
}

.burger-lines span {
  position: absolute;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--text);
  border-radius: 99px;
  transition: transform .2s ease, top .2s ease, opacity .2s ease;
}

.burger-lines span:nth-child(1) {
  top: 0;
}

.burger-lines span:nth-child(2) {
  top: 6px;
}

.burger-lines span:nth-child(3) {
  top: 12px;
}

/* ===== Mobile drawer ===== */
.backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .25);
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease;
  z-index: 999;
}

.drawer {
  position: fixed;
  top: 0;
  right: 0;
  height: 100vh;
  width: min(360px, 88vw);
  background: #fff;
  border-left: 1px solid var(--line);
  transform: translateX(100%);
  transition: transform .22s ease;
  z-index: 1000;
  display: flex;
  flex-direction: column;
}

.drawer-header {
  height: var(--header-h);
  padding: 0 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--line);
}

.drawer-title {
  font-weight: 800;
  color: var(--brand);
  letter-spacing: .5px;
  text-transform: uppercase;
}

.drawer-close {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  border: 1px solid transparent;
  background: transparent;
  cursor: pointer;
}

.drawer-close:hover {
  background: #f4f6f4;
  border-color: #eef1ee;
}

.drawer-body {
  padding: 10px;
  overflow: auto;
}

.m-nav {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.m-nav a,
.m-nav button {
  width: 100%;
  text-align: left;
  height: 48px;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px solid transparent;
  background: transparent;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: var(--text);
}

.m-nav a:hover,
.m-nav button:hover {
  background: #f4f6f4;
  border-color: #eef1ee;
}

.m-nav .is-active {
  background: var(--active-bg);
  color: var(--active-text);
}

.m-sub {
  list-style: none;
  margin: 6px 0 10px 0;
  padding: 0 0 0 10px;
  display: none;
  flex-direction: column;
  gap: 6px;
}

.m-sub a {
  height: 44px;
  border-radius: 10px;
  padding: 0 12px;
  display: flex;
  align-items: center;
  border: 1px solid transparent;
  background: #f7f8f7;
}

.m-sub a:hover {
  background: #eef2ee;
}

.m-item.is-open>.m-sub {
  display: flex;
}

/* Open states */
.is-drawer-open .backdrop {
  opacity: 1;
  pointer-events: auto;
}

.is-drawer-open .drawer {
  transform: translateX(0);
}

/* ===== Responsive ===== */
@media (max-width: 980px) {
  .nav {
    display: none;
  }

  .burger {
    display: grid;
  }

  .brand {
    min-width: unset;
  }

  .brand-name {
    font-size: 24px;
  }
}

/* ====== PAGE WRAP ====== */
.wrap {
  /* max width dell'area articolo */
  max-width: var(--container);
  margin: 0 auto;
  padding: 14px 18px 40px;
}

.breadcrumbs {
  font-size: 12px;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 6px 0 14px;
}

.crumb-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--brand);
  display: inline-block;
  opacity: .7;
}

/* ====== MAIN GRID ====== */
.grid {
  display: grid;
  grid-template-columns: minmax(0, var(--content)) 320px;
  /* contenuto + sidebar */
  gap: 18px;
  align-items: start;
  justify-content: space-between;
}

/* Colonna di lettura (testo) */
.grid>section {
  min-width: 0;
  max-width: var(--content);
}

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

  .grid>section {
    max-width: 100%;
  }
}

/* ====== TITLE AREA ====== */
.titleRow {
  display: grid;
  grid-template-columns: 1fr 220px;
  gap: 14px;
  align-items: start;
}

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

h1 {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  font-size: 34px;
  font-weight: 700;
  letter-spacing: -.3px;
  line-height: 1.15;
}

.subtitle {
  margin-top: 6px;
  font-size: 14px;
  color: var(--muted);
}

.shareBox {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 14px;
}

.shareBox h3 {
  margin: 0 0 10px;
  font-size: 14px;
  font-weight: 800;
  color: #3a3840;
}

.shareBtns {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-bottom: 10px;
}

.iconBtn {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  border: 1px solid var(--border);
  background: #fff;
  display: grid;
  place-items: center;
  cursor: pointer;
}

.iconBtn svg {
  width: 16px;
  height: 16px;
  opacity: .85;
}

.copyBtn {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: #fff;
  font-weight: 700;
  font-size: 13px;
  cursor: pointer;
  color: #3a3840;
}

.copyBtn svg {
  width: 16px;
  height: 16px;
  opacity: .75;
}

/* ====== INFO CARDS ====== */
.card {
  background: var(--panel-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 14px;
}

.author {
  display: flex;
  gap: 12px;
  align-items: center;
  padding: 14px;
  margin-top: 15px;
}

.avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, #d4f1ea, #f2d7ff);
  border: 1px solid var(--border);
  flex: 0 0 auto;
  overflow: hidden;
}

.avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.author b {
  display: block;
  font-size: 14px;
}

.author small {
  display: block;
  color: var(--muted);
  font-size: 12px;
  margin-top: 2px;
}

.author-cards {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 16px 0 20px;
}

.card.author {
 /* display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 12px;
  flex: 0 1 320px;
  max-width: 360px;
  min-width: 240px;*/
}

.card.author .avatar {
  width: 52px;
  height: 52px;
  min-width: 52px;
  border-radius: 50%;
  background: #e9ecef;
  overflow: hidden;
}

.card.author .avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.card.author b {
  display: block;
  font-size: 15px;
  line-height: 1.2;
  margin-bottom: 4px;
}

.card.author small {
  display: block;
  font-size: 13px;
  line-height: 1.35;
  color: #5f6b76;
  margin-top: 2px;
}

@media (max-width: 768px) {
  .author-cards {
    flex-direction: column;
  }

  .author-cards .card.author {
    flex: 1 1 100%;
  }
}


.author-cards{
    display:flex;
    flex-wrap:wrap;
    gap:16px;
    width:100%;
}

/* card autore */
.author-cards .card.author{
    display:flex;
    align-items:center;
    gap:12px;
    padding:12px 14px;
    border-radius:10px;

    flex:1 1 calc((100% - 32px) / 3); /* massimo 3 per riga */
    max-width:33%; /* evita card troppo strette */
    border: solid 2px var(--border);
}

/* avatar */
.card.author .avatar{
    width:50px;
    height:50px;
    min-width:50px;
    border-radius:50%;
    background:#e9ecef;
}

/* testo */
.card.author b{
    display:block;
    font-size:15px;
}

.card.author small{
    display:block;
    font-size:13px;
    color:#6b7280;
}
.review {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  margin-top: 10px;
  border-radius: var(--radius);
  background: var(--bg-sectionbox);
  border: 1px solid var(--border);
  color: #4a4752;
  font-size: 13px;
  /* Interlinea ridotta per metadati compatti */
  line-height: 1.35;
}
.review p, .review ul, .review ol, .review li { line-height: 1.35; }
.review__dates--inline { gap: 4px 14px; }

.review svg {
  width: 18px;
  height: 18px;
  opacity: .75;
}

/* ====== HERO ====== */
.hero {
  margin-top: 6px;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
  background: #fff;
  box-shadow: var(--shadow);
}

.hero img {
  width: 100%;
  height: auto;
  display: block;
}

/* ====== “IN BREVE” ====== */
.brief {
  margin-top: 6px;
  overflow: hidden;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: #f2f7f1;
  box-shadow: var(--shadow);
}

.brief__head {
  background: var(--accent);
  color: #fff;
  padding: 10px 14px;
  font-weight: 800;
  letter-spacing: .3px;
  font-size: 19px;
  text-transform: uppercase;
  text-align: center;
}

.brief__list {
  padding: 12px 14px 6px;
  display: grid;
  gap: 10px;
}

.briefItem {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  color: #3b3942;
  font-size: 14px;
}

.check {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  flex: 0 0 auto;
  opacity: 1;
  color: var(--verde-pdf);
}

/* ====== SECTION ====== */
h2 {
  margin: 18px 0 10px;
  font-size: 24px;
  font-weight: 800;
  letter-spacing: -.2px;
}

.videoCard {
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  background: #fff;
}

.videoThumb {
  position: relative;
  aspect-ratio: 16/9;
  background: #dde3ea;
}

.section-h2 .text {
  text-align: justify;
}

.videoThumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.videoOverlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(0, 0, 0, .55), rgba(0, 0, 0, .05));
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  padding: 16px;
  color: #fff;
  font-weight: 800;
  font-size: 24px;
}

.videoMeta {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #fff;
  font-size: 12px;
  opacity: .9;
}

.play {
  width: 28px;
  height: 18px;
  border-radius: 6px;
  background: rgba(255, 255, 255, .2);
  border: 1px solid rgba(255, 255, 255, .35);
  display: grid;
  place-items: center;
}

.play svg {
  width: 10px;
  height: 10px;
}

.text {
  margin-top: 14px;
  color: #3b3942;
  font-size: 14px;
}

/* ====== SIDEBAR ====== */
.sideGroup {
  display: grid;
  gap: 10px;
}

/* Titoli box sidebar (Cosa sappiamo, FAQ, Answer Box, ecc.) —
   stessa dimensione degli H3 del corpo articolo. */
.sideTitle {
  margin: 0 0 10px;
  font-size: 20px;
  font-weight: 800;
  line-height: 1.2;
  color: var(--verde);
}

.sideList {
  display: grid;
  gap: 10px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.sideList li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: var(--text-dx-fs);
  color: #3b3942;
}

/* Accordion espandibile per FAQ + Answer Box: il <li> diventa contenitore
   di un <details> click-to-expand. Sostituisce il vecchio layout flex
   con icona quadrato + testo sempre visibile. */
.sideList--accordion {
  gap: 6px;
}

.sideList--accordion li {
  display: block;
  padding: 0;
  /* Separator tra risposte rapide: più visibile, NON puntinata. */
  border-bottom: 1px solid #c5cdd2;
}

.sideList--accordion li:last-child {
  border-bottom: none;
}

.faq-item {
  /* niente outline default sui browser */
}

.faq-item__summary {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  list-style: none;        /* nasconde il marker default */
  padding: 10px 0;
  user-select: none;
}

.faq-item__summary::-webkit-details-marker {
  display: none;
}

.faq-item__chevron {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  transition: transform .18s ease;
  color: var(--verde-pdf);
}

.faq-item[open] > .faq-item__summary .faq-item__chevron {
  transform: rotate(180deg);
}

.faq-item .title-faq {
  color: var(--verde-pdf);
  font-weight: 800;
  width: auto;
  flex: 1 1 auto;
}

.faq-item .text-faq {
  padding: 0 0 12px 28px;   /* allinea col titolo dopo il chevron */
  width: auto;
  color: #3b3942;
}

/* Animazione apertura discreta — solo se il browser supporta details transition */
@supports selector(::details-content) {
  .faq-item::details-content {
    overflow: hidden;
    block-size: 0;
    transition: block-size .22s ease, content-visibility .22s allow-discrete;
  }
  .faq-item[open]::details-content {
    block-size: auto;
  }
}

.sideList .mini {
  width: 16px;
  height: 16px;
  margin-top: 2px;
  opacity: .7;
  flex: 0 0 auto;
}

.sideList a {
  color: #3b3942;
  text-decoration: none;
  font-weight: 800;
}

.sideList a:hover {
  text-decoration: underline;
}

.sideList small {
  display: block;
  color: var(--muted);
  margin-top: 2px;
  font-weight: 500;
  font-size: var(--text-dx-fs);
}

/* ====== UTIL ====== */
.spacer {
  height: 6px;
}

.article-actions{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
   /* margin:24px 0 0px;
    padding:14px 0;
    border-top:1px solid #e6ebf0;
    border-bottom:1px solid #e6ebf0;*/
}

.article-actions a{
    display:inline-flex;
    align-items:center;
    gap:10px;
    text-decoration:none;
    transition:all .2s ease;
}

/* bottone principale video */
.btn-video{
    background:var(--verde);
    color:#fff;
    padding:11px 16px;
    border-radius:10px;
    font-size:14px;
    font-weight:600;
    line-height:1.2;
    box-shadow:0 2px 8px rgba(31, 111, 235, 0.12);
}

.btn-video:hover{
    background:var(--verde);
    /*transform:translateY(-1px);*/
}

/* link secondario pdf */
.btn-pdf{
    color:#334155;
    font-size:14px;
    font-weight:600;
    line-height:1.2;
    white-space:nowrap;
}

.btn-pdf:hover{
    color:var(--verde);
}

/* icone */
.btn-icon{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:18px;
    height:18px;
    flex:0 0 18px;
}

.btn-video .btn-icon{
    width:16px;
    height:16px;
    flex:0 0 16px;
}

.btn-icon svg{
    width:100%;
    height:100%;
    display:block;
}

/* mobile */
@media (max-width: 768px){
    .article-actions{
        flex-direction:column;
        align-items:stretch;
        gap:12px;
    }

    .btn-video,
    .btn-pdf{
        justify-content:center;
    }

    .btn-pdf{
        padding:10px 14px;
        border:1px solid #dbe3ea;
        border-radius:10px;
        background:#fff;
    }
}
.lsh-dropcap::first-letter{
  float:left;
  font-size:56px;
  line-height:56px;
  margin-right:12px;
  margin-top:0px;
  font-weight:700;
  font-family: Georgia, "Times New Roman", serif;
  color:#0A5536;
}

.img-resp {
  width: 100%;
  height: auto;
  display: block;
}

.section-h2 .text a {
  color: var(--brand);
  font-weight: bold;
  ;
  text-decoration: underline;
}

/* ===== Header ===== */
.site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--bg);
  border-bottom: 1px solid var(--line);
}

/*Eccezione*/
.site-header {
  background: #f3f1f4 !important;
}


.header-inner {
  max-width: var(--container);
  margin: 0 auto;
  height: var(--header-h);
  padding: 0 16px;
  display: flex;
  align-items: center;
  gap: 18px;
}

/* ===== Logo ===== */
.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 160px;
}

.brand-mark {
  width: 0;
  height: 0;
}

.brand-logo {
  width: 50px;
  height: 50px;
}

.brand-name {
  font-weight: 900;
  letter-spacing: .5px;
  font-size: 28px;
  line-height: 1;
  color: var(--brand);
  text-transform: capitalize;
  white-space: nowrap;
}

/* ===== Desktop nav ===== */
.nav {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0;
  overflow: visible;
}

.nav>ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  gap: 10px;
}

.nav-item {
  position: relative;
}

/* Link e trigger */
.nav-link,
.nav-trigger {
  height: 42px;
  padding: 0 14px;
  border-radius: 2px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  font-weight: 500;
  color: var(--text);
  border: 1px solid transparent;
  background: transparent;
  cursor: pointer;
  white-space: nowrap;
}

.nav-link:hover {
  background: #567348;
  border: 1px solid #567348;
  color: #ffffff;
}

/* Trigger dropdown */
.nav-trigger {
  font-weight: 600;
}

.nav-trigger:hover {
  background: #567348;
  color: #ffffff;
  border-color: #567348;
}

/* Stato attivo */


/* Chevron */
.chev {
  width: 8px;
  height: 8px;
  display: inline-block;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  transform-origin: center;
  transition: transform .16s ease;
}

.nav-item.is-open .chev {
  transform: rotate(-135deg);
  margin-top: 6px;
}

/* ===== Dropdown desktop =====
.dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 0px;
  min-width: 240px;

  background: #f3f1f4;
  border: none;
  border-radius: 0px;
  box-shadow:
    0 8px 18px rgba(0, 0, 0, 0.08),
    0 2px 4px rgba(0, 0, 0, 0.06);
  padding: 0;

  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.dropdown::before {
  display: none;
}


.dropdown a {
  display: block;
  padding: 16px 16px;
  font-size: 15px;
  border-radius: 0;
  border-top: solid 1px #e6e6e6;
  color: var(--text);
}

.dropdown a:hover {
  background: #cfdbc9;
}

.dropdown a.is-active {
  background: #567348;
  color: #ffffff;
}

.nav-item.is-open>.dropdown,
.nav-item.has-dropdown:hover>.dropdown,
.nav-item.has-dropdown:focus-within>.dropdown {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.nav-item.is-open>.nav-trigger,
.nav-item.has-dropdown:hover>.nav-trigger,
.nav-item.has-dropdown:focus-within>.nav-trigger {
  background: #567348;
  color: #ffffff;
  border-color: #567348;
}
*/
/* ===== Right actions ===== */
.header-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.icon-btn {
  width: 42px;
  height: 42px;
  border-radius: 2px;
  border: 1px solid transparent;
  background: transparent;
  display: grid;
  place-items: center;
  cursor: pointer;
}

.icon-btn:hover {
  background: #f2f4f2;
}

.mail-icon {
  width: 22px;
  height: 22px;
}

/* ===== Burger (mobile only) ===== */
.burger {
  display: none;
  width: 42px;
  height: 42px;
  border-radius: 2px;
  border: 1px solid transparent;
  background: transparent;
  cursor: pointer;
  place-items: center;
}

.burger:hover {
  background: #f2f4f2;
}

.burger-lines {
  width: 20px;
  height: 14px;
  position: relative;
}

.burger-lines span {
  position: absolute;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--text);
  border-radius: 99px;
}

.burger-lines span:nth-child(1) {
  top: 0;
}

.burger-lines span:nth-child(2) {
  top: 6px;
}

.burger-lines span:nth-child(3) {
  top: 12px;
}

/* ===== Mobile drawer ===== */
.backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .25);
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease;
  z-index: 999;
}

.drawer {
  position: fixed;
  top: 0;
  right: 0;
  height: 100vh;
  width: min(360px, 88vw);
  background: #ffffff;
  border-left: 1px solid #d8ddd8;
  transform: translateX(100%);
  transition: transform .22s ease;
  z-index: 1000;
  display: flex;
  flex-direction: column;
}

.drawer-header {
  height: var(--header-h);
  padding: 0 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--line);
}

.drawer-title {
  font-weight: 800;
  color: var(--brand);
  letter-spacing: .5px;
  text-transform: uppercase;
}

.drawer-close {
  width: 40px;
  height: 40px;
  border-radius: 2px;
  border: 1px solid transparent;
  background: transparent;
  cursor: pointer;
}

.drawer-close:hover {
  background: #f2f4f2;
}

.drawer-body {
  padding: 12px;
  overflow: auto;
}

/* ===== Mobile nav ===== */
.m-nav {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.m-nav a,
.m-nav button {
  width: 100%;
  text-align: left;
  height: 44px;
  padding: 0 14px;
  border-radius: 2px;
  border: 1px solid transparent;
  background: transparent;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  font-size: 15px;
  color: var(--text);
}

.m-nav a:hover,
.m-nav button:hover {
  background: #f2f4f2;
}

.m-nav .is-active {
  background: #567348;
  color: #ffffff;
}

/* ===== Mobile submenu ===== */
.m-sub {
  list-style: none;
  margin: 4px 0 8px 0;
  padding: 0 0 0 12px;
  display: none;
  flex-direction: column;
  gap: 2px;
}

.m-sub a {
  height: 42px;
  border-radius: 2px;
  padding: 0 14px;
  display: flex;
  align-items: center;
  border: 1px solid transparent;
  background: #f5f7f5;
  font-size: 14.5px;
}

.m-sub a:hover {
  background: #e9eee9;
}

.m-sub a.is-active {
  background: #567348;
  color: #ffffff;
}

.m-item.is-open>.m-sub {
  display: flex;
}

/* ===== Open states ===== */
.is-drawer-open .backdrop {
  opacity: 1;
  pointer-events: auto;
}

.is-drawer-open .drawer {
  transform: translateX(0);
}

/* ===== Responsive ===== */
@media (max-width: 980px) {
  .nav {
    display: none;
  }

  .burger {
    display: grid;
  }

  .brand {
    min-width: unset;
  }

  .brand-name {
    font-size: 24px;
  }

  .header-actions {
    margin-left: auto;
  }

  .header-inner {
    gap: 5px;
  }

  .burger {
    order: 2;
  }

  .icon-btn {
    order: 1;
  }

  .drawer {
    border-left: none;
    background-color: #e7e7e7;
  }

  .drawer-header {
    justify-content: end;
    border-bottom: 1px solid #cccccc !important;
  }

  .drawer-body {
    padding: 16px;
  }

  .drawer-close {
    width: 40px;
    height: 40px;
    border-radius: 2px;
    border: 1px solid transparent;
    background: transparent;
    cursor: pointer;
    color: #567348;
    display: grid;
    place-items: center;
  }

  .m-sub {
    padding: 5px 0;
  }

  .m-nav {
    gap: 16px;
  }

  .m-nav a {
    background-color: #ffffff;
  }

  .m-nav a:hover {
    background-color: #567348;
    color: #ffffff;
  }

  .m-nav button {
    background-color: #ffffff !important;
    color: var(--text) !important;
  }

  .m-nav .is-active {
    background-color: #567348 !important;
    color: #ffffff !important;
  }
}

.f16 {
  font-size: 13px !important;
}

.title-faq {
  color: #3b3942;
  text-decoration: none;
  font-weight: 800;
  width: 90%;
  display: block;
  font-size: var(--text-dx-fs);

}

.text-faq {


  margin-top: 6px;
  width: 90%;
  height: auto;
  display: block;
  text-align: left;
  font-size:var(--text-dx-fs);

}

.brief__list {
  padding: 14px;
  gap: 14px;
}

.briefItem {
  gap: 14px;
}

h2 {
  margin: 10px 0 5px;
  font-size: 26px;
  color: var(--verde);
  line-height: 26px;
}

.sectionImage {
  margin-top: 6px;
  border-radius: 8px;                      /* stessi angoli della copertina rivista */
  overflow: hidden;
  border: 1px solid var(--border);
  background: #fff;
  box-shadow: 0 6px 18px rgba(0, 0, 0, .10);
}

.sectionImage figcaption {
  /* Caption editoriale ≤50 parole, limitata a 3 righe visive con
     line-clamp + ellipsis. Hover/focus → si espande a tutta altezza. */
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-8px);
  transition: max-height .35s ease, opacity .25s ease, transform .25s ease, padding .25s ease;
  margin: 0;
  padding: 0 12px;
  box-shadow: none;
  border: 0;
  font-size: 14px;
  font-weight: 600;
  background: #f3f1f4;
  line-height: 1.45;
  color: #222;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}

.sectionImage:hover figcaption,
.sectionImage:focus-within figcaption {
  max-height: 2000px;                      /* abbondante: caption ≥100 parole = ~6-8 righe = ~250px */
  opacity: 1;
  transform: translateY(0);
  padding: 12px;
}

@media (max-width: 768px) {
  .sectionImage figcaption {
    opacity: 1;
    transform: none;
    pointer-events: auto;
  }
}

.text {
  margin-top: 20px;
  font-size: 16px;
}

.h3-block {
  margin: 15px 0;
}
th {
  text-transform: uppercase;
}
/* Più aria sopra il titolo H3 (separazione visiva dal paragrafo precedente)
   + leggera tightness sotto. */
.h3-block h3 {
  margin: 20px 0 10px;
  line-height: 1.17em;
}
.h3-block:first-child h3 { margin-top: 12px; }

.h3-block .h3_content {
  margin: 0;
}
p{
  margin:0px !important
}
ul{
  margin-top: 0px !important;
  margin-bottom: 0px !important;
  margin-block-start: 0px !important;
  margin-block-end: 0px !important;
}
.briefInSection {
  border-top: solid 1px var(--bg-sectionbox);
  padding: 0px 0 0 0;
  font-weight: bold;
  color: var(--verde);
}

.brevedescr{    font-style: italic;}
.sectionImage,
.hero {
  position: relative;
  overflow: hidden;
}

/* assicurati che l’immagine rimanga normale */
.sectionImage>img,
.hero>img {
  display: block;
  width: 100%;
  height: auto;
}

/* video overlay */
.sectionImage .hoverVideo,
.hero .hoverVideo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity .25s ease;
  pointer-events: none;
}

/* quando in play lo mostriamo */
.sectionImage.is-playing .hoverVideo,
.hero.is-playing .hoverVideo {
  opacity: 1;
}

.hero {
  position: relative;
}

.hero figcaption {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-8px);
  transition: all .25s ease;
  margin: 0;
  padding: 0;
  box-shadow: none;
  border: 0;
  font-size: 14px;
}

.hero:hover figcaption {
  max-height: 200px;
  opacity: 1;
  transform: translateY(0);
  padding: 8px;
  font-weight: bold;
  background: #f3f1f4;
}


.saveBtn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border: 1px solid #ccc;
  background: #fff;
  cursor: pointer;
  font-size: 14px;
  border-radius: 8px;
  margin: 30px 0 0 0;

  /* colore base */
  color: #444;

  /* transizioni fluide */
  transition:
    color .25s ease,
    border-color .25s ease,
    background-color .25s ease,
    transform .15s ease;
}

.saveBtn svg {
  width: 20px;
  height: 20px;
  display: block;
}

/* Hover */
.saveBtn:hover {
  color: #567348;
  /* colore icona + testo */
  border-color: #567348;
  background-color: #faf6f8;
}

/* Click micro-feedback */
.saveBtn:active {
  transform: scale(0.97);
}

/* Focus accessibile */
.saveBtn:focus-visible {
  outline: 2px solid #567348;
  outline-offset: 3px;
}



@media (max-width: 768px) {
  .hero figcaption {
    opacity: 1;
    transform: none;
    pointer-events: auto;
  }
}

.sideTitleArticle {
 /* margin: 30px 0 5px 0;*/
}

.grid_bottom .studiCorrelati div {
  font-size: 16px;
  margin: 0 0 5px 0;
}

.comparative-table-wrap {
  overflow-x: auto;
  margin: var(--lsh-table-gap) 0 0 0;
 /* padding: 30px 0 0 0;*/
  border-top: 1px solid var(--bg-sectionbox);
}

.comparative-table {
  width: 100%;
  border-collapse: collapse;
  font-family: inherit;
  font-size: 15px;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.05);
}

/* Header */
.comparative-table thead {
 /* background-color: #567348;*/
 background-color: var(--accent);
  color: #ffffff;
}

.comparative-table th {
  padding: 14px 16px;
  text-align: left;
  font-weight: 600;
  border: 1px solid var(--bg-sectionbox);
}

/* Celle */
.comparative-table td {
  padding: 14px 16px;
  border: 1px solid var(--bg-sectionbox);
}

/* Righe alternate */
.comparative-table tbody tr:nth-child(even) {
  background-color: #f8f9f7;
}

.comparative-table tbody tr:nth-child(odd) {
  background-color: #fff;
}

/* Hover */
.comparative-table tbody tr:hover {
  background-color: rgba(86, 115, 72, 0.08);
  transition: background-color 0.2s ease-in-out;
}

.bg-light-green{
  background-color: var(--bg-sectionbox);
}

/* ──────────────────────────────────────────────────────
   [EXTERNAL] home.css  (   24984 bytes)
   ────────────────────────────────────────────────────── */

 body {padding:0; margin:0;}

    .site-header {
      position: relative;
      overflow: hidden;
      max-height:350px;
    }

    .header-bg {
      position: absolute;
      inset: 0;
      background-image: url("sfondo_header.jpg");
      background-size: cover;
      background-position: center;
      background-repeat: no-repeat;
      z-index: 0;
    }

    .header-inner {
      position: relative;
      z-index: 2;
    }

    /* contenitore centrato */
    .wrap{
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 20px;
    }

    /* TOP NAV */
    .top{
      height: 44px;
      display: flex;
      align-items: center;
      background-color:rgba(10, 85, 54, 0.95);
      position: relative; /* per il pannello mobile assoluto */
    }

    .top-inner{
      height: 44px;
      display: flex;
      align-items: center;
      justify-content: flex-start;
      gap: 12px;
    }

    .menu{
      list-style: none;
      margin: 0;
      padding: 0;
      display: flex;
      gap: 40px;
      align-items: center;
      flex-wrap: wrap; /* evita overflow in casi limite */
    }

    .menu a{
      color: #fff;
      text-decoration: none;
      font: 600 14px/1 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      padding: 10px 0;
      opacity: .95;
    }

    .menu a:hover{
      opacity: 1;
      text-decoration: underline;
      text-underline-offset: 4px;
    }

    /* Hamburger (nascosto su desktop) */
    .nav-toggle{
      display: none;
      border: 0;
      background: transparent;
      width: 44px;
      height: 44px;
      cursor: pointer;
      padding: 0;
    }

    .nav-toggle-icon{
      display: inline-block;
      width: 22px;
      height: 2px;
      background: #fff;
      position: relative;
      opacity: .95;
    }
    .nav-toggle-icon::before,
    .nav-toggle-icon::after{
      content:"";
      position: absolute;
      left: 0;
      width: 22px;
      height: 2px;
      background: #fff;
    }
    .nav-toggle-icon::before{ top: -7px; }
    .nav-toggle-icon::after{ top: 7px; }

    /* Pannello menu: desktop */
    .nav-panel{
      flex: 1;
    }
    @media (min-width: 901px){
      .nav-panel{ display: block !important; }
    }

    /* MID: logo + social */
    .mid{
      padding-top: 20px;
      padding-bottom: 8px;
    }

    .mid-inner{
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 18px;
    }

    .brand{
      display: flex;
      align-items: center;
      gap: 20px;
      color: #fff;
      text-decoration: none;
    }

    .logo-mark{
      width: 120px;
      height: 120px;
      flex: 0 0 120px;
      display: grid;
      place-items: center;
    }

    .logo-mark img{
      width: 100%;
      height: 100%;
      object-fit: contain;
      display: block;
    }

    .logo-text .title{
      display: block;
      font: 900 54px/1.02 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      letter-spacing: .2px;
    }

    .logo-text .subtitle{
      display: block;
      margin-top: 4px;
      font: 700 20px/1.1 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      opacity: .95;
    }

    /* SOCIAL */
    .social{
      list-style: none;
      margin: 0;
      padding: 0;
      display: flex;
      gap: 14px;
      align-items: center;
    }

    .social a{
      display: grid;
      place-items: center;
    }

    .social a img{ width:40px;}

    /* BOT: search */
    .bot{
      margin-top: 10px;
      margin-bottom:22px;
    }

    .search{
      display: flex;
      align-items: stretch;
      width: min(1280px, 100%);
      background: #fff;
      border-radius: 6px;
      overflow: hidden;
      box-shadow: 0 5px 10px rgba(0, 0, 0, 0.50);
    }

    .search input{
      width: 100%;
      border: 0;
      outline: none;
      padding: 16px 18px;
      font-size: 20px;
    }

    .search .clear{
      border: 0;
      background: transparent;
      width: 56px;
      cursor: pointer;
      border-left: 1px solid rgba(0,0,0,.10);
      font-size: 18px;
      opacity: .65;
    }

    .search .submit{
      border: 0;
      cursor: pointer;
      padding: 0 22px;
      background:#207359;
      color: #fff;
      font-weight: 800;
      font-size: 20px;
    }

    /* utility label offscreen */
    .sr-only{
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0,0,0,0);
      white-space: nowrap;
      border: 0;
    }

    /* Rimuove la X nativa degli input type="search" */
    input[type="search"]::-webkit-search-cancel-button,
    input[type="search"]::-webkit-search-decoration,
    input[type="search"]::-webkit-search-results-button,
    input[type="search"]::-webkit-search-results-decoration {
      -webkit-appearance: none;
      appearance: none;
      display: none;
    }

    /* Per sicurezza */
    input[type="search"] {
      -webkit-appearance: textfield;
      appearance: textfield;
    }

    .search .clear:disabled{
      visibility: hidden;
    }

    /* ===== Overlay mobile (nuovo) ===== */
    .nav-overlay{
      position: fixed;
      inset: 0;
      opacity: 0;
      pointer-events: none;
      transition: opacity .25s ease;
      z-index: 4; /* sotto al panel (che sta a 5) */
    }
    .nav-overlay.is-open{
      opacity: 1;
      pointer-events: auto;
    }
    body.no-scroll{
      overflow: hidden;
      touch-action: none;
    }
@media (min-width: 901px){
        .sommario-desktop {
        display:none;
      }
    }
    /* ============ MOBILE ============ */
    @media (max-width: 990px){

      .site-header{overflow:visible;}

      /* hamburger a sinistra, non “centrato” */
      .top-inner{
        justify-content: flex-start;
      }
      .nav-toggle{
        display: inline-flex;
        align-items: center;
        justify-content: center;
      }

      .header-inner{ padding-bottom:5px; }

      /* animazione hamburger -> X (solo mobile) */
      .nav-toggle-icon,
      .nav-toggle-icon::before,
      .nav-toggle-icon::after{
        transition: transform .22s ease, opacity .18s ease, top .22s ease;
      }
      .nav-toggle.is-open .nav-toggle-icon{
        background: transparent;
      }
      .nav-toggle.is-open .nav-toggle-icon::before{
        top: 0;
        transform: rotate(45deg);
      }
      .nav-toggle.is-open .nav-toggle-icon::after{
        top: 0;
        transform: rotate(-45deg);
      }

      /* menu panel*/
      .nav-panel{
        display: block; /* lo teniamo nel flow, ma lo nascondiamo con transform/opacity */
        position: absolute;
        left: 12px;
        right: 12px;
        top: 52px; /* un po' più sotto della barra */
        background: rgba(10, 85, 54, 0.98);
        border: 1px solid rgba(255,255,255,.10);
        border-radius: 14px;
        z-index: 5;

        transform: translateY(-8px);
        opacity: 0;
        pointer-events: none;

        box-shadow: 0 18px 40px rgba(0,0,0,.45);
        overflow: hidden;
      }
      .nav-panel.is-open{
        transform: translateY(0);
        opacity: 1;
        pointer-events: auto;
        transition: transform .28s cubic-bezier(.2,.9,.2,1), opacity .18s ease;
      }

      /* lista: più “UI” */
      .menu{
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        padding: 6px;
      }
      .menu li{
        border-radius: 10px;
        overflow: hidden;
      }
      .menu a{
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        padding: 20px 14px;
        font-size: 16px;
        border-top: 0;
        text-decoration: none;
        background: transparent;
        position: relative;
      }

      /* separatore soft tra items */
      .menu li + li a{
        border-top: 1px solid rgba(255,255,255,.08);
      }

      /* effetto tap/hover (mobile friendly) */
      .menu a::after{
        content: "›";
        opacity: .55;
        transform: translateX(-2px);
        transition: transform .2s ease, opacity .2s ease;
      }
      .menu a:active{
        background: rgba(255,255,255,.08);
      }
      .menu a:hover{
        text-decoration: none;
        opacity: 1;
        background: rgba(255,255,255,.06);
      }
      .menu a:hover::after{
        opacity: .85;
        transform: translateX(2px);
      }

      /* MID: impila logo e social (come già avevi) */
      .mid{ padding-top: 14px; padding-bottom: 10px; }
      .mid-inner{
        flex-direction: column;
        align-items: center;
        gap: 12px;
        text-align: center;
      }

      .brand{
        flex-direction: column;
        gap: 8px;
      }
      .logo-mark{
        width: 88px;
        height: 88px;
        flex: 0 0 88px;
      }
      .logo-text .title{
        font-size: 34px;
        line-height: 1.05;
      }
      .logo-text .subtitle{
        font-size: 16px;
        line-height: 1.2;
      }

      /* Social più piccoli */
      .social{ gap: 12px; }
      .social a img{ width: 34px; }

      /* Search full width + touch */
      .bot{ margin-top: 10px; margin-bottom: 18px; }
      .search{
        width: 100%;
        border-radius: 10px;
      }
      .search input{
        padding: 14px 14px;
        font-size: 18px;
      }
      .search .clear{
        width: 52px;
        font-size: 18px;
      }
      .search .submit{
        padding: 0 16px;
        font-size: 18px;
      }
    }

    /* Smartphone */
    @media (max-width: 420px){
      .logo-text .title{ font-size: 30px; }
      .logo-text .subtitle{ font-size: 15px; }
      .search .submit{ padding: 0 14px; }
    }

    /* Smartphone | Lanscape*/
    @media (max-width: 990px) and (orientation: landscape) and (max-height: 500px){
      .menu{ padding: 4px; }
      .menu a{ padding: 8px 12px; font-size: 14px; }
    }

    /* Tablet | Portrait */
    @media (min-width: 600px) and (max-width: 1024px) and (orientation: portrait){
      .menu{
        gap: 10px;
      }
    }

    /* Tablet | Landscape */
    @media (min-width: 900px) and (max-width: 1366px) and (orientation: landscape){
      .menu{
        gap: 38px;
      }
    }

    /* =========================================================
       CSS CHI SIAMO (solo pagina) — aggiunto IN FONDO allo style
       ========================================================= */

    /* NOTA: tutto scoped su main per evitare collisioni */

    main{
      background: #ffffff;
      padding: 20px 0;
      color: #2b2f2d;
      font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      line-height: 1.6;
    }

    /* HEADER PAGINA + area illustrazione */
    main .page-header{
      padding: 0 0 0 0;
      border-bottom: 3px solid #648077;
      margin-bottom: 20px;
    }

    main .breadcrumb{
      font-size: 14px;
      color: #6b7470;
      margin-bottom: 20px;
      padding-bottom: 12px;
      border-bottom: 1px solid rgba(0, 0, 0, .08);
    }
    main .breadcrumb a{
      color: inherit;
      text-decoration: none;
    }
    main .breadcrumb a:hover{ text-decoration: underline; }
    main .breadcrumb [aria-current="page"]{ font-weight: 700; }

    main .page-header__grid{
      display: grid;
      grid-template-columns: 1fr 400px;
      gap: 18px;
      align-items: center;
    }

    main .page-header__text h1{
      margin: 0 0 6px;
      font-size: 44px;
      line-height: 1.05;
      font-weight: 800;
      letter-spacing: -0.3px;
      color: #1f2422;
    }

    main .page-header__text p{
      margin: 0;
      font-size: 18px;
      color: #4a524f;
    }

    /* Placeholder illustrazione (img verrà sostituita quando disponibile) */
    main .page-header__illustration{
      margin: 0;
      justify-self: end;
      width: 357px;
      height: 131px; /* circa altezza vista nel mockup */
      /*border-radius: 10px;*/
      overflow: hidden;
      /*
      background: #e9ecea;
      border: 1px solid rgba(0,0,0,.06);*/
    }
    main .page-header__illustration img{
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    /* PANEL (box con head grigio + icona) */
    main .panel{
      background: #fff;
      border: 1px solid rgba(20, 38, 30, 0.12);
      border-radius: 6px;
      overflow: hidden;
      margin: 0 0 18px;
    }

    /* Eccezioni */
    main .panel.panel--collaborazioni{
      margin-top:30px;
    }

    main .panel.panel--project{
      margin-bottom:30px;
    }

    main .panel__head{
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 12px 18px;
      background: #e9ecea;
      border-bottom: 1px solid rgba(0,0,0,.06);
    }

    /* Placeholder icona (img verrà sostituita quando disponibile) */
    main .panel__icon{
      width: 26px;
      height: 26px;
      flex: 0 0 26px;
    }
    main .panel__icon path{
      stroke:#207359;
    }
    main .panel__title{
      margin: 0;
      font-size: 18px;
      font-weight: 800;
      color: #2e3a36;
    }

    main .panel__body{
      padding: 14px 18px 16px;
      background-color: #f2f7f3;
    }

    main .panel__body p{ margin: 0 0 12px; }
    main .panel__body p:last-child{ margin-bottom: 0; }

    /* GRIGLIA 2 COLONNE */
    main .content-grid{
      display: grid;
      grid-template-columns: 1fr 420px;
      gap: 30px;
      align-items: start;
    }

    /* Colonna sinistra: blocchi con separatore come mockup */
    main .main-col{
      padding: 4px 0;
    }

    main .content-block{
      padding: 0;
      margin: 0;
    }

    main .content-block h2{
      margin: 0 0 8px;
      font-size: 20px;
      font-weight: 800;
      color: #2e3a36;
    }

    main .content-block p{ margin: 0 0 12px; }

    main .main-col .content-block + .content-block{
      border-top: 1px solid rgba(0,0,0,.10);
      padding-top: 18px;
      margin-top: 18px;
    }

    /* Liste con check (sia sinistra che destra) */
    main .checklist{
      list-style: none;
      margin: 8px 0 14px;
      padding: 0;
    }

    main .checklist li{
      position: relative;
      padding-left: 26px;
      margin: 10px 0;
      color: #3a4340;
    }

    main .checklist li::before{
      content: "✓";
      position: absolute;
      left: 0;
      top: 0;
      color: #2b6b56;
      font-weight: 900;
    }

    main .checklist li a{
      color: #3a4340;
      text-decoration: none;
    }
    
    main .checklist li a:hover{
      color: #207359;
      text-decoration: none;
    }

    main em{
      color: #6b7470;
      font-size: 13px;
    }

    /* Sidebar: i panel già gestiti con .panel */
    main .side-col{
      display: grid;
      gap: 14px;
    }

    /* CTA verde pieno (Governance editoriale) */
    main .btn-cta{
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      background: #207359;
      color: #fff;
      text-decoration: none;
      font-weight: 800;
      padding: 12px 14px;
      border-radius: 6px;
    }
    main .btn-cta:hover{ filter: brightness(0.98); }

    /* Footer link (Disclaimer sanitario >) */
    main .panel-footlink{
      display: inline-flex;
      align-items: center;
      gap: 8px;
      color: #2b6b56;
      text-decoration: none;
      font-weight: 800;
      padding-top: 15px;
      border-top: 1px solid rgba(0, 0, 0, .10);
      width: 100%;
      margin-top: 10px;
      justify-content: center;
    }
    main .panel-footlink:hover{ text-decoration: underline; }

    /* Banner finale “Principio guida…” */
    main .principle-banner{
      background: #207359;
      color: #fff;
      border-radius: 6px;
      padding: 14px 18px;
      margin-top: 12px;
    }

    main .principle-banner__head{
      display: flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 6px;
    }

    main .principle-banner__icon{
      width: 30px;
      height: 30px;
      flex: 0 0 30px;
    }

    main .principle-banner__icon path {
      stroke: #ffffff;
    }

    main .principle-banner h2{
      margin: 0;
      font-size: 16px;
      font-weight: 900;
      color: #fff;
    }

    main .principle-banner p{
      margin: 0;
      color: #eaf3ef;
    }

    main .principle-banner strong{ color: #fff; }

    /* Responsive */
    @media (max-width: 990px){
      main .page-header__grid{
        grid-template-columns: 1fr;
      }
      main .page-header__illustration{
        width: 100%;
        height: auto;
        justify-self: start;
      }
      main .content-grid{
        grid-template-columns: 1fr;
      }
      /* Eccezioni */
      main .panel.panel--collaborazioni{
        margin-bottom:0px;
      }
    }


    /* Per Max - Icollare da qui */

    .icon-nav-wrap {
      /*max-width: 1280px;*/
      /*margin: 0 auto;*/
      /*padding: 22px 16px;*/
    }

    .icon-nav {
      display: grid;
      grid-template-columns: repeat(10, minmax(110px, 1fr));
      gap: 10px;
      align-items: start;
    }

    .icon-nav__item {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: flex-start;
      /*gap: 12px;*/
      text-decoration: none;
      color: #294b47;
      transition: transform 0.22s ease, filter 0.22s ease;
      min-width: 0;
    }

    .icon-nav__item:hover,
    .icon-nav__item:focus-visible {
      transform: translateY(-4px);
      filter: saturate(1.03);
      outline: none;
    }

    .icon-nav__icon {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 100%;
      min-height: 104px;
    }

    .icon-nav__icon img {
      max-width: 100%;
      width: auto;
      height: auto;
      max-height: 90px;
      object-fit: contain;
      display: block;
    }

    .icon-nav__label {
      width: 100%;
      background: #dbe3de;
      border-radius: 0;
      padding: 0px;
      text-align: center;
      font-weight: 700;
      line-height: 1.12;
      font-size: 14px;
      min-height: 70px;
      display: flex;
      align-items: center;
      justify-content: center;
      box-shadow: 0 8px 20px rgba(20, 49, 45, 0.08);
      transition: box-shadow 0.22s ease, background-color 0.22s ease, color 0.22s ease;
      word-break: break-word;
    }

    .icon-nav__item:hover .icon-nav__label,
    .icon-nav__item:focus-visible .icon-nav__label {
      box-shadow: 0 12px 28px rgba(20, 49, 45, 0.15);
      background: #cfdbd5;
      color: #173634;
    }

    .icon-nav__item[aria-current="page"] .icon-nav__label {
      background: #c6d5ce;
      color: #173634;
      box-shadow: 0 12px 28px rgba(20, 49, 45, 0.15);
    }

    .didascalia{
      display:flex; 
      padding: 14px 18px 0px;
      justify-content: center;
    }

    .didascalia h2{
      font-size:18px; 
      margin:0; 
      color:#207359;
    }

    @media (max-width: 1280px) {
      .icon-nav {
        grid-template-columns: repeat(5, minmax(120px, 1fr));
      }
    }
.icon-nav-wrap {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0px 20px;
  box-sizing: border-box;
}

.icon-nav {
  display: grid;
  grid-template-columns: repeat(10, minmax(0, 1fr));
  gap: 10px;
  width: 100%;
}
    @media (max-width: 820px) {
      .icon-nav {
        grid-template-columns: repeat(3, minmax(110px, 1fr));
        gap: 14px;
      }

      .icon-nav__icon {
        min-height: 92px;
      }

      .icon-nav__icon img {
        max-height: 76px;
      }

      .icon-nav__label {
        min-height: 64px;
        font-size: 13px;
        padding: 12px 8px;
      }
    }

    @media (max-width: 560px) {
      .icon-nav-wrap {
        padding: 16px 12px;
      }

      .icon-nav {
        grid-template-columns: repeat(2, minmax(130px, 1fr));
        gap: 40px;
      }

      .icon-nav__item {
        gap: 8px;
      }

      .icon-nav__icon {
        min-height: 84px;
      }

      .icon-nav__icon img {
        max-height: 68px;
      }

      .icon-nav__label {
        min-height: 58px;
        font-size: 13px;
      }
    }

    .articoli_tendenza{
      display: flex;
      flex-direction: column;
    }

    .articoli_tendenza h4{
      text-transform: uppercase;
      color: #ffffff;
      background-color:#1a4a46;
      padding: 14px 18px 16px;
      border-radius: 6px;
      margin:0;
      font-size:24px;
    }

    .articoli_tendenza .elenco{
      margin-top:10px;
    }

    .article-card {
      width: 100%;
      margin-bottom: 3px;
    }

    .article-card__link {
      display: grid;
      grid-template-columns: 220px minmax(0, 1fr);
      gap: 22px;
      align-items: start;
      width: 100%;
      max-width: 100%;
      padding: 14px;
      text-decoration: none;
      color: inherit;
      background: #ffffff;
      border: 1px solid #e4e7e5;
      border-radius: 6px;
      transition:
        transform 0.22s ease,
        box-shadow 0.22s ease,
        border-color 0.22s ease,
        background-color 0.22s ease;
      box-sizing: border-box;
    }

    .article-card__media {
      width: 100%;
      min-width: 0;
      overflow: hidden;
      border-radius: 6px;
      background: #f3f5f4;
    }

    .article-card__image {
      display: block;
      width: 100%;
      max-width: 100%;
      height: auto;
      aspect-ratio: 16 / 9;
      object-fit: cover;
      transition: transform 0.35s ease;
    }

    .article-card__content {
      min-width: 0;
      max-width: 100%;
      padding-top: 2px;
    }

    .article-card__title {
      margin: 0 0 8px 0;
      font-size: 20px;
      line-height: 1.2;
      font-weight: 700;
      color: #1f7a6d;
      transition: color 0.2s ease;
      overflow-wrap: anywhere;
    }

    .article-card__meta {
      margin-bottom: 12px;
      font-size: 13px;
      line-height: 1.4;
      font-weight: 700;
      color: #2a2a2a;
      overflow-wrap: anywhere;
    }

    .article-card__excerpt {
      margin: 0;
      font-size: 15px;
      line-height: 1.55;
      color: #222222;
      overflow-wrap: anywhere;
    }

    .article-card__excerpt strong {
      font-weight: 700;
      color: #111111;
    }

    .article-card__link:hover,
    .article-card__link:focus-visible {
      transform: translateY(-2px);
      background: #ffffff;
      border-color: #d3ddd8;
      box-shadow: 0 10px 24px rgba(25, 58, 53, 0.08);
      outline: none;
    }

    .article-card__link:hover .article-card__title,
    .article-card__link:focus-visible .article-card__title {
      color: #165f56;
    }

    .article-card__link:hover .article-card__image,
    .article-card__link:focus-visible .article-card__image {
      transform: scale(1.03);
    }

    @media (max-width: 768px) {
      .article-card {
        margin-bottom: 14px;
      }

      .article-card__link {
        grid-template-columns: 1fr;
        gap: 14px;
        padding: 12px;
      }

      .article-card__title {
        font-size: 18px;
      }

      .article-card__meta {
        font-size: 12px;
      }

      .article-card__excerpt {
        font-size: 14px;
        line-height: 1.5;
      }
    }

    .pagination {
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      align-items: center;
      gap: 8px;
      margin-top: 6px;
      margin-bottom:12px;
      padding: 0;
    }

    .pagination__item,
    .pagination__dots {
      min-width: 42px;
      height: 42px;
      padding: 0 12px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      box-sizing: border-box;
      font-size: 15px;
      font-weight: 700;
      line-height: 1;
      border-radius: 6px;
    }

    .pagination__item {
      text-decoration: none;
      color: #1f5f59;
      background: #ffffff;
      border: 1px solid #d7dfdb;
      transition:
        background-color 0.2s ease,
        color 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease,
        box-shadow 0.2s ease;
    }

    .pagination__item:hover,
    .pagination__item:focus-visible {
      color: #ffffff;
      background: #1f5f59;
      border-color: #1f5f59;
      box-shadow: 0 6px 16px rgba(31, 95, 89, 0.16);
      transform: translateY(-1px);
      outline: none;
    }

    .pagination__item--current {
      color: #ffffff;
      background: #1f5f59;
      border: 1px solid #1f5f59;
      box-shadow: 0 6px 16px rgba(31, 95, 89, 0.16);
      cursor: default;
    }

    .pagination__item--prev,
    .pagination__item--next {
      font-size: 20px;
      padding-bottom: 2px;
    }

    .pagination__dots {
      color: #6f7d78;
      background: transparent;
      border: none;
      min-width: auto;
      padding: 0 4px;
    }

    @media (max-width: 640px) {
      .pagination {
        gap: 6px;
        margin-top: 24px;
      }

      .pagination__item,
      .pagination__dots {
        min-width: 38px;
        height: 38px;
        font-size: 14px;
      }

      .pagination__item--prev,
      .pagination__item--next {
        font-size: 18px;
      }
    }
.bl-main{
  padding:0px !important;
}

/* ──────────────────────────────────────────────────────
   [EXTERNAL] style.post.css  (    1934 bytes)
   ────────────────────────────────────────────────────── */

        .brief {
            /*list-style-type: none;;*/
            text-align: justify;
        }
        figcaption{
            text-align: justify;
            background: #f2f7f1 !important
        }
        .h3-block .h3_content {
    margin: -10px 0 0 0;
}

.sectionImage:hover figcaption {

    padding: 5px;
    padding-bottom:6px;
}

.per-approfondire{
    margin-top: 4px;
    width:auto;
    height:auto;
    display:inline-block;
    text-decoration: none !important;;
    
    
}
.per-approfondire:hover{
    text-decoration: underline !important;;
    color: var(--verde) !important;;
}

.section-h2 > .text p {
    margin: 0px;;
    margin-block-start: 8px;
    margin-block-end: 8px;;
}

.h3_content p{
   /* margin: 0px;;
    margin-block-start: 0px;
    margin-block-end: 0px;;*/
}
.h3-block h3 {
    /*margin: 0;
    margin-bottom: 5px;
    margin-top: 4px;;*/
}
.text {
    /*line-height: 20px;*/
}
p.brevedescr{
    /*margin: 0px;;
    margin-block-start: 0px;
    margin-block-end: 0px;;*/
}
/*
.section-h2 h2 {
    margin-bottom:0px !important
}
.sectionImage {
    margin-bottom: 0px !important;
}*/
.section-h2 .text {
    margin-top: 0px !important;
}

.brief__list,.briefItem{
    font-size:16px !important;
    /*line-height: 20px;;*/
}
.brief li,.section-h2 li {
    margin:5px 0px;
}

.sidebar-index >.card {
    padding:0px;
    background-color: #f2f7f1 !important;
}

.sidebar-index .brief__head {
    border-radius: var(--radius) var(--radius) 0px 0px;
}

.sidebar-index .brief__body {
    padding:14px;
} 
.sidebar-index .brief__body ul {
    margin:0px
} 
.sidebar-index .brief__body li{
    list-style-type: none;;
    margin:5px 0px;
} 
.chap-list {
        margin: 0px;
    padding-inline-start: 0px;
}
.fs-14{
    font-size:14px !important;
}
.article-card {
    margin-left: 0px;
    margin-right: 0px;
}

.comparative-table td {
    padding: 14px 16px;
    border: 1px solid var(--verde);
}

/* ──────────────────────────────────────────────────────
   [INLINE #1] 133 chars
   ────────────────────────────────────────────────────── */

img:is([sizes=auto i],[sizes^="auto," i]){contain-intrinsic-size:3000px 1500px}

/* ──────────────────────────────────────────────────────
   [INLINE #2] 336 chars
   ────────────────────────────────────────────────────── */

img.wp-smiley, img.emoji {
		display: inline !important;
		border: none !important;
		box-shadow: none !important;
		height: 1em !important;
		width: 1em !important;
		margin: 0 0.07em !important;
		vertical-align: -0.1em !important;
		background: none !important;
		padding: 0 !important;
	}

/* ──────────────────────────────────────────────────────
   [INLINE #3] 3551 chars
   ────────────────────────────────────────────────────── */

:root{--wp-block-synced-color:#7a00df;--wp-block-synced-color--rgb:122,0,223;--wp-bound-block-color:var(--wp-block-synced-color);--wp-editor-canvas-background:#ddd;--wp-admin-theme-color:#007cba;--wp-admin-theme-color--rgb:0,124,186;--wp-admin-theme-color-darker-10:#006ba1;--wp-admin-theme-color-darker-10--rgb:0,107,160.5;--wp-admin-theme-color-darker-20:#005a87;--wp-admin-theme-color-darker-20--rgb:0,90,135;--wp-admin-border-width-focus:2px}@media (min-resolution:192dpi){:root{--wp-admin-border-width-focus:1.5px}}.wp-element-button{cursor:pointer}:root .has-very-light-gray-background-color{background-color:#eee}:root .has-very-dark-gray-background-color{background-color:#313131}:root .has-very-light-gray-color{color:#eee}:root .has-very-dark-gray-color{color:#313131}:root .has-vivid-green-cyan-to-vivid-cyan-blue-gradient-background{background:linear-gradient(135deg,#00d084,#0693e3)}:root .has-purple-crush-gradient-background{background:linear-gradient(135deg,#34e2e4,#4721fb 50%,#ab1dfe)}:root .has-hazy-dawn-gradient-background{background:linear-gradient(135deg,#faaca8,#dad0ec)}:root .has-subdued-olive-gradient-background{background:linear-gradient(135deg,#fafae1,#67a671)}:root .has-atomic-cream-gradient-background{background:linear-gradient(135deg,#fdd79a,#004a59)}:root .has-nightshade-gradient-background{background:linear-gradient(135deg,#330968,#31cdcf)}:root .has-midnight-gradient-background{background:linear-gradient(135deg,#020381,#2874fc)}:root{--wp--preset--font-size--normal:16px;--wp--preset--font-size--huge:42px}.has-regular-font-size{font-size:1em}.has-larger-font-size{font-size:2.625em}.has-normal-font-size{font-size:var(--wp--preset--font-size--normal)}.has-huge-font-size{font-size:var(--wp--preset--font-size--huge)}.has-text-align-center{text-align:center}.has-text-align-left{text-align:left}.has-text-align-right{text-align:right}.has-fit-text{white-space:nowrap!important}#end-resizable-editor-section{display:none}.aligncenter{clear:both}.items-justified-left{justify-content:flex-start}.items-justified-center{justify-content:center}.items-justified-right{justify-content:flex-end}.items-justified-space-between{justify-content:space-between}.screen-reader-text{border:0;clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important}.screen-reader-text:focus{background-color:#ddd;clip-path:none;color:#444;display:block;font-size:1em;height:auto;left:5px;line-height:normal;padding:15px 23px 14px;text-decoration:none;top:5px;width:auto;z-index:100000}html :where(.has-border-color){border-style:solid}html :where([style*=border-top-color]){border-top-style:solid}html :where([style*=border-right-color]){border-right-style:solid}html :where([style*=border-bottom-color]){border-bottom-style:solid}html :where([style*=border-left-color]){border-left-style:solid}html :where([style*=border-width]){border-style:solid}html :where([style*=border-top-width]){border-top-style:solid}html :where([style*=border-right-width]){border-right-style:solid}html :where([style*=border-bottom-width]){border-bottom-style:solid}html :where([style*=border-left-width]){border-left-style:solid}html :where(img[class*=wp-image-]){height:auto;max-width:100%}:where(figure){margin:0 0 1em}html :where(.is-position-sticky){--wp-admin--admin-bar--position-offset:var(--wp-admin--admin-bar--height,0px)}@media screen and (max-width:600px){html :where(.is-position-sticky){--wp-admin--admin-bar--position-offset:0px}}


/* ──────────────────────────────────────────────────────
   [INLINE #4] 348 chars
   ────────────────────────────────────────────────────── */

/*! This file is auto-generated */
.wp-block-button__link{color:#fff;background-color:#32373c;border-radius:9999px;box-shadow:none;text-decoration:none;padding:calc(.667em + 2px) calc(1.333em + 2px);font-size:1.125em}.wp-block-file__button{background:#32373c;color:#fff;text-decoration:none}

/* ──────────────────────────────────────────────────────
   [INLINE #6] 283 chars
   ────────────────────────────────────────────────────── */

.review {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: unset;;
}

.review .row-review {
    display: flex;
    gap: 10px;
        justify-content: space-between; /* uno a sinistra, uno a destra */

}

.review .row-review span {
    display: block;
}

/* ──────────────────────────────────────────────────────
   [INLINE #7] 6137 chars
   ────────────────────────────────────────────────────── */

.share-article {
                        display: flex;
                        align-items: center;
                        gap: 14px;
                        flex-wrap: wrap;
                        /*  margin: 0 0 24px 0; */
                        padding: 14px 0;
                        /*border-top: 1px solid #e6ebf0;*/
                        /*border-bottom: 1px solid #e6ebf0;*/
                    }

                    .share-label {
                        font-size: 13px;
                        font-weight: 700;
                        letter-spacing: .04em;
                        text-transform: uppercase;
                        color: #5f6b76;
                    }

                    .share-actions {
                        display: flex;
                        align-items: center;
                        gap: 10px;
                        flex-wrap: wrap;
                    }

                    .share-btn {
                        position: relative;
                        display: inline-flex;
                        align-items: center;
                        justify-content: center;
                        width: 42px;
                        height: 42px;
                        padding: 0;
                        border: 2px solid var(--bg-section);
                        border-radius: 999px;
                        background: #fff;
                        color: #334155;
                        text-decoration: none;
                        cursor: pointer;
                        transition:
                            color .2s ease,
                            border-color .2s ease,
                            background .2s ease,
                            transform .2s ease,
                            box-shadow .2s ease;
                        appearance: none;
                        -webkit-appearance: none;
                    }

                    .share-btn {
                        border-radius: 10px;
                        width: 40px;
                        height: 40px;
                        background: #fff;
                        border: 2px solid var(--border);
                        box-shadow: var(--shadow);
                    }

                    .share-btn:hover,
                    .share-btn:focus-visible {
                        color: var(--verde);
                        border-color: var(--accent);
                        background: #f8fbff;
                        transform: translateY(-1px);
                        box-shadow: 0 4px 14px rgba(31, 111, 235, .08);
                        outline: none;
                    }

                    .share-icon {
                        width: 18px;
                        height: 18px;
                        display: inline-flex;
                        align-items: center;
                        justify-content: center;
                        flex: 0 0 18px;
                    }

                    .share-icon svg {
                        width: 100%;
                        height: 100%;
                        display: block;
                    }

                    .share-icon.ico-90-p svg {
                        width: 85%;
                        height: 85%;
                    }

                    .share-icon.ico-110-p svg {
                        width: 130%;
                        height: 130%;
                    }

                    .share-icon.ico-110-p {
                        flex: 0 0 28px;

                    }

                    /* tooltip */
                    .share-btn::after {
                        content: attr(data-tooltip);
                        position: absolute;
                        bottom: calc(100% + 10px);
                        left: 50%;
                        transform: translateX(-50%) translateY(4px);
                        background: var(--verde);
                        color: #fff;
                        font-size: 12px;
                        line-height: 1;
                        padding: 8px 10px;
                        border-radius: 7px;
                        white-space: nowrap;
                        opacity: 0;
                        visibility: hidden;
                        pointer-events: none;
                        transition: all .18s ease;
                        z-index: 30;
                    }

                    .share-btn::before {
                        content: "";
                        position: absolute;
                        bottom: 100%;
                        left: 50%;
                        transform: translateX(-50%) translateY(4px);
                        border: 6px solid transparent;
                        border-top-color: #1f2937;
                        opacity: 0;
                        visibility: hidden;
                        pointer-events: none;
                        transition: all .18s ease;
                        z-index: 30;
                    }

                    .share-btn:hover::after,
                    .share-btn:hover::before,
                    .share-btn:focus-visible::after,
                    .share-btn:focus-visible::before {
                        opacity: 1;
                        visibility: visible;
                        transform: translateX(-50%) translateY(0);
                    }

                    /* stato copiato */
                    .share-btn.is-copied::after {
                        content: "Link copiato";
                        opacity: 1;
                        visibility: visible;
                        transform: translateX(-50%) translateY(0);
                    }

                    @media (max-width: 768px) {
                        .share-article {
                            gap: 10px;
                        }

                        .share-btn {
                            width: 40px;
                            height: 40px;
                        }
                    }

                    .ico-90-p {
                        width: 90px;
                        height: 90px;
                    }

/* ──────────────────────────────────────────────────────
   [INLINE #8] 7952 chars
   ────────────────────────────────────────────────────── */

.article-actions {
                    display: flex;
                    align-items: center;
                    justify-content: space-between;
                    gap: 18px;
                    flex-wrap: wrap;
                }

                /* Pulsante video */
                .btn-video {
                    --video-green: #0f6b46;
                    --video-green-dark: #0b4f35;
                    --video-bg: linear-gradient(135deg, #0f6b46 0%, #147a52 100%);
                    --video-ring: rgba(15, 107, 70, 0.18);

                    position: relative;
                    display: inline-flex;
                    align-items: center;
                    gap: 14px;
                    min-height: 52px;
                    padding: 0 18px 0 14px;
                    border: 0;
                    border-radius: 14px;
                    background: var(--video-bg);
                    color: #fff;
                    font-size: 15px;
                    font-weight: 700;
                    line-height: 1.2;
                    cursor: pointer;
                    overflow: visible;
                    box-shadow: 0 10px 24px rgba(15, 107, 70, 0.22);
                    transition:
                        transform .22s ease,
                        box-shadow .22s ease,
                        background .22s ease;
                    appearance: none;
                    -webkit-appearance: none;
                }

                .btn-video:hover,
                .btn-video:focus-visible {
                    /* transform: translateY(-2px);
    box-shadow: 0 14px 30px rgba(15, 107, 70, 0.28);
    outline: none;*/
                }

                /* Luccicanza */
                /* .btn-video-shine {
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    overflow: hidden;
  }

  .btn-video-shine::before {
    content: "";
    position: absolute;
    top: -30%;
    left: -120%;
    width: 60%;
    height: 160%;
    transform: rotate(18deg);
    background: linear-gradient(90deg,
        rgba(255, 255, 255, 0) 0%,
        rgba(255, 255, 255, .12) 35%,
        rgba(255, 255, 255, .38) 50%,
        rgba(255, 255, 255, .12) 65%,
        rgba(255, 255, 255, 0) 100%);
    transition: left .75s ease;
  }
*/
                .btn-video:hover .btn-video-shine::before,
                .btn-video:focus-visible .btn-video-shine::before {
                    left: 140%;
                }

                /* Icona play */
                .btn-video .btn-icon {
                    position: relative;
                    z-index: 1;
                    width: 34px;
                    height: 34px;
                    flex: 0 0 34px;
                    display: inline-flex;
                    align-items: center;
                    justify-content: center;
                    border-radius: 999px;
                    background: rgba(255, 255, 255, 0.14);
                    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.12);
                }

                .btn-video .btn-icon svg {
                    width: 20px;
                    height: 20px;
                    display: block;
                    margin-left: 2px;
                    /* compensa visivamente il triangolo */
                }

                /* Testo centrato rispetto al play */
                .btn-video .btn-text {
                    position: relative;
                    z-index: 1;
                    display: inline-flex;
                    align-items: center;
                    min-height: 34px;
                }

                /* Popup anteprima */
                .video-preview {
                    position: absolute;
                    left: 0;
                    bottom: calc(100% + 2px);
                    width: 99%;
                    border-radius: 16px;
                    background: #fff;
                    color: #17202a;
                    box-shadow:
                        0 18px 40px rgba(15, 23, 42, 0.16),
                        0 4px 10px rgba(15, 23, 42, 0.08);
                    overflow: hidden;
                    opacity: 0;
                    visibility: hidden;
                    transform: translateY(8px) scale(.98);
                    transform-origin: bottom left;
                    transition:
                        opacity .2s ease,
                        visibility .2s ease,
                        transform .2s ease;
                    z-index: 40;
                    pointer-events: none;
                }

                .video-preview::after {
                    content: "";
                    position: absolute;
                    left: 24px;
                    top: 100%;
                    border: 8px solid transparent;
                    border-top-color: #fff;
                }

                .btn-video:hover .video-preview,
                .btn-video:focus-visible .video-preview {
                    opacity: 1;
                    visibility: visible;
                    transform: translateY(0) scale(1);
                }

                .video-preview-media {
                    position: relative;
                    display: block;
                    width: 100%;
                    aspect-ratio: 16 / 9;
                    background:
                        linear-gradient(rgba(0, 0, 0, .16), rgba(0, 0, 0, .28)),
                        var(--video-preview) center/cover no-repeat,
                        #dfe7ec;
                }

                .video-preview-play {
                    position: absolute;
                    inset: 50% auto auto 50%;
                    transform: translate(-50%, -50%);
                    width: 56px;
                    height: 56px;
                    border-radius: 999px;
                    display: flex;
                    align-items: center;
                    justify-content: center;
                    color: #fff;
                    background: rgba(15, 107, 70, 0.88);
                    box-shadow: 0 8px 20px rgba(0, 0, 0, .18);
                    backdrop-filter: blur(4px);
                }

                .video-preview-play svg {
                    width: 26px;
                    height: 26px;
                    margin-left: 2px;
                }

                .video-preview-body {
                    display: flex;
                    flex-direction: column;
                    gap: 4px;
                    padding: 12px 14px 14px;
                }

                .video-preview-body strong {
                    font-size: 14px;
                    line-height: 1.2;
                    color: #12202a;
                }

                .video-preview-body small {
                    font-size: 12px;
                    line-height: 1.35;
                    color: #5b6875;
                }

                /* Accessibilità / mobile */
                @media (hover:none) {
                    .video-preview {
                        display: none;
                    }
                }

                @media (max-width: 768px) {
                    .article-actions {
                        align-items: stretch;
                    }

                    .btn-video {
                        width: 100%;
                        justify-content: flex-start;
                    }
                }

                .video-preview-media.is-video {
                    overflow: hidden;
                    background: #000;
                }

                .video-preview-media.is-video video {
                    width: 100%;
                    height: 100%;
                    object-fit: cover;
                    display: block;
                }

                .per-approfondire {

                    color: #5f6b76;
                    text-decoration: underline;
                    font-style: italic;

                }

/* ──────────────────────────────────────────────────────
   [INLINE #9] 1307 chars
   ────────────────────────────────────────────────────── */

.yt {
                    position: relative;
                    width: 100%;
                    max-width: 960px;
                    aspect-ratio: 16 / 9;
                    background: #000;
                    overflow: hidden;
                    border-radius: 16px;
                    margin: 10px 0;
                    padding: 0px 0;
                    border-top: 1px solid #f1edf6;
                    border-bottom: 1px solid #f1edf6;
                }

                .yt__thumb {
                    width: 100%;
                    height: 100%;
                    object-fit: cover;
                    display: block;
                }

                .yt__play {
                    position: absolute;
                    inset: 0;
                    margin: auto;
                    width: 84px;
                    height: 84px;
                    border: 0;
                    border-radius: 999px;
                    cursor: pointer;
                    font-size: 30px;
                    line-height: 84px;
                    background: rgba(255, 255, 255, .9);
                }

                .yt__play:hover {
                    transform: scale(1.03);
                }

                .brevedescr {
                    font-style: italic;
                }

/* ──────────────────────────────────────────────────────
   [INLINE #10] 1334 chars
   ────────────────────────────────────────────────────── */

.sidebar-index {
                    position: sticky;
                    top: 3px !important;
                    font-size: var(--text-dx-fs);
                    /* distanza dal top viewport */
                    top: 90px;

                    /*max-height: calc(100vh - 40px);
                            overflow-y: auto;*/

                }

                .banner {
                    margin-top: 6px;
                }

                .banner img {
                    border: 1px solid var(--border);
                    border-radius: var(--radius);
                    box-shadow: var(--shadow);
                }

                .sidebar-all {
                    width: 100%;
                    height: 100%;
                }

                .grid {
                    align-items: stretch;
                }

                .sideGroup {
                    display: flex;
                    flex-direction: column;
                    height: 100%;
                }

                .sidebar-index {
                    position: sticky;
                    top: 20px;
                }

                .sidebar-all {
                    flex: 1;
                    /* prende tutta l'altezza disponibile */
                    display: flex;
                    flex-direction: column;
                }

/* ──────────────────────────────────────────────────────
   [INLINE #11] 255 chars
   ────────────────────────────────────────────────────── */

.h2-reference{
    margin-bottom: 10px;


    
    /* text-transform: uppercase; */
    color: #ffffff;
    background-color: var(--accent);
    padding: 14px 18px 16px;
    border-radius: 6px;
    margin: 0;
    font-size: 19px;
                        }

/* ──────────────────────────────────────────────────────
   [INLINE #12] 4222 chars
   ────────────────────────────────────────────────────── */

.articoli_tendenza {
                    display: flex;
                    flex-direction: column;

                }

                h4 {
                    /* text-transform: uppercase;*/
                    color: #ffffff;
                    background-color: var(--accent);
                    padding: 14px 18px 16px;
                    border-radius: 6px;
                    margin: 0;
                    font-size: 19px;
                }

                .articoli_tendenza .elenco {
                    margin-top: 10px;
                    padding: 0px 12px;
                }

                .article-card {
                    width: 100%;
                    margin-bottom: 3px;
                    box-shadow: var(--shadow);
                    margin-left: 10px;
                    margin-right: 10px;
                }

                .article-card__link {
                    display: grid;
                    grid-template-columns: 220px minmax(0, 1fr);
                    gap: 22px;
                    align-items: start;
                    width: 100%;
                    max-width: 100%;
                    padding: 14px;
                    text-decoration: none;
                    color: inherit;
                    background: #ffffff;
                    border: 2px solid #e4e7e5;
                    border-radius: 6px;
                    transition:
                        transform 0.22s ease,
                        box-shadow 0.22s ease,
                        border-color 0.22s ease,
                        background-color 0.22s ease;
                    box-sizing: border-box;
                }

                .article-card__media {
                    width: 100%;
                    min-width: 0;
                    overflow: hidden;
                    border-radius: 6px;
                    background: #f3f5f4;
                }

                .article-card__image {
                    display: block;
                    width: 100%;
                    max-width: 100%;
                    height: auto;
                    aspect-ratio: 16 / 9;
                    object-fit: cover;
                    transition: transform 0.35s ease;
                }

                .article-card__content {
                    min-width: 0;
                    max-width: 100%;
                    padding-top: 2px;
                }

                .article-card__title {
                    margin: 0 0 8px 0;
                    font-size: 20px;
                    line-height: 1.2;
                    font-weight: 700;
                    color: #1f7a6d;
                    transition: color 0.2s ease;
                    overflow-wrap: anywhere;
                }

                .article-card__meta {
                    margin-bottom: 12px;
                    font-size: 13px;
                    line-height: 1.4;
                    font-weight: 700;
                    color: #2a2a2a;
                    overflow-wrap: anywhere;
                }

                .article-card__excerpt {
                    margin: 0;
                    font-size: 15px;
                    line-height: 1.55;
                    color: #222222;
                    overflow-wrap: anywhere;
                }

                .article-card__excerpt strong {
                    font-weight: 700;
                    color: #111111;
                }

                .article-card__link:hover,
                .article-card__link:focus-visible {
                    transform: translateY(-2px);
                    background: #ffffff;
                    border-color: var(--accent);
                    border: solid 2px var(--accent);
                    box-shadow: 0 10px 24px rgba(25, 58, 53, 0.08);
                    outline: none;
                }

                .article-card__link:hover .article-card__title,
                .article-card__link:focus-visible .article-card__title {
                    color: #165f56;
                }

                .article-card__link:hover .article-card__image,
                .article-card__link:focus-visible .article-card__image {
                    transform: scale(1.03);
                }

/* ──────────────────────────────────────────────────────
   [INLINE #13] 549 chars
   ────────────────────────────────────────────────────── */

.biblio-title {
                    font-weight: 600;
                    margin: 8px 0;
                    font-style: italic;

                }

                .studiCorrelati .elenco {

                    padding: 0px 12px;
                }

                .studiCorrelati h4 {
                    margin-bottom: 10px
                }

                .studiCorrelati a {
                    text-decoration: underline;
                }

                .studiCorrelati a:hover {
                    color: var(--accent)
                }
 /* Sfondo dell'intera sezione "Riferimenti" */
  .studiCorrelati {

    border-radius: 10px;
    padding: 16px 18px 20px;
  }
  .biblio-card {
    background: #F8F9FA;
    border: 1px solid #e9ecef;
    padding: 14px 16px;
    margin-bottom: 10px;
    border-radius: 8px;
  }
  .biblio-card:last-child { margin-bottom: 0; }
  .biblio-title {
    font-weight: 600;
    margin: 0 0 var(--lsh-ref-row-gap);
    font-style: italic;
    color: #1f2937;
  }
  .biblio-meta {
    margin: 0 0 var(--lsh-ref-row-gap);
    font-size: 14px;
    color: #4b5563;
  }
  .biblio-btns {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    /* Stessa distanza delle righe sopra (meta) — riga DOI / PubMed / PubMed Central */
    margin-top: var(--lsh-ref-row-gap);
  }
  /* Link DOI / PubMed Central / PubMed nell'elenco riferimenti:
     niente bottone, solo testo in grassetto verde, cliccabile,
     separati da un trattino. */
  .biblio-btn {
    display: inline;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--verde-pdf, #2D6A4F) !important;
    font-size: 13px;
    font-weight: 700;
    text-decoration: none !important;
    letter-spacing: .01em;
    transition: color .15s ease;
  }
  .biblio-btn:hover,
  .biblio-btn:focus-visible {
    color: #1f5238 !important;
    text-decoration: underline !important;
  }
  .biblio-btns { gap: 6px 14px; }
  /* Separatore visivo "·" tra link consecutivi */
  .biblio-btn + .biblio-btn::before {
    content: "·";
    color: #9ca3af;
    margin-right: 14px;
    margin-left: -10px;
    font-weight: 400;
  }
  .studiCorrelati .elenco {
    padding: 0;
  }
/* ──────────────────────────────────────────────────────
   [INLINE #14] 703 chars
   ────────────────────────────────────────────────────── */

.sidebar-index ul ul {
            max-height: 0;
            overflow: hidden;
            transition: max-height 0.3s ease;
        }

        .sidebar-index li.open>ul {
            max-height: 500px;
            /* abbastanza alto */
        }

        .sidebar-index li>a {
            /*  display: flex;
            justify-content: space-between;
            align-items: center;*/
            cursor: pointer;
        }

        /* freccina */
        .sidebar-index li.has-sub>a::after {
            /*  content: "▸";
            font-size: 12px;
            transition: transform 0.2s ease;*/
        }

        .sidebar-index li.open>a::after {
            transform: rotate(90deg);
        }

/* ──────────────────────────────────────────────────────
   [INLINE #15] 3908 chars
   ────────────────────────────────────────────────────── */

.lsh-footer {
  background:
    radial-gradient(circle at top left, rgba(108, 205, 141, 0.08), transparent 28%),
    linear-gradient(180deg, #103226 0%, #0a2018 100%);
  color: rgba(255, 255, 255, 0.92);
  margin-top: 6px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.lsh-container {
  width: min(1200px, calc(100% - 32px));
  margin: 0 auto;
}

.lsh-footer-top {
  padding: 52px 0 34px;
}

.lsh-footer-grid {
  display: grid;
  grid-template-columns: 1.7fr 1fr 1fr;
  gap: 28px;
  align-items: start;
}

.lsh-footer-col h2 {
  margin: 0 0 14px;
  font-size: 0.95rem;
  line-height: 1.2;
  font-weight: 700;
  color: #ffffff;
  letter-spacing: 0.02em;
}

.lsh-footer-col ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.lsh-footer-col li + li {
  margin-top: 10px;
}

.lsh-footer a {
  color: rgba(255, 255, 255, 0.82);
  text-decoration: none;
  transition: color 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
}

.lsh-footer a:hover,
.lsh-footer a:focus-visible {
  color: #ffffff;
}

.lsh-footer a:focus-visible {
  outline: 2px solid rgba(162, 230, 184, 0.85);
  outline-offset: 3px;
  border-radius: 4px;
}

.lsh-footer-brand {
  padding-right: 12px;
}

.lsh-footer-logo {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}

.lsh-footer-logo-mark {
  width: 42px;
  height: 42px;
  
  display: inline-flex;
  align-items: center;
  justify-content: center;
  
  
  font-weight: 800;
  font-size: 1.1rem;
  
}

.lsh-footer-logo-text {
  font-size: 1.15rem;
  font-weight: 700;
  color: #ffffff;
  letter-spacing: 0.01em;
}

.lsh-footer-tagline {
  margin: 0 0 10px;
  font-size: 1rem;
  font-weight: 600;
  
}

.lsh-footer-desc {
  margin: 0;
  max-width: 34ch;
  font-size: 0.95rem;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.72);
}

.lsh-footer-social {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 16px;
  margin-top: 18px;
}

.lsh-footer-social a {
  font-size: 0.92rem;
}

.lsh-footer-paths {
  padding: 24px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.02);
  backdrop-filter: blur(4px);
}

.lsh-footer-paths-title {
  margin: 0 0 14px;
  font-size: 0.96rem;
  font-weight: 700;
  color: #ffffff;
}

.lsh-footer-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.lsh-footer-pills a {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.08);
  font-size: 0.92rem;
  line-height: 1;
}

.lsh-footer-pills a:hover,
.lsh-footer-pills a:focus-visible {
  background: rgba(121, 212, 143, 0.14);
  border-color: rgba(121, 212, 143, 0.28);
  transform: translateY(-1px);
}

.lsh-footer-bottom {
  padding: 18px 0 24px;
}

.lsh-footer-bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px 28px;
}

.lsh-footer-copy {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(255, 255, 255, 0.6);
}

.lsh-footer-legal {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px 18px;
}

.lsh-footer-legal a {
  font-size: 0.9rem;
  color: rgba(255, 255, 255, 0.68);
}

@media (max-width: 1080px) {
  .lsh-footer-grid {
    grid-template-columns: 1.2fr 1fr 1fr;
  }

  .lsh-footer-brand {
    grid-column: 1 / -1;
    padding-right: 0;
  }

  .lsh-footer-desc {
    max-width: 60ch;
  }
}

@media (max-width: 740px) {
  .lsh-footer-top {
    padding: 40px 0 26px;
  }

  .lsh-footer-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .lsh-footer-col {
    padding-bottom: 6px;
  }

  .lsh-footer-col h2 {
    margin-bottom: 10px;
  }

  .lsh-footer-bottom-inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .lsh-footer-legal {
    justify-content: flex-start;
  }

  .lsh-footer-pills {
    gap: 10px;
  }
}
  .yt {
        position: relative;
        width: 100%;
        max-width: 960px;
        aspect-ratio: 16 / 9;
        background: #000;
        overflow: hidden;
        border-radius: 16px;
        margin: 10px 0;
        padding: 0px 0;
        border-top: 1px solid #f1edf6;
        border-bottom: 1px solid #f1edf6;
    }

    .yt__thumb {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }

    .yt__play {
        position: absolute;
        inset: 0;
        margin: auto;
        width: 84px;
        height: 84px;
        border: 0;
        border-radius: 999px;
        cursor: pointer;
        font-size: 30px;
        line-height: 84px;
        background: rgba(255, 255, 255, .9);
    }

    .yt__play:hover {
        transform: scale(1.03);
    }
/* ── Citazioni Vancouver: inline + popup hover ───────────────
   [N] cliccabile sempre in grassetto, stesso colore del testo
   circostante a meno che non sia esplicitato altrimenti dal
   .ref-cite-group nel rendering di citazioni multiple. */
.ref-cite {
    color: var(--accent, #1f7a6d);
    text-decoration: none !important;
    font-weight: 700;
    cursor: pointer;
    transition: background-color .15s ease;
}
.ref-cite:hover,
.ref-cite:focus-visible {
    background-color: rgba(31, 122, 109, .12);
    border-radius: 3px;
    outline: none;
}
.ref-cite--missing { color: #999; cursor: help; }


.ref-popup {
    position: fixed;                /* viewport-based: ignora parent con transform/overflow */
    top: 0; left: 0;
    z-index: 2147483000;            /* sopra qualunque overlay/header */
    display: none;                  /* mostrato SOLO con .is-visible */
    width: max-content;
    max-width: 440px;
    background: #fff;
    border: 1px solid #d4d6d3;
    border-radius: 8px;
    box-shadow: 0 16px 48px rgba(0, 0, 0, .18);
    font-size: 14px;
    line-height: 1.45;
    color: #222;
}
.ref-popup.is-visible { display: block; }
.ref-popup__head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 8px 12px;
    border-bottom: 1px solid #ecedea;
    background: #f7faf8;
    border-radius: 8px 8px 0 0;
}
.ref-popup__num {
    font-size: 16px; font-weight: bold; letter-spacing: .5px;
    color: var(--accent, #1f7a6d);
    text-transform: uppercase;
}
.ref-popup__close {
    border: 0; background: transparent; cursor: pointer;
    font-size: 22px; line-height: 1; color: #888;
    padding: 0 4px;
}
.ref-popup__close:hover { color: #222; }
.ref-popup__body { padding: 12px 14px; }
.ref-popup__title { font-weight: 600; margin-bottom: 4px; }
.ref-popup__meta  { color: #555; font-size: 13px; margin-bottom: 10px; }
.ref-popup__links {
    display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
}
/* Link nel popup Vancouver: stile outline verde-pdf, sfondo trasparente,
   testo in grassetto. Hover → riempie di verde. */
.ref-popup__links a,
.ref-popup__iframe-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 12px;
    border: 1.5px solid var(--verde-pdf, #2D6A4F);
    border-radius: 6px;
    background: transparent;
    color: var(--verde-pdf, #2D6A4F);
    font-family: inherit;
    font-size: 13px;
    font-weight: 700;          /* grassetto */
    text-decoration: none;
    cursor: pointer;
    transition: background-color .18s ease, color .18s ease;
}
.ref-popup__links a:hover,
.ref-popup__links a:focus-visible,
.ref-popup__iframe-toggle:hover,
.ref-popup__iframe-toggle:focus-visible {
    background: var(--verde-pdf, #2D6A4F);
    color: #fff;
    outline: none;
}
.ref-popup__iframe-wrap {
    padding: 0 14px 14px;
}
.ref-popup__iframe-wrap iframe {
    width: 100%; height: 360px;
    border: 1px solid #ddd; border-radius: 4px;
}
.ref-popup__iframe-note {
    font-size: 12px; color: #888;
    margin: 0 0 8px;
    line-height: 1.4;
}
.btn-video,.video-block{
 /* display:none !important;*/
}
/* ── Box rivista (sidebar) + pulsanti azione "hub" ───────── */
.rivista-box {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 16px;
    margin-top:16px;
}
.rivista-box__cover {
    display: block;
    width: 100%;
    border-radius: 6px;
    overflow: hidden;
    box-shadow: 0 6px 18px rgba(0, 0, 0, .12);
    transition: transform .22s ease, box-shadow .22s ease;
}
.rivista-box__cover:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 24px rgba(0, 0, 0, .16);
}
.rivista-box__cover img {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 3 / 4;
    object-fit: cover;
}
.rivista-box__actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.lsh-action-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 12px 16px;
    background: var(--accent, #1f7a6d);
    color: #fff;
    border: 0;
    border-radius: 6px;
    font-family: inherit;
    font-size: 15px;
    font-weight: 600;
    text-align: left;                       /* <button> default è center → forza left per uniformare con <a> */
    text-decoration: none;
    cursor: pointer;
    transition: background-color .18s ease, transform .18s ease;
    box-shadow: 0 2px 6px rgba(31, 122, 109, .18);
}
.lsh-action-btn:hover,
.lsh-action-btn:focus-visible {
    background: #155f56;
    color: #fff;
    transform: translateY(-1px);
    outline: none;
}
.lsh-action-btn:active { transform: translateY(0); }
.lsh-action-btn svg {
    flex-shrink: 0;
    stroke: currentColor;
}
.lsh-action-btn span { flex: 1; }

/* ── Autori inline + affiliazioni numerate ────────────────── */
.article-authors {
    margin: 8px 0 14px;
}
.article-authors__line {
    margin: 0 0 6px !important;
    font-size: 16px;
    line-height: 1.5;
    color: #1a1a1a;
}
.article-authors__line sup {
    font-size: 0.65em;
    margin-left: 1px;
    font-weight: 600;
    color: #555;
}
/* Nome autore cliccabile → pagina dettaglio. Inline, sobrio.
   Niente underline (richiesta editoriale). */
.article-authors__name-link {
    color: inherit;
    text-decoration: none;
    border-bottom: 0;
    transition: color .15s ease;
}
.article-authors__name-link:hover {
    color: var(--verde-pdf, #2D6A4F);
}
.article-authors__affil {
    list-style: none;
    padding: 0;
    margin: 0;
    counter-reset: affil;
    font-size: 13px;
    line-height: 1.45;
    color: #555;
}
.article-authors__affil li {
    display: grid;
    grid-template-columns: 24px 1fr;
    gap: 6px;
    padding: 2px 0;
}
.article-authors__affil-n {
    font-weight: 600;
    color: #888;
    text-align: left;
}
.article-authors__affil-t { color: #444; }

/* ── Box meta (verde chiaro) — rivista + date + DOI ───────── */
.review {
    background: #ecf6f0;
    border: 1px solid #d6e9dd;
    border-radius: 8px;
    padding: 14px 16px;
    margin: 0 0 18px;
    font-size: 14px;
    line-height: 1.55;
    color: #1f2d28;
}
.review__head {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
    color: var(--accent, #1f7a6d);
}
.review__head svg { width: 18px; height: 18px; flex-shrink: 0; }
.review__journal { font-size: 14px; }
.review__journal strong { color: #1f5238; font-weight: 700; letter-spacing: .2px; }
.review__issue { color: #4a5a55; font-weight: 500; }

.review__dates {
    list-style: none;
    padding: 0;
    margin: 8px 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 4px 16px;
}
.review__dates li { font-size: 13px; color: #2a3a35; }
.review__dates strong { color: #1a2a25; }

.review__scientific {
    margin: 6px 0;
    font-size: 13px;
    color: #2a3a35;
}

.review__doi {
    margin: 8px 0 0;
    padding-top: 8px;
    border-top: 1px dashed #c2dccc;
    font-size: 13px;
}
.review__doi code {
    background: rgba(31, 122, 109, .08);
    padding: 1px 6px;
    border-radius: 3px;
    color: #155f56;
    font-family: ui-monospace, monospace;
    font-size: 12.5px;
}
.lettura-editoriale,.conclusioni-editoriali,.nota-critica {
  text-align: justify;
}
/* ── Badge ORCID inline accanto al nome autore ───────────── */
.orcid-badge {
    display: inline-flex;
    vertical-align: middle;
    margin-left: 3px;
    line-height: 1;
    border-radius: 50%;
    transition: transform .15s ease;
}
.orcid-badge:hover {
    transform: scale(1.15);
}
.orcid-badge svg {
    display: block;
}

/* ── Box "Dati della ricerca" (novita_aggiornamenti) — più compatto ── */
.novita__study {
    margin: 8px 0;
    padding: 8px 0;
}
.novita__study-title { margin: 4px 0 !important; line-height: 1.3; }
.novita__study-meta  { margin: 2px 0 !important; line-height: 1.35; }
.novita__study-doi   { margin: 4px 0 !important; line-height: 1.35; }
.novita__label       { margin-bottom: 4px; display: inline-block; }

/* ── Image lightbox: click su immagine → espansione fullscreen ───────
   Markup richiesto sull'<img> sorgente: niente, basta un container
   .sectionImage o .hero — l'attivazione è universale via JS. */
.lsh-lightbox {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(15, 23, 42, .92);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    cursor: zoom-out;
    animation: lshLightboxIn .18s ease;
}
.lsh-lightbox[hidden] { display: none; }
.lsh-lightbox__img {
    max-width: 96vw;
    max-height: 92vh;
    width: auto;
    height: auto;
    box-shadow: 0 16px 48px rgba(0,0,0,.4);
    border-radius: 6px;
    cursor: zoom-out;
}
.lsh-lightbox__caption {
    position: absolute;
    bottom: 18px;
    left: 50%;
    transform: translateX(-50%);
    max-width: 80vw;
    padding: 10px 16px;
    background: rgba(0,0,0,.7) !important;
    color: #fff;
    font-size: 14px;
    line-height: 1.4;
    border-radius: 6px;
    text-align: center;
}
.lsh-lightbox__close {
    position: absolute;
    top: 18px;
    right: 18px;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(0,0,0,.6);
    color: #fff;
    border: 0;
    font-size: 22px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.lsh-lightbox__close:hover { background: rgba(0,0,0,.85); }

/* Cursor: zoom-in su immagini cliccabili (hero + H2) */
.sectionImage img,
.hero img,
.lsh-art-hero img {
    cursor: zoom-in;
}

@keyframes lshLightboxIn {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* ============================================================
   MOBILE LAYOUT — article fixed bottom toolbar + TOC (Sommario)
   ============================================================
   Comportamento desiderato su smartphone (≤ 768px):
   - "Guarda video articolo" resta nella sua posizione (sotto l'hero)
     a piena larghezza su una propria riga.
   - I 4 pulsanti Sommario · Condividi · Cita · Download PDF
     (raggruppati in .article-actions-toolbar dentro .article-actions-bottom)
     si staccano e diventano una bottom-bar fissata al viewport.
   - Su desktop il wrapper .article-actions-toolbar è display:contents
     così le sue figlie si comportano come dirette del parent —
     il vecchio layout flex resta intatto.
   ============================================================ */

/* Desktop: wrapper "trasparente" — preserva layout flex esistente. */
.article-actions-toolbar {
    display: contents;
}

@media (max-width: 768px) {
    /* ─── Riga video full-width nella sua posizione naturale ─── */
    .article-actions-bottom {
        flex-direction: column;
        flex-wrap: wrap;
        align-items: stretch;
        gap: 10px;
    }
    .article-actions-bottom > .btn-video {
        width: 100%;
        justify-content: center;
    }

    /* ─── Wrapper degli altri 4 pulsanti: bottom-bar fissa ─── */
    .article-actions-toolbar {
        display: flex;
        flex-wrap: nowrap;
        gap: 4px;
        align-items: stretch;
        justify-content: space-between;
        position: fixed;
        left: 0; right: 0; bottom: 0;
        background: #fff;
        padding: 6px 6px;
        border-top: 1px solid #e5e7eb;
        box-shadow: 0 -4px 14px rgba(15, 23, 42, .12);
        z-index: 90;
        /* NIENTE overflow: con overflow:auto i dropdown absolute dei figli
           vengono clippati e non si vedono. I 4 pulsanti devono stare TUTTI
           in viewport — quindi flex:1 + padding compatto. */
        overflow: visible;
        padding-bottom: calc(6px + env(safe-area-inset-bottom, 0px));
    }

    /* "Sommario" prima a sinistra anche se viene dopo nel DOM */
    .article-actions-toolbar > .article-actions-bottom__group--toc {
        order: -1;
    }

    /* 4 pulsanti = ognuno occupa 1/4 della larghezza, senza overflow */
    .article-actions-toolbar > .article-pill,
    .article-actions-toolbar > .article-actions-bottom__group {
        flex: 1 1 0;
        min-width: 0;
    }
    .article-actions-toolbar .article-pill {
        padding: 8px 4px;
        font-size: 12px;
        gap: 4px;
        white-space: nowrap;
        justify-content: center;
        overflow: hidden;
        text-overflow: ellipsis;
        width: 100%;
    }
    .article-actions-toolbar .article-pill span {
        font-size: 12px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        min-width: 0;
    }
    /* Schermi molto stretti (≤ 360px): solo icona, niente testo. Riduce
       il rischio che il PDF resti tagliato sui device più piccoli. */
    @media (max-width: 360px) {
        .article-actions-toolbar .article-pill span {
            display: none;
        }
    }

    /* Padding bottom al body: spazio per non coprire footer */
    body.page-article {
        padding-bottom: calc(64px + env(safe-area-inset-bottom, 0px));
    }
}

/* ─── TOC dropdown (Sommario) ──────────────────────────────────
   Stile "IN QUESTO ARTICOLO": header verde scuro, lista numerata H2
   con eventuali H3 sotto-numerati (N.M) indentati. */
.article-toc-menu {
    padding: 0 !important;            /* il padding sta dentro head+body */
    overflow: hidden;                  /* clip dell'header al border-radius */
    min-width: 260px;
}
.article-toc-head {
    background: #2e5d4e;
    color: #fff;
    font-weight: 800;
    text-align: center;
    letter-spacing: .04em;
    padding: 14px 16px;
    font-size: 14px;
    text-transform: uppercase;
}
.article-toc-body {
    background: #fff;
    padding: 6px 0;
    overflow-y: auto;
    max-height: calc(50vh - 50px);     /* margine per l'header */
}
.article-toc-empty {
    padding: 18px;
    color: #9ca3af;
    font-style: italic;
    text-align: center;
    font-size: 13px;
}
/* Item: titolo H2 con numerazione già inclusa nel testo (gestita
   dallo script editoriale upstream). Niente colonna numero separata. */
.article-toc-item {
    display: block;
    padding: 10px 16px;
    line-height: 1.4;
    font-size: 14px;
    color: #103226;
    font-weight: 700;
    text-decoration: none;
    transition: background .12s ease;
    word-break: break-word;
}
.article-toc-item:hover,
.article-toc-item:focus-visible {
    background: #f3f6f4;
    outline: none;
}
/* Sub-item (H3): indentato + meno bold + colore lievemente più chiaro */
.article-toc-item--sub {
    padding-left: 36px;
    font-size: 13px;
    font-weight: 500;
    color: #374151;
}

@media (max-width: 768px) {
    /* Su mobile, dropdown ancorati al VIEWPORT (non al trigger): position:
       fixed, allineati sopra la barra in basso, larghi quanto lo schermo.
       Position:absolute dentro un parent fixed con overflow controllato è
       fragile e veniva clippato su schermi stretti. */
    .article-actions-toolbar .article-toc-menu,
    .article-actions-toolbar .article-share-menu {
        position: fixed;
        bottom: calc(60px + env(safe-area-inset-bottom, 0px));
        left: 6px;
        right: 6px;
        width: auto;
        min-width: 0;
        max-width: none;
        max-height: 50vh;
        background: #fff;
        border: 1px solid #e6e8ea;
        border-radius: 12px;
        box-shadow: 0 -10px 28px rgba(15, 23, 42, .18);
        padding: 6px;
        z-index: 95;
        overflow-y: auto;
    }
    .sidebar-all {
        display: none !important;
    }
}

/* ── Spaziatura titoli → contenuto sottostante (richiesta cliente) ──────────
   Distanzia dal testo gli H2 (Quadro comparativo, Sintesi delle evidenze,
   Lettura editoriale delle evidenze, Nota critica, Riferimenti… e in genere
   TUTTI gli H2) usando la STESSA distanza degli H3. Esclude l'header verde
   "In breve" (.brief__head). Gestibile da un solo punto via --lsh-heading-gap. */
.page-article .wrap h2:not(.brief__head),
.page-article .wrap .h3-block > h3 {
  margin-bottom: var(--lsh-heading-gap);
}
/* ── Nota editoriale FISSA in coda all'articolo (editorial_note.php) ──
   Box discreto con accent verde a sinistra. Stessa famiglia visiva del
   box .review (metadati). Testo giustificato, link "Storia articolo". */
.editorial-note {
  grid-column: 1 / -1;
  margin: 26px 0 8px;
  padding: 16px 18px;
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent, #1f7a6d);
  border-radius: var(--radius);
  background: var(--bg-sectionbox);
  color: #4a4752;
  font-size: 13.5px;
  line-height: 1.5;
  text-align: justify;
}
.editorial-note__title {
  margin: 0 0 8px !important;
  font-size: 15px;
  color: var(--accent, #1f7a6d);
}
.editorial-note p { margin: 0 0 8px; }
.editorial-note p:last-child { margin-bottom: 0; }
.editorial-note__link {
  color: var(--accent, #1f7a6d);
  text-decoration: underline;
  font-weight: 600;
  cursor: pointer;
}
.editorial-note__link:hover { text-decoration: none; }
