    :root{
      --bg: #fbf8f1;
      --ink: #111318;
      --muted: #5b616b;
      --paper: rgba(255,255,255,.72);
      --line: rgba(17,19,24,.14);
      --shadow: 0 20px 50px rgba(0,0,0,.16);

      --blue: #244a6a;
      --blue2:#16324a;
      --accent: #b00000;
      --cream: #efe6d6;

      --max: 1180px;

      --s1: .25rem;
      --s2: .5rem;
      --s3: .75rem;
      --s4: 1rem;
      --s5: 1.5rem;
      --s6: 2rem;
      --s7: 3rem;
      --s8: 4.5rem;

      --font-sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      --font-serif: ui-serif, "Iowan Old Style", "Palatino Linotype", Palatino, Garamond, Georgia, serif;
    }

    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{
      margin:0;
      font-family: var(--font-sans);
      color: var(--ink);
      background: radial-gradient(1200px 800px at 20% 0%, rgba(10, 37, 59, 0.12), transparent 60%),
                  radial-gradient(900px 700px at 90% 20%, rgba(0, 91, 176, 0.08), transparent 55%),
                  var(--bg);
    }
    a{color:inherit}
    img{max-width:100%; display:block}

    /* Top band */
    .topband{
      border-bottom: 1px solid var(--line);
      background: rgba(255,255,255,.55);
      backdrop-filter: blur(8px);
    }
    .topband__inner{
      max-width: var(--max);
      margin: 0 auto;
      padding: .85rem var(--s5);
      display:flex;
      gap: var(--s4);
      align-items:center;
      justify-content:space-between;
    }
    .crumb{
      display:flex; gap:.5rem; align-items:center; flex-wrap:wrap;
      font-size: 13px; color: var(--muted);
    }
    .crumb b{color: var(--ink)}
    .badge80{
      display:flex; align-items:center; gap:.6rem;
      padding: .35rem .65rem;
      border: 1px solid var(--line);
      background: rgba(255,255,255,.65);
      font-size: 12px;
      color: var(--blue2);
      white-space:nowrap;
    }
    .badge80 .dot{
      width:10px; height:10px;
      background: linear-gradient(135deg, var(--blue) 0%, var(--accent) 120%);
    }

    /* Sticky nav */
    .nav{
      position: sticky; top:0; z-index:50;
      border-bottom: 1px solid var(--line);
      background: rgba(251,248,241,.72);
      backdrop-filter: blur(10px);
    }
    .nav__inner{
      max-width: var(--max);
      margin: 0 auto;
      padding: .6rem var(--s5);
      display:flex; gap: .6rem;
      align-items:center; justify-content:space-between;
    }
    .nav__brand{
      display:flex; align-items:baseline; gap:.6rem;
      min-width: 220px;
    }
    .nav__brand .kicker{
      font-size: 11px;
      letter-spacing: .14em;
      text-transform: uppercase;
      color: var(--muted);
    }
    .nav__brand .title{
      font-family: var(--font-serif);
      font-weight: 650;
      font-size: 18px;
      color: var(--blue2);
    }

    /* Desktop links */
    .nav__links{
      display:flex; gap:.35rem; flex-wrap:wrap;
      justify-content:flex-end;
    }
    .nav__links a{
      text-decoration:none;
      font-size: 13px;
      color: var(--blue2);
      padding: .42rem .62rem;
      border: 1px solid transparent;
    }
    .nav__links a:hover{
      background: rgba(36,74,106,.08);
      border-color: rgba(36,74,106,.18);
    }

    /* Burger (mobile) */
    .nav__toggle{
      display:none;
      border: 1px solid rgba(0,0,0,.18);
      background: rgba(255,255,255,.70);
      padding: .45rem .62rem;
      cursor:pointer;
      font-weight: 800;
      color: var(--blue2);
      line-height: 1;
      min-width: 42px;
      text-align:center;
    }
    .nav__toggle:focus{outline: 2px solid rgba(36,74,106,.28); outline-offset:2px;}
    .nav__toggle .bars{
      width:18px; height:12px; position:relative; display:inline-block;
    }
    .nav__toggle .bars::before,
    .nav__toggle .bars::after,
    .nav__toggle .bars span{
      content:"";
      position:absolute; left:0; right:0;
      height:2px;
      background: var(--blue2);
      opacity:.9;
    }
    .nav__toggle .bars::before{top:0}
    .nav__toggle .bars span{top:5px}
    .nav__toggle .bars::after{bottom:0}

    /* Collapsible panel */
    .nav__panel{
      display:none;
      border-top: 1px solid var(--line);
      background: rgba(251,248,241,.92);
      backdrop-filter: blur(10px);
    }
    .nav__panelInner{
      max-width: var(--max);
      margin: 0 auto;
      padding: .6rem var(--s5) .9rem;
      display:grid;
      gap:.35rem;
    }
    .nav__panelInner a{
      text-decoration:none;
      padding: .55rem .5rem;
      border: 1px solid rgba(0,0,0,.10);
      color: var(--blue2);
      background: rgba(255,255,255,.60);
      font-size: 13px;
      font-weight: 650;
    }
    .nav__panelInner a:hover{background: rgba(36,74,106,.08)}
    .nav.is-open .nav__panel{display:block;}


    /* =========================
   INAUGURAZIONE
========================= */

