/* Services Cards (full-bleed) */
.section--services{
  margin: 60px 0;
  /* sfondo neutro che funziona in light/dark */
  background: var(--surface, #f9f9f9);

  /* esponiamo la variabile per il "morso" dell'angolo */
  --services-bg: var(--surface, #f9f9f9);
}

/* contenitore full-bleed con padding orizzontale */
.section--services .services__wrap{
  max-width: 1600px;        /* ampio respiro ma non infinito */
  margin: 0 auto;
  padding: 24px 16px;       /* gutter ai bordi */
}

.section--services .services__head{
  max-width: var(--body-max, 900px);
  margin: 0 auto 20px;
  padding: 0 4px;
}
.section--services .services__title{
  font-family: var(--font-title, "Roboto Condensed", system-ui, sans-serif);
  text-transform: uppercase;
  letter-spacing: 0.02em;
  font-weight: 700;
  color: var(--text-strong);
  margin: 0 0 8px 0;
}
.section--services .services__kicker{
  font-weight: 300;
  color: var(--text);
  opacity: .9;
  margin: 0;
}

/* GRID */
.section--services .services__grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-top: 24px;
}
@media (min-width: 700px){
  .section--services .services__grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1100px){
  .section--services .services__grid{ grid-template-columns: repeat(4, 1fr); }
}

/* CARD */
.card{
  position: relative;
  overflow: clip; /* taglio al vivo delle immagini */
  border-radius: 14px;
  background: var(--panel, #fff);

  /* bordo 1px grigio chiaro (light) / soft (dark) */
  border: 1px solid #e8e8e8;

  /* Ombra leggera che scompare a hover/focus */
  box-shadow: 0 10px 28px rgba(0,0,0,.10);

  transition:
    transform .35s cubic-bezier(.22,1,.36,1),
    box-shadow .25s ease,
    border-color .25s ease;
  will-change: transform;
}

/* “Morso” all’angolo in basso a destra (solo CSS) */
.card::after{
  content:"";
  position: absolute;
  /* il cerchio copre l’angolo in basso a destra */
  right: -12px;              /* sposta il centro fuori dal box per un “morso” dolce */
  bottom: -12px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  /* stesso colore dello sfondo della sezione: sembra scavato dal pannello */
  background: var(--services-bg);
  /* micro-anti aliasing per bordi belli */
  outline: 1px solid transparent;
  pointer-events: none;
  z-index: 1;
}

/* Accento rosso elegante (sottile) che cresce on-hover */
.card::before{
  content:"";
  position: absolute;
  inset: 0 auto auto 0;
  height: 3px;
  width: 36%;
  background: var(--brand, #e10600);
  transition: width .45s cubic-bezier(.2,.8,.2,1);
  z-index: 2;
}
.card:hover::before{ width: 100%; }

/* Immagine */
.card__media{
  position: relative;
  aspect-ratio: 16/10;    /* croppa bene su tutti i device */
  overflow: hidden;
}
.card__media img{
  width: 100%; height: 100%;
  object-fit: cover;
  transform: scale(1.02);
  transition: transform 1.2s ease;
}
.card:hover .card__media img{ transform: scale(1.06); }

/* Scrim leggero per leggere sempre i testi se appaiono sull’immagine */
.card__scrim{
  position: absolute; inset: 0;
  background: linear-gradient(to bottom,
    color-mix(in oklab, #000 0%, transparent) 0%,
    color-mix(in oklab, #000 22%, transparent) 70%,
    transparent 100%);
  pointer-events: none;
}

/* Contenuto */
.card__body{
  padding: 16px 18px 18px;
}
.card__title{
  font-family: var(--font-title, "Roboto Condensed", system-ui, sans-serif);
  text-transform: uppercase;
  letter-spacing: 0.02em;
  font-weight: 700;
  color: var(--text-strong);
  margin: 0 0 6px 0;
}
.card__abstract{
  color: var(--text);
  line-height: 1.6;
  margin: 0 0 14px 0;
  min-height: 3.2em; /* due righe min per allineare */
}

/* Bottone: usa i tuoi stili esistenti */
.card .btn{ width: max-content; }

/* HOVER: alziamo la card, togliamo l'ombra (effetto “si stacca”) */
.card:hover,
.card:focus-within{
  transform: translateY(-6px);
  box-shadow: 0 0 0 rgba(0,0,0,0); /* sparisce */
  border-color: color-mix(in oklab, var(--brand, #da291c) 28%, #e8e8e8);
}

/* ENTRATA ELEGANTE on-scroll (rispettando prefers-reduced-motion) */
@media (prefers-reduced-motion: no-preference){
  .card{
    opacity: 0;
    transform: translateY(18px);
    filter: blur(6px);
  }
  .card.is-in{
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
    transition: transform .6s cubic-bezier(.2,.8,.2,1),
                opacity .6s ease,
                filter .6s ease,
                box-shadow .25s ease,
                border-color .25s ease;
  }
}

/* Dark mode */
.theme-dark .section--services{
  background: color-mix(in oklab, #000 86%, var(--surface, #0e0e0e));
  --services-bg: color-mix(in oklab, #000 86%, var(--surface, #0e0e0e));
}
.theme-dark .card{
  background: color-mix(in oklab, #fff 3%, #000);
  border-color: color-mix(in oklab, #fff 10%, transparent);
  box-shadow: 0 8px 22px rgba(0,0,0,.35);
}
.theme-dark .card:hover,
.theme-dark .card:focus-within{
  border-color: color-mix(in oklab, #fff 18%, transparent);
}
