/* =====================================================================
   Riforma 2026 — Mini Design System (cross-page)
   Single source of truth per i componenti che vivono in più pagine:
   alert-bar, site-nav, pill, chip.
   Linkato da: index.html, comparatore.html, mappa.html
   ===================================================================== */

/* Self-hosted webfonts (Latin subset, ~280KB totali per tutti i pesi).
   Stessa strategia di codici.law.camp: woff2 servito dallo stesso origin
   con `font-display: swap`. Niente Google Fonts → niente DNS + TLS extra,
   FOUT minimo. Per i due pesi above-the-fold (numeri hero + H1 italico)
   index.html aggiunge `<link rel="preload">` così l'hero arriva senza flash. */
@font-face { font-family: 'Fira Sans'; font-style: normal; font-weight: 400;
  font-display: swap; src: local('Fira Sans Regular'), local('FiraSans-Regular'),
  url('./fonts/FiraSans-400.woff2') format('woff2'); }
@font-face { font-family: 'Fira Sans'; font-style: normal; font-weight: 500;
  font-display: swap; src: local('Fira Sans Medium'), local('FiraSans-Medium'),
  url('./fonts/FiraSans-500.woff2') format('woff2'); }
@font-face { font-family: 'Fira Sans'; font-style: normal; font-weight: 600;
  font-display: swap; src: local('Fira Sans SemiBold'), local('FiraSans-SemiBold'),
  url('./fonts/FiraSans-600.woff2') format('woff2'); }
@font-face { font-family: 'Fira Sans'; font-style: normal; font-weight: 700;
  font-display: swap; src: local('Fira Sans Bold'), local('FiraSans-Bold'),
  url('./fonts/FiraSans-700.woff2') format('woff2'); }
@font-face { font-family: 'Fira Sans'; font-style: normal; font-weight: 900;
  font-display: swap; src: local('Fira Sans Black'), local('FiraSans-Black'),
  url('./fonts/FiraSans-900.woff2') format('woff2'); }
@font-face { font-family: 'Noto Serif'; font-style: normal; font-weight: 400;
  font-display: swap; src: local('Noto Serif'), local('NotoSerif-Regular'),
  url('./fonts/NotoSerif-400.woff2') format('woff2'); }
@font-face { font-family: 'Noto Serif'; font-style: italic; font-weight: 400;
  font-display: swap; src: local('Noto Serif Italic'), local('NotoSerif-Italic'),
  url('./fonts/NotoSerif-400-italic.woff2') format('woff2'); }
@font-face { font-family: 'Noto Serif'; font-style: normal; font-weight: 700;
  font-display: swap; src: local('Noto Serif Bold'), local('NotoSerif-Bold'),
  url('./fonts/NotoSerif-700.woff2') format('woff2'); }
@font-face { font-family: 'Noto Serif'; font-style: italic; font-weight: 700;
  font-display: swap; src: local('Noto Serif Bold Italic'), local('NotoSerif-BoldItalic'),
  url('./fonts/NotoSerif-700-italic.woff2') format('woff2'); }
/* IBM Plex Serif: usato come body del comparatore diff (.col-body / .ref-paren).
   Scelta su Georgia per: lining figures default (numeri di articolo/comma più
   uniformi nel flusso prosa legale), x-height più alta a 15px (leggibilità sotto
   16px superiore al system Georgia), affinità visiva con Fira Sans (entrambi
   sono famiglie contemporanee designed-for-screen). Latin subset 19+20KB. */
@font-face { font-family: 'IBM Plex Serif'; font-style: normal; font-weight: 400;
  font-display: swap; src: local('IBM Plex Serif'), local('IBMPlexSerif'),
  url('./fonts/IBMPlexSerif-400.woff2') format('woff2'); }
@font-face { font-family: 'IBM Plex Serif'; font-style: normal; font-weight: 700;
  font-display: swap; src: local('IBM Plex Serif Bold'), local('IBMPlexSerif-Bold'),
  url('./fonts/IBMPlexSerif-700.woff2') format('woff2'); }

/* Body-level defaults che valgono per TUTTE le pagine che linkano shared.css
   (index, comparatore, mappa). Le pagine standalone hanno il loro `body
   { font-family: ... !important }` che vince sul nostro: serve solo come
   fallback se quell'override viene rimosso. font-smoothing invece non è
   sovrascritto da nessuno e produce rendering coerente sui display retina. */
