.homepage {
  background-color: #ffffff;
  display: grid;
  justify-items: center;
  align-items: start;
  width: 100vw;
}

.homepage .stage {
  background-color: var(--neros);
  overflow: hidden;
  width: 100vw;
  height: 100vh;
  position: relative;
}


.homepage .email {
  position: absolute;
  bottom: 2vh;
  right: 2vw; 
  font-family: var(--testi-font-family), Helvetica;
  font-weight: 400;
  opacity: 0.75;
  color: var(--blancos);
  font-size: 18px;
  letter-spacing: 0;
}
.homepage .copyright{
  position: absolute;
  bottom: 2vh;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--testi-font-family), Helvetica;
  font-weight: 400;
  opacity: 0.2;
  color: var(--blancos);
  font-size: 18px;
  letter-spacing: 0;
}
.homepage .telefono {
  position: absolute;
  bottom: 2vh;
  left: 2vw; 
  font-family: var(--testi-font-family), Helvetica;
  font-weight: 400;
  opacity: 0.75;
  color: var(--blancos);
  font-size: 18px;
  letter-spacing: 0;
}

.homepage .head_bar {
  position: relative;
  width: calc(100vw - 4vw);
  margin-left: 2vw;
  margin-top: 2vh;
  height: auto;

  display: grid;
  grid-template-columns: 1fr auto; /* sinistra + destra */
  grid-template-rows: auto auto;   /* riga 1: header, riga 2: projects/menu */
  grid-template-areas:
    "name about"
    "projects projects";
  row-gap: 1.2vh;
}

/* =========================
   TO TOP ARROW (home clone)
   ========================= */

.homepage .to-top{
  position: absolute;
  top: 0;
  left: 0;

  width: 18px;
  height: 12px;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: none;

  /* feedback */
  opacity: 1;
  transition: opacity .2s ease-in-out, transform .2s ease-in-out;
}

/* freccia colorata con mask (colore = background-color) */
.homepage .to-top::before{
  content:"";
  position: absolute;
  inset: 0;

  background-color: var(--blancos);

  /* usa il tuo svg come maschera */
  -webkit-mask-image: url("img/vector-1.svg");
  mask-image: url("img/vector-1.svg");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;

  /* ruota per puntare verso l’alto */
  transform: rotate(-90deg);
  transform-origin: center;
}

.homepage .to-top:hover{
  opacity: 0.75;
  transform: translateY(-1px);
}

/* se vuoi “clicked” come gli altri */
.homepage .to-top.clicked{
  opacity: 0.6;
}


.homepage .about {
  position: absolute;
  top: 0;
  right: 0;
  font-family: var(--Super_text-font-family);
  font-weight: var(--Super_text-font-weight);
  color: var(--blancos);
  font-size: var(--Super_text-font-size);
  letter-spacing: var(--Super_text-letter-spacing);
  line-height: var(--Super_text-line-height);
  font-style: var(--Super_text-font-style);
  cursor: none;
  transition: opacity 0.2s ease-in-out;
}

.homepage .WORKS {
  position: absolute;
  top: 0;
  left: 25vw;
  font-family: var(--Super_text-font-family);
  font-weight: var(--Super_text-font-weight);
  color: var(--blancos);
  font-size: var(--Super_text-font-size);
  letter-spacing: var(--Super_text-letter-spacing);
  line-height: var(--Super_text-line-height);
  font-style: var(--Super_text-font-style);
  opacity: 0.5;
}

.homepage .ORB,
.homepage .B_B,
.homepage .collectuscia,
.homepage .echoes_of_care,
.homepage .vuotoCO{
  position: absolute;
  top: 4vh;
  left: 25vw;
  font-family: var(--titoli_menu-font-family);
  font-weight: var(--titoli_menu-font-weight);
  color: var(--blancos);
  font-size: var(--titoli_menu-font-size);
  letter-spacing: var(--titoli_menu-letter-spacing);
  line-height: var(--titoli_menu-line-height);
  font-style: var(--titoli_menu-font-style);

  cursor: none;
  transition: opacity 0.2s ease-in-out;
}

/* “accapo” fluido: 1.25em = 1.25 volte il font-size corrente */
.homepage .ORB{ top: calc(4vh + 0em); }
.homepage .B_B{ top: calc(4vh + 1.25em); }
.homepage .collectuscia{ top: calc(4vh + 2.5em); }
.homepage .echoes_of_care{ top: calc(4vh + 3.75em); }
.homepage .vuotoCO{ top: calc(4vh + 5em); }
.homepage .menu a:hover,
.homepage .menu a,
.homepage .echoes_of_care{
  transition: all .2s ease-in-out;
}

.homepage .menu a:hover,
.homepage .echoes_of_care:hover{
  opacity: 0.75;
  text-shadow: 0 0 9px #6c6c6c;
  cursor: none;
  transform: scale(1.05);
  text-decoration: underline;
}

.homepage .about:hover{
  opacity: 0.75;
  text-shadow: 0 0 9px #6c6c6c;
  cursor: none;
  transform: scale(1.05);
  text-decoration: underline;
}


@media (max-width: 700px){

  .homepage .head_bar{
    position: relative; /* ok */
    width: calc(100vw - 4vw);
    margin-left: 2vw;
    margin-top: 2vh;

    display: flex;
    flex-direction: column;
    align-items: flex-start;

    --space: 0.6rem;
  }

  /* ✅ to-top torna nel flow e diventa il primo elemento */
  .homepage .to-top{
    position: static;     /* IMPORTANTISSIMO */
    margin-bottom: var(--space);
    transform: rotate(0); /* opzionale: evita eredità strane */
  }

  /* reset positioning (qui basta quello che c’è davvero nel tuo HTML) */
  .homepage .about,
  .homepage .WORKS,
  .homepage .menu{
    position: static;
    top: auto; left: auto; right: auto;
  }

  /* ABOUT → WORKS : 3X (come volevi prima) */
  .homepage .about{
    margin-bottom: calc(var(--space) * 3);
  }

  /* WORKS → MENU : 1X */
  .homepage .WORKS{
    margin-bottom: var(--space);
  }

  /* MENU links in colonna */
  .homepage .menu a{
    display: block;
    margin-top: 0.35em;
  }
  .homepage .menu a:first-child{
    margin-top: 0;
  }

  /* ✅ evita che le classi dei link (ORB, B_B, ecc) abbiano ancora posizioni assolute */
  .homepage .ORB,
  .homepage .B_B,
  .homepage .collectuscia,
  .homepage .echoes_of_care,
  .homepage .vuotoCO{
    position: static;
    top: auto;
    left: auto;
  }
}

@media (max-width: 700px){

  /* riusiamo lo stesso spazio X già definito */
  .homepage{
    --space: 0.6rem;
  }

  /* telefono sopra */
  .homepage .telefono{
    left: 2vw;
    right: auto;
    bottom: calc(6vh + var(--space) + 1em);
    font-size: 12px;
  }

    /* email sotto */
  .homepage .copyright{
    left: 50%;
    right: auto;
    bottom: 2vh;
    font-size: 12px;
    transform: translateX(-50%);
  }

  /* email sotto */
  .homepage .email{
    left: 2vw;
    right: auto;
    bottom: 6vh;
    font-size: 12px;
  }
}


