/*
 * GerinAuto 6 - pagine servizi riutilizzabili
 * Versione 1.5.5: CSS centralizzato per Revisione, Meccanica, Carrozzeria e Noleggio.
 */
.ga-service-page,
.ga-revisione-page,
.ga-meccanica-page,
.ga-carrozzeria-page,
.ga-noleggio-page,
.ga-contatti-page {
  display: grid;
  gap: 1.5rem;
}

.ga-page-hero,
.ga-service-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, .8fr);
  gap: 1.5rem;
  padding: clamp(1.3rem, 4vw, 2.5rem);
  color: #ffffff;
  border-radius: 28px;
  background: linear-gradient(135deg, var(--ga-blue-950), var(--ga-blue-800));
  box-shadow: var(--ga-shadow-md);
}

.ga-page-hero h1,
.ga-service-hero h1 {
  margin: .4rem 0 .7rem;
  line-height: 1.05;
}

.ga-page-hero p,
.ga-service-hero p {
  margin: 0;
  color: #d9e9f8;
}

.ga-page-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .7rem;
  margin-top: 1.25rem;
}

.ga-page-hero__side,
.ga-service-hero__side {
  display: grid;
  gap: .75rem;
}

.ga-quick-card {
  padding: 1rem;
  color: var(--ga-blue-950);
  border-radius: 18px;
  background: rgba(255, 255, 255, .95);
}

.ga-quick-card strong,
.ga-quick-card span {
  display: block;
}

.ga-section,
.ga-service-section {
  padding: 1rem 0;
}

.ga-section__head {
  max-width: 780px;
  margin-bottom: 1rem;
}

.ga-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.ga-card-grid--spaced {
  gap: 1.15rem;
}

.ga-mini-card,
.ga-price-card,
.ga-step-card,
.ga-note-box,
.ga-faq-box {
  padding: 1rem;
  border: 1px solid var(--ga-border);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: var(--ga-shadow-sm);
}

.ga-mini-card {
  position: relative;
}

.ga-mini-card--featured {
  border-color: rgba(19, 151, 99, .42);
  background: linear-gradient(145deg, rgba(19, 151, 99, .08), #ffffff);
}

.ga-mini-card h3,
.ga-price-card h3,
.ga-step-card h3 {
  margin-top: 0;
}

.ga-mini-card p,
.ga-step-card p {
  margin-bottom: 0;
  color: var(--ga-muted);
  font-weight: 650;
}

.ga-mini-card__tag {
  display: inline-flex;
  margin-bottom: .75rem;
  padding: .28rem .62rem;
  color: var(--ga-blue-950);
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
  border-radius: 999px;
  background: rgba(18, 58, 100, .08);
}

.ga-mini-card--featured .ga-mini-card__tag {
  color: #075f3b;
  background: rgba(19, 151, 99, .14);
}

.ga-mini-card__icon,
.ga-step-card__num {
  width: 52px;
  height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: .85rem;
  color: #f7fbff;
  font-size: .78rem;
  font-weight: 900;
  line-height: 1;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--ga-blue-950), var(--ga-blue-800));
  box-shadow: 0 8px 18px rgba(18, 58, 100, .18);
}

.ga-service-page .ga-mini-card__icon,
.ga-revisione-page .ga-mini-card__icon,
.ga-meccanica-page .ga-mini-card__icon,
.ga-carrozzeria-page .ga-mini-card__icon,
.ga-noleggio-page .ga-mini-card__icon {
  color: #f7fbff !important;
  background: linear-gradient(135deg, var(--ga-blue-950), var(--ga-blue-800)) !important;
}

.ga-mini-card__icon svg,
.ga-service-page .ga-mini-card__icon svg,
.ga-revisione-page .ga-mini-card__icon svg,
.ga-meccanica-page .ga-mini-card__icon svg,
.ga-carrozzeria-page .ga-mini-card__icon svg,
.ga-noleggio-page .ga-mini-card__icon svg {
  width: 27px !important;
  height: 27px !important;
  display: block !important;
  color: #f7fbff !important;
  fill: currentColor !important;
  stroke: none !important;
}

.ga-mini-card__icon svg path,
.ga-service-page .ga-mini-card__icon svg path,
.ga-revisione-page .ga-mini-card__icon svg path,
.ga-meccanica-page .ga-mini-card__icon svg path,
.ga-carrozzeria-page .ga-mini-card__icon svg path,
.ga-noleggio-page .ga-mini-card__icon svg path {
  fill: currentColor !important;
}

.ga-note-box p {
  margin-bottom: 0;
  color: var(--ga-muted);
}

.ga-note-box strong {
  color: var(--ga-blue-950);
}

