
    /* ==========================================================================
   Referendum Results — IlFattoQuotidiano
   ========================================================================== */

    :root {
      --color-bg: #7F8589;
      --color-surface: #ffffff;
      --color-text: #262424;
      --color-text-muted: #5C5C5C;
      --color-border: #E5EBEF;
      --color-accent: #a83946;
      --color-accent-hover: #960f20;

      --color-link: #a83946;
      --color-heading-bg: #262424;

      --radius: 2px;
      --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.06);
      --shadow-md: 0 2px 8px rgba(0, 0, 0, 0.08);
    }

    /* ── Base / Reset ───────────────────────────────────────────────────────── */

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

    body {
      font-size: 16px;
      line-height: 1.5;
      color: var(--color-text);
      background: var(--color-bg);
      -webkit-font-smoothing: antialiased;
    }

    a {
      color: var(--color-link);
      text-decoration: none;
    }

    a:hover {
      text-decoration: underline;
    }

    /* ── Main Grid ──────────────────────────────────────────────────────────── */

    .main-grid {
      max-width: 1120px;
      margin: 0 auto;
      font-family: 'TT Norms',sans-serif;
      padding: 0 20px;
    }

    /* ── Breadcrumb Header ──────────────────────────────────────────────────── */

    .header-elezioni {
      padding: 20px 0 12px;
      border-bottom: 2px solid var(--color-accent);
      margin-bottom: 0;
    }

    .header-elezioni h2 {

      font-size: 1.05rem;
      font-weight: 400;
      color: var(--color-text-muted);
      letter-spacing: 0.01em;
    }

    .header-elezioni h2 a {
      color: var(--color-link);
      font-weight: 600;
      transition: color 0.15s ease;
    }

    .header-elezioni h2 a:hover {
      color: var(--color-accent-hover);
    }

    /* ── Elections Menu (placeholder) ───────────────────────────────────────── */

    .elezioni-menu {
      min-height: 0;
    }

    /* ── Info Wrapper (main content + aside) ────────────────────────────────── */

    .elezioni-info-wrapper {
      display: grid;
      grid-template-columns: 1fr 300px;
      gap: 32px;
      padding: 24px 0 48px;
      align-items: start;
    }

    .left-column {
      min-width: 0;
    }

    /* ── Stats Comune — Horizontal location heading ─────────────────────────── */

    .stats-comune {
      background: var(--color-heading-bg);
      color: #ffffff;
      padding: 16px 24px;
      border-radius: var(--radius) var(--radius) 0 0;
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      gap: 8px 24px;
    }

    .comune-title {

      font-size: 1.6rem;
      font-weight: 700;
      line-height: 1.2;
      margin: 0;
      order: -1;
      color: #ffffff;
    }

    .comune-title small {
      font-size: 0.75em;
      font-weight: 400;
      opacity: 0.7;
    }

    .comune-affluenza {
      font-size: 0.95rem;
      font-weight: 600;
      background: var(--color-bg);
      padding: 3px 12px;
      border-radius: 50px;
      white-space: nowrap;
    }

    .comune-sezioni {
      font-size: 0.85rem;
      opacity: 0.75;
      white-space: nowrap;
    }

    /* ── Stats Seggi — Horizontal data strip ────────────────────────────────── */

    .stats-seggi {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-top: none;
      border-radius: 0 0 var(--radius) var(--radius);
      padding: 20px 24px;
      box-shadow: var(--shadow-sm);
      margin-bottom: 24px;
    }

    .stats-seggi .last-updated-link {
      font-size: 0.8rem;
      color: var(--color-text-muted);
      margin-bottom: 14px;
    }

    /* stat grid — horizontal row of key figures */
    .jgrid {
      display: flex;
      flex-wrap: wrap;
      gap: 0;
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
      overflow: hidden;
      margin-bottom: 16px;
    }

    .jgrid .stat {
      flex: 1 1 0;
      min-width: 120px;
      padding: 12px 16px;
      font-size: 0.9rem;
      color: var(--color-text-muted);
      border-right: 1px solid var(--color-border);
      text-align: center;
    }

    .jgrid .stat:last-child {
      border-right: none;
    }

    .jgrid .stat strong {
      display: block;
      font-size: 1.35rem;
      font-weight: 700;
      color: var(--color-text);
      line-height: 1.2;
      margin-bottom: 2px;
    }

    .consiglieri {
      font-size: 0.92rem;
      margin-bottom: 6px;
    }

    .consiglieri span {
      font-weight: 600;
    }

    .fonte {
      font-size: 0.8rem;
      color: var(--color-text-muted);
      font-style: italic;
      margin-bottom: 14px;
    }

    /* ── Buttons ────────────────────────────────────────────────────────────── */

    .btn {
      display: inline-block;
      padding: 8px 22px;

      font-size: 0.85rem;
      font-weight: 600;
      border-radius: var(--radius);
      border: none;
      cursor: pointer;
      text-align: center;
      transition: background 0.15s ease, transform 0.1s ease;
      text-transform: uppercase;
    }

    .btn-update {
      background: var(--color-accent);
      color: #fff;
    }

    .btn-update:hover {
      background: var(--color-accent-hover);
      text-decoration: none;
    }

    .btn-update:active {
      transform: scale(0.97);
    }

    /* ── Results / Candidato tables ─────────────────────────────────────────── */

    .stats-figures {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
      margin-bottom: 24px;
    }

    .stats-candidato {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
      overflow: hidden;
      box-shadow: var(--shadow-sm);
      transition: box-shadow 0.2s ease;
    }

    .stats-candidato:hover {
      box-shadow: var(--shadow-md);
    }

    .table-candidato {
      width: 100%;
      border-collapse: collapse;
    }

    .first-row-elezioni {
      display: flex;
      align-items: center;
      padding: 0;
    }

    .first-row-elezioni th {
      font-weight: 400;
      text-align: left;
      padding: 16px 18px;
    }

    /* Sì / No label column */
    .col-candidato {
      flex: 0 0 auto;
      border-right: 1px solid var(--color-border);
    }

    .col-candidato h4 {

      font-size: 1.5rem;
      font-weight: 700;
      margin: 0;
      line-height: 1;
    }

    /* colour-code Sì and No */
    .stats-candidato:first-child .col-candidato h4 {
      color: var(--color-text);
    }

    .stats-candidato:last-child .col-candidato h4 {
      color: var(--color-text);
    }

    /* accent bar on top of each card */
    .stats-candidato:first-child {
      border-top: 3px solid var(--color-border);
    }

    .stats-candidato:last-child {
      border-top: 3px solid var(--color-border);
    }

    .col-tot-voti {
      flex: 1 1 auto;
      font-size: 1.05rem;
      font-weight: 600 !important;
      color: var(--color-text);
    }

    .col-tot-percent {
      flex: 0 0 auto;
      font-size: 1.15rem;
      font-weight: 700 !important;
      color: var(--color-text);
      text-align: right !important;
    }

    /* ── Bottom Update ──────────────────────────────────────────────────────── */

    .last-updated.bottom-update {
      display: flex;
      align-items: center;
      gap: 16px;
      padding-top: 8px;
      border-top: 1px solid var(--color-border);
    }

    .last-updated.bottom-update p {
      font-size: 0.8rem;
      color: var(--color-text-muted);
    }

    /* ── Aside / Adv ────────────────────────────────────────────────────────── */

    aside {
      position: sticky;
      top: 20px;
    }

    .ifq-adv-flux {
      min-height: 250px;
      background: var(--color-surface);
      border: 1px dashed var(--color-border);
      border-radius: var(--radius);
      display: flex;
      align-items: center;
      justify-content: center;
    }

    /* ── Side Category Menu (Regioni / Navigation) ─────────────────────────── */

    .side-category-menu {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
      box-shadow: var(--shadow-sm);
      margin-bottom: 24px;
      overflow: hidden;
    }

    .side-category-menu-header {
      background: var(--color-heading-bg);
      padding: 12px 20px;
    }

    .side-category-menu-header h2 {
      color: #ffffff;
      font-size: 1rem;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.03em;
      margin: 0;
    }

    /* main list */
    .side-category-menu-list {
      list-style: none;
      margin: 0;
      padding: 0;
    }

    .side-category-menu-list>li {
      border-bottom: 1px solid var(--color-border);
    }

    .side-category-menu-list>li:last-child {
      border-bottom: none;
    }

    /* top-level links (Italia, Italia+Estero, Estero) */
    .side-category-menu-list>li>a.type {
      display: block;
      padding: 10px 20px;
      font-size: 0.95rem;
      font-weight: 700;
      color: var(--color-text);
      transition: background 0.12s ease;
    }

    .side-category-menu-list>li>a.type:hover {
      background: rgba(0, 0, 0, 0.03);
      text-decoration: none;
    }

    /* sub-menu regioni */
    .sub-menu-comuni {
      list-style: none;
      margin: 0;
      padding: 0;
    }

    .side-category-menu-list-striped .sub-menu-comuni>li {
      display: flex;
      align-items: baseline;
      flex-wrap: wrap;
      gap: 0 6px;
      padding: 8px 20px 8px 32px;
      border-top: 1px solid var(--color-border);
      font-size: 0.88rem;
      transition: background 0.12s ease;
    }

    .side-category-menu-list-striped .sub-menu-comuni>li:nth-child(even) {
      background: rgba(0, 0, 0, 0.015);
    }

    .side-category-menu-list-striped .sub-menu-comuni>li:hover {
      background: rgba(0, 0, 0, 0.04);
    }

    /* region name link */
    .sub-menu-comuni>li>a {
      color: var(--color-text);
      font-weight: 600;
      text-transform: uppercase;
      font-size: 0.84rem;
      letter-spacing: 0.02em;
    }

    .sub-menu-comuni>li>a:hover {
      color: var(--color-link);
      text-decoration: none;
    }

    /* province count */
    .sub-menu-comuni>li>a small {
      font-weight: 400;
      color: var(--color-text-muted);
      text-transform: none;
      letter-spacing: 0;
    }

    /* doubleStroke utility (header decoration) */
    .doubleStroke.top {
      border-top: 3px double rgba(255, 255, 255, 0.25);
    }

    /* circoscrizione variant — optional tweak if needed */
    .side-category-menu.circoscrizione {
      /* same base style, available for overrides */
    }

    /* ── Responsive ─────────────────────────────────────────────────────────── */

    @media (max-width: 900px) {
      .elezioni-info-wrapper {
        grid-template-columns: 1fr;
      }

      aside {
        position: static;
      }
    }

    @media (max-width: 680px) {
      .stats-comune {
        flex-direction: column;
        gap: 6px;
        padding: 14px 18px;
      }

      .comune-title {
        font-size: 1.3rem;
      }

      .jgrid {
        flex-direction: column;
      }

      .jgrid .stat {
        border-right: none;
        border-bottom: 1px solid var(--color-border);
        text-align: left;
        display: flex;
        align-items: baseline;
        gap: 8px;
      }

      .jgrid .stat:last-child {
        border-bottom: none;
      }

      .jgrid .stat strong {
        display: inline;
        font-size: 1.1rem;
      }

      .stats-figures {
        grid-template-columns: 1fr;
      }

      .first-row-elezioni {
        flex-wrap: wrap;
      }

      .last-updated.bottom-update {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
      }
    }