/*
 * pl-privacy-news single template — version-scoped via .pl-pn-single body class.
 * Source: mockup c:/tmp/preview-provvedimento.html (user-approved).
 */

.pl-pn-single {
  --ink-900: #1a2426;
  --ink-700: #364448;
  --ink-500: #5b6b6f;
  --ink-300: #9aa7ab;
  --ink-100: #e5ebec;
  --bg: #f7f9f9;
  --card: #ffffff;
  --teal-500: #288890;
  --teal-50: #eef7f7;
  --border: #e1e7e8;
  --grav-fg: #ca8a04;
  --grav-bg: #fef9c3;
}

.pl-pn-single * { box-sizing: border-box; }

.pl-pn-single {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  line-height: 1.65;
  color: var(--ink-900);
  background: var(--bg);
  margin: 0;
  font-size: 17px;
}

.pl-pn-single .container { max-width: 1200px; margin: 0 auto; padding: 32px 24px 80px; }

.pl-pn-single .breadcrumb { font-size: 14px; color: var(--ink-500); margin-bottom: 24px; }
.pl-pn-single .breadcrumb a { color: var(--teal-500); text-decoration: none; }

.pl-pn-single .chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.pl-pn-single .chip { display: inline-flex; align-items: center; padding: 4px 12px; border-radius: 999px;
                      font-size: 12px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
                      background: var(--ink-100); color: var(--ink-700); }
