
:root{
  --paper:#F8F1E5;
  --paper2:#FFF9EF;
  --ink:#171313;
  --muted:#6F6660;
  --line:rgba(111,29,42,.16);
  --green:#B3262D;
  --blue:#6F1D2A;
  --clay:#9E3B32;
  --gold:#D6A23A;
  --glass:rgba(255,249,239,.64);
  --glass2:rgba(255,249,239,.82);
  --shadow:0 34px 110px rgba(75,34,28,.15);
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Avenir Next", Avenir, Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 28% 0%, rgba(214,162,58,.16), transparent 34rem),
    radial-gradient(circle at 78% 12%, rgba(179,38,45,.12), transparent 35rem),
    linear-gradient(180deg,#FFF9EF,var(--paper));
  min-height:100vh;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
p{color:var(--muted);line-height:1.72}
#webgl-stage{
  position:fixed;
  inset:0;
  z-index:-6;
  overflow:hidden;
  background:#efe3d0;
}
#webgl-stage .maplibregl-map{
  position:absolute;
  inset:0;
  opacity:.88;
  filter:saturate(.98) contrast(1.00) brightness(1.04);
}
#webgl-stage:after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(245,239,226,.80) 0%, rgba(245,239,226,.56) 34%, rgba(245,239,226,.28) 62%, rgba(245,239,226,.12) 100%),
    radial-gradient(circle at 28% 35%, rgba(255,250,240,.24), transparent 22rem),
    linear-gradient(180deg, rgba(245,239,226,.22), rgba(245,239,226,.38));
}
.maplibregl-ctrl-bottom-left,
.maplibregl-ctrl-bottom-right{
  z-index:5;
}
.maplibregl-ctrl-attrib{
  font-family:inherit;
  font-size:10px;
  background:rgba(255,250,240,.68)!important;
  backdrop-filter:blur(10px);
}

/* NAV FIX DEFINITIVO: fisso, centrato, sempre visibile */
.nav{
  position:fixed;
  top:16px;
  left:50%;
  transform:translateX(-50%);
  z-index:9999;
  width:min(var(--max), calc(100% - 32px));
  max-width:var(--max);
  margin:0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,250,240,.76);
  backdrop-filter:blur(26px) saturate(1.25);
  -webkit-backdrop-filter:blur(26px) saturate(1.25);
  box-shadow:0 22px 80px rgba(36,33,26,.12);
}

body{
  padding-top:92px;
}