.inaugurazione{
  background: var(--blue2);
  color: rgba(255,255,255,.92);
  padding: var(--s6) var(--s5);
  border-bottom: 1px solid rgba(255,255,255,.15);
}

.inaugurazione__title{
  margin: 0 0 var(--s3);
  font-family: var(--font-serif);
  font-size: 22px;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 650;
  color: rgba(255,255,255,.85);
}

.inaugurazione__text{
  margin: 0;
  max-width: 90ch;
  line-height: 1.7;
  font-size: 15px;
}

/* =========================
   SEZIONE LA MOSTRA
========================= */

.mostra{
  background: #fff;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.mostra__inner{
  padding: var(--s7) 0;
}

.mostra__head{
  margin-bottom: var(--s5);
}

.mostra__title{
  margin: 0;
  font-family: var(--font-serif);
  font-size: 30px;
  font-weight: 650;
  color: var(--blue2);
}



.mostra__body p{
  margin: 0 0 var(--s4);
  line-height: 1.75;
  color: var(--ink);
}

.mostra__quote{
  margin: var(--s6) 0 0;
  padding: var(--s4) var(--s5);
  border-left: 3px solid rgba(22,50,74,.25);
  background: rgba(36,74,106,.05);
  font-family: var(--font-serif);
  font-size: 17px;
  line-height: 1.6;
  color: var(--blue2);
}

.mostra__quote footer{
  margin-top: var(--s3);
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--muted);
}

/* =========================
   INTRO – CONTINUA A LEGGERE
========================= */

.intro__details{
  margin-top: var(--s5);
  border-top: 1px solid var(--line);
  padding-top: var(--s4);
}

.intro__summary{
  cursor: pointer;
  list-style: none;
  font-weight: 650;
  font-size: 14px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--blue2);
}

.intro__summary::-webkit-details-marker{
  display: none;
}

.intro__summary::after{
  content: " ↓";
  font-weight: 400;
}

details[open] .intro__summary::after{
  content: " ↑";
}

.intro__extended{
  margin-top: var(--s5);
  
}

.intro__sectionHead{
  margin-bottom: var(--s4);
}

.intro__sectionTitle{
  margin: 0;
  font-family: var(--font-serif);
  font-size: 26px;
  font-weight: 650;
  color: var(--blue2);
}

.intro__extended p{
  margin: 0 0 var(--s4);
  line-height: 1.75;
  color: var(--ink);
}

.intro__quote{
  margin: var(--s6) 0 0;
  padding-left: var(--s4);
  border-left: 3px solid rgba(22,50,74,.25);
  font-family: var(--font-serif);
  color: var(--blue2);
  line-height: 1.6;
}

.intro__quote footer{
  margin-top: var(--s2);
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--muted);
}





/* =========================
   CITAZIONE LEGGE 2012
========================= */

.law-quote{
  padding: 2.8rem 0 3.2rem;
}

