/* 1) Box-sizing universale */
*, *::before, *::after {
  box-sizing: border-box;
}

/* 2) Header fisso full-width */
header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  /* width auto garantisce l’uso di left/right */
  width: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;

  background-color: #f5f5f5;
  padding: 10px 30px;
  border-bottom: 1px solid #ccc;
  box-shadow: 0 2px 5px rgba(0,0,0,0.1);
  z-index: 999;
}

/* 3) Wrapper centrale (facoltativo) */
header .container {
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* Se usi il wrapper, sposta qui dentro .header-left e nav.menu */

/* Left side: logo + titolo */
.header-left {
  display: flex;
  align-items: center;
  gap: 15px;
}

.header-logo {
  height: 60px;
  width: auto;
  object-fit: contain;
}

.header-title {
  display: flex;
  flex-direction: column;
  line-height: 1.1;
}
.header-title h1 {
  font-size: 1.7em;
  font-weight: bold;
  margin: 0;
}
.header-title p {
  font-size: 0.85em;
  margin: 0;
  color: #666;
}

/* Menu di navigazione */
nav.menu {
  display: flex;
  gap: 20px;
}
nav.menu a {
  text-decoration: none;
  color: #333;
  font-weight: 500;
  font-size: 1.2em;
  font-weight: bold;
}
nav.menu a:hover {
  text-decoration: underline;
}

/* 4) Padding sul body per compensare l’header fisso */
body {
  margin: 0;
  padding-top: calc(10px + 60px + 10px); /* padding-top = header padding verticale + img-height + padding */
  font-family: Arial, sans-serif;
}

/* 5) Responsive: menu a capo o hamburger sotto 768px */
@media (max-width: 768px) {
  header {
    padding: 10px 20px;
  }
  nav.menu {
    flex-wrap: wrap;
    gap: 10px;
  }
  /* oppure nascondi nav.menu e mostra un’icona per il drawer */
}