.noise{
  position:fixed;
  inset:0;
  z-index:-4;
  pointer-events:none;
  opacity:.105;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 260 260' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.76' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
}
.brand{display:flex;align-items:center;gap:12px}
.brand-glyph{
  width:42px;height:42px;border-radius:50%;
  background:
    radial-gradient(circle at 30% 24%,#fff,rgba(255,255,255,.1) 28%,transparent 30%),
    conic-gradient(from 140deg,var(--blue),var(--green),var(--gold),var(--clay),var(--blue));
  box-shadow:0 18px 50px rgba(179,38,45,.24);
}
.brand strong{display:block;font-weight:440;letter-spacing:-.055em}
.brand small{display:block;color:var(--muted);font-size:.72rem}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{padding:11px 15px;border-radius:999px;font-size:.92rem;font-weight:420;color:#30383a}
.nav-links a:hover{background:rgba(179,38,45,.09)}
.nav-action{background:var(--ink)!important;color:white!important}
.nav-toggle{display:none;border:0;background:transparent;font:inherit;color:var(--ink);padding:12px}
.hero{
  min-height:calc(100vh - 84px);
  max-width:var(--max);
  margin:0 auto;
  padding:92px 22px 72px;
  display:grid;
  grid-template-columns:minmax(0, .98fr) 340px;
  gap:44px;
  align-items:center;
  position:relative;
}
.micro{
  color:var(--green);
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:.72rem;
  font-weight:520;
  margin:0 0 14px;
}
h1,h2,h3{
  margin:0 0 18px;
  color:var(--ink);
  font-weight:360;
  letter-spacing:-.078em;
}
h1{font-size:clamp(3.6rem,8.4vw,7.8rem);line-height:.84;max-width:880px}
h2{font-size:clamp(2.5rem,6vw,5.8rem);line-height:.86}
h3{font-size:1.65rem}
.lead{font-size:clamp(1.12rem,2vw,1.46rem);max-width:750px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.btn{
  border:1px solid var(--line);
  border-radius:999px;
  padding:14px 19px;
  font:inherit;
  font-weight:430;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:transform .24s ease, box-shadow .24s ease;
}
.btn:hover{transform:translateY(-3px)}
.btn.dark{background:var(--ink);color:white;border-color:var(--ink);box-shadow:0 18px 55px rgba(16,21,26,.18)}
.btn.ghost{background:rgba(255,250,240,.60);backdrop-filter:blur(18px)}
.control-panel{
  display:grid;
  gap:12px;
}
.control-panel div,.atlas-card,.mission,.participate-panel,.installation-copy,.installation-steps,.candidate-card,.program-block,.protocol,.detail-panel,.legal{
  border:1px solid var(--line);
  background:rgba(255,250,240,.62);
  backdrop-filter:blur(28px) saturate(1.08);
  border-radius:34px;
  box-shadow:var(--shadow);
}
.control-panel div{padding:22px}
.control-panel span{color:var(--gold);font-size:.9rem}
.control-panel strong{display:block;margin-top:10px;font-weight:430;font-size:1.45rem;letter-spacing:-.05em}
.control-panel p{margin-bottom:0;font-size:.94rem}
.experience-hint{
  position:absolute;
  left:22px;
  bottom:22px;
  color:var(--muted);
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:.78rem;
}
.section{max-width:var(--max);margin:0 auto;padding:92px 22px}
.section-heading{max-width:920px;margin-bottom:34px}
.atlas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.atlas-card{padding:28px;min-height:260px;display:flex;flex-direction:column;justify-content:space-between}
.atlas-card span{color:var(--gold);letter-spacing:.16em;text-transform:uppercase;font-size:.75rem}
.mission-strip{
  display:grid;
  grid-template-columns:repeat(5,minmax(235px,1fr));
  gap:16px;
  overflow-x:auto;
  padding-bottom:18px;
  scroll-snap-type:x mandatory;
}
.mission{
  min-height:330px;
  padding:24px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  scroll-snap-align:start;
  transition:transform .22s ease;
}
.mission:hover{transform:translateY(-8px)}
.mission span{color:var(--gold)}
.mission strong{font-size:2.1rem;font-weight:360;letter-spacing:-.065em}
.mission em{font-style:normal;color:var(--muted);line-height:1.55}
.installation{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.installation-copy{padding:36px}
.installation-steps{
  padding:18px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.installation-steps div{
  border:1px solid var(--line);
  background:rgba(255,255,255,.20);
  border-radius:26px;
  padding:22px;
  min-height:170px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.installation-steps strong{font-size:3.5rem;font-weight:300;letter-spacing:-.08em}
.installation-steps span{color:var(--muted)}
.candidates-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.candidates-grid.large{grid-template-columns:repeat(4,1fr)}
.candidate-card{overflow:hidden;transition:transform .2s ease}
.candidate-visual{
  min-height:250px;
  display:grid;
  place-items:center;
  color:white;
  font-size:4.2rem;
  font-weight:280;
  letter-spacing:-.09em;
  background:
    radial-gradient(circle at 28% 22%,rgba(255,255,255,.50),transparent 27%),
    linear-gradient(135deg,var(--green),var(--blue) 55%,var(--clay));
}
.candidate-copy{padding:24px}
.text-link{color:var(--green);border-bottom:1px solid rgba(31,97,77,.28)}
.participate-panel{
  padding:34px;
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:34px;
}
.contact-form{display:grid;gap:12px}
input,textarea{
  width:100%;
  border:1px solid var(--line);
  background:rgba(255,255,255,.52);
  border-radius:20px;
  padding:16px 17px;
  font:inherit;
  color:var(--ink);
  outline:none;
}
input:focus,textarea:focus{border-color:rgba(179,38,45,.42);box-shadow:0 0 0 5px rgba(179,38,45,.08)}
.contact-form label{color:var(--muted);line-height:1.5;font-size:.94rem}
.page-hero{
  max-width:var(--max);
  margin:0 auto;
  padding:112px 22px 55px;
}
.program-wrap{max-width:var(--max);margin:0 auto;padding:20px 22px 60px;display:grid;gap:18px}
.program-block{
  padding:34px;
  display:grid;
  grid-template-columns:120px 1fr;
  gap:26px;
}
.program-index{font-size:4rem;color:var(--gold);font-weight:300;letter-spacing:-.08em}
.chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}
.chips span{
  padding:10px 13px;
  border:1px solid rgba(179,38,45,.18);
  border-radius:999px;
  background:rgba(179,38,45,.075);
  color:var(--green);
}
.protocol{padding:38px}
.protocol ol,.detail-panel ul{color:var(--muted);line-height:1.9}
.candidate-hero{
  max-width:var(--max);
  margin:0 auto;
  padding:105px 22px 60px;
  display:grid;
  grid-template-columns:360px 1fr;
  gap:42px;
  align-items:center;
}
.candidate-orb{
  min-height:360px;
  border-radius:50%;
  display:grid;
  place-items:center;
  color:white;
  font-size:6rem;
  font-weight:260;
  letter-spacing:-.09em;
  background:
    radial-gradient(circle at 28% 22%,rgba(255,255,255,.55),transparent 28%),
    conic-gradient(from 120deg,var(--green),var(--blue),var(--clay),var(--gold),var(--green));
  box-shadow:0 45px 100px rgba(31,97,77,.18);
}
blockquote{
  margin:24px 0 0;
  padding-left:22px;
  border-left:1px solid var(--green);
  color:var(--ink);
  font-size:1.18rem;
  line-height:1.55;
}
.candidate-detail{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.detail-panel{padding:34px}
.legal{max-width:900px;margin:0 auto 90px;padding:38px}
.legal h2{font-size:2rem}
.footer{max-width:var(--max);margin:30px auto 20px;padding:34px 22px;border-top:1px solid var(--line)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:28px}
.footer h2{font-size:2.4rem}
.footer h3{font-weight:430}
.footer-bottom{
  display:flex;
  justify-content:space-between;
  gap:18px;
  margin-top:24px;
  padding-top:18px;
  border-top:1px solid var(--line);
  color:var(--muted);
  font-size:.92rem;
}
.cookie-banner{
  position:fixed;
  z-index:120;
  left:20px;
  right:20px;
  bottom:20px;
  max-width:940px;
  margin:0 auto;
  padding:16px;
  display:none;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  border:1px solid var(--line);
  border-radius:28px;
  background:rgba(255,250,240,.88);
  backdrop-filter:blur(22px);
  box-shadow:var(--shadow);
}
.cookie-banner.show{display:flex}
.cookie-banner p{margin:4px 0 0}
.cookie-actions{display:flex;gap:10px;flex-shrink:0}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .85s ease,transform .85s cubic-bezier(.2,.7,.2,1)}
.reveal.visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  #webgl-stage{display:none}
}
@media(max-width:980px){
  body{
    padding-top:84px;
  }
  .nav{
    position:fixed;
    top:10px;
    left:50%;
    transform:translateX(-50%);
    width:calc(100% - 20px);
    max-width:none;
    margin:0;
    z-index:9999;
  }
    .nav-toggle{display:block}
  .nav-links{
    display:none;
    position:absolute;
    top:68px;
    left:0;
    right:0;
    flex-direction:column;
    padding:12px;
    border:1px solid var(--line);
    border-radius:26px;
    background:rgba(255,250,240,.97);
    backdrop-filter:blur(22px);
    box-shadow:var(--shadow);
  }
  .nav-links.open{display:flex}
  .nav-links a{width:100%}
  .hero,.installation,.participate-panel,.program-block,.candidate-hero,.candidate-detail{grid-template-columns:1fr}
  .hero{padding-top:74px}
  .control-panel{grid-template-columns:1fr}
  .atlas-grid,.candidates-grid,.candidates-grid.large,.footer-grid{grid-template-columns:1fr}
  .mission-strip{grid-template-columns:repeat(5,78vw)}
  .candidate-orb{border-radius:38px;min-height:280px}
  .footer-bottom{display:block}
  .cookie-banner{flex-direction:column;align-items:stretch}
}
@media(max-width:560px){
  h1{font-size:clamp(3.4rem,17vw,5rem)}
  h2{font-size:clamp(2.4rem,13vw,3.8rem)}
  .mission{min-height:300px}
  .installation-steps{grid-template-columns:1fr}
}


/* Overlay narrativo per la versione drone */
.flight-caption{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:18;
  pointer-events:none;
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,250,240,.62);
  backdrop-filter:blur(18px);
  box-shadow:0 16px 50px rgba(36,33,26,.10);
  color:var(--muted);
  font-size:.82rem;
  letter-spacing:.08em;
  text-transform:uppercase;
}
@media(max-width:780px){
  .flight-caption{left:18px;right:18px;bottom:14px;text-align:center}
}


/* MapLibre drone mode */
body.map-flight-ready .hero-copy{
  position:relative;
  z-index:10;
}
body.map-flight-ready .control-panel{
  position:relative;
  z-index:10;
}
body.map-flight-ready .nav,
body.map-flight-ready main,
body.map-flight-ready .footer,
body.map-flight-ready .cookie-banner{
  position:relative;
}
body.map-flight-ready .hero-copy:before{
  content:"";
  position:absolute;
  z-index:-1;
  inset:-24px -28px -20px -28px;
  border-radius:42px;
  background:linear-gradient(90deg, rgba(245,239,226,.76), rgba(245,239,226,.40), transparent);
  backdrop-filter:blur(1.5px);
}
.flight-caption{
  z-index:8;
}
@media(max-width:980px){
  #webgl-stage:after{
    background:
      linear-gradient(180deg, rgba(245,239,226,.78), rgba(245,239,226,.48) 48%, rgba(245,239,226,.66)),
      radial-gradient(circle at 50% 25%, rgba(255,250,240,.26), transparent 20rem);
  }
  body.map-flight-ready .hero-copy:before{
    inset:-16px;
    background:rgba(245,239,226,.66);
  }
}




/* Admin CMS */
.admin-page{
  background:#F8F1E5;
}
.admin-shell{
  max-width:1180px;
  margin:0 auto;
  padding:70px 22px 100px;
}
.admin-hero{
  border:1px solid var(--line);
  background:rgba(255,249,239,.78);
  border-radius:34px;
  padding:34px;
  box-shadow:var(--shadow);
  margin-bottom:24px;
}
.admin-hero h1{
  font-size:clamp(2.8rem,6vw,5.5rem);
}
.admin-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.admin-card{
  border:1px solid var(--line);
  background:rgba(255,249,239,.78);
  border-radius:28px;
  padding:24px;
  box-shadow:var(--shadow);
}
.admin-card h2{
  font-size:2rem;
}
.admin-field{
  display:grid;
  gap:8px;
  margin-bottom:16px;
}
.admin-field label{
  font-size:.82rem;
  color:var(--green);
  letter-spacing:.12em;
  text-transform:uppercase;
}
.admin-field textarea,
.admin-field input{
  width:100%;
  min-height:48px;
  border:1px solid var(--line);
  border-radius:16px;
  padding:13px 14px;
  background:white;
  color:var(--ink);
  font:inherit;
}
.admin-field textarea{
  min-height:110px;
  resize:vertical;
}
.admin-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.admin-note{
  color:var(--muted);
  font-size:.95rem;
}
.admin-preview-link{
  display:inline-flex;
  margin-top:18px;
}
@media(max-width:900px){
  .admin-grid{
    grid-template-columns:1fr;
  }
  }



.candidate-visual.has-photo{
  background:#efe3d0;
  overflow:hidden;
}
.candidate-img{
  display:block;
  width:100%;
  height:100%;
  min-height:250px;
  background-size:cover;
  background-position:center;
}
.candidate-orb.has-photo{
  background-size:cover;
  background-position:center;
}

.admin-page{
  background:#F8F1E5;
}
.admin-shell{
  max-width:1180px;
  margin:0 auto;
  padding:70px 22px 100px;
}
.admin-hero,
.admin-card,
.admin-subcard{
  border:1px solid var(--line);
  background:rgba(255,249,239,.82);
  border-radius:30px;
  padding:26px;
  box-shadow:var(--shadow);
}
.admin-hero{
  margin-bottom:20px;
}
.admin-hero h1{
  font-size:clamp(2.7rem,6vw,5.2rem);
}
.admin-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.admin-card h2{
  font-size:2.1rem;
}
.admin-subcard{
  margin:14px 0;
  padding:18px;
  box-shadow:none;
  background:rgba(255,255,255,.36);
}
.admin-subcard h3{
  font-size:1.4rem;
}
.admin-field{
  display:grid;
  gap:8px;
  margin-bottom:14px;
}
.admin-field label{
  color:var(--green);
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:.76rem;
}
.admin-field input,
.admin-field textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:16px;
  padding:13px 14px;
  background:white;
  color:var(--ink);
  font:inherit;
}
.admin-field textarea{
  min-height:105px;
  resize:vertical;
}
.admin-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:16px;
}
.admin-note{
  color:var(--muted);
}
@media(max-width:900px){
  .admin-grid{
    grid-template-columns:1fr;
  }
  }





