:root{
  --bg:#f4f7fb;
  --white:#fff;
  --ink:#0f2233;
  --muted:#556574;
  --navy:#0b2a3c;
  --blue:#0b5fa5;
  --blue-2:#0a4d86;
  --green:#4f7d6b;
  --border:rgba(15,34,51,.12);
  --shadow:0 16px 40px rgba(9,24,38,.10);
  --radius:16px;
  --max:1180px;
  --focus:0 0 0 4px rgba(11,95,165,.14);
}

*{box-sizing:border-box; min-width:0}
html,body{height:100%}

body{
  margin:0;
  font-family: system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";
  color:var(--ink);
  line-height:1.55;

  background:
    radial-gradient(900px 420px at 18% 0%, rgba(11,95,165,.12), transparent 55%),
    radial-gradient(760px 420px at 88% 10%, rgba(79,125,107,.12), transparent 60%),
    var(--bg);
  background-repeat:no-repeat;
  background-attachment:fixed;

  overflow-x:hidden;
}

img,svg,video,canvas{max-width:100%; height:auto}
a{color:inherit}

.container{max-width:var(--max); margin:0 auto; padding:0 18px}

.skip{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip:focus{
  left:18px; top:18px; width:auto; height:auto; padding:10px 12px;
  background:#fff; border:1px solid var(--border); border-radius:12px; z-index:9999;
  box-shadow:var(--shadow);
}

/* =========================
   HEADER + NAV
========================= */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.90);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:12px 0;
}

/* Brand */
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  flex:1 1 auto;
}

.brand img{
  width:44px; height:44px; object-fit:contain;
  border-radius:12px;
  background:#fff;
  border:1px solid var(--border);
  padding:6px;
  flex:0 0 auto;
}

.brand .t{display:flex; flex-direction:column; gap:2px}
.brand .name{
  margin:0;
  font-weight:900;
  letter-spacing:.2px;
  font-size:14px;
  text-transform:uppercase;
  color:var(--navy);
  white-space:nowrap;
}
.brand .tag{
  margin:0;
  font-size:12px;
  color:var(--muted);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  max-width:62ch;
}

/* Desktop nav */
.nav-main{flex:0 0 auto}
.nav-main ul{
  list-style:none;
  display:flex;
  gap:18px;
  margin:0;
  padding:0;
  align-items:center;
}
.nav-main a{
  text-decoration:none;
  color:var(--muted);
  font-size:14px;
  padding:10px 8px;
  border-radius:10px;
  white-space:nowrap;
}
.nav-main a:hover{color:var(--navy); background:rgba(11,95,165,.06)}
.nav-main a:focus-visible{outline:none; box-shadow:var(--focus)}

/* Actions */
.actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex:0 0 auto;
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(79,125,107,.10);
  border:1px solid rgba(79,125,107,.22);
  color:var(--navy);
  font-size:12px;
  white-space:nowrap;
}
.dot{width:8px;height:8px;border-radius:50%;background:var(--green)}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--navy);
  text-decoration:none;
  font-size:14px;
  cursor:pointer;
  box-shadow:0 6px 18px rgba(9,24,38,.06);
  white-space:nowrap;
}
.btn:hover{background:rgba(11,95,165,.06)}
.btn:focus-visible{outline:none; box-shadow:var(--focus)}
.btn.primary{
  background:linear-gradient(135deg,var(--blue),var(--blue-2));
  border-color:transparent;
  color:#fff;
  box-shadow:0 14px 28px rgba(11,95,165,.20);
  font-weight:900;
}
.btn.primary:hover{filter:brightness(1.02)}
.btn.ghost{background:transparent; box-shadow:none}

.hamburger{display:none}

/* =========================
   DROPDOWN DESKTOP (Sindacato)
========================= */
.nav-main li{position:relative}
.has-dropdown .dropdown{
  display:none;
  position:absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: 240px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:12px;
  box-shadow:0 16px 40px rgba(9,24,38,.12);
  padding:8px;
  z-index:2000;
}
.has-dropdown:hover .dropdown{display:block}
.dropdown li{display:block}
.dropdown a{
  display:block;
  padding:10px 10px;
  border-radius:10px;
  color:var(--navy);
  white-space:nowrap;
}
.dropdown a:hover{background:rgba(11,95,165,.06)}

/* =========================
   DRAWER MOBILE
========================= */
.drawer-backdrop{
  position:fixed; inset:0;
  background:rgba(0,0,0,.35);
  opacity:0; pointer-events:none;
  transition:opacity .18s ease;
  z-index:60;
}
.drawer{
  position:fixed; top:0; right:0; height:100%;
  width:min(86vw, 360px);
  background:rgba(255,255,255,.98);
  border-left:1px solid var(--border);
  box-shadow:-20px 0 60px rgba(0,0,0,.20);
  transform:translateX(110%);
  transition:transform .18s ease;
  z-index:70;
  padding:14px;
  display:flex; flex-direction:column; gap:10px;
}
.drawer-header{
  display:flex; align-items:center; justify-content:space-between;
  padding-bottom:10px;
  border-bottom:1px solid var(--border);
}
.drawer nav a{
  display:block;
  padding:12px 12px;
  border-radius:12px;
  background:rgba(11,95,165,.05);
  margin-top:8px;
  text-decoration:none;
  color:var(--navy);
  font-weight:900;
  font-size: 10pt;	
}
.drawer nav a:hover{background:rgba(11,95,165,.09)}
.drawer-actions{margin-top:auto; display:grid; gap:10px}

