/* =========================================================
   LEGIS Dynamic Lists
   File: assets/css/dynamiclists.css
   ========================================================= */

/* ---------------------------------------------------------
   Base minima
--------------------------------------------------------- */

.legis-list {
  --legis-list-gap: var(--wp--preset--spacing--lg, 1.5rem);
  --legis-list-gap-small: var(--wp--preset--spacing--md, 1rem);

  --legis-list-radius: 4px;
  --legis-list-border: 1px solid rgba(15, 23, 42, .10);
  --legis-list-border-strong: 1px solid #d7dee8;

  --legis-list-shadow: var(--wp--preset--shadow--card, 0 8px 18px rgba(15, 36, 71, .06));
  --legis-list-shadow-hover: var(--wp--preset--shadow--card-hover, 0 10px 24px rgba(15, 36, 71, .10));

  --legis-list-bg: #fff;
  --legis-list-bg-soft: var(--wp--preset--color--yellow-soft, #F6F3E8);
  --legis-list-bg-muted: var(--wp--preset--color--gray-bg, #F5F7FA);

  --legis-list-text: var(--wp--preset--color--gray-text, #2B2B2B);
  --legis-list-primary: var(--wp--preset--color--blue-primary, #003A70);
  --legis-list-primary-hover: var(--wp--preset--color--blue-hover, #0B4FA2);
  --legis-list-accent: var(--wp--preset--color--yellow-accent, #FFD65A);

  --legis-list-title-font: var(--wp--preset--font-family--serif, "Merriweather", serif);
  --legis-list-body-font: var(--wp--preset--font-family--sans, "Source Sans 3", sans-serif);

  color: var(--legis-list-text);
  font-family: var(--legis-list-body-font);
}

.legis-list,
.legis-list * {
  box-sizing: border-box;
}

.legis-list__item {
  min-width: 0;
  margin: 0;
}

.legis-list__link {
  display: block;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

.legis-list__link:hover {
  color: inherit;
  text-decoration: none;
}

.legis-list__link:focus-visible {
  outline: 3px solid var(--legis-list-accent);
  outline-offset: 3px;
  border-radius: var(--legis-list-radius);
}

.legis-list__media {
  margin: 0;
}

.legis-list__logo {
  display: block;
  max-width: 100%;
  height: auto;
}

.legis-list__title {
  margin: var(--wp--preset--spacing--sm, .75rem) 0 0;
  color: var(--legis-list-primary);
  font-family: var(--legis-list-title-font);
  font-size: var(--wp--preset--font-size--xl, 1.5rem);
  font-weight: 500;
  line-height: 1.25;
}

.legis-list__link:hover .legis-list__title {
  color: var(--legis-list-primary-hover);
}

.legis-list__description {
  margin-top: var(--wp--preset--spacing--sm, .75rem);
  color: var(--legis-list-text);
  font-family: var(--legis-list-body-font);
  font-size: var(--wp--preset--font-size--md, 1rem);
  line-height: 1.45;
  hyphens: none;
}

.legis-list__description > :first-child {
  margin-top: 0;
}

.legis-list__description > :last-child {
  margin-bottom: 0;
}

.legis-list__description a {
  color: var(--legis-list-primary);
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

.legis-list__description a:hover {
  color: var(--legis-list-primary-hover);
}


/* ---------------------------------------------------------
   Layout: logo-grid
--------------------------------------------------------- */

.legis-list--logo-grid {
  --legis-list-logo-card-min-height: 132px;
  --legis-list-logo-max-height: 72px;
  --legis-list-logo-title-size: var(--wp--preset--font-size--md);

  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--legis-list-gap);
  align-items: stretch;
}

.legis-list--logo-grid .legis-list__item {
  display: flex;
  align-items: center;
  justify-content: center;

  min-height: var(--legis-list-logo-card-min-height);
  padding: var(--wp--preset--spacing--md, 1rem);

  text-align: center;
  background: var(--legis-list-bg);
  border: var(--legis-list-border);
  border-radius: var(--legis-list-radius);
  box-shadow: var(--legis-list-shadow);

  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}

.legis-list--logo-grid .legis-list__item:hover,
.legis-list--logo-grid .legis-list__item:focus-within {
  transform: translateY(-2px);
  box-shadow: var(--legis-list-shadow-hover);
  border-color: rgba(0, 58, 112, .22);
}

.legis-list--logo-grid .legis-list__link {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;

  width: 100%;
}

.legis-list--logo-grid .legis-list__media {
  display: flex;
  align-items: center;
  justify-content: center;

  width: 100%;
  min-height: var(--legis-list-logo-max-height);
}

.legis-list--logo-grid .legis-list__logo {
  width: auto;
  max-height: var(--legis-list-logo-max-height);
  margin-inline: auto;
  object-fit: contain;
}

.legis-list--logo-grid .legis-list__title {
  margin-top: var(--wp--preset--spacing--sm, .75rem);
  font-family: var(--legis-list-body-font);
  font-size: var(--legis-list-logo-title-size);
  font-weight: 450;
  line-height: 1.25;
}

/* ---------------------------------------------------------
   Layout: logo-grid-VAR3
--------------------------------------------------------- */

.var3 .legis-list--logo-grid {
  --legis-list-logo-card-min-height: 132px;
  --legis-list-logo-max-height: 96px;
  --legis-list-logo-title-size: var(--wp--preset--font-size--xl);

  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--legis-list-gap);
  align-items: stretch;
}


/* ---------------------------------------------------------
   Layout: organization-card
--------------------------------------------------------- */

.legis-list--organization-card {
  --legis-list-organization-logo-max-height: 92px;
  --legis-list-organization-title-size: var(--wp--preset--font-size--lg, 1.25rem);

  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--legis-list-gap);
  align-items: stretch;
}

.legis-list--organization-card .legis-list__item {
  display: flex;
  flex-direction: column;

  height: 100%;
  padding: var(--wp--preset--spacing--md, 1rem);

  background: var(--legis-list-bg);
  border: var(--legis-list-border);
  border-radius: var(--legis-list-radius);
  box-shadow: var(--legis-list-shadow);

  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}

.legis-list--organization-card .legis-list__item:hover,
.legis-list--organization-card .legis-list__item:focus-within {
  transform: translateY(-2px);
  box-shadow: var(--legis-list-shadow-hover);
  border-color: rgba(0, 58, 112, .22);
}

.legis-list--organization-card .legis-list__link {
  display: flex;
  flex-direction: column;
}

.legis-list--organization-card .legis-list__media {
  display: flex;
  align-items: center;
  justify-content: center;

  min-height: 110px;
  margin-bottom: var(--wp--preset--spacing--sm, .75rem);
  padding: var(--wp--preset--spacing--xs, .5rem);

  background: var(--legis-list-bg-soft);
  border: var(--legis-list-border);
  border-radius: var(--legis-list-radius);
}

.legis-list--organization-card .legis-list__logo {
  width: auto;
  max-height: var(--legis-list-organization-logo-max-height);
  margin-inline: auto;
  object-fit: contain;
}

.legis-list--organization-card .legis-list__title {
  margin-top: 0;
  font-size: var(--legis-list-organization-title-size);
/* Centra il nome dell'organizzazione */
  text-align: center !important;
}

.legis-list--organization-card .legis-list__description {
  padding-top: var(--wp--preset--spacing--sm, .75rem);
  border-top: var(--legis-list-border);
}


/* ---------------------------------------------------------
   Layout: person-card
--------------------------------------------------------- */

.legis-list--person-card {
  --legis-list-person-image-ratio: 4 / 3;
  --legis-list-person-title-size: var(--wp--preset--font-size--xl, 1.5rem);

  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--legis-list-gap);
  align-items: stretch;
}

.legis-list--person-card .legis-list__item {
  display: flex;
  flex-direction: column;

  height: 100%;
  padding: var(--wp--preset--spacing--md, 1rem);

  background: var(--legis-list-bg);
  border: var(--legis-list-border);
  border-radius: var(--legis-list-radius);
  box-shadow: var(--legis-list-shadow);

  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}

.legis-list--person-card .legis-list__item:hover,
.legis-list--person-card .legis-list__item:focus-within {
  transform: translateY(-2px);
  box-shadow: var(--legis-list-shadow-hover);
  border-color: rgba(0, 58, 112, .22);
}

.legis-list--person-card .legis-list__link {
  display: flex;
  flex-direction: column;
}

.legis-list--person-card .legis-list__media {
  margin-bottom: var(--wp--preset--spacing--sm, .75rem);
}

.legis-list--person-card .legis-list__logo {
  width: 100%;
  aspect-ratio: var(--legis-list-person-image-ratio);
  object-fit: cover;

  background: var(--legis-list-bg-muted);
  border: var(--legis-list-border-strong);
  border-radius: 2px;
  box-shadow: 0 8px 18px rgba(15, 36, 71, .06);
}

.legis-list--person-card .legis-list__title {
  margin-top: 0;
  font-size: var(--legis-list-person-title-size);
  text-align: center;
}

.legis-list--person-card .legis-list__description {
  padding-top: var(--wp--preset--spacing--sm, .75rem);
  border-top: 1px solid var(--wp--preset--color--gray-disabled, #CBD5E1);
  text-align: center;
}


/* ---------------------------------------------------------
   Layout: product-card
--------------------------------------------------------- */

.legis-list--product-card {
  --legis-list-product-image-max-height: 220px;
  --legis-list-product-title-size: var(--wp--preset--font-size--lg, 1.25rem);

  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--legis-list-gap);
  align-items: stretch;
}

.legis-list--product-card .legis-list__item {
  display: flex;
  flex-direction: column;

  height: 100%;
  padding: var(--wp--preset--spacing--md, 1rem);

  background: var(--legis-list-bg);
  border: var(--legis-list-border);
  border-radius: var(--legis-list-radius);
  box-shadow: var(--legis-list-shadow);

  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}

.legis-list--product-card .legis-list__item:hover,
.legis-list--product-card .legis-list__item:focus-within {
  transform: translateY(-2px);
  box-shadow: var(--legis-list-shadow-hover);
  border-color: rgba(0, 58, 112, .22);
}

.legis-list--product-card .legis-list__link {
  display: flex;
  flex-direction: column;
}

.legis-list--product-card .legis-list__media {
  display: flex;
  align-items: center;
  justify-content: center;

  min-height: 240px;
  margin-bottom: var(--wp--preset--spacing--sm, .75rem);
  padding: var(--wp--preset--spacing--sm, .75rem);

  background: var(--legis-list-bg-muted);
  border: var(--legis-list-border);
  border-radius: var(--legis-list-radius);
}

.legis-list--product-card .legis-list__logo {
  width: auto;
  max-height: var(--legis-list-product-image-max-height);
  margin-inline: auto;
  object-fit: contain;
}

.legis-list--product-card .legis-list__title {
  margin-top: 0;
  font-size: var(--legis-list-product-title-size);
}

.legis-list--product-card .legis-list__description {
  margin-top: var(--wp--preset--spacing--sm, .75rem);
}


/* ---------------------------------------------------------
   Layout con descrizione
--------------------------------------------------------- */

.legis-list--has-description .legis-list__description {
  display: block;
}


/* ---------------------------------------------------------
   Responsive
--------------------------------------------------------- */

@media (max-width: 1024px) {
  .legis-list--logo-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .legis-list--organization-card,
  .legis-list--product-card {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .legis-list--person-card {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 781px) {
  .legis-list {
    --legis-list-gap: var(--wp--preset--spacing--md, 1rem);
  }

  .legis-list--logo-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .legis-list--organization-card,
  .legis-list--person-card,
  .legis-list--product-card {
    grid-template-columns: 1fr;
  }

  .legis-list--organization-card .legis-list__item,
  .legis-list--person-card .legis-list__item,
  .legis-list--product-card .legis-list__item {
    padding: var(--wp--preset--spacing--md, 1rem);
  }

  .legis-list--person-card {
    --legis-list-person-title-size: var(--wp--preset--font-size--lg, 1.25rem);
  }

  .legis-list--product-card .legis-list__media {
    min-height: 200px;
  }
}

@media (max-width: 480px) {
  .legis-list--logo-grid {
    grid-template-columns: 1fr;
  }

  .legis-list--logo-grid .legis-list__item {
    min-height: 112px;
  }

  .legis-list--logo-grid {
    --legis-list-logo-max-height: 64px;
  }
}


/* ---------------------------------------------------------
   Motion safe
--------------------------------------------------------- */

@media (prefers-reduced-motion: reduce) {
  .legis-list__item,
  .legis-list__title {
    transition: none !important;
  }

  .legis-list__item:hover,
  .legis-list__item:focus-within {
    transform: none !important;
  }
}