.law-quote .shell.narrow{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.law-quote .eyebrow.centered{
  margin: 0 0 .95rem;
  text-align: center;
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
}

.law-quote__box{
  position: relative;
  max-width: 980px;
  margin: 0 auto;
  padding: 1.35rem 1rem 1.1rem;
  text-align: center;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.law-quote__box::before,
.law-quote__box::after{
  content: "";
  display: block;
  width: 100%;
  max-width: 720px;
  height: 1px;
  margin: 0 auto;
  background: linear-gradient(
    to right,
    rgba(82, 112, 149, 0) 0%,
    rgba(82, 112, 149, .38) 18%,
    rgba(82, 112, 149, .55) 50%,
    rgba(82, 112, 149, .38) 82%,
    rgba(82, 112, 149, 0) 100%
  );
}

.law-quote__box::before{
  margin-bottom: 1rem;
}

.law-quote__box::after{
  margin-top: .95rem;
}

.law-quote__box > p{
  margin: 0 auto .7rem;
  max-width: 56ch;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(.96rem, .75vw + .5rem, 1.14rem);
  line-height: 1.72;
  letter-spacing: 0;
  color: var(--blue);
  text-wrap: pretty;
}

.law-quote__box > .text-link{
  display: inline-block;
  margin-top: .15rem;
  font-family: var(--font-serif);
  font-size: .9rem;
  line-height: 1.35;
  color: var(--blue);
  text-decoration: underline;
  text-underline-offset: .12em;
}

.law-quote__box > .text-link:hover{
  opacity: .82;
}

@media (max-width: 640px){
  .law-quote{
    padding: 2.2rem 0 2.5rem;
  }

  .law-quote .shell.narrow{
    padding: 0 1rem;
  }

  .law-quote__box{
    max-width: 100%;
    padding: 1.1rem .5rem .95rem;
  }

  .law-quote__box::before,
  .law-quote__box::after{
    max-width: 100%;
  }

  .law-quote__box > p{
    max-width: 34ch;
    font-size: .98rem;
    line-height: 1.65;
  }

  .law-quote__box > .text-link{
    font-size: .88rem;
  }
}
   /* HERO "invito" */
.hero{
  position: relative;
  border-bottom: 1px solid var(--line);
  min-height: clamp(520px, 68vh, 700px);
  display: grid;
  place-items: stretch;
  overflow: hidden;
  background: #13253c;
}

.hero__bg{
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      90deg,
      rgba(78, 71, 62, 0.78) 0%,
      rgba(71, 59, 47, 0.62) 40%,
      rgba(99, 69, 52, 0.34) 60%,
      rgba(88, 68, 48, 0.1) 70%,
      rgba(112, 101, 91, 0) 78%
    ),
    url("img/hero/hero.jpg") center 24% / cover no-repeat;
}
.hero__lede{
  margin: 0;
  
  font-family: var(--font-serif);
  font-size: clamp(19px, 1.8vw, 30px);
  line-height: 1.08;
  font-weight: 500;
  color: rgba(255,255,255,.96);
  text-wrap: balance;
}

.hero__info{
  display: grid;
  gap: 10px;
}

.hero__meta{
  align-items: start;
}

.hero__meta .placeSub{
  max-width: 22ch;
}

@media (max-width: 760px){
  .hero__lede{
    max-width: 30ch;
    font-size: clamp(20px, 1.8vw, 30px);
  }

  .hero__meta .placeSub{
    max-width: none;
  }
}
.hero__inner{
  position: relative;
  z-index: 2;
  max-width: var(--max);
  margin: 0 auto;
  padding: clamp(28px, 4vw, 56px) var(--s5);
  width: 100%;
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: start;
}

.hero__left{
  width: min(590px, 100%);
  display: grid;
  gap: 16px;
}

.hero__brand{
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding-top: 6px;
}

.hero__kicker{
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.72);
  margin: 0;
}

.hero__brand img{
  width: min(220px, 92%);
  height: auto;
  filter: drop-shadow(0 8px 22px rgba(0,0,0,.22));
}

.hero__info{
  width: 100%;
  margin: 0;
  color: rgba(255,255,255,.96);
}

.hero__subtitle{
  margin: 0 0 14px;
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: rgba(255,255,255,.86);
}

.hero__rule{
  height: 1px;
  background: rgba(255,255,255,.26);
  margin: 10px 0 10px;
}

.hero__speciale {
  margin-top: 0.75rem;
  font-size: 1.5rem;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-style: italic;
  line-height: 1.08;
  font-weight: 400;
  color: rgba(255,255,255,0.9);
  text-shadow: 0 1px 2px rgba(0,0,0,0.95);
  text-wrap: balance;
}


@media (max-width: 767px) {
  .hero__speciale {
    margin-top: 0.6rem;
    
    font-size: 1.3rem;
    line-height: 1.06;
  }
}

.hero__meta{
  display: grid;
  grid-template-columns: 0.7fr 1fr;
  gap: 18px 26px;
  align-items: start;
}

.hero__meta .big{
  font-family: var(--font-serif);
  font-size: clamp(34px, 4.2vw, 54px);
  line-height: .95;
  font-weight: 650;
  margin: 0;
  letter-spacing: .4px;
  color: #fff;
}

.hero__meta .big2{
  font-family: var(--font-serif);
  font-size: clamp(14px, 3vw, 24px);
  line-height: .95;
  font-weight: 650;
  margin: 0;
  letter-spacing: .4px;
  color: #fff;
}

.hero__meta .place{
  font-family: var(--font-serif);
  font-size: clamp(30px, 4vw, 52px);
  line-height: .95;
  font-weight: 650;
  margin: 0;
  color: #fff;
}

.hero__meta .placeSub{
  margin: 6px 0 0;
  font-size: 15px;
  color: rgba(255,255,255,.84);
  line-height: 1.35;
}

/* Buttons */
.hero__cta{
  margin-top: 18px;
  display: flex;
  gap: .6rem;
  flex-wrap: wrap;
}

.btn{
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  padding: .72rem 1rem;
  border: 1px solid rgba(22,50,74,.25);
  background: rgba(255,255,255,.78);
  text-decoration: none;
  font-size: 13px;
  color: var(--blue2);
  font-weight: 650;
}

.btn:hover{background: rgba(36,74,106,.10)}

.btn--primary{
  border-color: rgba(22,50,74,.32);
  background: linear-gradient(180deg, rgba(36,74,106,.16), rgba(255,255,255,.78));
}

.hero .btn{
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.22);
  color: rgba(255,255,255,.92);
}

.hero .btn:hover{background: rgba(255,255,255,.18)}

.hero .btn--primary{
  border-color: rgba(255,255,255,.28);
  background: rgba(255,255,255,.16);
}

/* =========================
   INTRO 
========================= */

