/* ──────────────────────────────────────────
   PAGE: HOME (index.php)
   ────────────────────────────────────────── */

/* Hero */
#home-hero {
  min-height: clamp(460px, 70vh, 720px);
  background-image: url("../img/star-texture.svg"),
    linear-gradient(rgba(0, 0, 0, 0.85), rgba(0, 0, 0, 0.85));
  background-size: auto, cover;
  background-repeat: repeat, no-repeat;
  padding: 4.5rem 0 4rem;
  border-bottom: 1px solid var(--accent-soft);
}

.home-hero__logo {
  width: clamp(220px, 32vw, 320px);
  height: auto;
}

#home-hero h1 {
  font-size: clamp(1.8rem, 5vw, 3.1rem);
  line-height: 1.15;
  letter-spacing: 0.01em;
}

@media (max-width: 575.98px) {
  #home-hero {
    min-height: auto;
    padding: 3rem 0 3rem;
  }
  #home-hero h1 {
    font-size: clamp(1.6rem, 7vw, 2.3rem);
  }
}

/* Section padding helper (BS non ha py-6) */
.py-lg-6 {
  /* default already from py-5 */
}

@media (min-width: 992px) {
  .py-lg-6 {
    padding-top: 5rem !important;
    padding-bottom: 5rem !important;
  }
}

/* Process step (4 step della candidatura) */
.process-step {
  position: relative;
  padding: 2rem 1.5rem 1.75rem;
  border-radius: var(--radius-card);
  background-color: rgba(255, 255, 255, 0.025);
  border: 1px solid rgba(255, 255, 255, 0.07);
  transition: border-color var(--transition-mid), transform var(--transition-fast), box-shadow var(--transition-mid);
  display: flex;
  flex-direction: column;
}

.process-step:hover {
  border-color: var(--border-soft);
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
}

.process-step__num {
  position: absolute;
  top: -0.85rem;
  left: 1.5rem;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background-color: var(--accent-color);
  color: var(--bg-color);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-family: var(--font-primary);
  font-size: 0.85rem;
  box-shadow: 0 0 0 4px var(--bg-color);
}

.process-step__icon {
  font-size: 1.7rem;
  color: var(--accent-color);
  margin-bottom: 0.65rem;
  margin-top: 0.5rem;
}

.process-step__label {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-color);
  background-color: var(--accent-softer);
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  margin-bottom: 0.5rem;
  align-self: flex-start;
}

@media (max-width: 575.98px) {
  .process-step {
    padding: 1.75rem 1.25rem 1.5rem;
  }
}

/* Dot indicator (visibile solo nella vista carosello mobile) */
.process-dots {
  display: none;
}

/* Process mobile: carosello a scroll orizzontale con peek + dot indicator.
   Scroll-snap su center: clic su una card la centra nel viewport,
   prima e ultima card raggiungibili centrate grazie al padding orizzontale. */
@media (max-width: 767.98px) {
  .process-row {
    flex-wrap: nowrap;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scroll-snap-type: x mandatory;
    padding-bottom: 0.5rem;
    /* vw (non %) per allineamento preciso al viewport: la prima e l'ultima card
       arrivano a centrarsi esattamente nel viewport tramite scroll-snap. */
    padding-left: 11vw;
    padding-right: 11vw;
  }

  .process-row > [class*="col-"] {
    flex: 0 0 78vw;
    max-width: 78vw;
    scroll-snap-align: center;
  }

  .process-step {
    padding-top: 1.5rem;
    cursor: pointer;
  }

  /* Numero della card: in flusso su mobile per non venire clippato dall'overflow */
  .process-step__num {
    position: static;
    margin-bottom: 0.75rem;
    box-shadow: none;
  }

  .process-dots {
    display: flex;
    justify-content: center;
    gap: 0.55rem;
    margin-top: 1.25rem;
  }

  .process-dots__dot {
    width: 10px;
    height: 10px;
    padding: 0;
    border-radius: 50%;
    border: 1px solid var(--accent-color);
    background-color: transparent;
    cursor: pointer;
    transition: transform var(--transition-fast), background-color var(--transition-fast);
  }

  .process-dots__dot.is-active {
    background-color: var(--accent-color);
    transform: scale(1.25);
  }

  .process-dots__dot:focus-visible {
    outline: 2px solid var(--accent-color);
    outline-offset: 3px;
  }
}

/* Learning card (anteprima guide nella home) */
.learning-card {
  padding: 2rem 1.75rem;
  border-radius: var(--radius-card);
  background-color: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--border-soft);
  text-decoration: none;
  color: inherit;
  transition: transform var(--transition-fast), border-color var(--transition-mid), box-shadow var(--transition-mid);
}

.learning-card:hover {
  transform: translateY(-4px);
  border-color: var(--accent-color);
  box-shadow: 0 12px 32px rgba(225, 163, 75, 0.12);
  color: inherit;
}

.learning-card:hover .learning-card__cta {
  color: var(--accent-hover);
}

.learning-card__icon {
  font-size: 2rem;
  color: var(--accent-color);
  line-height: 1;
}

.learning-card__tag {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-color);
  background-color: var(--accent-softer);
  padding: 0.25rem 0.7rem;
  border-radius: 999px;
}

.learning-card__cta {
  display: inline-block;
  margin-top: auto;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent-color);
  transition: color var(--transition-fast);
}

@media (max-width: 575.98px) {
  .learning-card {
    padding: 1.75rem 1.35rem;
  }
}

/* Hub card variant compatto (in fondo alla home) */
.hub-card--compact {
  padding: 1.5rem 1.25rem;
}

.hub-card--compact .hub-card__icon {
  font-size: 1.8rem;
}

/* Final CTA card */
.home-final-card {
  max-width: 760px;
  padding: 3rem 2rem;
  border-radius: var(--radius-card);
  background-image: linear-gradient(rgba(225, 163, 75, 0.08), rgba(225, 163, 75, 0.02));
  border: 1px solid var(--border-soft);
}

.home-final-card h2 {
  font-size: clamp(1.5rem, 3.5vw, 2rem);
  letter-spacing: 0.02em;
}

@media (max-width: 575.98px) {
  .home-final-card {
    padding: 2.25rem 1.5rem;
  }
}