/* =========================================================
   NAV FINALE DEFINITIVA — centrata, fissa, non sborda
   ========================================================= */

html,
body{
  overflow-x:hidden !important;
}

html body{
  padding-top:96px !important;
}

html body > nav.nav,
html body nav.nav{
  position:fixed !important;
  top:14px !important;
  left:50vw !important;
  right:auto !important;
  bottom:auto !important;
  transform:translateX(-50%) !important;

  width:min(1160px, calc(100vw - 160px)) !important;
  max-width:1160px !important;
  min-width:0 !important;
  box-sizing:border-box !important;

  margin:0 !important;
  z-index:2147483647 !important;

  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:12px !important;

  padding:9px 10px !important;
  border-radius:999px !important;
  border:1px solid rgba(111,29,42,.18) !important;
  background:rgba(255,249,239,.90) !important;
  backdrop-filter:blur(26px) saturate(1.20) !important;
  -webkit-backdrop-filter:blur(26px) saturate(1.20) !important;
  box-shadow:0 18px 58px rgba(75,34,28,.14) !important;
}

html body nav.nav .brand{
  flex:0 0 auto !important;
}

html body nav.nav .nav-links{
  flex:0 1 auto !important;
}

@media(max-width:980px){
  html body{
    padding-top:88px !important;
  }

  html body > nav.nav,
  html body nav.nav{
    top:10px !important;
    left:50vw !important;
    transform:translateX(-50%) !important;
    width:calc(100vw - 24px) !important;
    max-width:none !important;
    border-radius:24px !important;
    align-items:flex-start !important;
  }

  html body nav.nav .nav-links{
    top:66px !important;
  }
}