body.menu-open .drawer-backdrop{opacity:1; pointer-events:auto}
body.menu-open .drawer{transform:translateX(0)}

/* =========================
   BASE
========================= */
main{padding-bottom:18px}
section{padding:34px 0}

.card{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}

/* Section head */
.section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  margin-bottom:16px;
}
.section-head h3{margin:0; color:var(--navy)}
.section-head p{margin:8px 0 0; color:var(--muted); max-width:80ch}

/* =========================
   HERO
========================= */
.hero{padding:44px 0 22px}
.hero-grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:18px;
  align-items:stretch;
}
.kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  letter-spacing:.25px;
  color:var(--blue);
  font-weight:900;
  text-transform:uppercase;
}
.kicker .bar{width:22px;height:2px;background:var(--blue);border-radius:999px}

.hero h1{
  margin:10px 0 12px;
  font-size:42px;
  line-height:1.08;
  letter-spacing:-.7px;
  color:var(--navy);
}
.hero p{
  margin:0 0 16px;
  font-size:16px;
  color:var(--muted);
  max-width:68ch;
}
.ctas{display:flex; gap:12px; flex-wrap:wrap; margin-top:14px}

.trust{
  display:flex; flex-wrap:wrap; gap:10px;
  margin-top:14px;
  font-size:13px;
  color:var(--muted);
}
.badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 10px;
  border-radius:999px;
  background:rgba(11,95,165,.06);
  border:1px solid rgba(11,95,165,.14);
  color:var(--navy);
  font-weight:800;
}

/* hero side */
.hero-side{padding:16px; display:flex; flex-direction:column; gap:12px}
.hero-side h3{margin:0; color:var(--navy); font-size:16px}
.hero-side p{margin:0; color:var(--muted); font-size:13px}

.stats{display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:6px}
.stat{
  padding:12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:linear-gradient(180deg,#fff,#fbfdff);
}
.stat .n{font-size:22px;font-weight:900;color:var(--navy);line-height:1}
.stat .l{margin-top:6px;font-size:12px;color:var(--muted)}

.hero-actions{display:flex; gap:10px; flex-wrap:wrap}

/* =========================
   GRIDS
========================= */
.grid{display:grid; gap:14px}
.grid.services{grid-template-columns:repeat(3,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}

.service{
  padding:16px;
  display:flex;
  flex-direction:column;
  gap:12px;
  min-height:170px;
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.service:hover{
  transform:translateY(-2px);
  border-color:rgba(11,95,165,.22);
  box-shadow:0 18px 44px rgba(9,24,38,.12);
}
.service .top{display:flex; gap:12px; align-items:flex-start}
.icon{
  width:40px;height:40px;
  border-radius:14px;
  background:rgba(11,95,165,.08);
  border:1px solid rgba(11,95,165,.18);
  display:grid; place-items:center;
  flex:0 0 auto;
  color:var(--blue);
  font-weight:900;
  font-size:12px;
}
.service-text{min-width:0}
.service h4{margin:0;font-size:16px;color:var(--navy)}
.service p{margin:6px 0 0;color:var(--muted);font-size:13px}
.link{
  display:inline-flex; gap:8px; align-items:center;
  color:var(--blue);
  text-decoration:none;
  font-weight:900;
  font-size:13px;
  margin-top:auto;
}
.link:hover{text-decoration:underline}

/* =========================
   BANNER
========================= */
.banner{
  padding:18px;
  background:linear-gradient(135deg, rgba(11,95,165,.10), rgba(79,125,107,.10));
  border:1px solid rgba(11,95,165,.18);
  display:flex; align-items:center; justify-content:space-between;
  gap:16px;
}
.banner h3{margin:0;font-size:18px;color:var(--navy)}
.banner p{margin:6px 0 0;color:var(--muted);font-size:13px}
.banner .cta{display:flex; gap:10px; flex-wrap:wrap}

/* =========================
   BOX
========================= */
.box{padding:16px}
.label{font-size:12px;font-weight:900;letter-spacing:.25px;color:var(--green);text-transform:uppercase}
.box h4{margin:8px 0 8px;color:var(--navy)}
.box p{margin:0;color:var(--muted);font-size:13px}

/* =========================
   FORM
========================= */
label{display:block; font-size:13px; color:var(--muted); margin:10px 0 6px}
input,select,textarea{
  width:100%;
  padding:12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--ink);
  font:inherit;
  outline:none;
}
input:focus,select:focus,textarea:focus{
  border-color:rgba(11,95,165,.45);
  box-shadow:var(--focus);
}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:12px}

.consent{
  display:grid;
  grid-template-columns:18px 1fr;
  column-gap:10px;
  align-items:start;
  margin-top:10px;
}
.consent input{
  width:18px; height:18px;
  margin:2px 0 0 0;
}
.consent span{
  overflow-wrap:anywhere;
  word-break:break-word;
  color:var(--muted);
  font-size:12px;
  line-height:1.45;
}

/* =========================
   FOOTER
========================= */
.site-footer{
  margin-top:10px;
  padding:28px 0;
  background:rgba(255,255,255,.65);
  border-top:1px solid var(--border);
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:16px;
}
.footer-grid h5{margin:0 0 10px;color:var(--navy);font-size:14px}
.footer-grid a{
  display:block; padding:6px 0;
  text-decoration:none; color:var(--muted); font-size:13px;
}
.footer-grid a:hover{color:var(--navy)}
.footer-brand{display:flex; gap:12px; align-items:center}
.footer-logo{
  width:38px;height:38px;object-fit:contain;
  border-radius:12px;border:1px solid var(--border);
  padding:6px;background:#fff;
}
.footer-sub{color:var(--muted); font-size:12px; margin-top:4px}
.footer-note{color:var(--muted); font-size:13px; margin:12px 0 0}
.fineprint{
  margin-top:16px;
  color:var(--muted);
  font-size:12px;
  display:flex; justify-content:space-between;
  gap:10px; flex-wrap:wrap;
}

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr}
  .grid.services{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .pill{display:none}
  body{background-attachment:scroll}
}