.ga-note-box--strong {
  border-color: rgba(19, 151, 99, .38);
  background: linear-gradient(145deg, rgba(19, 151, 99, .09), #ffffff);
}

.ga-note-box--spaced {
  margin-top: 1rem;
}

.ga-checklist {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .7rem 1rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ga-checklist li {
  position: relative;
  padding: .8rem .85rem .8rem 2.2rem;
  color: var(--ga-muted);
  font-weight: 700;
  border: 1px solid var(--ga-border);
  border-radius: 14px;
  background: #ffffff;
}

.ga-checklist li::before {
  position: absolute;
  top: .78rem;
  left: .82rem;
  color: #139763;
  content: "✓";
  font-weight: 950;
}

.ga-step-grid,
.ga-price-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.ga-price-card {
  position: relative;
  overflow: hidden;
}

.ga-price-card--featured {
  border-color: rgba(19, 151, 99, .45);
  background: linear-gradient(145deg, rgba(19, 151, 99, .10), #ffffff);
}

.ga-price-card__value {
  display: block;
  margin: .55rem 0;
  color: var(--ga-blue-950);
  font-size: 1.7rem;
  line-height: 1;
}

.ga-price-card ul {
  margin-bottom: 0;
}

.ga-faq-box + .ga-faq-box {
  margin-top: .8rem;
}

.ga-faq-box h3 {
  margin: 0 0 .3rem;
  font-size: 1.05rem;
}

.ga-faq-box p {
  margin: 0;
  color: var(--ga-muted);
  font-weight: 650;
}

.ga-service-cta {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: center;
  padding: 1.35rem;
  color: #ffffff;
  border-radius: 22px;
  background: linear-gradient(135deg, var(--ga-blue-950), var(--ga-blue-800));
  box-shadow: var(--ga-shadow-md);
}

.ga-service-cta h2 {
  margin: 0 0 .3rem;
  color: #ffffff;
}

.ga-service-cta p {
  margin: 0;
  color: #ffffff;
  opacity: .92;
}

.ga-service-cta__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .65rem;
}

@media (max-width: 980px) {
  .ga-page-hero,
  .ga-service-hero,
  .ga-service-cta {
    grid-template-columns: 1fr;
  }

  .ga-card-grid,
  .ga-step-grid,
  .ga-price-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ga-service-cta__actions {
    justify-content: flex-start;
  }
}

@media (max-width: 680px) {
  .ga-page-hero,
  .ga-service-hero {
    border-radius: 20px;
  }

  .ga-card-grid,
  .ga-step-grid,
  .ga-price-grid,
  .ga-checklist {
    grid-template-columns: 1fr;
  }

  .ga-page-hero__actions,
  .ga-service-cta__actions {
    flex-direction: column;
    align-items: stretch;
  }
}

/* v1.5.6: contrasto icone servizi */
@media (max-width: 680px) {
  .ga-mini-card__icon, .ga-step-card__num { width:48px; height:48px; border-radius:14px; }
  .ga-mini-card__icon svg { width:25px !important; height:25px !important; }
}


/* v1.5.7: FAQ dinamiche servizi */
.ga-service-faq { margin-top: 1.6rem; padding-top: 1.2rem; border-top: 1px solid var(--ga-border); }
.ga-service-faq h2 { margin: 0 0 1rem; color: var(--ga-blue-950); }
.ga-service-faq__list { display: grid; gap: .7rem; }
.ga-service-faq__item { overflow: hidden; border: 1px solid var(--ga-border); border-radius: 16px; background: #fff; box-shadow: var(--ga-shadow-sm); }
.ga-service-faq__item summary { position: relative; padding: .95rem 3rem .95rem 1rem; color: var(--ga-blue-950); font-weight: 850; cursor: pointer; list-style: none; }
.ga-service-faq__item summary::-webkit-details-marker { display: none; }
.ga-service-faq__item summary::after { position: absolute; top: .9rem; right: 1rem; color: #139763; content: '+'; font-size: 1.35rem; font-weight: 900; line-height: 1; }
.ga-service-faq__item[open] summary::after { content: '−'; }
.ga-service-faq__item div { padding: 0 1rem 1rem; }
.ga-service-faq__item p { margin: 0; color: var(--ga-muted); font-weight: 650; line-height: 1.7; }


/* v1.7.1 - checklist pagine servizio: segnalatore verde ridotto */
.ga-checklist li{
  padding-left:2rem
}
.ga-checklist li::before{
  top:50%;
  left:.9rem;
  width:10px;
  height:10px;
  border-radius:50%;
  background:#139763;
  color:transparent;
  content:"";
  transform:translateY(-50%)
}
@media(max-width:700px){
  .ga-checklist li{
    padding-left:1.85rem
  }
  .ga-checklist li::before{
    left:.78rem;
    width:9px;
    height:9px
  }
}