/* =========================================================
   LOGO BORELLI NEL MENU — FIX VISIBILITÀ
   ========================================================= */

html body nav.nav{
  min-height:104px !important;
  padding:12px 18px !important;
}

html body nav.nav .brand{
  gap:20px !important;
  align-items:center !important;
}

html body nav.nav .brand-glyph{
  width:92px !important;
  height:92px !important;
  flex:0 0 92px !important;
  border-radius:50% !important;
  background-image:url("/assets/img/borelli-logo.png?v=2") !important;
  background-size:contain !important;
  background-position:center !important;
  background-repeat:no-repeat !important;
  background-color:#fff !important;
  box-shadow:
    0 18px 46px rgba(179,38,45,.22),
    0 0 0 1px rgba(179,38,45,.20) !important;
}

html body nav.nav .brand strong{
  font-size:1.34rem !important;
  line-height:1.05 !important;
  letter-spacing:-.045em !important;
}

html body nav.nav .brand small{
  font-size:.92rem !important;
  margin-top:6px !important;
}

html body .hero{
  padding-top:178px !important;
}

html body .page-hero,
html body .candidate-hero,
html body .admin-shell{
  padding-top:178px !important;
}

@media(max-width:980px){
  html body nav.nav{
    min-height:82px !important;
    padding:9px 12px !important;
  }

  html body nav.nav .brand{
    gap:12px !important;
  }

  html body nav.nav .brand-glyph{
    width:68px !important;
    height:68px !important;
    flex-basis:68px !important;
  }

  html body nav.nav .brand strong{
    font-size:1.08rem !important;
  }

  html body nav.nav .brand small{
    font-size:.78rem !important;
  }

  html body .hero,
  html body .page-hero,
  html body .candidate-hero,
  html body .admin-shell{
    padding-top:136px !important;
  }
}


