/* Corpo e sfondo */
html, body {
  margin: 0;
  padding: 0;
  height: 100%;
  font-family: "Montserrat", "Segoe UI", sans-serif;
  background: url('sfondo.jpg') no-repeat center center fixed;
  background-size: cover;
  color: #222;
  display: flex;
  justify-content: center;
  align-items: center;
}

/* Tabella principale */
.layout {
  width: 100%;
  max-width: 1000px;
  border-collapse: collapse;
  table-layout: fixed;
}

/* Celle invisibili ma con padding */
.layout td {
  border: none;
  padding: 15px 20px;
  vertical-align: middle;
}

/* Titolo */
.title {
  text-align: center;
  font-size: 3rem;
  font-weight: 700;
  color: #004c91;
  letter-spacing: 2px;
  padding-top: 30px;
}

/* Sottotitolo */
.subtitle {
  text-align: center;
  font-size: 1.2rem;
  color: #333;
  padding-bottom: 20px;
}

/* Spazio vuoto */
.spazio {
  height: 5px;
}

/* Sezioni Portfolio e Programma */
.section td {
  vertical-align: middle;
}

.icon {
  width: 15%;
  text-align: right;
}

.icon img {
  width: 60px;
  height: 60px;
  object-fit: contain;
}

.link {
  width: 25%;
  text-align: left;
}

.link a {
  font-size: 1.3rem;
  font-weight: 600;
  color: #0077cc;
  text-decoration: none;
}

.link a:hover {
  text-decoration: underline;
}

.desc {
  text-align: left;
  font-size: 1rem;
  color: #222;
}

/* Footer */
.footer td {
  font-size: 0.9rem;
  padding-top: 20px;
  padding-bottom: 20px;
}

.spazio {
  height: 10px;
}

.foot-left {
  text-align: left;
}

.foot-center {
  text-align: center;
}

.foot-right {
  text-align: right;
}