.pl-pn-single .chip[data-gravita] { background: var(--grav-bg); color: var(--grav-fg); }
.pl-pn-single .chip.tipologia { background: var(--teal-50); color: var(--teal-500); }
/* Tematica = argomento evidenziato; Tag = parole chiave più discrete (lowercase). */
.pl-pn-single .chip.tematica { background: var(--teal-500); color: #fff; }
.pl-pn-single .chip.tag { background: transparent; border: 1px solid var(--border);
                          color: var(--ink-500); text-transform: none; letter-spacing: 0; font-weight: 500; }

.pl-pn-single h1 { font-size: 2.1rem; line-height: 1.25; margin: 0 0 12px; font-weight: 700; letter-spacing: -.01em; }

.pl-pn-single .byline { color: var(--ink-500); font-size: 15px; margin-bottom: 18px; }
.pl-pn-single .byline strong { color: var(--ink-900); font-weight: 600; }

.pl-pn-single .pl-source-cta { margin: 0 0 36px; }
.pl-pn-single .pl-pn-btn { display: inline-flex; align-items: center; gap: 8px;
  background: var(--teal-500); color: #fff; text-decoration: none;
  font-weight: 600; font-size: 15px; line-height: 1; padding: 13px 22px;
  border-radius: 10px; transition: background .15s ease; }
.pl-pn-single .pl-pn-btn:hover { background: #1f6f76; }
.pl-pn-single .pl-pn-btn:focus-visible { outline: 2px solid var(--teal-500); outline-offset: 2px; }

/* minmax(0,1fr): senza, il min-content della colonna (es. tabella articoli con
   nowrap) può superare il viewport su mobile e il testo esce dallo schermo. */
.pl-pn-single .layout { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 48px; align-items: start; }
@media (max-width: 900px) { .pl-pn-single .layout { grid-template-columns: minmax(0, 1fr); } }
.pl-pn-single .layout article { min-width: 0; overflow-wrap: break-word; }

.pl-pn-single article h2 { font-size: 1.5rem; margin: 40px 0 14px; padding-bottom: 8px;
                           border-bottom: 1px solid var(--border); font-weight: 700; }
.pl-pn-single article h2:first-child { margin-top: 0; }
.pl-pn-single article h3 { font-size: 1.1rem; margin: 24px 0 8px; font-weight: 600; color: var(--ink-700); }
.pl-pn-single article p { margin: 0 0 14px; }
.pl-pn-single article ul.actions { list-style: none; padding-left: 0; margin: 0 0 14px; }
.pl-pn-single article ul.actions li { padding: 8px 0 8px 32px; position: relative; }
.pl-pn-single article ul.actions li::before { position: absolute; left: 0; top: 8px;
                                               font-weight: 700; }
.pl-pn-single article ul.do li::before { content: "✓"; color: #16a34a; }
.pl-pn-single article ul.dont li::before { content: "✗"; color: #dc2626; }
.pl-pn-single article ul.ask li::before { content: "?"; color: var(--teal-500); }

.pl-pn-single .ratio-box { background: var(--teal-50); border-left: 4px solid var(--teal-500);
                           padding: 16px 20px; border-radius: 6px; margin: 16px 0;
                           font-style: italic; color: var(--ink-700); }
.pl-pn-single .ratio-box strong { font-style: normal; color: var(--teal-500); font-size: 12px;
                                  text-transform: uppercase; letter-spacing: .08em; display: block;
                                  margin-bottom: 6px; }

.pl-pn-single table.articoli { width: 100%; border-collapse: collapse; margin: 12px 0 14px;
                               font-size: 14px; }
.pl-pn-single table.articoli th { text-align: left; padding: 10px 12px; background: var(--ink-100);
                                  color: var(--ink-700); font-size: 12px; text-transform: uppercase;
                                  letter-spacing: .04em; }
.pl-pn-single table.articoli td { padding: 10px 12px; border-bottom: 1px solid var(--border); vertical-align: top; }
.pl-pn-single table.articoli td.art-code { font-weight: 600; white-space: nowrap; color: var(--ink-900); }
.pl-pn-single table.articoli .rilevanza { display: inline-block; padding: 2px 8px; border-radius: 999px;
                                          font-size: 11px; text-transform: uppercase; font-weight: 600; }
/* Su schermi stretti la tabella scorre orizzontalmente invece di sfondare il layout. */
@media (max-width: 700px) {
  .pl-pn-single table.articoli { display: block; overflow-x: auto; }
}
.pl-pn-single .ril-alta { background: #fee2e2; color: #dc2626; }
.pl-pn-single .ril-media { background: #fef3c7; color: #ca8a04; }
.pl-pn-single .ril-bassa { background: #dcfce7; color: #16a34a; }

.pl-pn-single .related-card { display: flex; gap: 12px; padding: 12px 0;
                              border-bottom: 1px solid var(--border); }
.pl-pn-single .related-card:last-child { border-bottom: 0; }
.pl-pn-single .related-card .num { color: var(--teal-500); font-weight: 600; font-size: 14px; min-width: 80px; }

.pl-pn-single aside.sidebar { display: flex; flex-direction: column; gap: 16px;
                              position: sticky; top: 32px; }
.pl-pn-single .side-card { background: var(--card); border: 1px solid var(--border); border-radius: 12px;
                           padding: 20px; }
.pl-pn-single .side-card h4 { margin: 0 0 14px; font-size: 12px; text-transform: uppercase;
                              letter-spacing: .08em; color: var(--ink-500); font-weight: 700; }
.pl-pn-single .side-card dl { margin: 0; display: grid; grid-template-columns: auto 1fr;
                              gap: 8px 12px; font-size: 14px; }
.pl-pn-single .side-card dt { color: var(--ink-500); }
.pl-pn-single .side-card dd { margin: 0; font-weight: 500; }
.pl-pn-single .side-card.importo .amount { font-size: 1.8rem; font-weight: 700; color: var(--grav-fg);
                                           line-height: 1.1; margin-bottom: 6px; }
.pl-pn-single .side-card.importo .tipo { font-size: 13px; color: var(--ink-500); }
.pl-pn-single .side-card ul.bullets { list-style: none; padding: 0; margin: 0; font-size: 14px; }
.pl-pn-single .side-card ul.bullets li { padding: 6px 0 6px 22px; position: relative; }
.pl-pn-single .side-card ul.bullets li::before { position: absolute; left: 0; top: 8px; font-size: 12px; }
.pl-pn-single .side-card ul.attenuanti li::before { content: "↓"; color: #16a34a; font-weight: 700; }
.pl-pn-single .side-card ul.aggravanti li::before { content: "↑"; color: #dc2626; font-weight: 700; }
.pl-pn-single .side-card ul.parti li::before { content: "•"; color: var(--ink-500); }
.pl-pn-single .side-card .taglist { display: flex; flex-wrap: wrap; gap: 6px; }
.pl-pn-single .side-card .taglist span { background: var(--ink-100); color: var(--ink-700);
                                         padding: 4px 10px; border-radius: 999px; font-size: 12px; }
.pl-pn-single .side-card .taglist.tematiche span { background: var(--teal-50); color: var(--teal-500); }

.pl-pn-single .source-link { display: inline-flex; align-items: center; gap: 8px;
                             color: var(--teal-500); text-decoration: none; font-weight: 600;
                             border-bottom: 1px solid currentColor; padding-bottom: 2px; margin-top: 24px; }

.pl-pn-single .footer-note { margin-top: 60px; padding: 20px; background: var(--card);
                             border: 1px dashed var(--ink-300); border-radius: 8px;
                             font-size: 13px; color: var(--ink-500); }

/* ── Novità: stesso layout ricco a 2 colonne dei provvedimenti, box Fonte in ──
   evidenza sopra al layout, corpo articolo GIUSTIFICATO (richiesta utente). ── */
.pl-pn-novita .pl-source-box { display: flex; align-items: baseline; flex-wrap: wrap; gap: 8px 12px;
                               background: var(--teal-50); border-left: 4px solid var(--teal-500);
                               border-radius: 8px; padding: 14px 18px; margin: 0 0 32px; }
.pl-pn-novita .pl-source-label { font-size: 12px; font-weight: 700; letter-spacing: .08em;
                                 text-transform: uppercase; color: var(--teal-500); }
.pl-pn-novita .pl-source-link { color: var(--ink-900); font-weight: 600; text-decoration: none;
                                border-bottom: 1px solid var(--teal-500); }
.pl-pn-novita .pl-source-link:hover { color: var(--teal-500); }
.pl-pn-novita .pl-source-name { color: var(--ink-700); font-weight: 600; }
.pl-pn-novita .layout article { text-align: justify; }
.pl-pn-novita .layout article li { text-align: justify; }
.pl-pn-novita .pl-source-cta { margin-top: 32px; }
.pl-pn-novita .pl-pn-tags { margin: 32px 0 0; }