/* =========================================================
   PROGRAMMA HOME — riga unica scrollabile
   ========================================================= */

html body .mission-strip.horizontal-scroll,
html body .mission-strip{
  display:flex !important;
  flex-wrap:nowrap !important;
  gap:18px !important;
  overflow-x:auto !important;
  overflow-y:hidden !important;
  padding:8px 6px 26px !important;
  scroll-snap-type:x mandatory !important;
  -webkit-overflow-scrolling:touch !important;
  scrollbar-width:thin !important;
  scrollbar-color:rgba(179,38,45,.32) rgba(255,249,239,.38) !important;
  position:relative !important;
}

html body .mission-strip.horizontal-scroll::-webkit-scrollbar,
html body .mission-strip::-webkit-scrollbar{
  height:10px !important;
}

html body .mission-strip.horizontal-scroll::-webkit-scrollbar-track,
html body .mission-strip::-webkit-scrollbar-track{
  background:rgba(255,249,239,.46) !important;
  border-radius:999px !important;
}

html body .mission-strip.horizontal-scroll::-webkit-scrollbar-thumb,
html body .mission-strip::-webkit-scrollbar-thumb{
  background:rgba(179,38,45,.34) !important;
  border-radius:999px !important;
}

html body .mission-strip.horizontal-scroll .mission,
html body .mission-strip .mission{
  flex:0 0 285px !important;
  width:285px !important;
  min-width:285px !important;
  max-width:285px !important;
  min-height:385px !important;
  scroll-snap-align:start !important;
}

html body .mission-strip.horizontal-scroll .mission strong,
html body .mission-strip .mission strong{
  font-size:clamp(1.85rem, 2.4vw, 2.35rem) !important;
  line-height:.98 !important;
  word-break:normal !important;
  overflow-wrap:normal !important;
}

html body .mission-strip.horizontal-scroll .mission em,
html body .mission-strip .mission em{
  font-size:1rem !important;
  line-height:1.58 !important;
}

.scroll-hint{
  display:flex !important;
  justify-content:flex-end !important;
  align-items:center !important;
  gap:10px !important;
  margin:-16px 4px 14px !important;
  color:var(--green) !important;
  font-size:.78rem !important;
  letter-spacing:.14em !important;
  text-transform:uppercase !important;
  font-weight:600 !important;
}

.scroll-arrow{
  display:inline-grid !important;
  place-items:center !important;
  width:34px !important;
  height:34px !important;
  border-radius:999px !important;
  background:rgba(179,38,45,.10) !important;
  border:1px solid rgba(179,38,45,.18) !important;
  font-size:1.1rem !important;
  animation:scrollArrowPulse 1.4s ease-in-out infinite !important;
}

@keyframes scrollArrowPulse{
  0%,100%{
    transform:translateX(0);
    opacity:.72;
  }
  50%{
    transform:translateX(6px);
    opacity:1;
  }
}

/* Fade laterale per suggerire contenuto fuori schermo */
html body .mission-strip.horizontal-scroll::after,
html body .mission-strip::after{
  content:"" !important;
  position:sticky !important;
  right:-6px !important;
  flex:0 0 74px !important;
  width:74px !important;
  min-width:74px !important;
  align-self:stretch !important;
  pointer-events:none !important;
  background:linear-gradient(90deg, rgba(248,241,229,0), rgba(248,241,229,.78)) !important;
  border-radius:24px !important;
  margin-left:-74px !important;
  z-index:3 !important;
}

@media(max-width:980px){
  html body .mission-strip.horizontal-scroll .mission,
  html body .mission-strip .mission{
    flex-basis:78vw !important;
    width:78vw !important;
    min-width:78vw !important;
    max-width:78vw !important;
    min-height:340px !important;
  }

  .scroll-hint{
    justify-content:flex-start !important;
    margin-top:-8px !important;
  }
}


/* =========================================================
   CANDIDATI HOME — riga orizzontale scrollabile
   ========================================================= */