.intro{
  padding: var(--s7) var(--s5);
  border-bottom: 1px solid var(--line);
  background: rgba(255,255,255,.55);
}

.intro__head{
  margin-bottom: var(--s5);
}

.intro__title{
  font-family: var(--font-serif);
  font-weight: 650;
  font-size: clamp(1.6rem, 1.2rem + 1vw, 2.2rem);
  line-height: 1.2;
  color: var(--blue2);
  margin: 0;
}

.intro__date{
  display:block;
  font-size: 1rem;
  font-weight: 500;
  color: var(--muted);
  margin-top: var(--s2);
}



.intro__body p{
  margin: 0 0 var(--s4);
  line-height: 1.7;
  color: var(--ink);
}

.intro__body p:last-child{
  margin-bottom: 0;
}

    /* Sections */
    section{ padding: var(--s7) var(--s5); }
    .wrap{ max-width: var(--max); margin: 0 auto; }
    .wrapp{ max-width: var(--max); margin: 50px auto; }
    .h2{
      font-family: var(--font-serif);
      font-weight: 650;
      font-size: 28px;
      margin: 0 0 var(--s3);
      color: var(--blue2);
      letter-spacing: .2px;
    }
    .lead{
      margin: 0 0 var(--s5);
      color: var(--muted);
      line-height: 1.65;
      
    }
    .grid{ display:grid; gap: var(--s5); }
    .grid--2{ grid-template-columns: 1.1fr .9fr; align-items:start; }

    .card{
      border: 1px solid var(--line);
      background: rgba(255,255,255,.66);
      overflow:hidden;
    }
    .card__pad{padding: var(--s5)}
    .divider{height:1px; background: var(--line);}

    .list{
      margin:0;
      padding-left: 1.1rem;
      color: var(--muted);
      line-height: 1.7;
    }


    .padri-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:var(--s4);
  align-items:start;
}

.padri-grid .press__figure{
  width:100%;
}

.padri-grid__img{
  display:block;
  width:100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
}

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

  .padri-grid__img{
    aspect-ratio:auto;
  }
}

.repub-list{
  display:grid;
  gap:var(--s5);
}

.speech-thumb{
  max-width:180px;
  margin:0 0 var(--s4);
  cursor:pointer;
}

.speech-thumb img{
  display:block;
  width:100%;
  aspect-ratio:2 / 3;
  object-fit:cover;
}

.video--wide iframe{
  display:block;
  width:100%;
  aspect-ratio:16 / 9;
  min-height:420px;
  border:0;
}

@media (max-width: 900px){
  .video--wide iframe{
    min-height:260px;
  }
}

.speech-row{
  display:grid;
  grid-template-columns:180px minmax(0, 1fr);
  gap:var(--s5);
  align-items:start;
  margin:0 0 var(--s4);
}

.speech-row .speech-thumb{
  max-width:none;
  margin:0;
}

.speech-row .speech-thumb img{
  display:block;
  width:100%;
  aspect-ratio:2 / 3;
  object-fit:cover;
}

.speech-excerpt p{
  margin:0 0 var(--s4);
  line-height:1.7;
}

.speech-excerpt p:last-child{
  margin-bottom:0;
}

@media (max-width: 700px){
  .speech-row{
    grid-template-columns:1fr;
    gap:var(--s4);
  }

  .speech-row .speech-thumb{
    max-width:180px;
  }
}
.speech-thumb{
  cursor: default;
}

.speech-thumb img{
  pointer-events: none;
}
/* =========================
   COMUNICATI
========================= */

.press{
  display: grid;
  gap: var(--s4);
}

.press__item{
  border: 1px solid var(--line);
  background: rgba(255,255,255,.66);
}

/* SUMMARY */

.press__summary{
  cursor: pointer;
  padding: var(--s5);
  list-style: none;
}

.press__summary::-webkit-details-marker{
  display: none;
}

.press__who{
  display:block;
  font-family: var(--font-serif);
  font-weight: 650;
  color: var(--blue2);
  font-size: 18px;
  line-height: 1.25;
}

.press__meta{
  display:block;
  margin-top: var(--s2);
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
}

.press__preview{
  display:block;
  margin-top: var(--s3);
  color: var(--muted);
  line-height: 1.65;
  
}

/* --- Press / Voci istituzionali: media --- */
.press__mediaGrid{
  margin: var(--s6) 0;
  display: grid;
  gap: var(--s4);
  grid-template-columns: 1fr;
}

@media (min-width: 720px){
  .press__mediaGrid{
    grid-template-columns: repeat(3, 1fr);
    align-items: start;
  }
}

.press__figure{
  margin: 0;
}

.press__figure img{
  display: block;
  width: 100%;
  height: auto;
  border: 1px solid var(--line);
  background: #fff;
}

.press__caption{
  margin-top: var(--s2);
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.4;
}

.press__figure--wide{
  margin: var(--s6) 0;
}

.press__figure--wide img{
  border: 1px solid var(--line);
}

