/* Jenia Post Grid — griglia autonoma per evitare conflitti con
   Isotope / Bootstrap del tema Brighthub.
   Le card interne mantengono le classi .pxl-grid__item-*
   così lo styling del tema (.pxl-b2b-grid--layout-1 ...) si applica. */

.jew-case-post-grid {
  /* Override: il tema potrebbe usare .pxl-grid__masonry per Isotope;
     qui siamo una griglia CSS classica, quindi azzero gli effetti collaterali. */
  position: relative;
}

.jew-case-post-grid .jew-cpg__grid {
  display: grid;
  grid-template-columns: repeat(var(--jew-cpg-cols-xl, 3), minmax(0, 1fr));
  gap: var(--jew-cpg-gap, 30px);
  width: 100%;
}

/* Ogni item: nessun position absolute, nessun float, nessuna larghezza bootstrap */
.jew-case-post-grid .jew-cpg__item {
  position: static !important;
  float: none !important;
  width: auto !important;
  max-width: 100%;
  padding: 0;
}

/* Neutralizza eventuali effetti di Isotope che ereditano dalle classi del tema */
.jew-case-post-grid .pxl-grid__item-inner {
  position: relative;
  height: auto;
  transition:
    transform 0.5s cubic-bezier(0.22, 0.61, 0.36, 1),
    box-shadow 0.5s cubic-bezier(0.22, 0.61, 0.36, 1);
}

/* ======= HOVER MICRO-INTERAZIONI ======= */

/* Card: lieve sollevamento + ombra soft */
.jew-case-post-grid .jew-cpg__item:hover .pxl-grid__item-inner {
  transform: translateY(-6px);
  box-shadow: 0 18px 40px -20px rgba(0, 0, 0, 0.35);
}

/* Immagine: clip + zoom dolce */
.jew-case-post-grid .pxl-grid__item-featured {
  display: block;
  overflow: hidden;
  border-radius: inherit;
}

.jew-case-post-grid .pxl-grid__item-featured img {
  transition: transform 0.7s cubic-bezier(0.22, 0.61, 0.36, 1);
  will-change: transform;
}

.jew-case-post-grid .jew-cpg__item:hover .pxl-grid__item-featured img {
  transform: scale(1.06);
}

/* Sottile shift del titolo a destra */
.jew-case-post-grid .pxl-grid__item-title a {
  display: inline-block;
  transition: transform 0.4s cubic-bezier(0.22, 0.61, 0.36, 1);
}

.jew-case-post-grid .jew-cpg__item:hover .pxl-grid__item-title a {
  transform: translateX(4px);
}

/* Pill "Scopri": leggero lift + background un po' più marcato */
.jew-case-post-grid .pxl-grid__item-btn-label {
  transition:
    transform 0.3s cubic-bezier(0.22, 0.61, 0.36, 1),
    background 0.3s ease,
    color 0.3s ease;
}

.jew-case-post-grid .jew-cpg__item:hover .pxl-grid__item-btn-label {
  transform: translateY(-1px);
}

/* In hover sulla card NON tocchiamo né animation-duration né transform
   della freccia: cambiare quelle proprietà fa ripartire l'anello da 0,
   mentre vogliamo che continui a ruotare fluido. */

@media (prefers-reduced-motion: reduce) {
  .jew-case-post-grid .jew-cpg__item:hover .pxl-grid__item-inner,
  .jew-case-post-grid .jew-cpg__item:hover .pxl-grid__item-featured img,
  .jew-case-post-grid .jew-cpg__item:hover .pxl-grid__item-title a,
  .jew-case-post-grid .jew-cpg__item:hover .pxl-grid__item-btn-label {
    transform: none !important;
    box-shadow: none !important;
  }
}

