.lfr-layout-structure-item-container {padding: 0;} .lfr-layout-structure-item-row {overflow: hidden;} .portlet-borderless .portlet-content {padding: 0;}/* =========================================================
   Main Regulatory Sources - stile card senza rompere same height grid
   Classe da mettere sul contenitore: fonti-card-stabili
   ========================================================= */


/* Non disattiva la same height grid */
.fonti-card-stabili .lfr-layout-structure-item-card-bianca {
  margin-bottom: 24px !important;
}

/* Mantiene l'altezza generata da Liferay */
.fonti-card-stabili .lfr-layout-structure-item-card-bianca > div {
  height: 100% !important;
}

/* Stile card senza modificare i link */
.fonti-card-stabili .card.card-bianca {
  height: 100% !important;
  display: flex !important;
  flex-direction: column !important;

  border-radius: 16px !important;
  border: 1px solid #d8e2f0 !important;
  background: #ffffff !important;
  box-shadow: 0 6px 16px rgba(0, 43, 92, 0.08) !important;
}

/* Titolo compatto e più grande */
.fonti-card-stabili .card.card-bianca .title {
  margin-bottom: 8px !important;
  padding-bottom: 0 !important;
}

.fonti-card-stabili .card.card-bianca .title div {
  font-size: 1.18rem !important;
  line-height: 1.3 !important;
}

/* Testo compatto e più piccolo */
.fonti-card-stabili .card.card-bianca .text {
  margin-bottom: 12px !important;
}

.fonti-card-stabili .card.card-bianca .text div {
  font-size: 0.95rem !important;
  line-height: 1.45 !important;
}

/* Link sotto il testo, senza modificarne colore o dimensione */
.fonti-card-stabili .card.card-bianca .link-wrapper {
  margin-top: auto !important;
  padding-top: 8px !important;
}

/* Evita movimenti delle card, ma senza rompere le altezze */
.fonti-card-stabili .card.card-bianca,
.fonti-card-stabili .card.card-bianca:hover {
  transform: none !important;
}

/* Mobile */
@media (max-width: 768px) {
  .fonti-card-stabili .lfr-layout-structure-item-card-bianca {
    margin-bottom: 18px !important;
  }
}.lfr-layout-structure-item-9262f898-28cd-a787-a54c-478d71aeca67 {
margin-bottom: var(--spacer-4,1.5rem) !important;
}
.lfr-layout-structure-item-e27bcb6b-80cb-e138-d93d-ef643379e4d7 {
background-color: rgb(255, 255, 255) !important;
border-radius: 12px !important;
margin-bottom: var(--spacer-5,3rem) !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: #163a5c;
    --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: 28px;
    line-height: 1.15;
    font-weight: 700;
    color: var(--text);
  }

  .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: 22px;
    line-height: 1.15;
    color: var(--text);
  }

  .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: 24px;
    }

    .fonti-normative__card-title {
      font-size: 20px;
    }

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

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

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