
*{
  margin:0;
  padding:0;
  box-sizing:border-box;
  font-family:"Inter",system-ui;
}

body{
  background:#0b0b0c;
  color:#f5f5f5;
  overflow-x:hidden;
}

/* NAV */
header{
  position:fixed;
  top:0;
  width:100%;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:20px 70px;
  background:rgba(10,10,10,0.6);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,255,255,0.06);
  z-index:1000;
}

.logo{
  font-weight:500;
  letter-spacing:2px;
  font-size:13px;
  text-transform:uppercase;
}

nav{
  display:flex;
  gap:30px;
}

nav a{
  color:#ddd;
  text-decoration:none;
  font-size:13px;
  letter-spacing:1px;
  transition:.3s;
}

nav a:hover{
  color:#fff;
}


/* HERO PARALLAX */
.hero{
  height:100vh;
  position:relative;
  display:flex;
  align-items:center;
  padding:0 70px;
  overflow:hidden;
}

.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:url("img/consulente_orizzontale.jpg");
  background-size:cover;
  background-position:center;
  transform:translateY(0);
  filter:brightness(0.8);
  z-index:-2;
}

/* PARALLAX LAYER */
.parallax{
  position:absolute;
  width:120%;
  height:120%;
  top:-10%;
  left:-10%;
  background:radial-gradient(circle at center, rgba(255,255,255,0.08), transparent 60%);
  z-index:-1;
  transform:translateY(0);
}

.hero-content{
  max-width:700px;
}

.hero h1{
  font-size: clamp(44px, 6vw, 72px);
  letter-spacing: -2px;
  line-height: 1.05;
}

.hero p{
  margin-top:20px;
  color:#ccc;
  max-width:500px;
  font-size:16px;
}

.btn{
  display:inline-block;
  margin-top:30px;
  padding:14px 24px;
  border:1px solid rgba(255,255,255,0.2);
  border-radius:12px;
  color:#fff;
  text-decoration:none;
  transition:.3s;
}

.btn:hover{
  background:#fff;
  color:#111;
}



/* SECTIONS */
section{
  padding:50px 70px;
}

/* GRID LUXURY */
.grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:30px;
}

.card{
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.06);
  padding:30px;
  border-radius:18px;
  transition:.4s;
  transform:translateY(20px);
  opacity:0;
}

.card.show{
  transform:translateY(0);
  opacity:1;
}

.card:hover{
  transform:translateY(-8px);
  border-color:rgba(255,255,255,0.15);
}

.card h3{
  font-size:18px;
  margin-bottom:10px;
  letter-spacing:-0.3px;
}

.card p{
  color:#aaa;
  font-size:14px;
}

/* DARK LUX SECTION */
.lux{
  background:linear-gradient(180deg,#0b0b0c,#111);
}

/* IMAGE SECTION PARALLAX */
.parallax-section{
  height:60vh;
  position:relative;
  overflow:hidden;
}

.parallax-section img{
  width:100%;
  height:120%;
  object-fit:cover;
  position:absolute;
  top:0;
  left:0;
  transform:translateY(0);
  filter:brightness(0.5);
}

/* FORM */
form{
  max-width:500px;
  display:flex;
  flex-direction:column;
  gap:14px;
}

input,textarea{
  padding:14px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.1);
  background:rgba(255,255,255,0.03);
  color:white;
}

button{
  padding:14px;
  border:none;
  border-radius:12px;
  background:#fff;
  color:#111;
  cursor:pointer;
}

/* Messaggio di errore della validazione form (nascosto di default via attributo hidden) */
.form-errore{
  margin:0;
  font-size:0.9rem;
  color:#ff8a8a; /* rosso tenue, leggibile sul fondo scuro */
}