/* ======== Breakpoint responsive ======== */
@media (max-width: 1199px) {
  .jew-case-post-grid .jew-cpg__grid {
    grid-template-columns: repeat(var(--jew-cpg-cols-lg, 3), minmax(0, 1fr));
  }
}
@media (max-width: 991px) {
  .jew-case-post-grid .jew-cpg__grid {
    grid-template-columns: repeat(var(--jew-cpg-cols-md, 2), minmax(0, 1fr));
  }
}
@media (max-width: 767px) {
  .jew-case-post-grid .jew-cpg__grid {
    /* Mobile: forziamo sempre una colonna (ignora eventuale col_sm > 1) */
    grid-template-columns: 1fr;
    gap: 20px;
  }
  /* Card a piena larghezza ma leggibile */
  .jew-case-post-grid .jew-cpg__item {
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
  }
  /* Meno stagger su mobile così non si attende troppo per l'ultima card */
  .jew-case-post-grid .jew-cpg__item {
    transition-duration: 0.55s;
  }
  /* Action bar: resta a destra, ma con un filo di margine top ridotto */
  .jew-case-post-grid .jew-cpg__action {
    margin-top: 10px;
  }
}
@media (max-width: 575px) {
  .jew-case-post-grid .jew-cpg__grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

/* ======= SCROLL REVEAL =======
   Stato iniziale: card invisibili e leggermente spostate dal basso.
   Quando il widget entra in viewport (IntersectionObserver aggiunge .is-visible),
   ogni card fade-up in sequenza con delay staggered (impostato via JS). */
.jew-case-post-grid .jew-cpg__item {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity 0.7s cubic-bezier(0.22, 0.61, 0.36, 1),
    transform 0.7s cubic-bezier(0.22, 0.61, 0.36, 1);
  transition-delay: var(--jew-cpg-delay, 0ms);
  will-change: opacity, transform;
}

.jew-case-post-grid.is-visible .jew-cpg__item {
  opacity: 1;
  transform: translateY(0);
}

/* Editor Elementor + reduced-motion: tutto subito visibile */
.elementor-editor-active .jew-case-post-grid .jew-cpg__item {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}

@media (prefers-reduced-motion: reduce) {
  .jew-case-post-grid .jew-cpg__item {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* Wrapper che affianca etichetta + freccia, allineato a destra */
.jew-case-post-grid .jew-cpg__action {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 12px;
  margin-left: auto;
  width: 100%;
}

/* Etichetta "Scopri": stesso stile del badge prezzo, ma pill + font 2px più piccolo,
   alta quanto il cerchietto (32px) */
.jew-case-post-grid .pxl-grid__item-btn-label {
  display: inline-flex;
  align-items: center;
  height: 32px;
  padding: 0 14px;
  text-decoration: none;
  border-radius: 100px !important;
  font-size: calc(1em - 2px);
  line-height: 1;
  box-sizing: border-box;
}

/* Freccia: cerchietto nero, freccia bianca, anello animato che ruota */
.jew-case-post-grid .jew-cpg__arrow {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #181D27;
  color: #ffffff;
  text-decoration: none;
  flex-shrink: 0;
  overflow: visible;
  transition: transform 0.2s ease;
}

/* Anello rotante (conic gradient) attorno al cerchietto */
.jew-case-post-grid .jew-cpg__arrow::before {
  content: "";
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  padding: 2px;
  background: conic-gradient(
    from 0deg,
    rgba(255,255,255,0) 0deg,
    rgba(255,255,255,0) 200deg,
    rgba(255,255,255,0.85) 300deg,
    rgba(255,255,255,0) 360deg
  );
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  animation: jew-cpg-spin 6s linear infinite;
  pointer-events: none;
}

/* NB: deliberatamente NON modifichiamo animation-duration né applichiamo
   transform sul :hover della freccia. Cambiare animation-* in hover fa
   ricominciare il @keyframes da 0 — serve invece che l'anello continui
   a girare fluido senza scatti né spostamenti. */

.jew-case-post-grid .jew-cpg__arrow svg {
  width: 15px;
  height: 14px;
  display: block;
  position: relative;
  z-index: 1;
}

/* Assicura la freccia bianca anche se il tema imposta stroke differenti */
.jew-case-post-grid .jew-cpg__arrow svg path {
  stroke: #ffffff;
}

@keyframes jew-cpg-spin {
  to { transform: rotate(360deg); }
}

@media (prefers-reduced-motion: reduce) {
  .jew-case-post-grid .jew-cpg__arrow::before {
    animation: none;
  }
}