/* opzionale: per testi lunghi */
.press__inner p{
  hyphens: auto;
}

/* BODY */

.press__body{
  border-top: 1px solid var(--line);
  padding: var(--s6) var(--s5);
}

.press__inner{
  max-width: 78ch;
  margin: 0 auto;
}

.press__kicker{
  margin: 0 0 var(--s2);
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
}

.press__body p{
  margin: 0 0 var(--s4);
  line-height: 1.75;
  color: var(--ink);
}

.press__quote{
  margin: var(--s6) 0 0;
  padding-left: var(--s4);
  border-left: 3px solid rgba(22,50,74,.25);
  color: var(--muted);
  line-height: 1.7;
}

.press__more{
  margin-left: .5rem;
  font-style: normal;
  font-weight: 600;
  color: var(--blue2);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  cursor: pointer;
  transition: color .2s ease, transform .2s ease;
}

.press__more::after{
  content: " →";
  display: inline-block;
  transition: transform .2s ease;
}

.press__summary:hover .press__more::after,
.press__summary:focus-visible .press__more::after{
  transform: translateX(3px); /* micro movimento elegante */
}

details[open] .press__more{
  display: none;
}
  /* =========================
   PUBBLICAZIONE (sezione)
========================= */

.pub{
  border-top: 1px solid var(--line);
  background: #fff;
}

.pub__inner{
  max-width: var(--max);
  margin: 0 auto;
  padding: var(--s7) var(--s5);
}

.pub__head{
  margin: 0 0 var(--s5);
}

.pub__eyebrow{
  margin: 0 0 var(--s2);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: 12px;
  color: var(--muted);
}

.pub__title{
  margin: 0;
  font-size: clamp(1.45rem, 1.1rem + 1.2vw, 2rem);
  line-height: 1.15;
  color: var(--ink);
}

.pub__subtitle{
  margin: var(--s2) 0 0;
  color: var(--muted);
  max-width: 70ch;
}

.pub__grid{
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--s6);
  align-items: start;
}

.pub__cover{
  position: relative;
  display: block;
  border: 1px solid var(--line);
  background: #fff;
  box-shadow: 0 14px 30px rgba(0,0,0,.08);
  text-decoration: none;
}

.pub__cover img{
  display: block;
  width: 100%;
  height: auto; /* niente tagli */
}

.pub__cover-badge{
  position: absolute;
  top: 10px;
  left: 10px;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 6px 8px;
  background: rgba(0,0,0,.78);
  color: #fff;
}

.pub__cover:focus-visible{
  outline: 3px solid rgba(0,0,0,.25);
  outline-offset: 3px;
}

.pub__body{
  padding-top: 2px;
}

.pub__lead{
  margin: 0 0 var(--s4);
  
  color: var(--ink);
}

.pub__meta{
  margin: 0 0 var(--s4);
  padding: var(--s4);
  border: 1px solid var(--line);
  background: rgba(0,0,0,.02);
}

.pub__meta-row{
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--s3);
  padding: var(--s2) 0;
  border-top: 1px solid var(--line);
}

.pub__meta-row:first-child{
  border-top: 0;
  padding-top: 0;
}

.pub__meta dt{
  color: var(--muted);
  font-size: 13px;
}

.pub__meta dd{
  margin: 0;
  color: var(--ink);
}

.pub__cta{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--accent);
  text-decoration: none;
  font-weight: 600;
}

.pub__cta:hover{
  text-decoration: underline;
}

.pub__note{
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  max-width: 78ch;
}

/* Responsive */
@media (max-width: 860px){
  .pub__grid{
    grid-template-columns: 220px 1fr;
  }
}

@media (max-width: 640px){
  .pub__grid{
    grid-template-columns: 1fr;
  }
  .pub__cover{
    max-width: 320px;
  }
}  
    /* ====== STORIA / TIMELINE ====== */
.card__title{
  margin:0 0 var(--s2);
  font-family: var(--font-serif);
  color: var(--blue2);
}

.timeline__h{
  margin: var(--s5) 0 var(--s2);
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--muted);
}

.timeline{
  list-style: none;
  margin: 0;
  padding: 0;
  border-left: 2px solid rgba(22,50,74,.18);
}

.timeline__item{
  position: relative;
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 14px;
  padding: 12px 0 12px 18px;
}

.timeline__item::before{
  content:"";
  position:absolute;
  left:-7px;
  top: 18px;
  width: 12px;
  height: 12px;
  border: 2px solid rgba(22,50,74,.35);
  background: var(--paper);
}

.timeline__date{
  font-size: 12px;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: var(--muted);
  white-space: nowrap;
}

.timeline__title{
  font-weight: 700;
  color: var(--ink);
  line-height: 1.35;
}

.timeline__text{
  margin-top: 4px;
  color: var(--muted);
  line-height: 1.6;
  font-size: 14px;
}

.note{
  color: var(--muted);
  font-size: 12px;
  line-height: 1.6;
}

.bullets{
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  line-height: 1.65;
}