html body .candidates-home-scroll{
  display:flex !important;
  flex-wrap:nowrap !important;
  gap:18px !important;
  overflow-x:auto !important;
  overflow-y:hidden !important;
  padding:8px 6px 28px !important;
  scroll-snap-type:x mandatory !important;
  -webkit-overflow-scrolling:touch !important;
  scrollbar-width:thin !important;
  scrollbar-color:rgba(179,38,45,.32) rgba(255,249,239,.38) !important;
}

html body .candidates-home-scroll::-webkit-scrollbar{
  height:10px !important;
}

html body .candidates-home-scroll::-webkit-scrollbar-track{
  background:rgba(255,249,239,.46) !important;
  border-radius:999px !important;
}

html body .candidates-home-scroll::-webkit-scrollbar-thumb{
  background:rgba(179,38,45,.34) !important;
  border-radius:999px !important;
}

html body .candidates-home-scroll .candidate-card{
  flex:0 0 295px !important;
  width:295px !important;
  min-width:295px !important;
  max-width:295px !important;
  scroll-snap-align:start !important;
}

html body .candidates-home-scroll .candidate-visual,
html body .candidates-home-scroll .candidate-img{
  min-height:270px !important;
}

.candidates-scroll-hint{
  margin-top:-14px !important;
}

/* Fade laterale per suggerire altri candidati */
html body .candidates-home-scroll::after{
  content:"" !important;
  position:sticky !important;
  right:-6px !important;
  flex:0 0 78px !important;
  width:78px !important;
  min-width:78px !important;
  align-self:stretch !important;
  pointer-events:none !important;
  background:linear-gradient(90deg, rgba(248,241,229,0), rgba(248,241,229,.82)) !important;
  border-radius:24px !important;
  margin-left:-78px !important;
  z-index:3 !important;
}

@media(max-width:980px){
  html body .candidates-home-scroll .candidate-card{
    flex-basis:78vw !important;
    width:78vw !important;
    min-width:78vw !important;
    max-width:78vw !important;
  }
}

/* =========================================================
   PDF CASELLARIO — consultazione in pagina
   ========================================================= */

.candidate-docs{
  padding-top:20px !important;
}

.pdf-viewer-frame{
  width:100%;
  height:min(78vh, 760px);
  border:1px solid var(--line);
  border-radius:26px;
  overflow:hidden;
  background:rgba(255,249,239,.74);
  box-shadow:var(--shadow);
}

.pdf-viewer-frame iframe{
  display:block;
  width:100%;
  height:100%;
  border:0;
  background:white;
}

/* Su mobile il viewer resta alto ma gestibile */
@media(max-width:780px){
  .pdf-viewer-frame{
    height:70vh;
    border-radius:20px;
  }
}


.pdf-admin-note{
  margin:0 0 18px;
  padding:14px 16px;
  border:1px solid rgba(179,38,45,.18);
  border-radius:18px;
  background:rgba(179,38,45,.07);
  color:var(--muted);
  line-height:1.55;
}

.pdf-admin-note code{
  background:rgba(255,255,255,.7);
  border:1px solid var(--line);
  border-radius:8px;
  padding:2px 6px;
}


.admin-field select{
  width:100%;
  border:1px solid var(--line);
  border-radius:16px;
  padding:13px 14px;
  background:white;
  color:var(--ink);
  font:inherit;
}

.admin-help{
  display:block;
  color:var(--muted);
  line-height:1.45;
  font-size:.86rem;
}

.admin-help code{
  background:rgba(255,255,255,.72);
  border:1px solid var(--line);
  border-radius:8px;
  padding:2px 6px;
}

.pdf-viewer-frame{
  position:relative;
}

.pdf-viewer-frame:before{
  content:"Documento consultabile online";
  position:absolute;
  z-index:2;
  top:12px;
  right:12px;
  padding:8px 11px;
  border-radius:999px;
  background:rgba(255,249,239,.86);
  border:1px solid var(--line);
  color:var(--green);
  font-size:.72rem;
  letter-spacing:.10em;
  text-transform:uppercase;
  pointer-events:none;
}


/* =========================================================
   CASELLARIO PDF — apertura in modal separata
   ========================================================= */

.compact-docs{
  padding-top:18px !important;
}

.compact-docs .detail-panel{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:10px;
}

.pdf-modal{
  position:fixed;
  inset:0;
  z-index:2147483646;
  display:none;
  align-items:center;
  justify-content:center;
  padding:28px;
}

.pdf-modal.is-open{
  display:flex;
}

.pdf-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(23,19,19,.52);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}

.pdf-modal-panel{
  position:relative;
  z-index:2;
  width:min(1120px, calc(100vw - 42px));
  height:min(88vh, 900px);
  display:flex;
  flex-direction:column;
  border:1px solid rgba(111,29,42,.22);
  border-radius:34px;
  background:rgba(255,249,239,.96);
  box-shadow:0 34px 120px rgba(23,19,19,.32);
  overflow:hidden;
}

.pdf-modal-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:20px;
  padding:22px 24px 16px;
  border-bottom:1px solid var(--line);
}

.pdf-modal-head h2{
  font-size:clamp(1.55rem, 2.4vw, 2.35rem);
  margin:0;
  letter-spacing:-.05em;
}

