:root {
  --personaggi-purple: #5f24d6;
  --personaggi-dark: #0b0b0b;
}

.characters-hero {
  position: relative;
  background: radial-gradient(circle at 50% 25%, rgba(120, 62, 214, 0.85), rgba(52, 14, 90, 0.95));
  padding: clamp(5rem, 12vw, 8rem) 0 clamp(4.5rem, 14vw, 6.5rem);
  overflow: visible;
  text-align: center;
  min-height: 30vw;
}

.characters-hero__tear {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: clamp(80px, 18vw, 160px);
  object-fit: cover;
  z-index: 2;
}

.characters-hero__stage {
  position: relative;
  z-index: 3;
  display: grid;
  place-items: center;
  min-height: clamp(220px, 40vw, 380px);
}

.characters-hero__group {
  width: min(980px, 95vw);
  filter: drop-shadow(0 18px 28px rgba(0, 0, 0, 0.35));
}

.characters-hero__group--back {
  position: absolute;
  width: min(860px, 90vw);
  opacity: 0.8;
  mix-blend-mode: screen;
}

.characters-hero__title {
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 57%);
  z-index: 5;
  width: min(750px, 96vw);
  text-align: center;
}

.characters-hero__title img {
  width: 100%;
  filter: drop-shadow(0 12px 18px rgba(0, 0, 0, 0.4));
}

.characters-hero__title p {
  font-size: 30px;
  margin: 0 auto;
  max-width: 750px;
  font-family: "Mistery Silent", "Trebuchet MS", sans-serif;
  color: rgba(255, 255, 255, 0.9);
}

.characters-band {
  background: #6a2fe3;
  padding: clamp(2.2rem, 6vw, 3.5rem) 0;
  position: relative;
  text-align: center;
}

.characters-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../assets/personaggi/esplosione%20giallo%20viola.png") center/cover no-repeat;
  opacity: 0.35;
}

.characters-band__frame {
  position: relative;
  z-index: 3;
}

.characters-band__title {
  width: min(320px, 70vw);
  margin: 0 auto 0.8rem;
}

.characters-band__arrow {
  position: absolute;
  width: 48px;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0.8;
}

.characters-band__arrow--left {
  left: 12%;
}

.characters-band__arrow--right {
  right: 12%;
}

.characters-choice {
  --choice-bg-height: calc(100vw * 0.790625);
    background-color: transparent;
    padding-top: calc(var(--choice-bg-height) * 0.42);
    position: relative;
    overflow: visible;
    margin-top: -8vw;
    z-index: 2;
}

.characters-choice::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  padding-top: calc(var(--choice-bg-height) * 0.80);
  background: url("../assets/personaggi/strappo di sopra LARGO.png") top/100% 50% no-repeat;
  z-index: 0;
}

.characters-choice::after { content: none; }

.characters-choice .container {
  position: relative;
  z-index: 1;
}
.characters-choice__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: start;
  transform: translateY(-50%);
}

.character-card {
  position: relative;
  display: grid;
  place-items: center;
  gap: 1rem;
  padding: 1rem;
  width: clamp(80%, 46vw, 100%);
  justify-self: center;
  --label-size: 15vw;
  --reveal-size: 27vw;
}

.character-card__frame {
  width: 25vw;
  filter: drop-shadow(0 16px 30px rgba(0, 0, 0, 0.4));
}

.character-card__label {
  position: absolute;
  top: 38%;
  width: var(--label-size);
  --label-x: -30px;
  transform: translateX(var(--label-x)) translateY(0);
  filter: drop-shadow(0 8px 10px rgba(0, 0, 0, 0.4));
  transition: transform 0.35s ease;
  z-index: 2;
}

.character-card__button {
  position: absolute;
  bottom: -12%;
  transform: translateY(50%);
  transition: transform 0.2s ease;
}

.character-card__button img {
  width: min(140px, 36vw);
}

.character-card__button:hover img,
.character-card__button:focus-visible img {
  content: url("../assets/personaggi/tasto%20alunni%20hover.png");
}

.character-card--alt .character-card__button:hover img,
.character-card--alt .character-card__button:focus-visible img {
  content: url("../assets/personaggi/tasto%20prof%20hover.png");
}

.character-card--alt .character-card__label {
  --label-x: 35px;
  --label-size: 10vw;
  transform: translateX(var(--label-x)) translateY(15px);
  transition: transform 0.35s ease;
  z-index: 2;
}


.character-card__reveal {
  position: absolute;
  top: 12%;
  left: 50%;
  width: var(--reveal-size);
  opacity: 0;
  transform: translate(-50%, 24px);
  transition: transform 0.35s ease, opacity 0.35s ease;
  z-index: 1;
  pointer-events: none;
}

.character-card:hover .character-card__reveal,
.character-card:focus-within .character-card__reveal {
  opacity: 1;
  transform: translate(-50%, 10%);
}



.character-card--alt .character-card__reveal {
  transform: translate(-42%, 24px);
}

