
:root {
  --color-bg: #F7F9FC;
  --color-surface: #FFFFFF;
  --color-surface-alt: #F1F5FB;
  --color-surface-strong: #E6EEF9;
  --color-text: #10233F;
  --color-text-muted: #4E6180;
  --color-border: #D7E0EE;
  --color-primary: #002060;
  --color-primary-hover: #001748;
  --color-accent: #47D45A;
  --color-accent-hover: #2FBE43;
  --color-on-primary: #FFFFFF;
  --color-dark-panel: #071D4D;
  --font-display: 'Source Serif 4', Georgia, serif;
  --font-body: 'Inter', system-ui, sans-serif;
  --text-xs: clamp(0.78rem, 0.74rem + 0.16vw, 0.88rem);
  --text-sm: clamp(0.92rem, 0.88rem + 0.2vw, 1rem);
  --text-base: clamp(1rem, 0.98rem + 0.22vw, 1.08rem);
  --text-lg: clamp(1.18rem, 1.05rem + 0.55vw, 1.45rem);
  --text-xl: clamp(1.85rem, 1.35rem + 1.5vw, 2.5rem);
  --text-2xl: clamp(2.6rem, 1.7rem + 3vw, 4.7rem);
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;
  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 18px;
  --shadow-soft: 0 10px 30px rgba(0, 32, 96, 0.08);
  --shadow-card: 0 18px 48px rgba(0, 32, 96, 0.06);
  --content-default: 1180px;
  --content-narrow: 760px;
  --transition: 180ms cubic-bezier(0.16, 1, 0.3, 1);
}
* , *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.68;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
.container { width: min(calc(100% - 2rem), var(--content-default)); margin-inline: auto; }
.section { padding: clamp(var(--space-12), 8vw, var(--space-24)) 0; }
.section-alt { background: var(--color-surface-alt); }
.eyebrow {
  display: inline-flex; align-items: center; gap: 0.5rem; margin-bottom: var(--space-4);
  font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-primary);
}
.eyebrow::before {
  content: ''; width: 10px; height: 10px; border-radius: 999px; background: var(--color-accent); box-shadow: 0 0 0 4px rgba(71,212,90,0.12);
}
.site-header {
  position: sticky; top: 0; z-index: 40; backdrop-filter: blur(14px);
  background: rgba(247,249,252,0.92); border-bottom: 1px solid rgba(215,224,238,0.95);
}
.header-inner { min-height: 78px; display: flex; align-items: center; justify-content: space-between; gap: var(--space-8); }
.brand { display: flex; align-items: center; gap: var(--space-4); min-width: 0; }
.brand img { width: 150px; height: auto; border-radius: 8px; background: #002060; box-shadow: var(--shadow-soft); }
.brand-meta { display: flex; flex-direction: column; gap: 0.1rem; }
.brand-meta strong { font-size: var(--text-sm); color: var(--color-primary); }
.brand-meta span { font-size: var(--text-xs); color: var(--color-text-muted); }
.nav { display: flex; align-items: center; gap: var(--space-6); }
.nav-links { display: flex; align-items: center; gap: var(--space-6); font-size: var(--text-sm); color: var(--color-text-muted); }
.nav-links a:hover, .nav-links a:focus-visible { color: var(--color-primary); }
.lang-toggle {
  display: inline-flex; align-items: center; justify-content: center; min-height: 42px; padding: 0.6rem 0.8rem;
  border: 1px solid var(--color-border); border-radius: 999px; font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--color-primary); background: var(--color-surface);
}
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; min-height: 48px; padding: 0.85rem 1.2rem;
  border-radius: 999px; border: 1px solid transparent; font-size: var(--text-sm); font-weight: 600;
  transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition);
}
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: var(--color-primary); color: var(--color-on-primary); box-shadow: 0 10px 24px rgba(0, 32, 96, 0.16); }
.btn-primary:hover, .btn-primary:focus-visible { background: var(--color-primary-hover); }
.btn-secondary { border-color: var(--color-border); background: var(--color-surface); color: var(--color-primary); }
.btn-secondary:hover, .btn-secondary:focus-visible { border-color: var(--color-primary); }
.hero, .hero-page {
  padding: clamp(var(--space-16), 10vw, 8rem) 0 clamp(var(--space-12), 8vw, var(--space-20));
  background: radial-gradient(circle at top right, rgba(71,212,90,0.10), transparent 26%), linear-gradient(180deg, rgba(0,32,96,0.035), rgba(0,32,96,0));
}
.hero-grid, .hero-page-grid {
  display: grid; grid-template-columns: minmax(0,1.15fr) minmax(300px,0.85fr); gap: clamp(var(--space-8), 5vw, var(--space-16)); align-items: end;
}
.hero h1, .hero-page h1 {
  margin: 0; font-family: var(--font-display); font-size: var(--text-2xl); line-height: 0.96; letter-spacing: -0.035em; color: var(--color-primary); max-width: 11ch;
}
.hero-lead, .hero-page p.lead { margin: var(--space-6) 0 0; max-width: 60ch; font-size: var(--text-lg); color: var(--color-text-muted); }
.hero-actions { display: flex; flex-wrap: wrap; gap: var(--space-4); margin-top: var(--space-8); }
.hero-trust { margin-top: var(--space-10); padding-top: var(--space-6); border-top: 1px solid var(--color-border); max-width: 68ch; color: var(--color-text-muted); font-size: var(--text-sm); }
.hero-panel, .hero-side {
  background: linear-gradient(160deg, var(--color-primary), var(--color-dark-panel)); color: var(--color-on-primary); border-radius: 22px; padding: var(--space-8); box-shadow: 0 24px 56px rgba(0,32,96,0.22);
}
.hero-panel strong, .hero-side strong { display: block; margin-bottom: var(--space-4); font-size: var(--text-lg); line-height: 1.15; }
.hero-panel p, .hero-side p { margin: 0; color: rgba(255,255,255,0.84); font-size: var(--text-sm); }
.mini-kicker {
  display: inline-flex; align-items: center; gap: 0.45rem; margin-bottom: var(--space-4); font-size: var(--text-xs); letter-spacing: 0.08em; text-transform: uppercase; font-weight: 700; color: #C8FFD0;
}
.mini-kicker::before { content: ''; width: 9px; height: 9px; border-radius: 999px; background: var(--color-accent); }
.section-heading { max-width: 780px; display: grid; gap: var(--space-4); margin-bottom: var(--space-10); }
.section-heading h2 { margin: 0; font-family: var(--font-display); font-size: var(--text-xl); line-height: 1.04; letter-spacing: -0.025em; color: var(--color-primary); }
.section-heading p { margin: 0; color: var(--color-text-muted); }
.grid-2, .grid-3 { display: grid; gap: var(--space-6); }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.card {
  background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-6); min-height: 100%; box-shadow: var(--shadow-soft);
}
.card h3 { margin: 0 0 var(--space-3); font-size: var(--text-lg); line-height: 1.14; letter-spacing: -0.02em; color: var(--color-primary); }
.card p, .card li { color: var(--color-text-muted); font-size: var(--text-sm); }
.card p { margin: 0; }
.card ul { margin: var(--space-4) 0 0 1.1rem; padding: 0; }
.principles { display: grid; grid-template-columns: 1.15fr 1fr 1fr; gap: var(--space-6); align-items: start; }
.principles .lead-block p { margin: 0; color: var(--color-text-muted); }
.list-link { display: inline-flex; align-items: center; gap: 0.45rem; margin-top: var(--space-6); font-size: var(--text-sm); font-weight: 700; color: var(--color-primary); }
.rich-block { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--space-8); align-items: start; }
.note-box {
  background: linear-gradient(180deg, rgba(0,32,96,0.98), rgba(7,29,77,0.98)); color: white; border-radius: 18px; padding: var(--space-8); box-shadow: 0 24px 56px rgba(0,32,96,0.18);
}
.note-box p { margin: 0; color: rgba(255,255,255,0.84); }
.note-box strong { display:block; margin-bottom: var(--space-4); font-size: var(--text-lg); }
.profile-block { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-8); }
.profile-role {
  display: inline-block; margin-bottom: var(--space-3); padding: 0.35rem 0.65rem; border-radius: 999px; background: rgba(71,212,90,0.12); color: #0D5F1B;
  font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
}
.profile-block h3 { margin: 0 0 var(--space-4); font-family: var(--font-display); font-size: var(--text-xl); line-height: 1.05; color: var(--color-primary); }
.profile-block p { margin: 0 0 var(--space-4); color: var(--color-text-muted); }
.footer {
  padding: var(--space-16) 0; background: linear-gradient(180deg, var(--color-primary), var(--color-dark-panel)); color: var(--color-on-primary); margin-top: var(--space-8);
}
.footer-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: var(--space-8); align-items: start; }
.footer .eyebrow { color: #D5FFDB; }
.footer .eyebrow::before { box-shadow: none; }
.footer h2 { margin: 0 0 var(--space-4); font-family: var(--font-display); font-size: var(--text-xl); line-height: 1.06; color: #FFFFFF; }
.footer p { margin: 0; color: rgba(255,255,255,0.82); }
.contact-list { display: grid; gap: var(--space-4); font-size: var(--text-sm); }
.contact-list strong { display: block; margin-bottom: 0.2rem; color: #FFFFFF; }
.contact-list a { color: #B7FFD0; }
@media (max-width: 1024px) {
  .hero-grid, .hero-page-grid, .principles, .rich-block, .profile-block, .footer-grid, .grid-3 { grid-template-columns: 1fr 1fr; }
  .grid-2 { grid-template-columns: 1fr; }
  .brand img { width: 126px; }
}
/* NUOVA */
@media (max-width: 780px) {
  .header-inner { min-height: 68px; flex-wrap: wrap; padding: 0.8rem 0; }
  .nav { width: 100%; justify-content: space-between; gap: var(--space-3); flex-wrap: wrap; }
  .nav-links {
    display: flex; width: 100%; order: 3; justify-content: flex-start; gap: 0.55rem; overflow-x: auto; padding-bottom: 0.25rem; scrollbar-width: none;
  }
  .nav-links::-webkit-scrollbar { display: none; }
  .nav-links a {
    flex: 0 0 auto; padding: 0.55rem 0.8rem; border: 1px solid var(--color-border); border-radius: 999px; background: var(--color-surface); white-space: nowrap;
  }
  .lang-toggle { order: 1; }
  .btn-primary { order: 2; }
  .hero-grid, .hero-page-grid, .grid-2, .grid-3, .principles, .rich-block, .profile-block, .footer-grid { grid-template-columns: 1fr; }
  .brand { align-items: flex-start; }
  .brand img { width: 112px; }
  .btn { width: auto; }
}