@media (max-width: 640px){
  .timeline__item{
    grid-template-columns: 1fr;
    gap: 6px;
    padding-left: 18px;
  }
  .timeline__date{
    order: -1;
  }
}

    /* Opening dates */
   .dates{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s4);
}
    .date{
      padding: var(--s4);
      border: 1px solid rgba(22,50,74,.18);
      background: linear-gradient(180deg, rgba(36,74,106,.30), rgba(255,255,255,.70));
    }
    .date b{
      display:block;
      font-size: 14px;
      color: var(--blue2);
      margin-bottom: .15rem;
    }
    .date span{color: var(--muted); font-size: 13px}

    /* Docs */
    .docs{
      display:grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: var(--s3);
    }
    .doc{
      padding: var(--s4);
      border: 1px dashed rgba(22,50,74,.28);
      background: rgba(255,255,255,.6);
      min-height: 110px;
      display:flex;
      flex-direction:column;
      justify-content:space-between;
      gap: .6rem;
    }
    .doc .t{
      font-weight: 700;
      color: var(--blue2);
      line-height: 1.2;
    }
    .doc .m{
      color: var(--muted);
      font-size: 13px;
      line-height: 1.4;
    }
    .doc a{
      font-size: 13px;
      color: var(--blue2);
      text-decoration: underline;
      text-decoration-thickness: 1px;
      width: fit-content;
    }

    /* Works gallery */
    .works{
      display:grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: var(--s3);
    }
    .work{
      border: 1px solid rgba(0,0,0,.14);
      overflow:hidden;
      background: rgba(255,255,255,.72);
      cursor:pointer;
      transition: transform .14s ease, box-shadow .14s ease;
      display:flex;
      flex-direction:column;
      min-height: 260px;
    }
    .work:hover{
      transform: translateY(-2px);
      box-shadow: 0 18px 40px rgba(0,0,0,.12);
    }
    .work__thumb{
      aspect-ratio: 3/4;
      background: linear-gradient(135deg, rgba(36,74,106,.18), rgba(176,0,0,.10));
      position:relative;
      overflow:hidden;
    }
    .work__thumb img{
      width:100%;
      height:100%;
      object-fit: cover;
      opacity:.98;
    }
    .work__body{padding: .85rem .9rem 1rem}
    .work__title{
      font-family: var(--font-serif);
      font-weight: 650;
      margin: 0 0 .3rem;
      font-size: 16px;
      color: var(--ink);
      line-height: 1.15;
    }
    .work__meta{
      margin:0;
      color: var(--muted);
      font-size: 13px;
      line-height: 1.4;
    }

    /* Costituenti */
    .filters{
      display:flex;
      gap:.45rem;
      flex-wrap:wrap;
      margin-top: var(--s4);
      margin-bottom: var(--s5);
    }
    .chip{
      appearance:none;
      border: 1px solid rgba(22,50,74,.22);
      background: rgba(255,255,255,.70);
      padding: .45rem .7rem;
      font-size: 13px;
      color: var(--blue2);
      cursor:pointer;
      font-weight: 650;
    }
    .chip[aria-pressed="true"]{
      background: rgba(36,74,106,.10);
      border-color: rgba(22,50,74,.32);
    }
    .people{
      display:grid;
      grid-template-columns: repeat(6, minmax(0, 1fr));
      gap: var(--s3);
    }
    .person{
      position:relative;
      border: 1px solid rgba(0,0,0,.14);
      overflow:hidden;
      background: rgba(255,255,255,.72);
      cursor:pointer;
      transition: transform .14s ease, box-shadow .14s ease;
      min-height: 190px;
    }
    .person:hover{transform: translateY(-2px); box-shadow: 0 18px 40px rgba(0,0,0,.10);}
    .person__photo{
      width:100%;
      height: 250px;
      object-fit: contain;
      background: rgba(36,74,106,.10);
    }
    .person__name{
      padding: .65rem .75rem 0;
      font-weight: 800;
      font-size: 13px;
      line-height: 1.15;
      color: var(--ink);
    }
    .person__meta{
      padding: .35rem .75rem .85rem;
      font-size: 12px;
      color: var(--muted);
      line-height: 1.25;
    }
    .person__dates{
  font-size: 0.85rem;
  color: var(--muted);
  margin-top: 2px;
  margin-bottom: 2px;
  letter-spacing: .02em;
  padding: .65rem .75rem 0;
}
    .tag{
      position:absolute;
      top: .55rem;
      left: .55rem;
      background: rgba(255,255,255,.82);
      border: 1px solid rgba(0,0,0,.16);
      padding: .18rem .45rem;
      font-size: 11px;
      font-weight: 800;
      color: var(--blue2);
    }

    /* Modal */
    .modal{
      position:fixed;
      inset:0;
      background: rgba(0,0,0,.54);
      display:none;
      align-items:center;
      justify-content:center;
      padding: 24px;
      z-index: 200;
    }
    .modal[aria-hidden="false"]{display:flex;}
    .modal__panel{
  width:min(980px, 100%);
  display:flex;
  flex-direction:column;
  max-height: calc(100dvh - 48px);
  overflow:hidden;
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(255,255,255,.22);
  box-shadow: 0 30px 80px rgba(0,0,0,.28);
}
    .modal__top{
  position: sticky;
  top: 0;
  z-index: 2;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: var(--s3);
  padding: 14px 16px;
  background: linear-gradient(90deg, rgba(36,74,106,.12), rgba(255,255,255,.88));
  border-bottom: 1px solid rgba(0,0,0,.10);
}
    .modal__top b{
      font-family: var(--font-serif);
      font-size: 18px;
      color: var(--blue2);
    }
    .modal__actions{
      display:flex;
      gap:.45rem;
      align-items:center;
    }
    .modal__nav{
      border: 1px solid rgba(0,0,0,.16);
      background: rgba(255,255,255,.70);
      padding: .35rem .6rem;
      font-size: 15px;
      cursor:pointer;
      font-weight: 900;
      color: var(--ink);
      line-height: 1;
      min-width: 38px;
      text-align:center;
    }
    .modal__nav:hover{background: rgba(36,74,106,.10)}
    .modal__nav:disabled{opacity:.35; cursor:not-allowed;}

    .modal__close{
      border: 1px solid rgba(0,0,0,.16);
      background: rgba(255,255,255,.70);
      padding: .35rem .65rem;
      font-size: 13px;
      cursor:pointer;
      font-weight: 750;
      color: var(--ink);
    }
    .modal__body{
  flex: 1;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  touch-action: pan-y;
  padding: 16px;
  display:grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 16px;
  align-items:start;
}
    .modal__img{
      border: 1px solid rgba(0,0,0,.14);
      background: rgba(36,74,106,.08);
      display:flex;
      align-items:center;
      justify-content:center;
      padding: 8px;
    }
    .modal__img img{
      width: 100%;
      height: auto;
      max-height: 64dvh;
      object-fit: contain;
    }
    .modal__text p{margin: 0 0 .6rem; color: var(--muted); line-height: 1.55;}
    .kv{
      display:grid;
      grid-template-columns: 160px 1fr;
      gap: .35rem .75rem;
      margin-top: .9rem;
      padding-top: .9rem;
      border-top: 1px solid rgba(0,0,0,.10);
      font-size: 13px;
    }
    .kv b{color: var(--ink)}
    .kv span{color: var(--muted)}

    /* Footer */
    footer{
      border-top: 1px solid var(--line);
      padding: var(--s6) var(--s5);
      color: var(--muted);
      font-size: 12px;
      background: rgba(255,255,255,.45);
    }
    footer .wrap{display:flex; gap: var(--s4); justify-content:space-between; flex-wrap:wrap;}

 /* ================================
   FOOTER ISTITUZIONALE (1 riga desktop)
================================ */

