/* Reset minimale: evita spazi strani */
* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: system-ui, Arial, sans-serif;
  background: #f7f5ef; /* leggermente caldo come nello screenshot */
}

/* contenitore centrato */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* barra alta */
.site-header {
  background: #fbfaf7;
  border-bottom: 1px solid #e8e6df;
}

/* brand a sinistra */
.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: #111;
}

.brand__logo {
  height: 44px;      /* altezza fissa coerente con la barra */
  width: auto;       /* mantiene proporzioni rettangolari */
  border-radius: 0;  /* niente cerchio */
  object-fit: contain; /* non taglia il logo */
  display: block;
}

.brand__name {
  font-weight: 700;
  font-size: 18px;
}

/* nav a destra */
.nav {
  display: flex;
  gap: 28px;
}

.nav__link {
  text-decoration: none;
  color: #6b7280;       /* grigio come nello screenshot */
  font-size: 14px;
}

.nav__link:hover {
  color: #111;
}
/* HERO: sfondo e spazio (per ora solo per la pill) */
.hero {
  background: #f7f5ef;      /* beige chiaro come screenshot */
  padding: 28px 0 40px;     /* spazio sopra e sotto */
}

.hero__container {
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* La pill */
.hero__pill {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 10px 18px;
  border-radius: 999px;     /* super arrotondato */
  background: #f3e9cf;      /* giallino tenue */
  color: #7a4b00;           /* testo marroncino */
  font-size: 14px;
  font-weight: 600;
}

.hero__pill .dot {
  opacity: 0.6;             /* pallino più leggero */
}
.hero__title {
  margin: 22px 0 0;
  text-align: center;
  font-size: 72px;
  line-height: 1.05;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0f172a;
}

.accent {
  color: #e67c00;
}
.hero__subtitle {
  margin: 10px 0 0;
  text-align: center;
  font-size: 20px;
  color: #6b7280;
}
.hero__cta {
  margin-top: 26px;
  display: inline-flex;
  align-items: center;
  gap: 10px;

  padding: 18px 28px;
  border-radius: 999px;
  background: #e67c00;
  color: white;

  text-decoration: none;
  font-weight: 700;
  box-shadow: 0 10px 18px rgba(0, 0, 0, 0.12);
}

.hero__cta:hover {
  filter: brightness(0.95);
}

.hero__ctaIcon {
  display: inline-block;
  transform: translateY(1px);
}
.about {
  background: #ffffff;
  padding: 5px 0;
}

.about__container {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.about__logo {
  height: 144px;
  width: auto;
  display: block;
}
.about__text {
  margin: 14px auto 0;   /* auto = centra il blocco */
  text-align: center;    /* centra le righe del testo */
  max-width: 700px;      /* larghezza controllata */
  width: 100%;           /* si adatta su schermi piccoli */
  font-size: 18px;
  line-height: 1.7;
  color: #6b7280;
}
.highlight {
  color: #e67c00;   /* stesso arancione di FreeBar e bottone */
  font-weight: 700;
}
.boxes {
  background: #ffffff;
  padding: 60px 0;
}

.boxes__container {
  display: flex;
  flex-direction: column;
  gap: 36px;
}

.boxes__grid {
  display: grid;
  gap: 22px;
}

.boxes__grid--top {
  grid-template-columns: repeat(3, 1fr);
}

.boxes__grid--bottom {
  grid-template-columns: repeat(4, 1fr);
}

/* Box base */
.box {
  background: #fff;
  border-radius: 18px;
  padding: 26px 22px;
  box-shadow: 0 18px 30px rgba(0, 0, 0, 0.06);
  border: 1px solid #f0efe9;
  text-align: center;
}

.box__icon {
  width: 58px;
  height: 58px;
  margin: 0 auto 14px;
  border-radius: 16px;
  background: #ff9500;
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 22px;
}

.box__title {
  margin: 0;
  font-size: 18px;
  font-weight: 800;
  color: #0f172a;
}

.box__text {
  margin: 10px 0 0;
  color: #6b7280;
  line-height: 1.6;
}

/* Box piccoli */
.box--small {
  padding: 22px 16px;
  border: 1px solid #f4d8a6;
  box-shadow: 0 18px 30px rgba(0, 0, 0, 0.04);
}

.box__miniIcon {
  color: #e67c00;
  font-size: 20px;
  margin-bottom: 10px;
}

.box__big {
  font-size: 26px;
  font-weight: 900;
  color: #0f172a;
  margin-bottom: 6px;
}

.box__small {
  color: #6b7280;
  font-size: 14px;
}

/* Box menu arancione */
.box--menu {
  background: linear-gradient(180deg, #ff9900, #ff7a00);
  color: #fff;
  border: none;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.box__menuIcon {
  font-size: 26px;
  margin-bottom: 12px;
}

.box__menuTitle {
  font-weight: 800;
  font-size: 18px;
}

.box__menuSub {
  margin-top: 6px;
  opacity: 0.95;
  font-size: 14px;
}
/* Stato iniziale: fuori a sinistra e invisibile */
.reveal {
  opacity: 0;
  transform: translateX(-40px);
  transition: opacity 600ms ease, transform 600ms ease;
  transition-delay: var(--d, 0ms);
}

/* Stato finale: visibile */
.reveal.is-visible {
  opacity: 1;
  transform: translateX(0);
}
.menu {
  background: #ffffff;
  padding: 70px 0;
}

.menu__container {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.menu__title {
  margin: 0;
  text-align: center;
  font-size: 40px;
  font-weight: 900;
  color: #0f172a;
}

.menu__subtitle {
  margin: 10px 0 0;
  text-align: center;
  font-size: 16px;
  color: #6b7280;
}
.accordion {
  width: 100%;
  max-width: 760px;
  margin-top: 40px;
  display: grid;
  gap: 16px;
}

.acc {
  background: #fff;
  border: 1px solid #eef0f3;
  border-radius: 14px;
  box-shadow: 0 14px 24px rgba(0, 0, 0, 0.05);
  overflow: hidden;
}

/* rimuove il triangolino default del summary */
.acc__summary {
  list-style: none;
  cursor: pointer;
  padding: 18px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.acc__summary::-webkit-details-marker {
  display: none;
}

.acc__left {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}

.acc__icon {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  color: #e67c00;
  font-size: 18px;
}

.acc__label {
  font-weight: 800;
  color: #0f172a;
}

.acc__chev {
  color: #0f172a;
  opacity: 0.7;
  transition: transform 200ms ease;
}

/* quando è aperto, ruota la freccia */
.acc[open] .acc__chev {
  transform: rotate(180deg);
}

.acc__content {
  border-top: 1px solid #eef0f3;
  padding: 6px 18px 12px;
}

.acc__row {
  padding: 14px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid #f1f3f6;
  color: #0f172a;
}

.acc__row:last-child {
  border-bottom: none;
}

.acc__price {
  color: #e67c00;
  font-weight: 800;
}
/* toglie il bordo blu quando clicchi sul summary */
.acc__summary:focus {
  outline: none;
}

/* (consigliato) focus accessibile ma più bello */
.acc__summary:focus-visible {
  outline: 2px solid rgba(230, 124, 0, 0.45);
  outline-offset: 2px;
  border-radius: 12px;
}
.order {
  background: #f7f5ef;  /* beige come lo stile del sito */
  padding: 70px 0;
}

.order__container {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.order__title {
  margin: 0;
  text-align: center;
  font-size: 40px;
  font-weight: 900;
  color: #0f172a;
}

.order__subtitle {
  margin: 10px 0 0;
  text-align: center;
  font-size: 16px;
  color: #6b7280;
}
.orderCard {
  width: 100%;
  max-width: 860px;
  margin-top: 34px;
  background: #ffffff;
  border: 1px solid #eef0f3;
  border-radius: 18px;
  box-shadow: 0 18px 32px rgba(0, 0, 0, 0.06);
  padding: 22px;
}

.orderCard__header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 6px 6px 18px;
}

.orderCard__icon {
  color: #e67c00;
  font-size: 20px;
}

.orderCard__title {
  font-weight: 900;
  color: #0f172a;
}

.orderCard__body {
  padding: 0 6px 6px;
}

.orderCard__hint {
  margin: 0;
  color: #6b7280;
  font-size: 14px;
}
.orderList {
  display: grid;
  gap: 12px;
}

.orderItem {
  background: #f7f8fa;
  border-radius: 14px;
  padding: 14px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.orderItem__left {
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
}

.orderItem__name {
  font-weight: 700;
  color: #0f172a;
}

.orderItem__price {
  font-weight: 800;
  color: #e67c00;
}

.orderItem__right {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}

.qtyBtn {
  width: 36px;
  height: 36px;
  border-radius: 12px;
  border: 1px solid #e5e7eb;
  background: #ffffff;
  color: #0f172a;
  font-size: 18px;
  cursor: pointer;
}

.qtyBtn:active {
  transform: translateY(1px);
}

.qtyValue {
  width: 22px;
  text-align: center;
  font-weight: 800;
  color: #0f172a;
}
.orderCheckout {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid #eef0f3;
}

.orderCheckout__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.field--full {
  margin-top: 14px;
}

.field__label {
  font-size: 13px;
  font-weight: 700;
  color: #0f172a;
}

.field__input {
  width: 100%;
  padding: 12px 12px;
  border-radius: 12px;
  border: 1px solid #e5e7eb;
  background: #ffffff;
  outline: none;
}

.field__input:focus {
  border-color: rgba(230, 124, 0, 0.45);
  box-shadow: 0 0 0 3px rgba(230, 124, 0, 0.15);
}

.field__textarea {
  resize: vertical;
  min-height: 80px;
}

.orderTotal {
  margin-top: 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-weight: 900;
  color: #0f172a;
}

.orderTotal__value {
  color: #e67c00;
}

.waBtn {
  margin-top: 18px;
  width: 100%;
  border: none;
  border-radius: 14px;
  padding: 14px 16px;
  font-weight: 900;
  color: #ffffff;
  background: #5fbf7a; /* verde WhatsApp-like */
  cursor: pointer;
}

.waBtn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.orderHint {
  margin: 10px 0 0;
  font-size: 13px;
  color: #6b7280;
  text-align: center;
}

/* responsive: su schermi stretti mettiamo 1 colonna */
@media (max-width: 700px) {
  .orderCheckout__grid {
    grid-template-columns: 1fr;
  }
}
.orderGroup {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 6px 6px;
  margin-top: 8px;
}

.orderGroup__icon {
  color: #e67c00;
  font-size: 18px;
}

.orderGroup__title {
  font-weight: 900;
  color: #0f172a;
}
.reviews {
  background: #ffffff;
  padding: 80px 0;
}

.reviews__container {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.reviews__title {
  margin: 0;
  text-align: center;
  font-size: 40px;
  font-weight: 900;
  color: #0f172a;
}

.reviews__meta {
  margin: 12px 0 0;
  display: flex;
  align-items: center;
  gap: 10px;
  color: #6b7280;
  font-size: 16px;
}

.reviews__star {
  color: #e67c00;
}

.reviews__score {
  font-weight: 900;
  color: #0f172a;
}

.reviews__sep {
  opacity: 0.7;
}
.reviewsGrid {
  width: 100%;
  margin-top: 36px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.reviewCard {
  background: #ffffff;
  border: 1px solid #eef0f3;
  border-radius: 16px;
  padding: 22px;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.05);
}

.reviewCard__stars {
  color: #f59e0b; /* giallo stelle */
  letter-spacing: 2px;
  font-size: 16px;
}

.reviewCard__text {
  margin: 12px 0 0;
  color: #6b7280;
  font-style: italic;
  line-height: 1.6;
}

.reviewCard__name {
  margin: 18px 0 0;
  font-weight: 900;
  color: #0f172a;
}

/* responsive: 2 colonne */
@media (max-width: 980px) {
  .reviewsGrid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* responsive: 1 colonna */
@media (max-width: 640px) {
  .reviewsGrid {
    grid-template-columns: 1fr;
  }
}
.visit {
  background: #ffffff;
  padding: 80px 0;
}

.visit__container {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.visit__title {
  margin: 0;
  text-align: center;
  font-size: 40px;
  font-weight: 900;
  color: #0f172a;
}

.visit__grid {
  width: 100%;
  margin-top: 40px;
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 34px;
  align-items: start;
}

/* responsive */
@media (max-width: 900px) {
  .visit__grid {
    grid-template-columns: 1fr;
  }
}
.contactList {
  display: grid;
  gap: 18px;
}

.contactItem {
  display: grid;
  grid-template-columns: 46px 1fr;
  gap: 14px;
  align-items: center;
}

.contactItem__icon {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  background: #fff3cf; /* giallino */
  display: grid;
  place-items: center;
  font-size: 18px;
}

.contactItem__label {
  font-size: 14px;
  font-weight: 900;
  color: #0f172a;
}

.contactItem__value {
  margin-top: 4px;
  font-size: 15px;
  color: #6b7280;
}

.contactItem__link {
  color: #e67c00;
  text-decoration: none;
}

.contactItem__link:hover {
  text-decoration: underline;
}

.mapBtn {
  margin-top: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 460px;
  padding: 14px 16px;
  border-radius: 14px;
  background: #e67c00;
  color: #ffffff;
  font-weight: 900;
  text-decoration: none;
}
.hoursCard {
  width: 100%;
  background: #ffffff;
  border: 1px solid #eef0f3;
  border-radius: 18px;
  box-shadow: 0 18px 32px rgba(0, 0, 0, 0.06);
  padding: 18px;
}

.hoursCard__header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 6px 6px 14px;
}

.hoursCard__icon {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  background: #fff3cf;
  display: grid;
  place-items: center;
  font-size: 18px;
}

.hoursCard__title {
  font-weight: 900;
  color: #0f172a;
  font-size: 18px;
}

.hoursList {
  margin-top: 6px;
}

.hoursRow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 6px;
  border-top: 1px solid #f1f3f5;
}

.hoursRow:first-child {
  border-top: none;
}

.hoursRow__day {
  color: #0f172a;
  font-weight: 600;
}

.hoursRow__time {
  color: #e67c00;
  font-weight: 900;
}

.hoursRow__time--closed {
  color: #ef4444; /* rosso */
}
.social {
  background: #ffffff;
  padding: 40px 0 80px;
}

.social__container {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.social__title {
  margin: 0;
  font-size: 18px;
  font-weight: 900;
  color: #0f172a;
  text-align: center;
}

.social__links {
  margin-top: 18px;
  display: flex;
  gap: 18px;
}

.socialBtn {
  width: 54px;
  height: 54px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  text-decoration: none;
  font-weight: 900;
  color: #ffffff;
  box-shadow: 0 14px 26px rgba(0, 0, 0, 0.12);
  transition: transform 0.15s ease;
}

.socialBtn:hover {
  transform: translateY(-2px);
}

.socialBtn--fb {
  background: #1877f2;
  font-size: 22px;
  text-transform: lowercase;
}

.socialBtn--ig {
  background: radial-gradient(circle at 30% 110%, #fdf497 0%, #fdf497 5%, #fd5949 35%, #d6249f 60%, #285aeb 90%);
  font-size: 18px;
}
.social__container {
  width: 100%;
  margin: 0 auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.social__links {
  justify-content: center;
}
/* ✅ forza centratura indipendente dal tuo .container globale */
.social .social__container {
  width: min(1100px, calc(100% - 48px));
  margin-left: auto;
  margin-right: auto;
  text-align: center;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

/* centra i bottoni */
.social__links {
  width: 100%;
  display: flex;
  justify-content: center;
}

/* dimensione icone SVG */
.socialIcon {
  width: 22px;
  height: 22px;
  display: block;
}
.socialIcon {
  width: 22px;
  height: 22px;
  display: block;
}
/* ====== GALLERIA (slider) ====== */
.gallery {
  background: #ffffff;
  padding: 70px 0;
}

.gallery__container {
  text-align: center;
}

.gallery__title {
  margin: 0;
  font-size: 44px;
  font-weight: 900;
  color: #0f172a;
}

.gallery__subtitle {
  margin: 12px 0 0;
  color: #6b7280;
  font-size: 16px;
}

/* "finestra" dello slider */
.gallery__slider {
  margin-top: 34px;
  overflow-x: auto;          /* ✅ permette lo scroll orizzontale */
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch; /* ✅ scroll fluido su Mac/iOS */
  scroll-snap-type: x mandatory;     /* ✅ si "aggancia" alle foto */
  padding-bottom: 6px;
}

/* nasconde la scrollbar (Chrome/Safari) */
.gallery__slider::-webkit-scrollbar {
  height: 0px;
}

/* la striscia lunga con tutte le immagini */
.gallery__track {
  display: flex;     /* ✅ mette le immagini in riga */
  gap: 22px;         /* spazio tra le foto */
  padding: 0 4px;
}

/* immagine singola */
.gallery__img {
  width: 360px;          /* larghezza card */
  height: 220px;         /* altezza card */
  object-fit: cover;     /* ritaglia bene senza deformare */
  border-radius: 18px;   /* angoli arrotondati */
  flex: 0 0 auto;        /* ✅ non si restringe */
  scroll-snap-align: start; /* aggancio dello snap */
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.08);
}
.gallery__container {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.gallery__slider {
  width: 100%;
}
/* ====== RESPONSIVE BASE (GLOBAL) ====== */

/* 1) immagini e svg non devono mai uscire dal contenitore */
img, svg {
  max-width: 100%;
  height: auto;
}

/* 2) evita overflow orizzontali fastidiosi su mobile */
html, body {
  overflow-x: hidden;
}

/* 3) container: un po’ più “stretto” su mobile (padding laterale) */
.container {
  width: min(1100px, calc(100% - 48px));
  margin: 0 auto;
}

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

  /* 4) tutte le griglie a 2/3 colonne diventano 1 colonna */
  .visit__grid,
  .testimonials__grid,
  .features__grid,
  .stats__grid {
    grid-template-columns: 1fr;
  }

  /* 5) se hai sezioni con flex in riga, le mettiamo in colonna */
  .header__container,
  .hero__container {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  /* 6) spazi laterali un po’ più piccoli */
  .container {
    width: min(1100px, calc(100% - 32px));
  }
}

@media (max-width: 600px) {

  /* 7) titoli più piccoli su telefono */
  .hero__title {
    font-size: 44px;
    line-height: 1.05;
  }

  /* 8) padding sezioni più piccolo (evita “vuoti enormi”) */
  section {
    padding-top: 48px;
    padding-bottom: 48px;
  }

  /* 9) bottoni: più comodi da cliccare su mobile */
  .btn, button, .ctaBtn {
    min-height: 48px;
  }
}
/* ====== MOBILE: sistemazione box servizi + box info ====== */
@media (max-width: 600px) {

  /* 1) I 3 box sopra: una colonna (niente card sottili) */
  .features__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
  }

  /* 2) I box sotto: 2 colonne */
  .stats__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }

  /* 3) Il box arancione (menu) a tutta larghezza */
  .stats__card--menu {
    grid-column: 1 / -1;
  }

  /* 4) Evita overflow/tagli strani */
  .features__grid > *,
  .stats__grid > * {
    min-width: 0;
  }
}
/* ====== BOXES: MOBILE FIX ====== */
@media (max-width: 600px) {

  /* 1) Riga top: una colonna */
  .boxes__grid--top {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
  }

  /* 2) Riga bottom: 2 colonne */
  .boxes__grid--bottom {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }

  /* 3) Box "Menu" arancione: tutta larghezza */
  .box--menu {
    grid-column: 1 / -1;
  }

  /* 4) Evita tagli/overflow strani */
  .boxes__grid--top > *,
  .boxes__grid--bottom > * {
    min-width: 0;
  }

  /* 5) Un po’ più “compatti” su mobile */
  .box {
    padding: 18px;
  }

  .box__title {
    font-size: 18px;
  }

  .box__text {
    font-size: 14px;
    line-height: 1.4;
  }
}
/* ====== HEADER: MOBILE FIX (nav su 2 righe) ====== */
@media (max-width: 600px) {

  .header__container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding-top: 14px;
    padding-bottom: 14px;
  }

  /* blocco logo (logo + scritta) */
  .brand {
    display: flex;
    align-items: center;
    gap: 10px;
  }

  /* lista link */
  .nav {
    width: 100%;
  }

  .nav__list {
    display: flex;
    justify-content: center;
    gap: 18px;
    flex-wrap: wrap;      /* ✅ se non ci stanno, vanno a capo */
    padding: 0;
    margin: 0;
  }

  .nav__link {
    font-size: 14px;
    padding: 8px 10px;
  }

  /* logo non enorme su telefono */
  .brand__logo {
    height: 32px;
    width: auto;
  }

  .brand__name {
    font-size: 18px;
  }
}
/* ====== HAMBURGER BUTTON ====== */
.navToggle {
  display: none;              /* nascosto su desktop */
  width: 44px;
  height: 44px;
  border: 0;
  background: transparent;
  border-radius: 12px;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  gap: 5px;
}

.navToggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: #0f172a;
  border-radius: 999px;
}

/* ====== MOBILE NAV ====== */
@media (max-width: 600px) {

  /* il contenitore header deve poter “contenere” il menu a tendina */
  .site-header .container {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  /* su mobile nascondo i link in riga */
  .nav {
    display: none;
  }

  /* mostro hamburger */
  .navToggle {
    display: flex;
  }

  /* quando il menu è aperto */
  .nav.is-open {
    display: flex;
    position: absolute;
    left: 14px;
    right: 14px;
    top: 64px;

    flex-direction: column;
    gap: 10px;
    padding: 14px;

    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 16px;
    box-shadow: 0 18px 34px rgba(0, 0, 0, 0.10);
    z-index: 999;
  }

  /* link più “cliccabili” */
  .nav.is-open .nav__link {
    padding: 10px 12px;
    border-radius: 12px;
  }
}