.character-card--alt:hover .character-card__reveal,
.character-card--alt:focus-within .character-card__reveal {
  transform: translate(-42%, 10%);
}
.character-card:hover .character-card__label,
.character-card:focus-within .character-card__label {
  transform: translateX(var(--label-x)) translateY(90px);
}

.characters-band--dark {
  background: #0b0b0b;
  padding: clamp(2.5rem, 8vw, 5rem) 0;
}

.characters-band--dark .characters-band__title {
  width: min(260px, 65vw);
}



.character-card__button {
  bottom: -6%;
}

.characters-band__arrow--left {
  left: 6%;
}

.characters-band__arrow--right {
  right: 6%;
}


@media (max-width: 600px) {
  .characters-hero__group--back {
    display: flex;
  }

  .characters-band__arrow {
    display: flex;
  }

  .character-card__label {
    top: 34%;
  }
}

.characters-hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 106%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
}


.characters-choice__arrows {
  margin-top: 0.35rem;
  display: flex;
  gap: clamp(0.5rem, 2.5vw, 1.4rem);
  align-items: flex-start;
  z-index: 5;
  pointer-events: none;
}

.characters-choice__arrow {
  width: clamp(42px, 7vw, 64px) !important;
  opacity: 0.9;
}

.characters-choice__arrow--left {
  transform: translateY(-8px);
  margin-left: auto;
}

.characters-choice__arrow--right {
  transform: translateY(18px);
  margin-right: auto;
}

@media (min-width: 768px) and (max-width: 1024px) {
  .characters-hero__title p{
    font-size: 23px;
    margin-top: -5vw;
  }

  .characters-hero__title{
    transform: translate(-50%, 50%);
  }

  .characters-choice__grid{
    transform: translateY(-11vw);
  }

  .character-card__label{
    --label-x: -20px;
  }

  .character-card--alt .character-card__label{
    --label-x: 20px;
  }

  .characters-choice::before{
    padding-top: calc(var(--choice-bg-height) * 1);
  }

  .character-card:hover .character-card__label{
    transform: translateX(var(--label-x)) translateY(60px);
  }

  .characters-choice{
    margin-top: -9vw;
  }
}

@media (max-width: 767px) {
  .characters-hero {
    padding: clamp(4.5rem, 16vw, 7rem) 0 clamp(6.5rem, 20vw, 8.5rem);
    min-height: 46vw;
  }

  .characters-hero__title {
    width: min(440px, 92vw);
    transform: translate(-50%, 70%);
  }

  .characters-hero__title p {
    font-size: 0.95rem;
    line-height: 1.4;
    padding: 0 1rem;
  }

  .characters-choice {
    margin-top: clamp(-210px, -22vw, -110px);
  }

  .characters-choice__grid {
    grid-template-columns: 1fr;
    gap: clamp(1.2rem, 6vw, 2rem);
    transform: translateY(-40%);
  }

  .character-card {
    width: min(90vw, 100%);
  }

  .character-card__label {
    width: 35vw;
    top: 38%;
  }

  .character-card:hover .character-card__label, .character-card:focus-within .character-card__label{
    transform: translateX(var(--label-x)) translateY(65px);
  }

  .character-card:hover .character-card__reveal, .character-card:focus-within .character-card__reveal{
    width: 70vw;
  }

  .card_alunni{
    margin-right: -28px;
  }

  .card_prof{
    margin-left: -28px;
    margin-top: -10vw;
  }
}

@media (max-width: 600px) {
  .characters-choice {
    --choice-bg-height: calc(100vw * 0.7);
    padding-bottom: clamp(3.5rem, 12vw, 5rem);
  }

  .characters-choice__grid {
    transform: translateY(0);
  }

  .characters-hero__title {
    transform: translate(-50%, 30%);
  }
}


@media (max-width: 600px) {
  .characters-hero {
    min-height: 92vw;
    overflow: hidden;
  }

  .characters-hero__video {
    inset: auto;
    top: 50%;
    left: 50%;
    height: 85%;
    width: auto;
    transform: translate(-50%, -50%);
  }

  .character-card__frame{
    width: 65vw;
  }

  .characters-choice::before {
    height: 100%;
    top: 7vw;
    padding-top: 0;
    background-size: 200% auto;
    background: url("../assets/strappo di sopra alto.png") top/100% 95% no-repeat;
  }

  .characters-choice__arrows {
    display: none;
  }

  .characters-choice__grid {
    grid-template-columns: 1fr;
  }

  .character-card__label {
    transform: translateX(-20px) translateY(58px);
  }

  .character-card--alt .character-card__label {
    transform: translateX(15px) translateY(58px);
  }

  .character-card__reveal {
    opacity: 1;
    transform: translate(-53%, 10%);
    width: 70vw;
  }

  .character-card--alt .character-card__reveal {
    transform: translate(-42%, 10%);
    width: 70vw;
  }
  
}