.s-footer{
  background: var(--paper);
  border-top: 1px solid var(--line);
}

.s-footer__inner{
  max-width: var(--max);
  margin: 0 auto;
  padding: 40px var(--s5);
}

/* 1 riga in desktop */
.s-footer__logos{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;          
  flex-wrap: nowrap;  /* NON andare a capo in desktop */
}

/* link */
.s-footer__logo{
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 1 auto;
  min-width: 0;
}

/* altezza identica per tutti */
.s-footer__logo img{
  height: 46px;     
  width: auto;
  display: block;
  opacity: .92;
  transition: opacity .2s ease;
}

.s-footer__logo:hover img{ opacity: 1; }

/* cap a Moebius */
.s-footer__logo img[alt="Moebius"]{
  height: 46px;     
}

/* ================================
   RESPONSIVE
================================ */
@media (max-width: 1100px){
  .s-footer__logos{
    justify-content: center;
    flex-wrap: wrap;     
    gap: 26px 34px;
  }
}

@media (max-width: 768px){
  .s-footer__inner{ padding: 32px var(--s5); }
  .s-footer__logo img{ height: 42px; }
}

@media (max-width: 520px){
  .s-footer__logos{
    flex-direction: column;
    gap: 22px;
  }
  .s-footer__logo img{ height: 40px; }
}
    /* Responsive */
    @media (max-width: 980px){
      /* burger */
      .nav__toggle{display:inline-flex; align-items:center; justify-content:center;}
      .nav__links{display:none;}

     
      .grid--2{grid-template-columns: 1fr;}
      .dates{grid-template-columns: 1fr 1fr;}
      .docs{grid-template-columns: 1fr;}
      .works{grid-template-columns: repeat(2, minmax(0, 1fr));}
      .people{grid-template-columns: repeat(3, minmax(0, 1fr));}
      .modal__body{grid-template-columns: 1fr;}
      .nav__brand{min-width: 0;}
    }
    @media (max-width: 520px){
      .topband__inner{padding-left: 1rem; padding-right: 1rem;}
      .nav__inner{padding-left: 1rem; padding-right: 1rem;}
      section{padding-left: 1rem; padding-right: 1rem;}
        
      .dates{grid-template-columns: 1fr;}
      .works{grid-template-columns: 1fr;}
      .people{grid-template-columns: repeat(2, minmax(0, 1fr));}

      .hero__meta{grid-template-columns: 0.4fr 1fr;}
    }


