/* Vero INCI — articolo prodotto auto v4
   Layout allineato agli articoli prodotto tipo Riso Rosso / Artifit.
*/

.vi-explainer {
  max-width: 960px;
}

.vi-explainer-hero {
  margin-bottom: 1rem;
}

.vi-explainer-kicker {
  margin: 0 0 .45rem;
  color: #177d59;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.vi-explainer h1 {
  margin: 0 0 .45rem;
  color: #103b2e;
  font-size: clamp(1.55rem, 3.6vw, 2.45rem);
  line-height: 1.12;
  letter-spacing: -.035em;
}

.vi-explainer-updated {
  margin: .55rem 0 0;
  color: #5a746a;
  font-size: .88rem;
}

.vi-explainer-lead {
  margin: 1rem 0 1.1rem;
  border-left: 4px solid #23a474;
  padding: .85rem 1rem;
  border-radius: 14px;
  background: #f4fffa;
  color: #24483d;
  line-height: 1.65;
}

/* Hero stile articolo manuale */
.vi-basico-hero {
  margin: 1.1rem 0 1.35rem;
  padding: 1rem;
  border: 1px solid rgba(23, 128, 92, .18);
  border-radius: 18px;
  background:
    radial-gradient(circle at 12% 15%, rgba(55, 190, 132, .16), transparent 34%),
    linear-gradient(135deg, #f7fffb 0%, #ffffff 58%, #f8fbff 100%);
  box-shadow: 0 10px 28px rgba(20, 55, 45, .07);
}

.vi-basico-hero__inner {
  display: grid;
  grid-template-columns: minmax(110px, 180px) 1fr;
  gap: 1rem;
  align-items: center;
}

.vi-basico-hero img {
  width: 100%;
  max-width: 180px;
  height: auto;
  display: block;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 8px 22px rgba(0, 0, 0, .08);
}

.vi-basico-hero__kicker {
  margin: 0 0 .35rem;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #177d59;
}

.vi-basico-hero__title {
  margin: 0 0 .45rem;
  font-size: clamp(1.05rem, 2vw, 1.45rem);
  line-height: 1.18;
  color: #103b2e;
}

.vi-basico-hero__text {
  margin: 0;
  color: #31554a;
  line-height: 1.65;
}

/* Mappa rapida */
.vi-basico-map {
  margin: 1.2rem 0 1.35rem;
  padding: .95rem;
  border: 1px solid rgba(23, 128, 92, .18);
  border-radius: 18px;
  background: #f8fffb;
}

.vi-basico-map__title {
  margin: 0 0 .7rem;
  font-weight: 800;
  color: #103b2e;
}

.vi-basico-map__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .55rem;
}

.vi-basico-map a {
  display: block;
  padding: .65rem .7rem;
  border: 1px solid rgba(23, 128, 92, .2);
  border-radius: 14px;
  background: #fff;
  color: #145f45;
  font-weight: 700;
  text-decoration: none;
  line-height: 1.25;
}

.vi-basico-map a:hover {
  background: #effbf5;
}

/* Cards rapide */
.vi-basico-fast {
  margin: 1.25rem 0 1.45rem;
}

.vi-basico-fast__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
}

.vi-basico-fast-card {
  padding: .9rem;
  border: 1px solid rgba(23, 128, 92, .18);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 8px 22px rgba(20, 55, 45, .06);
}

.vi-basico-fast-card strong {
  display: block;
  margin-bottom: .35rem;
  color: #103b2e;
  font-size: .95rem;
}

.vi-basico-fast-card p {
  margin: 0;
  color: #37584d;
  line-height: 1.55;
}

/* Sezioni */
.vi-article-section {
  margin: 1.25rem 0;
  padding: 1.05rem;
  border: 1px solid rgba(20, 60, 48, .10);
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfffd 100%);
}

.vi-article-section > h2 {
  margin-top: 0;
  padding-bottom: .45rem;
  border-bottom: 1px solid rgba(23, 128, 92, .14);
  color: #103b2e;
}

.vi-article-section p {
  max-width: 72ch;
  line-height: 1.75;
  color: #24483d;
}

.vi-article-section ul {
  margin: .85rem 0 0;
  padding: .85rem 1rem .85rem 1.35rem;
  border: 1px solid rgba(23, 128, 92, .14);
  border-radius: 16px;
  background: #fff;
}

.vi-article-section li {
  margin: .42rem 0;
  line-height: 1.55;
}

.vi-article-section li::marker {
  color: #18825e;
}

/* Tabella */
.vi-table-wrap {
  overflow-x: auto;
  margin: 1rem 0;
  border: 1px solid rgba(20, 60, 48, .12);
  border-radius: 16px;
  background: #fff;
}

.vi-table-wrap table {
  width: 100%;
  border-collapse: collapse;
  font-size: .94rem;
}

.vi-table-wrap th,
.vi-table-wrap td {
  padding: .75rem .8rem;
  border-bottom: 1px solid rgba(20, 60, 48, .1);
  text-align: left;
  vertical-align: top;
}

.vi-table-wrap th {
  width: 30%;
  background: #f3fbf7;
  color: #123d31;
  font-weight: 800;
}

.vi-table-wrap tr:last-child th,
.vi-table-wrap tr:last-child td {
  border-bottom: 0;
}

/* FAQ */
.vi-article-section details,
details {
  margin: .45rem 0;
  padding: .7rem .85rem;
  border: 1px solid rgba(20, 60, 48, .12);
  border-radius: 14px;
  background: #fff;
}

.vi-article-section details summary,
details summary {
  cursor: pointer;
  font-weight: 700;
  color: #103b2e;
}

details p {
  margin-bottom: 0;
}

/* Related */
.spf-like-related {
  margin: 1.35rem 0 0;
  padding: 1rem;
  border: 1px solid rgba(20, 60, 48, .12);
  border-radius: 18px;
  background: #fbfffd;
}

.spf-like-related h2 {
  margin: 0 0 .85rem;
  color: #103b2e;
  font-size: 1.05rem;
}

.spf-like-related-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: .8rem;
  align-items: stretch;
}

.spf-like-related-card {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid rgba(23, 128, 92, .18);
  border-radius: 16px;
  background: #fff;
  text-decoration: none;
  box-shadow: 0 8px 20px rgba(15, 75, 55, .05);
}

.spf-like-related-card__media {
  display: block;
  aspect-ratio: 16 / 9;
  background: #f4fbf7;
  overflow: hidden;
}

.spf-like-related-card__media img,
.spf-like-related-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.spf-like-related-card__body {
  padding: .75rem;
}

.spf-like-related-card__kicker {
  margin: 0 0 .3rem;
  font-size: .72rem;
  font-weight: 800;
  color: #17805b;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.spf-like-related-card__title {
  margin: 0;
  color: #103b2e;
  font-weight: 800;
  line-height: 1.25;
  font-size: .92rem;
}

.spf-like-related-card__text {
  margin: .45rem 0 0;
  color: #3a5a50;
  line-height: 1.45;
  font-size: .84rem;
}

@media (max-width: 760px) {
  .vi-basico-map__grid,
  .vi-basico-fast__grid {
    grid-template-columns: 1fr;
  }

  .vi-basico-hero {
    padding: .85rem;
  }

  .vi-basico-hero__inner {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .vi-basico-hero img {
    margin: 0 auto;
    max-width: 145px;
  }

  .vi-article-section {
    padding: .9rem;
  }

  .vi-table-wrap table {
    font-size: .88rem;
  }

  .spf-like-related {
    padding: .85rem;
  }
}