.pdf-modal-close{
  width:44px;
  height:44px;
  border:1px solid var(--line);
  border-radius:999px;
  background:white;
  color:var(--ink);
  font-size:2rem;
  line-height:1;
  cursor:pointer;
  display:grid;
  place-items:center;
}

.pdf-modal-close:hover{
  background:rgba(179,38,45,.08);
}

.pdf-viewer-frame.modal-frame{
  flex:1;
  height:auto;
  min-height:0;
  border:0;
  border-radius:0;
  box-shadow:none;
  background:white;
}

.pdf-viewer-frame.modal-frame:before{
  content:"Documento consultabile online";
  top:14px;
  right:14px;
}

.pdf-viewer-frame.modal-frame iframe{
  width:100%;
  height:100%;
  border:0;
}

.pdf-modal-note{
  margin:0;
  padding:10px 18px 14px;
  font-size:.86rem;
  color:var(--muted);
  border-top:1px solid var(--line);
}

html.pdf-modal-open,
body.pdf-modal-open{
  overflow:hidden !important;
}

@media(max-width:780px){
  .pdf-modal{
    padding:12px;
  }

  .pdf-modal-panel{
    width:calc(100vw - 24px);
    height:88vh;
    border-radius:24px;
  }

  .pdf-modal-head{
    padding:18px 18px 12px;
  }

  .pdf-modal-close{
    width:40px;
    height:40px;
    font-size:1.7rem;
  }
}


/* =========================================================
   PAGINA PROGRAMMA — PDF completo, indice e badge coerenti
   ========================================================= */

.program-page-hero .program-actions{
  margin-top:24px;
}

.program-index-panel{
  padding-top:24px !important;
}

.compact-heading{
  margin-bottom:20px !important;
}

.compact-heading h2{
  max-width:780px;
}

.program-index-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:14px;
}

.program-index-link{
  min-height:120px;
  border:1px solid var(--line);
  border-radius:26px;
  background:rgba(255,249,239,.76);
  box-shadow:0 18px 60px rgba(75,34,28,.10);
  padding:18px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  text-decoration:none;
  color:var(--ink);
  transition:transform .22s ease, background .22s ease, border-color .22s ease;
}

.program-index-link:hover{
  transform:translateY(-4px);
  background:rgba(255,249,239,.92);
  border-color:rgba(179,38,45,.28);
}

.program-index-link span{
  color:var(--gold);
  font-size:.95rem;
  font-weight:700;
}

.program-index-link strong{
  font-size:1.18rem;
  line-height:1.1;
  letter-spacing:-.035em;
}

.program-block{
  scroll-margin-top:130px !important;
}

.program-block .chips span{
  border-color:rgba(179,38,45,.18) !important;
  background:rgba(179,38,45,.075) !important;
  color:var(--green) !important;
}

@media(max-width:980px){
  .program-index-grid{
    display:flex;
    overflow-x:auto;
    gap:12px;
    padding-bottom:18px;
    scroll-snap-type:x mandatory;
  }

  .program-index-link{
    flex:0 0 72vw;
    min-width:72vw;
    scroll-snap-align:start;
  }
}


/* =========================================================
   PROGRAMMA — missioni aprono PDF completo in modal
   ========================================================= */

.program-index-panel,
.program-index-grid,
.program-index-link{
  display:none !important;
}

.program-pdf-trigger{
  cursor:pointer !important;
  transition:transform .22s ease, border-color .22s ease, background .22s ease;
}

.program-pdf-trigger:hover{
  transform:translateY(-4px);
  border-color:rgba(179,38,45,.28) !important;
  background:rgba(255,249,239,.92) !important;
}

.program-pdf-trigger:focus-visible{
  outline:3px solid rgba(179,38,45,.28);
  outline-offset:4px;
}

.program-open-hint{
  display:inline-flex;
  margin-top:16px;
  color:var(--green);
  font-weight:700;
  border-bottom:1px solid rgba(179,38,45,.30);
}


/* =========================================================
   PROGRAMMA COMPLETO HTML IN MODAL
   ========================================================= */

.program-index-panel,
.program-index-grid,
.program-index-link{
  display:none !important;
}

.program-html-trigger{
  cursor:pointer !important;
  transition:transform .22s ease, border-color .22s ease, background .22s ease;
}

.program-html-trigger:hover{
  transform:translateY(-4px);
  border-color:rgba(179,38,45,.28) !important;
  background:rgba(255,249,239,.92) !important;
}

.program-html-trigger:focus-visible{
  outline:3px solid rgba(179,38,45,.28);
  outline-offset:4px;
}

.program-open-hint{
  display:inline-flex;
  margin-top:18px;
  color:var(--green);
  font-weight:700;
  border-bottom:1px solid rgba(179,38,45,.30);
}

.program-html-modal{
  position:fixed;
  inset:0;
  z-index:2147483646;
  display:none;
  align-items:center;
  justify-content:center;
  padding:28px;
}

.program-html-modal.is-open{
  display:flex;
}