/* SOCIAL – default: dock in basso */
    .social{
      position: fixed;
      left: 50%;
      bottom: calc(12px + env(safe-area-inset-bottom, 0px));
      top: auto;
      transform: translateX(-50%);
      display: flex;
      flex-direction: row;
      gap: 10px;
      padding: 6px 10px;
      background: rgba(255,255,255,.92);
      border-radius: 999px;
      border: 1px solid var(--line);
      box-shadow: 0 12px 28px rgba(0,0,0,.18);
      backdrop-filter: blur(8px);
      z-index: 50;
    }

    .social a{
      width: 40px;
      height: 40px;
      display:flex;
      align-items:center;
      justify-content:center;
      border-radius: 999px;
      background: transparent;
      border: 0;
      box-shadow: none;
      transition: transform .15s ease;
      color: var(--blue2);
      text-decoration:none;
    }

    .social a:hover{
      transform: translateY(-2px);
    }

    .social svg{
      width: 18px;
      height: 18px;
      fill: currentColor;
      display:block;
    }

    /* Torna su */
    .social .to-top{
      width: 40px;
      height: 40px;
      display:flex;
      align-items:center;
      justify-content:center;
      border-radius: 999px;
      border: 0;
      background: transparent;
      color: var(--blue2);
      cursor: pointer;
      transition: transform .15s ease, opacity .2s ease;
      opacity: 0;
      pointer-events: none;
    }
    .social .to-top.show{
      opacity: 1;
      pointer-events: auto;
    }
    .social .to-top:hover{
      transform: translateY(-2px);
    }
    .social .to-top svg{
      width: 18px;
      height: 18px;
      fill: currentColor;
      display:block;
    }

    /* DESKTOP : sidebar laterale */
    @media (min-width: 1400px){
      .social{
        left: 14px;
        top: 50%;
        bottom: auto;
        transform: translateY(-50%);
        flex-direction: column;
        padding: 0;
        background: transparent;
        border: 0;
        box-shadow: none;
        backdrop-filter: none;
        gap: 10px;
      }

      .social a{
        width: 42px;
        height: 42px;
        background: rgba(255,255,255,.95);
        border: 1px solid var(--line);
        box-shadow: 0 10px 22px rgba(0,0,0,.10);
      }

      .social a:hover{
        transform: translateY(-2px);
        box-shadow: 0 14px 28px rgba(0,0,0,.14);
        background: #fff;
      }

      .social svg{
        width: 20px;
        height: 20px;
      }

      .social .to-top{
        width: 42px;
        height: 42px;
        background: rgba(255,255,255,.95);
        border: 1px solid var(--line);
        box-shadow: 0 10px 22px rgba(0,0,0,.10);
      }
      .social .to-top:hover{
        box-shadow: 0 14px 28px rgba(0,0,0,.14);
        background:#fff;
      }
      .social .to-top svg{
        width: 20px;
        height: 20px;
      }

      header .container,
      main .container{
        padding-left: 72px;
      }
    }


/* Modal: mobile layout */
@media (max-width: 520px){
  .modal{
    padding: 10px;
    align-items: stretch;
    justify-content: stretch;
  }
  .modal__panel{
    width: 100%;
    max-height: calc(100dvh - 20px);
  }
  .modal__body{
    padding: 12px;
    gap: 12px;
  }
  .modal__img img{
    max-height: 46dvh;
  }
  .kv{
    grid-template-columns: 120px 1fr;
  }
}
/* =========================
   CREDITI FOTOGRAFICI
========================= */

.photo-credits{
  border-top: 1px solid var(--line);
  background: rgba(255,255,255,.6);
}

.photo-credits .wrap{
  padding: var(--s6) 0;
}

.photo-credits__title{
  margin: 0 0 var(--s4);
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 650;
  color: var(--blue2);
  letter-spacing: .08em;
  text-transform: uppercase;
}

.photo-credits__list{
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: .6rem;
  max-width: 90ch;
}

.photo-credits__list li{
  font-size: 13px;
  line-height: 1.6;
  color: var(--muted);
}

/* Responsive */
@media (min-width: 860px){
  .photo-credits__list{
    grid-template-columns: 1fr 1fr;
    column-gap: 40px;
  }
}

/* ===== Fix: anchor + nav sticky (solo sezioni principali) ===== */

:root{
  /* Desktop: leggermente più alto */
  --scroll-offset: 76px;
}

html{
  scroll-padding-top: var(--scroll-offset);
}

/* Applica offset SOLO alle ancore “di pagina”, cioè alle <section id="..."> */
main section[id]{
  scroll-margin-top: var(--scroll-offset);
}

/* Mobile: offset più contenuto (se ora “scende troppo” o crea troppo margine) */
@media (max-width: 980px){
  :root{ --scroll-offset: 64px; }
}