/* Open·Parlamento — stile delle pagine statiche del corpus (norme/articoli).
   Stand-alone (niente dipendenze dal bundle SPA): caricato via <link>. */
:root {
  --ink: #0b0d11; --ink-2: #11141b; --ink-3: #161a23;
  --parchment: #ece6d8; --parchment-2: #c8c2b3; --muted: #8a8678; --faint: #5f5c54;
  --brass: #c9a24b; --brass-2: #e0bd6a; --brass-dim: #6e5a2c;
  --verde: #5aa385; --rosso: #c65a48; --azzurro: #6592b8; --viola: #8a86d6;
  --line: rgba(236,230,216,0.10); --line-2: rgba(236,230,216,0.16);
  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body: 'Spectral', Georgia, serif;
  --font-mono: 'IBM Plex Mono', ui-monospace, monospace;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; background: var(--ink); color: var(--parchment);
  font-family: var(--font-body); font-size: 17px; line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--brass-2); text-decoration: none; }
a:hover { text-decoration: underline; }

.wrap { max-width: 820px; margin: 0 auto; padding: 0 24px 96px; }

/* header */
.c-header {
  position: sticky; top: 0; z-index: 5;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 14px 24px; border-bottom: 1px solid var(--line-2);
  background: var(--ink-glass, rgba(15,18,25,0.82)); backdrop-filter: blur(8px);
}
.c-brand { display: flex; align-items: center; gap: 12px; color: inherit; }
.c-seal {
  width: 30px; height: 30px; border-radius: 50%; flex: none; position: relative;
  border: 1.5px solid var(--brass);
  background: radial-gradient(circle at 50% 40%, rgba(201,162,75,0.25), transparent 70%);
}
.c-seal::before { content: "§"; position: absolute; inset: 0; display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 600; color: var(--brass-2); font-size: 16px; }
.c-wordmark { font-family: var(--font-display); font-weight: 600; font-size: 19px; letter-spacing: .02em; }
.c-wordmark b { color: var(--brass-2); font-weight: 900; }
.c-nav { display: flex; gap: 16px; font-family: var(--font-mono); font-size: 12px; letter-spacing: .06em; }
.c-nav a { color: var(--muted); }
.c-nav a:hover { color: var(--brass-2); text-decoration: none; }

/* breadcrumb */
.crumbs { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .04em;
  color: var(--faint); margin: 26px 0 8px; }
.crumbs a { color: var(--muted); }
.crumbs span { color: var(--faint); }

/* headings */
.kicker { font-family: var(--font-mono); font-size: 12px; letter-spacing: .26em;
  text-transform: uppercase; color: var(--brass); margin-bottom: 10px; }
h1 { font-family: var(--font-display); font-weight: 500; line-height: 1.12;
  font-size: 34px; margin: 6px 0 8px; letter-spacing: .01em; }
.subtitle { color: var(--parchment-2); font-size: 18px; margin: 0 0 18px; }
h2 { font-family: var(--font-display); font-weight: 500; font-size: 22px;
  margin: 38px 0 12px; padding-bottom: 6px; border-bottom: 1px solid var(--line); }

/* meta chips */
.meta { display: flex; flex-wrap: wrap; gap: 8px; margin: 16px 0 8px; }
.chip { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .03em;
  color: var(--parchment-2); background: var(--ink-2); border: 1px solid var(--line-2);
  border-radius: 999px; padding: 4px 11px; }
.chip b { color: var(--brass-2); font-weight: 600; }
.chip.eli { color: var(--muted); }

/* verbatim legal text */
.lex { white-space: pre-wrap; font-family: var(--font-body); font-size: 17.5px; line-height: 1.78;
  color: var(--parchment); background: var(--ink-2); border: 1px solid var(--line);
  border-left: 3px solid var(--brass-dim); border-radius: 10px; padding: 22px 24px; margin: 14px 0; }

/* relations */
.rel-group { margin: 14px 0; }
.rel-type { font-family: var(--font-mono); font-size: 12px; letter-spacing: .08em; text-transform: uppercase;
  color: var(--brass-2); margin-bottom: 6px; }
.rel-list { list-style: none; margin: 0; padding: 0; }
.rel-list li { padding: 7px 0; border-bottom: 1px solid var(--line); }
.rel-list .ev { display: block; color: var(--faint); font-size: 13.5px; font-family: var(--font-mono);
  line-height: 1.5; margin-top: 3px; }
.tag { font-family: var(--font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase;
  color: var(--verde); border: 1px solid rgba(90,163,133,.4); border-radius: 4px; padding: 1px 6px; margin-left: 8px; }

/* article list */
.arts { columns: 2; column-gap: 28px; margin: 12px 0; }
.arts a { display: block; padding: 5px 0; break-inside: avoid; color: var(--parchment-2); }
.arts a:hover { color: var(--brass-2); }
.arts .n { font-family: var(--font-mono); color: var(--brass); margin-right: 8px; }

/* norme index */
.norme-grid { display: grid; gap: 12px; margin: 18px 0; }
.norma-card { display: block; padding: 16px 18px; border: 1px solid var(--line-2); border-radius: 12px;
  background: var(--ink-2); color: inherit; }
.norma-card:hover { border-color: var(--brass-dim); text-decoration: none; }
.norma-card h3 { font-family: var(--font-display); font-weight: 500; font-size: 18px; margin: 0 0 4px; color: var(--parchment); }
.norma-card p { margin: 0; color: var(--muted); font-size: 14px; }
.norma-card .nm { font-family: var(--font-mono); font-size: 11px; color: var(--brass-2); letter-spacing: .04em; }

/* footer + source */
.source { margin-top: 26px; font-size: 14.5px; color: var(--muted); }
.disclaimer { margin-top: 14px; font-family: var(--font-mono); font-size: 12px; color: var(--faint); }
.c-foot { border-top: 1px solid var(--line-2); margin-top: 40px; padding: 26px 24px;
  text-align: center; color: var(--muted); font-family: var(--font-mono); font-size: 12px; letter-spacing: .04em; }
.c-foot a { color: var(--brass-2); }
.prevnext { display: flex; justify-content: space-between; gap: 16px; margin-top: 30px;
  font-family: var(--font-mono); font-size: 13px; }

@media (max-width: 640px) {
  h1 { font-size: 27px; } .arts { columns: 1; } body { font-size: 16px; }
}