.program-html-backdrop{
  position:absolute;
  inset:0;
  background:rgba(23,19,19,.54);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}

.program-html-panel{
  position:relative;
  z-index:2;
  width:min(1220px, calc(100vw - 42px));
  height:min(90vh, 940px);
  display:flex;
  flex-direction:column;
  border:1px solid rgba(111,29,42,.22);
  border-radius:34px;
  background:rgba(255,249,239,.98);
  box-shadow:0 34px 120px rgba(23,19,19,.34);
  overflow:hidden;
}

.program-html-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:20px;
  padding:24px 26px 18px;
  border-bottom:1px solid var(--line);
}

.program-html-head h2{
  font-size:clamp(1.8rem, 3vw, 3.2rem);
  line-height:.95;
  letter-spacing:-.065em;
  margin:0 0 8px;
}

.program-html-head p:not(.micro){
  color:var(--muted);
  margin:0;
}

.program-html-close{
  width:46px;
  height:46px;
  border:1px solid var(--line);
  border-radius:999px;
  background:white;
  color:var(--ink);
  font-size:2rem;
  line-height:1;
  cursor:pointer;
  display:grid;
  place-items:center;
}

.program-html-close:hover{
  background:rgba(179,38,45,.08);
}

.program-html-layout{
  flex:1;
  min-height:0;
  display:grid;
  grid-template-columns:270px 1fr;
}

.program-html-nav{
  border-right:1px solid var(--line);
  padding:18px;
  overflow:auto;
  background:rgba(255,255,255,.28);
}

.program-html-nav-btn{
  width:100%;
  border:1px solid transparent;
  border-radius:18px;
  background:transparent;
  padding:12px 12px;
  display:flex;
  align-items:center;
  gap:10px;
  text-align:left;
  cursor:pointer;
  color:var(--ink);
  font:inherit;
  font-weight:700;
}

.program-html-nav-btn span{
  color:var(--gold);
  min-width:28px;
}

.program-html-nav-btn:hover,
.program-html-nav-btn.is-active{
  background:rgba(179,38,45,.08);
  border-color:rgba(179,38,45,.16);
}

.program-html-body{
  overflow:auto;
  padding:26px;
  scroll-behavior:smooth;
}

.program-html-intro,
.program-html-section{
  border:1px solid var(--line);
  border-radius:30px;
  padding:26px;
  background:rgba(255,255,255,.56);
  margin-bottom:20px;
}

.program-html-intro h3,
.program-html-section h3{
  font-size:clamp(2.2rem, 4vw, 4.6rem);
  line-height:.92;
  letter-spacing:-.075em;
  margin:0 0 18px;
}

.program-html-number{
  color:var(--gold);
  font-weight:800;
  font-size:1rem;
  margin-bottom:12px;
}

.program-html-text p,
.program-html-intro p{
  font-size:1.03rem;
  line-height:1.72;
  color:var(--muted);
  max-width:860px;
}

.program-html-actions{
  margin-top:22px;
  border-top:1px solid var(--line);
  padding-top:18px;
}

.program-html-actions strong{
  display:block;
  margin-bottom:10px;
  color:var(--green);
}

.program-html-actions ul{
  margin:0;
  padding-left:20px;
  color:var(--muted);
  line-height:1.65;
}

.program-html-foot{
  padding:10px 18px 14px;
  font-size:.86rem;
  color:var(--muted);
  border-top:1px solid var(--line);
}

html.program-html-open,
body.program-html-open{
  overflow:hidden !important;
}

@media(max-width:900px){
  .program-html-modal{
    padding:12px;
  }

  .program-html-panel{
    width:calc(100vw - 24px);
    height:90vh;
    border-radius:24px;
  }

  .program-html-layout{
    grid-template-columns:1fr;
  }

  .program-html-nav{
    display:flex;
    gap:8px;
    overflow-x:auto;
    border-right:0;
    border-bottom:1px solid var(--line);
    padding:10px;
  }

  .program-html-nav-btn{
    flex:0 0 auto;
    width:auto;
    white-space:nowrap;
  }

  .program-html-body{
    padding:16px;
  }

  .program-html-intro,
  .program-html-section{
    padding:20px;
    border-radius:22px;
  }
}


/* =========================================================
   FIX DOPPIA MODAL PROGRAMMA
   La pagina Programma usa solo la modal HTML, non la vecchia PDF.
   ========================================================= */

.program-wrap .js-open-pdf-modal,
.program-wrap .program-pdf-trigger{
  cursor:default;
}

.program-wrap .program-pdf-trigger .program-open-hint{
  display:none !important;
}


/* =========================================================
   SEO CONTENT — testo locale leggibile ma discreto
   ========================================================= */

.seo-local-content{
  max-width:1180px;
  margin:0 auto 80px;
  padding:0 22px;
  color:var(--muted);
}

.seo-local-content h2{
  font-size:clamp(1.7rem, 3vw, 3rem);
  letter-spacing:-.055em;
  color:var(--ink);
  max-width:760px;
}

.seo-local-content p{
  max-width:860px;
  line-height:1.72;
  font-size:1rem;
}