body {
  font-family: var(--font-sans);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

:root {
  /* ========== Brand & Surfaces ========== */
  --color-red-500:    #C3443F;
  --color-red-600:    #A33632;     /* hover */
  --color-red-400:    #D8605B;     /* soft */
  --color-blue-400:   #0E87CA;
  --color-blue-500:   #0C6498;
  /* Accent navy (riusato da codici.law.camp). Riservato per usi futuri,
     attualmente non in uso. */
  --color-accent:     #29417C;
  /* Background della banda alert: rosso brand. Scelta deliberata per
     distinguere visivamente questa pagina (riforma-2026) dal sito principale
     codici.law.camp, dove la stessa banda è invece navy. */
  --color-alert-bg:   var(--color-red-500);
  --color-nero-900:        #1A1D1F;
  --color-ink:       #262626;
  --color-nero-700: #374151;
  --color-muted:     #7C8492;
  --color-nero-200:    #E5E7EA;
  --color-white:      #FFFFFF;

  /* ========== Stati semantici ========== */
  --color-mod-fg:     #854D0E;  --color-mod-bg: #FAF6E3;  --color-mod-border: #EAE2B0;
  --color-mod-bold:   #A16207;  /* uso prominente (numeri grandi) */
  --color-new-fg:     #15803D;  --color-new-bg: #DCFCE7;  --color-new-border: #86EFAC;
  --color-abr-fg:     #B91C1C;  --color-abr-bg: #FEE2E2;  --color-abr-border: #FCA5A5;

  /* ========== Type ========== */
  --font-sans:  'Fira Sans', -apple-system, 'Segoe UI', sans-serif;
  --font-serif: 'Noto Serif', Georgia, serif;
  --font-mono:  ui-monospace, Menlo, Consolas, monospace;
}

/* =====================================================================
   1. ALERT BAR — banda di contesto sopra la nav
   Geometria allineata a codici.law.camp `.bg-accent` (font Fira Sans 400,
   padding-y 8px, font-size 14/16, line-height 20/24, padding-x 16 mobile,
   0 desktop). COLORE invece divergente: rosso brand al posto del navy,
   per dare identità a questa pagina rispetto al sito principale.
   ===================================================================== */
.alert-bar {
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-alert-bg);
  color: #fff;
  text-align: center;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  letter-spacing: 0;
  padding: 8px 16px;
}
.alert-bar strong { font-weight: 600; }
.alert-bar a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.alert-bar a:hover { opacity: 0.88; }
@media (min-width: 768px) {
  .alert-bar {
    padding: 8px 0;
    font-size: 16px;
    line-height: 24px;
    white-space: nowrap;
  }
}

/* =====================================================================
   2. SITE NAV — allineato a codici.law.camp
   (loro: nav h-[72px] mobile, h-full desktop · bg-white/95 + shadow-lg ·
    logo SVG 316×95 nascosto mobile · CTA px-5 py-3 / md:px-6 md:py-4)
   Nostro adattamento: logo sempre visibile (è un sito vetrina),
   nav-padding-y 8px → altezza 72px mobile, 80px desktop.
   ===================================================================== */
/* Wrapper alert+nav: sticky come unico blocco (come fa codici.law.camp) */
.site-topbar {
  position: sticky;
  top: 0;
  z-index: 50;
}

.site-nav {
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: saturate(150%) blur(8px);
  -webkit-backdrop-filter: saturate(150%) blur(8px);
  /* Box-shadow IDENTICA a codici.law.camp (grigia chiara, non nera) */
  box-shadow: rgba(229, 231, 234, 0.8) 0px 10px 15px -3px,
              rgba(229, 231, 234, 0.8) 0px 4px 6px -4px;
  padding: 0 24px;
}

.site-nav-inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  /* Mobile: solo logo centrato (come codici.law.camp); il CTA d'acquisto vive
     in .site-cta-mobile in fondo allo schermo. */
  justify-content: center;
  gap: 16px;
  /* Mobile: logo 40 + 16+16 padding = 72px (= nav h-[72px] di codici.law.camp) */
  padding: 16px 0;
}
@media (min-width: 768px) {
  /* Desktop: nav alta esattamente come il logo (95px), niente padding-y.
     Allineato a codici.law.camp che usa `h-full` sulla nav e si fa
     dimensionare dal logo SVG. Topbar totale = alert 40 + nav 95 = 135. */
  .site-nav-inner {
    padding: 0;
    gap: 28px;
    justify-content: space-between;
  }
}

.site-nav-logo {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  transition: opacity 0.15s;
  text-decoration: none;
}
.site-nav-logo:hover { opacity: 0.85; }
/* Due SVG distinti come fa codici.law.camp:
   - logo mobile (206×40, layout squat)  → visibile <768
   - logo desktop (316×95, layout pieno) → visibile ≥768 */
.site-nav-logo .logo-mobile { display: block; height: 40px; width: auto; }
.site-nav-logo .logo-desktop { display: none; }
@media (min-width: 768px) {
  .site-nav-logo .logo-mobile  { display: none; }
  .site-nav-logo .logo-desktop { display: block; height: 95px; width: auto; }
}

/* Mobile: nascosta — su <768px la nav contiene solo il logo centrato.
   Da md+ la barra destra ricompare con links + CTA d'acquisto. */