@media (max-width: 680px){
  .nav-main ul{display:none}
  .hamburger{display:inline-flex}

  .has-dropdown .dropdown{display:none !important;}

  .grid.services{grid-template-columns:1fr}
  .grid.cols-2,.grid.cols-3{grid-template-columns:1fr}

  .hero h1{font-size:34px}
  .stats{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .banner{flex-direction:column; align-items:flex-start}
  .footer-grid{grid-template-columns:1fr}

  .brand .tag{max-width:32ch}
  .ctas .btn{width:100%}

  .section-head{
    flex-direction:column;
    align-items:flex-start;
  }
  .section-head .btn{
    width:100%;
    white-space:normal;
    justify-content:center;
  }
}
/* ===== Mobile drawer accordion (Sindacato) ===== */
.m-nav .m-acc-toggle{
  width:100%;
  text-align:left;
  border:0;
  cursor:pointer;

  padding:12px 12px;
  border-radius:12px;
  background:rgba(11,95,165,.05);
  margin-top:8px;

  color:var(--navy);
  font-weight:900;
  font-size:10pt;

  display:flex;
  align-items:center;
  justify-content:space-between;
}

.m-nav .m-acc-toggle:hover{
  background:rgba(11,95,165,.09);
}

.m-acc-icon{
  transition: transform .18s ease;
}

.m-acc-toggle[aria-expanded="true"] .m-acc-icon{
  transform: rotate(180deg);
}

.m-acc-panel{
  margin-top:8px;
  padding:8px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
}

.m-sublink{
  display:block;
  padding:10px 10px;
  border-radius:10px;
  text-decoration:none;
  color:var(--navy);
  font-weight:800;
  background: rgba(11,95,165,.03);
  margin-top:8px;
}

.m-sublink:hover{
  background: rgba(11,95,165,.07);
}
/* su mobile: nessun dropdown desktop */
@media (max-width: 680px){
  .has-dropdown .dropdown{ display:none !important; }
}
.tag-chip{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--navy);
  text-decoration:none;
  font-size:12px;
  font-weight:800;
}

.tag-chip:hover{
  background:rgba(11,95,165,.06);
}

.tag-chip.active{
  background:linear-gradient(135deg,var(--blue),var(--blue-2));
  color:#fff;
  border-color:transparent;
}
/* ===== Quill output rendering (frontend) ===== */
/* Applica solo dentro .content (dettaglio articolo) */
.content{
  font-size: 15px;
  line-height: 1.65;
}

.content p{ margin: 0 0 12px; }
.content h2{ margin: 18px 0 10px; }
.content h3{ margin: 16px 0 10px; }
.content ul, .content ol{ margin: 0 0 12px 18px; }
.content li{ margin: 6px 0; }

.content blockquote{
  margin: 12px 0;
  padding: 10px 14px;
  border-left: 4px solid rgba(11,95,165,.35);
  background: rgba(11,95,165,.06);
  border-radius: 12px;
}

.content pre{
  margin: 12px 0;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: #fff;
  overflow-x: auto;
  font-size: 13px;
}

/* Quill align */
.content .ql-align-center { text-align: center; }
.content .ql-align-right  { text-align: right; }
.content .ql-align-justify{ text-align: justify; }

/* Quill sizes (default Quill set) */
.content .ql-size-small { font-size: 0.85em; }
.content .ql-size-large { font-size: 1.25em; }
.content .ql-size-huge  { font-size: 1.6em; }

/* Link styling */
.content a{
  color: var(--blue);
  font-weight: 800;
  text-decoration: none;
}
.content a:hover{ text-decoration: underline; }
}
.news-cover{
  width:100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius:12px;
  border:1px solid var(--border);
  margin-bottom:10px;
}

