.lfr-layout-structure-item-container {padding: 0;} .lfr-layout-structure-item-row {overflow: hidden;} .portlet-borderless .portlet-content {padding: 0;}.lfr-layout-structure-item-8ddfdd18-be4b-df85-c9fa-c46bdbb4955d {
margin-bottom: var(--spacer-4,1.5rem) !important;
}
.lfr-layout-structure-item-f0e157de-05bd-5413-eb3d-f457742ebcb5 {
margin-bottom: var(--spacer-3,1rem) !important;
}
/* Titolo standard allineato allo stile del blocco sotto */
.titolo-fonti-normative .component-heading,
.titolo-fonti-normative h1,
.titolo-fonti-normative h2,
.titolo-fonti-normative h3 {
  color: #1f2937;
  font-family: "Playfair Display", serif;
  font-size: 26px;
  font-weight: 600;
  line-height: 48px;
  letter-spacing: 0.2px;
  margin: 0;
}

/* Eventuale sottotitolo, se presente */
.titolo-fonti-normative .component-text,
.titolo-fonti-normative p {
  color: #262626;
  font-family: Inter, sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 24px;
  margin-top: 12px;
  margin-bottom: 0;
}

/* Mobile */
@media (max-width: 767px) {
  .titolo-fonti-normative .component-heading,
  .titolo-fonti-normative h1,
  .titolo-fonti-normative h2,
  .titolo-fonti-normative h3 {
    font-size: 32px;
    line-height: 38px;
  }
}/* Contenitore generale delle card principali */
.fonti-normative-cards {
  background: linear-gradient(180deg, #f8fbff 0%, #e6eef8 100%);
  border: none;
  border-radius: 18px;
  padding: 20px 12px 32px;
  margin-bottom: 32px;
}

/* Mantiene la griglia originale Liferay */
.fonti-normative-cards .grid-same-height {
  background: transparent !important;
}

/* Le righe restano righe Liferay: non forziamo grid né display contents */
.fonti-normative-cards .lfr-layout-structure-item-row {
  background: transparent !important;
  margin-bottom: 24px !important;
  overflow: visible !important;
  border-radius: 0 !important;
}

.fonti-normative-cards .lfr-layout-structure-item-row:last-child {
  margin-bottom: 0 !important;
}

/* Mantiene le colonne originali Liferay */
.fonti-normative-cards .row {
  align-items: stretch !important;
}

/* Le colonne devono solo allungare la card, senza cambiare larghezza */
.fonti-normative-cards .col,
.fonti-normative-cards [class*="col-"] {
  display: flex !important;
  flex-direction: column;
}

/* Wrapper Liferay della card */
.fonti-normative-cards .lfr-layout-structure-item-card-bianca,
.fonti-normative-cards .lfr-layout-structure-item-card-bianca > div {
  display: flex !important;
  flex-direction: column;
  flex: 1 1 auto;
  height: 100% !important;
}

/* Card */
.fonti-normative-cards .card.card-bianca {
  background: linear-gradient(180deg, #ffffff 0%, #f4f8fd 100%);
  border: 1px solid #c7d5e6;
  border-radius: 18px;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.06);
  padding: 22px 24px;
  height: 100% !important;
  min-height: 184px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1 1 auto;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

/* Hover fermo */
.fonti-normative-cards .card.card-bianca:hover {
  border-color: #c7d5e6;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.06);
  transform: none !important;
}

/* Titolo */
.fonti-normative-cards .card.card-bianca .title {
  color: #1f2937;
  font-family: "Playfair Display", serif;
  font-size: 20px;
  font-weight: 600;
  line-height: 26px;
  letter-spacing: 0.18px;
  margin: 0;
  overflow: visible;
  display: block;
}

/* Testo */
.fonti-normative-cards .card.card-bianca .text {
  color: #262626;
  font-family: Inter, sans-serif;
  font-size: 15px;
  font-weight: 400;
  line-height: 23px;
  letter-spacing: 0.07px;
  margin: 0;
  flex-grow: 1;
  overflow: visible;
  display: block;
}

/* Link sempre in basso */
.fonti-normative-cards .card.card-bianca .link-wrapper {
  width: 100% !important;
  display: flex;
  justify-content: flex-end;
  margin-top: auto;
}

/* Link */
.fonti-normative-cards .card.card-bianca .consob-link {
  color: #134dce;
  font-family: Inter, sans-serif;
  font-size: 15px;
  font-weight: 600;
  line-height: 22px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.fonti-normative-cards .card.card-bianca .consob-link:hover,
.fonti-normative-cards .card.card-bianca .consob-link:focus {
  color: #0b3aa8;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.fonti-normative-cards .card.card-bianca .consob-link:focus-visible {
  outline: 2px solid #134dce;
  outline-offset: 3px;
  border-radius: 4px;
}

/* Mobile */
@media (max-width: 767px) {
  .fonti-normative-cards {
    padding: 16px 10px 28px;
  }

  .fonti-normative-cards .lfr-layout-structure-item-row {
    margin-bottom: 16px !important;
  }

  .fonti-normative-cards .card.card-bianca {
    min-height: auto;
    padding: 18px;
  }

  .fonti-normative-cards .card.card-bianca .title {
    font-size: 19px;
    line-height: 25px;
  }

  .fonti-normative-cards .card.card-bianca .text {
    font-size: 14px;
    line-height: 22px;
  }

  .fonti-normative-cards .card.card-bianca .link-wrapper {
    justify-content: flex-start;
  }
}.lfr-layout-structure-item-e27bcb6b-80cb-e138-d93d-ef643379e4d7 {
background-color: rgb(255, 255, 255) !important;
border-radius: 12px !important;
}
.lfr-layout-structure-item-566e66e1-aabb-8b3f-abde-a610feb2bf95 {
background-color: rgb(255, 255, 255) !important;
border-radius: 12px !important;
margin-bottom: var(--spacer-4,1.5rem) !important;
}
.lfr-layout-structure-item-88d250a0-564a-9d3a-a050-4d9c51e2a187 {
margin-bottom: var(--spacer-4,1.5rem) !important;
}
.fonti-normative {
  --bg-start: #f8fbff;
  --bg-end: #e6eef8;
  --surface-start: #ffffff;
  --surface-end: #f4f8fd;
  --surface-alt: #eef4ff;
  --text: #262626;
  --title: #1f2937;
  --line: #c7d5e6;
  --accent: #0457e7;
  --accent-soft: #dbe9ff;
  --example-start: #eaf1f8;
  --example-end: #d6e2f0;
  --focus: #ffbf47;
  --shadow: 0 8px 18px rgba(15, 23, 42, 0.06);
  --shadow-hover: 0 12px 24px rgba(15, 23, 42, 0.1);
  --radius-xl: 18px;
  --radius-md: 12px;

  color: var(--text);
  line-height: 1.5;
}

.fonti-normative * {
  box-sizing: border-box;
}

.fonti-normative__wrap {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: 20px 12px 32px;
  background: linear-gradient(180deg, var(--bg-start) 0%, var(--bg-end) 100%);
  border-radius: 18px;
}

.fonti-normative__intro {
  background: linear-gradient(180deg, var(--surface-start) 0%, var(--surface-end) 100%);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: 18px;
  box-shadow: var(--shadow);
  margin-bottom: 16px;
}

.fonti-normative__label {
  margin: 0 0 6px;
  font-size: 14px;
  font-weight: 700;
  color: var(--accent);
}

.fonti-normative__title {
  margin: 0 0 8px;
  font-size: 26px;
  line-height: 1.15;
  font-weight: 700;
  color: var(--title);
}

.fonti-normative__text {
  margin: 0;
  font-size: 16px;
  color: var(--text);
}

.fonti-normative__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  align-items: stretch;
}

.fonti-normative__card {
  background: linear-gradient(180deg, var(--surface-start) 0%, var(--surface-end) 100%);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: 18px;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  min-height: 300px;
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.fonti-normative__card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
}

.fonti-normative__card-head {
  display: grid;
  grid-template-columns: 46px 1fr;
  gap: 12px;
  align-items: start;
  margin-bottom: 12px;
}

.fonti-normative__icon {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  background: linear-gradient(180deg, #f7fbff 0%, var(--surface-alt) 100%);
  border: 1px solid #cfe0ff;
  display: flex;
  align-items: center;
  justify-content: center;
}

.fonti-normative__icon img {
  width: 30px;
  height: 30px;
  object-fit: contain;
  display: block;
}

.fonti-normative__kicker {
  display: inline-block;
  margin-bottom: 5px;
  padding: 4px 8px;
  border-radius: 999px;
  background: linear-gradient(180deg, #edf5ff 0%, var(--accent-soft) 100%);
  color: var(--accent);
  font-size: 13px;
  line-height: 1.2;
  font-weight: 700;
  text-transform: uppercase;
}

.fonti-normative__card-title {
  margin: 0;
  min-height: 52px;
  font-size: 21px;
  line-height: 27px;
  font-weight: 600;
  color: var(--title);
}

.fonti-normative__description {
  margin: 0 0 6px;
  min-height: 72px;
  font-size: 16px;
  line-height: 1.45;
  color: var(--text);
}

.fonti-normative__example {
  margin-top: 0;
  padding: 12px;
  background: linear-gradient(180deg, var(--example-start) 0%, var(--example-end) 100%);
  border: 1px solid #b9cadd;
  border-radius: var(--radius-md);
  color: var(--text);
}

.fonti-normative__example strong {
  display: block;
  margin-bottom: 4px;
  font-size: 15px;
  color: var(--text);
}

.fonti-normative__example p {
  margin: 0;
  font-size: 15px;
  line-height: 1.45;
  color: var(--text);
}

.fonti-normative__card:focus-within {
  outline: 3px solid var(--focus);
  outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
  .fonti-normative *,
  .fonti-normative *::before,
  .fonti-normative *::after {
    animation: none !important;
    transition: none !important;
  }

  .fonti-normative__card:hover {
    transform: none;
  }
}

@media (max-width: 860px) {
  .fonti-normative__grid {
    grid-template-columns: 1fr;
  }

  .fonti-normative__card {
    min-height: auto;
  }

  .fonti-normative__card-title,
  .fonti-normative__description {
    min-height: 0;
  }
}

@media (max-width: 480px) {
  .fonti-normative__wrap {
    padding: 16px 10px 28px;
  }

  .fonti-normative__intro,
  .fonti-normative__card {
    padding: 16px;
  }

  .fonti-normative__title {
    font-size: 26px;
  }

  .fonti-normative__card-title {
    font-size: 19px;
    line-height: 25px;
  }

  .fonti-normative__text,
  .fonti-normative__description {
    font-size: 15px;
  }

  .fonti-normative__example p {
    font-size: 14px;
  }

  .fonti-normative__kicker {
    font-size: 12px;
  }
}