.site-nav-right { display: none; }
@media (min-width: 768px) {
  .site-nav-right {
    display: flex;
    align-items: center;
    gap: 28px;
  }
}

.site-nav-links {
  display: none;
  align-items: center;
  gap: 24px;
}
@media (min-width: 768px) {
  .site-nav-links { display: flex; }
}
.site-nav-link {
  font-weight: 500;
  font-size: 15px;
  color: var(--color-nero-700);
  text-decoration: none;
  padding-bottom: 2px;
  border-bottom: 2px solid transparent;
  transition: color 0.15s, border-color 0.15s;
}
.site-nav-link:hover { color: var(--color-red-500); }
.site-nav-link.is-active {
  color: var(--color-red-500);
  border-bottom-color: var(--color-red-500);
}

.site-nav-cta {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  /* gap:8px coerente con l'hero CTA (.btn-shadow Tailwind gap-2): separa
     visivamente il testo dalla freccia → senza doppio spazio (no nbsp
     dentro il markup, vedi index.html). */
  gap: 8px;
  padding: 14px 20px;
  border: 1px solid var(--color-nero-200);
  border-radius: 8px;
  background: var(--color-red-400);
  color: #fff;
  font-weight: 600;
  font-size: 16px;
  line-height: 1.5;
  text-decoration: none;
  white-space: nowrap;
  filter: drop-shadow(0 4px 3px rgba(0, 0, 0, 0.07))
          drop-shadow(0 2px 2px rgba(0, 0, 0, 0.06));
  transition: background 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.site-nav-cta:hover { background: var(--color-red-500); }
/* Su mobile (<768px) il top CTA è ridondante (c'è la sticky bottom-bar)
   e il top nav diventa stretto. Lo nascondiamo. Da 768+ resta visibile
   (vedi sotto la regola dual-span per il copy: tablet senza "2026",
   desktop con "2026" per parità con l'hero CTA). */
@media (max-width: 767.98px) {
  .site-nav-cta { display: none; }
}
@media (min-width: 768px) {
  .site-nav-cta {
    padding: 17px 24px;
    font-size: 18px;
  }
}
/* Dual-span copy: a 768-1023 mostra "Acquista i Codici" (no year, il nav
   non ha spazio); a >=1024 mostra "Acquista i Codici 2026" come l'hero.
   Due text node distinti = stessa struttura flex dell'hero su desktop
   (testo single + freccia span con gap:8px), niente trucchi nbsp. */
.cta-text-desktop { display: none; }
@media (min-width: 1024px) {
  .cta-text-tablet { display: none; }
  .cta-text-desktop { display: inline; }
}

/* CTA arrow normalization. Il glifo "→" (U+2192 RIGHTWARDS ARROW) non è
   incluso nel subset Latin dei woff2 self-hosted, quindi su ogni piattaforma
   cade su font diversi (Roboto su Android, San Francisco/Helvetica su iOS,
   ecc.) con metriche verticali divergenti — il flex items-center allinea
   bounding-box che variano per font, risultato: arrow misaligned su Android
   ma OK su iOS. Forzo line-height:1 + inline-block + vertical-align:middle
   per disaccoppiare la posizione della freccia dalla line-box del testo. */
.cta-arrow {
  display: inline-block;
  line-height: 1;
  vertical-align: middle;
}

/* =====================================================================
   3. STICKY CTA MOBILE — banda bottom fissa, visibile solo <768px.
   Pattern allineato a codici.law.camp: wrapper bianco con shadow-top
   che contiene un button rosso `rounded-lg` full-width al suo interno
   (non un bar edge-to-edge). Si nasconde da md in su, dove il CTA
   "Acquista i Codici" è sempre visibile nella nav destra.

   Markup richiesto:
     <div class="site-cta-mobile">
       <a class="site-cta-mobile-btn" href="…">…</a>
     </div>
   ===================================================================== */
.site-cta-mobile {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 60;
  display: flex;
  align-items: center;
  background: var(--color-white);
  padding: 16px;
  padding-bottom: calc(16px + env(safe-area-inset-bottom));
  /* Shadow-top identica per direzione/colore alla nav (shadow-lg grigio chiaro
     di codici.law.camp, semplicemente capovolta verso l'alto). */
  box-shadow: rgba(229, 231, 234, 0.8) 0px -10px 15px -3px,
              rgba(229, 231, 234, 0.8) 0px -4px 6px -4px;
  /* Visibile di default. La classe .is-hidden la nasconde sotto la fold (con
     hero-cta in viewport l'utente vede già il CTA in chiaro, doppia
     esposizione = rumore). Lo script in index.html toggla la classe via
     IntersectionObserver. CSS-only fallback: se JS è disabilitato resta
     sempre visibile (no regressione). */
  transform: translateY(0);
  opacity: 1;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1),
              opacity 0.25s ease-out;
}
.site-cta-mobile.is-hidden {
  transform: translateY(100%);
  opacity: 0;
  pointer-events: none;
}
.site-cta-mobile-btn {
  box-sizing: border-box;
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 20px;
  border: 1px solid var(--color-nero-200);
  border-radius: 8px;
  background: var(--color-red-400);
  color: #fff;
  font-weight: 600;
  /* Tipografia allineata visivamente al button bottom-nav di codici.law.camp:
     loro hanno il bottone a 16/24 ma con un <span class="text-lg"> dentro
     che dilata la line-box a 28. Noi semplifichiamo applicando 18/28
     direttamente: stesso resultato visivo, stessa altezza box (54px). */
  font-size: 18px;
  line-height: 28px;
  text-decoration: none;
  white-space: nowrap;
  filter: drop-shadow(0 4px 3px rgba(0, 0, 0, 0.07))
          drop-shadow(0 2px 2px rgba(0, 0, 0, 0.06));
  transition: background 0.3s cubic-bezier(0.4, 0, 0.2, 1),
              border-color 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.site-cta-mobile-btn:hover {
  background: var(--color-red-500);
  border-color: var(--color-nero-700);
}

/* Quando una pagina contiene la sticky CTA, il body riserva spazio in fondo
   pari all'altezza del CTA + safe-area iOS, così footer e contenuti non
   restano coperti. Wrapper 16+16 + button (~52px) ≈ 84px.
   Da md (768) in su la CTA è display:none e il padding scompare. */
body:has(.site-cta-mobile) {
  padding-bottom: calc(84px + env(safe-area-inset-bottom));
}
@media (min-width: 768px) {
  .site-cta-mobile { display: none; }
  body:has(.site-cta-mobile) { padding-bottom: 0; }
}

/* =====================================================================
   4. PILL (filter button: idle = outline grigio, active = colore stato)
   Usato in: comparatore (filtri Tutti/Mod/Nuovi/Abr) e mappa (idem).
   ===================================================================== */
.pill {
  -webkit-appearance: none;
  appearance: none;
  font-weight: 500;
  font-size: 13px;
  line-height: 1;
  padding: 8px 14px;
  border: 1px solid var(--color-nero-200);
  background: var(--color-white);
  color: var(--color-nero-700);
  border-radius: 999px;
  cursor: pointer;
  transition: all 0.15s;
  white-space: nowrap;
}
.pill:hover {
  border-color: var(--color-blue-400);
  color: var(--color-blue-400);
}
@media (max-width: 640px) {
  .pill { padding: 6px 10px; font-size: 12px; }
}

/* Active = outline del colore dello stato che filtra
   .active e .is-active sono alias (compatibilità con JS legacy).
   NB: NON cambiare font-weight nel passaggio active — la differenza fra
   500 e 600 cambia la larghezza del testo, quindi del bottone (no width
   fissa), causando uno "shift" visibile al click. La distinzione active
   è già garantita da background + bordo + colore testo. */
.pill.is-active,
.pill.active {
  background: rgba(14, 135, 202, 0.10);
  color: var(--color-blue-400);
  border-color: var(--color-blue-400);
  box-shadow: inset 0 0 0 1px var(--color-blue-400);
}
.pill.is-active.pill--mod,
.pill.active.pill--mod {
  background: var(--color-mod-bg);
  color: var(--color-mod-fg);
  border-color: var(--color-mod-fg);
  box-shadow: inset 0 0 0 1px var(--color-mod-fg);
}
.pill.is-active.pill--new,
.pill.active.pill--new {
  background: var(--color-new-bg);
  color: var(--color-new-fg);
  border-color: var(--color-new-fg);
  box-shadow: inset 0 0 0 1px var(--color-new-fg);
}
.pill.is-active.pill--abr,
.pill.active.pill--abr {
  background: var(--color-abr-bg);
  color: var(--color-abr-fg);
  border-color: var(--color-abr-fg);
  box-shadow: inset 0 0 0 1px var(--color-abr-fg);
}
.pill.is-disabled,
.pill.disabled {
  opacity: 0.35;
  pointer-events: none;
  text-decoration: line-through;
}

/* =====================================================================
   5. CHIP (badge categoria: usato in liste articoli, headers)
   ===================================================================== */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  border: 1px solid;
  vertical-align: middle;
  white-space: nowrap;
}
.chip--mod {
  color: var(--color-mod-fg);
  background: var(--color-mod-bg);
  border-color: var(--color-mod-border);
}
.chip--new {
  color: var(--color-new-fg);
  background: var(--color-new-bg);
  border-color: var(--color-new-border);
}
.chip--abr {
  color: var(--color-abr-fg);
  background: var(--color-abr-bg);
  border-color: var(--color-abr-border);
}