/* Messaggio di esito dopo l'invio (successo o errore) */
.form-esito{
  margin:0;
  font-size:0.95rem;
}
.form-esito.ok{ color:#8affb0; }  /* verde tenue: invio riuscito */
.form-esito.ko{ color:#ff8a8a; }  /* rosso tenue: invio fallito */

/*
  HONEYPOT anti-spam: campo "esca" invisibile e fuori dal flusso.
  Lo nascondiamo del tutto agli utenti reali; i bot che compilano
  tutti i campi lo valorizzano e l'invio viene scartato.
*/
.hp-botcheck{
  position:absolute !important;
  left:-9999px !important;
  width:1px;
  height:1px;
  opacity:0;
  overflow:hidden;
}

/* FOOTER */
footer{
  padding:40px;
  text-align:center;
  color:#777;
  border-top:1px solid rgba(255,255,255,0.06);
}

@media(max-width:900px){

section{
  padding:50px 20px; /* FIX PRINCIPALE: meno aria inutile */
}

.hero{
  padding:0 20px;
}

/* CAROUSEL SERVIZI */
.grid{
  display:flex;
  overflow-x:auto;
  gap:14px;

  padding:0 0 10px 0; /* niente padding laterale pesante */

  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}

.grid::-webkit-scrollbar{
  display:none;
}

.card{
  flex:0 0 78%; /* più equilibrato */
  scroll-snap-align:start;

  padding:22px; /* meno padding interno */
  border-radius:16px;
}

}

/* FAQ LUXURY ACCORDION */
.faq{
  max-width:900px;
  margin-top:50px;
}

/* separazione a linee come sito premium */
.faq-item{
  border-bottom:1px solid rgba(255,255,255,0.08);
}

/* bottone domanda */
.faq-question{
  width:100%;
  background:none;
  border:none;
  color:#fff;
  text-align:left;
  padding:22px 0;
  font-size:16px;
  cursor:pointer;
  display:flex;
  justify-content:space-between;
  align-items:center;
  letter-spacing:0.2px;
}

/* + / - animato */
.faq-question::after{
  content:"+";
  font-size:18px;
  color:#aaa;
  transition:.3s;
}

.faq-item.active .faq-question::after{
  content:"–";
  color:#fff;
}

/* contenuto animato */
.faq-answer{
  max-height:0;
  overflow:hidden;
  transition:max-height 0.45s ease, padding 0.3s ease;
}

.faq-content{
  padding:0 0 22px 0;
  color:#aaa;
  font-size:14px;
  line-height:1.6;
  opacity:0;
  transform:translateY(-6px);
  transition:0.3s ease;
}

/* stato aperto */
.faq-item.active .faq-answer{
  max-height:300px;
}

.faq-item.active .faq-content{
  opacity:1;
  transform:translateY(0);
}

@media(max-width:900px){

.grid{
  display:flex;
  overflow-x:auto;
  gap:16px;
  padding:0 20px 10px 20px;

  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}

.grid::-webkit-scrollbar{
  display:none;
}

.card{
  flex:0 0 80%;
  scroll-snap-align:start;

  /* look premium */
  border-radius:18px;
}

/* IMPORTANT: crea il "peek" della prossima card */
.grid::after{
  content:"";
  flex:0 0 20px;
}
}

/* DESKTOP NAV */
.desktop-nav{
  display:flex;
  gap:30px;
}

/* HAMBURGER */
.hamburger{
  display:none;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
}

.hamburger span{
  width:22px;
  height:2px;
  background:#fff;
  transition:.3s;
}

/* MOBILE MENU */
.mobile-menu{
  position:fixed;
  top:0;
  right:0;
  width:100%;
  height:100vh;
  background:rgba(10,10,10,0.98);
  backdrop-filter:blur(12px);

  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:30px;

  transform:translateY(-100%);
  transition:0.4s ease;
  z-index:999;
}

.mobile-menu a{
  color:#fff;
  text-decoration:none;
  font-size:22px;
  letter-spacing:1px;
}

/* ACTIVE STATE */
.mobile-menu.active{
  transform:translateY(0);
}

/* MOBILE FIX HEADER */
@media(max-width:900px){

  header{
    padding:18px 20px;
  }

  .desktop-nav{
    display:none;
  }

  .hamburger{
    display:flex;
  }
}

/* FOOTER ONE LINE LUXURY */
.footer{
  background:#0a0a0b;
  border-top:1px solid rgba(255,255,255,0.06);
  padding:50px 70px;
}

/* LINEA UNICA */
.footer-line{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:40px;
  flex-wrap:wrap;
}

/* LEFT */
.footer-left{
  display:flex;
  align-items:center;
  gap:12px;
  color:#aaa;
  font-size:13px;
}

.footer-logo{
  color:#fff;
  letter-spacing:2px;
  text-transform:uppercase;
}

.footer-sep{
  color:#444;
}

.footer-desc{
  color:#888;
}

/* RIGHT */
.footer-right{
  display:flex;
  align-items:center;
  gap:12px;
  color:#aaa;
  font-size:13px;
}

.footer-dot{
  color:#444;
}

@media(max-width:900px){

.footer{
  padding:50px 20px;
}

.footer-line{
  flex-direction:column;
  align-items:center;   /* 👈 CENTRATO */
  text-align:center;    /* 👈 TESTO CENTRATO */
  gap:18px;
}

.footer-left{
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:6px;
}

.footer-right{
  display:flex;
  flex-direction:column;
  align-items:center;   /* 👈 CENTRATO */
  text-align:center;
  gap:10px;
}

/* rimuove separatori visivi su mobile */
.footer-dot,
.footer-sep{
  display:none;
}
}

/* REVIEWS */
.reviews{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:30px;
    margin-top:50px;
  }

  /* CARD */
  .review-card{
    background:rgba(255,255,255,0.03);
    border:1px solid rgba(255,255,255,0.06);
    padding:28px;
    border-radius:18px;

    color:#ccc;
    font-size:14px;
    line-height:1.6;

    transition:.3s;
  }

  .review-card:hover{
    border-color:rgba(255,255,255,0.15);
    transform:translateY(-6px);
  }

  .review-author{
    display:block;
    margin-top:18px;
    font-size:13px;
    color:#888;
  }

  /* MOBILE CAROUSEL */
  @media(max-width:900px){

    .reviews{
      display:flex;
      overflow-x:auto;
      gap:14px;

      scroll-snap-type:x mandatory;
      -webkit-overflow-scrolling:touch;

      padding-bottom:10px;
    }

    .reviews::-webkit-scrollbar{
      display:none;
    }

    .review-card{
      flex:0 0 80%;
      scroll-snap-align:start;
    }

  }

  /* SPLIT SECTION */
.split-section{
    padding:50px 70px;
  }

  .split-container{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:60px;
    align-items:center;
  }

  /* IMMAGINE */
  .split-image img{
    width:100%;
    aspect-ratio:1/1; /* 👈 quadrata */
    object-fit:cover;
    border-radius:18px;
    filter:brightness(0.85);
  }

  /* TESTO */
  .split-text h2{
    font-size:36px;
    line-height:1.2;
    margin-bottom:20px;
  }

  .split-text p{
    color:#aaa;
    line-height:1.7;
    max-width:500px;
  }

  /* MOBILE */
  @media(max-width:900px){

    .split-section{
      padding:50px 20px;
    }

    .split-container{
      grid-template-columns:1fr;
      gap:30px;
    }

    .split-text h2{
      font-size:28px;
    }

  }

  /* CENTRATURA FAQ + CONTATTI */
#faq,
#contatti{
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* limita larghezza e centra */
.faq{
  width: 100%;
  max-width: 900px;
}

#contatti form{
  width: 100%;
  max-width: 500px;
}

#recensioni h3{
  text-align: center;
}

#servizi h3{
  text-align:center;
  margin-bottom:45px;
}