:root{
  --text:#0f172a;
  --muted:#334155;
  --test:##f44336;
  --blue:#1e63d6;
  --blueDark:#0b3f9b;
  --line:#e5e7eb;

  --radius:18px;
  --shadow:0 18px 60px rgba(2,6,23,.10);
  --shadow2:0 10px 30px rgba(2,6,23,.10);

  --maxw:1120px;
}

*{box-sizing:border-box;}
html,body{height:100%;}
body{
  margin:0;
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial;
  color:var(--text);
  line-height:1.45;

  /* background pista visibile su tutta la pagina */
  background: url("../bg-track.png") center/cover no-repeat fixed;
}
/* overlay leggero per leggibilità (modifica .55 -> .45 se vuoi più pista) */
body::before{
  content:"";
  position:fixed;
  inset:0;
  background: rgba(245,247,255,.55);
  pointer-events:none;
  z-index:-1;
}

a{color:inherit;text-decoration:none;}
.container{ width:min(var(--maxw), calc(100% - 36px)); margin:0 auto; }

/* Utility visibilità */
.only-mobile{ display:none; }
.only-desktop{ display:inline-flex; }

/* =========================
   HEADER / NAV (pulito)
   ========================= */
.site-header{
  position: sticky;
  top: 0;
  z-index: 999;

  /* ✅ respiro sopra/sotto (spazio vuoto che volevi) */
  padding: 14px 0;

  /* separazione elegante dal contenuto + leggibilità su bg */
  background: rgba(245,247,255,.55);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(15,23,42,.08);
}

.topbar{
  /* ✅ layout usabile: logo | menu | azioni */
  display:grid;
  grid-template-columns: auto 1fr auto;
  align-items:center;
  gap:16px;
}

.brand img{ display:block; height:34px; width:auto; }

/* NAV desktop */
.main-nav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  min-width:0;
  flex-wrap:wrap; /* se stringe, va a capo senza esplodere */
}

/* NAV link: “menu” con pill + underline */
.nav-link{
  position: relative;
  display:inline-flex;
  align-items:center;
  height: 38px;                 /* hit-area comoda */
  padding: 0 12px;
  border-radius: 999px;
  font-weight: 650;
  font-size: 14px;
  color: var(--text);
  opacity: 1;
  background: transparent;
  transition: background .18s ease, transform .18s ease;
}
.nav-link.active{
  background: rgba(30,99,214,.12);
}

.nav-link.active::after{
  transform: scaleX(1);
}
.nav-link:hover{
  background: rgba(30,99,214,.08);
  transform: translateY(-1px);
}

/* underline elegante (non troppo “urlata”) */
.nav-link::after{
  content:"";
  position:absolute;
  left: 12px;
  right: 12px;
  bottom: 7px;
  height: 2px;
  border-radius: 2px;
  background: linear-gradient(90deg, rgba(30,99,214,.0), rgba(30,99,214,.55), rgba(30,99,214,.0));
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .18s ease;
}

.nav-link:hover::after{
  transform: scaleX(1);
}

/* Bottoni (CTA) */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:9px 14px;          /* leggermente più compatti -> più “usabile” */
  border-radius:12px;
  font-weight:700;
  text-decoration:none;
  transition: all .2s ease;
  white-space:nowrap;
}

.btn-primary{
  background: linear-gradient(135deg, #1e63d6, #0b3f9b);
  color:#fff !important;
  box-shadow: 0 6px 18px rgba(30,99,214,.35);
}
.btn-primary:hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(30,99,214,.45);
}

.btn-secondary{
  background: rgba(30,99,214,.08);
  color:#1e63d6;
  border:1px solid rgba(30,99,214,.25);
}
.btn-secondary:hover{ background: rgba(30,99,214,.15); }

/* Stato attivo per anchor #aziende */
.btn-secondary.active{
  background: rgba(30,99,214,.18);
  border-color: rgba(30,99,214,.35);
}

/* Azioni a destra */
.top-actions{
  justify-self:end;
  display:flex;
  align-items:center;
  gap:12px;
  flex: 0 0 auto;
}

/* Instagram */
.insta-link{
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  transition:transform .2s ease;
}
.insta-link svg{
  width:34px;
  height:34px;
  display:block;
}
.insta-link:hover{ transform:scale(1.08); }

/* QR */
.qr{
  width:40px;
  height:40px;
  flex: 0 0 40px;
  display:grid;
  place-items:center;
  border-radius:10px;
  overflow:hidden;
  background:#fff;
  border:1px solid rgba(148,163,184,.35);
  box-shadow:0 8px 18px rgba(2,6,23,.08);
}
.qr img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}

/* Burger */
.nav-toggle{
  display:none;
  background:transparent;
  border:0;
  padding:10px;
  cursor:pointer;
}
.nav-toggle span{
  display:block;
  width:22px;
  height:2px;
  margin:5px 0;
  border-radius:2px;
  background: currentColor;
}

/* Mobile menu */
@media (max-width: 860px){
  .only-mobile{ display:block; }
  .only-desktop{ display:none !important; }

  /* Mobile header più pulito: logo + burger */
  .top-actions{ display:none !important; }
  .nav-toggle{ grid-column: 3; justify-self: end; }

  .nav-toggle{ display:block; }
  .qr{ display:none !important; } /* ✅ unica regola, niente duplicati */

  .main-nav{
    position: fixed;
    left: 14px;
    right: 14px;
    top: 86px; /* ✅ più spazio sopra rispetto a 78px */
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:10px;
    padding:14px;
    border-radius:16px;
    background:#fff;
    border:1px solid rgba(0,0,0,.08);
    box-shadow: 0 18px 60px rgba(2,6,23,.18);
  }
  .main-nav.is-open{ display:flex; }

  .nav-link{
    height:auto;
	padding:12px 12px;
	border-radius:12px;
	background: #fff;
	border:1px solid rgba(148,163,184,.22);
	transform:none;
  }
  .nav-link::after{ display:none; }
  .nav-link:hover{
	background: rgba(30,99,214,.06);
  }
  .main-nav .btn{
    width:100%;
    justify-content:center;
  }
}

/* =========================
   HERO (glass)
   ========================= */
.hero-wrap{
  position:relative;
  margin-top:12px; /* ✅ un filo più respiro sotto header */
  border-radius:26px;
  overflow:hidden;
  box-shadow:var(--shadow);
  background: rgba(255,255,255,.36);
  border:1px solid rgba(255,255,255,.40);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.hero-wrap::after{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(900px 380px at 15% 12%, rgba(30,99,214,.12), transparent 55%),
    radial-gradient(900px 380px at 85% 12%, rgba(11,63,155,.08), transparent 55%);
  pointer-events:none;
}
.hero{
  position:relative; z-index:1;
  display:grid; grid-template-columns: 1.05fr .95fr; gap:22px;
  padding:34px 34px 18px;
}
h1{ margin:10px 0 14px; font-size:clamp(26px,3.2vw,40px); line-height:1.08; letter-spacing:-0.02em; }
.hero p{ margin:0 0 10px; color:var(--muted); font-size:15px; }
.machine{ display:flex; align-items:flex-end; justify-content:center; padding:10px 0 0; }
.machine .img-wrap{ width:min(340px,100%); border-radius:18px; background:rgba(255,255,255,.75); border:1px solid rgba(148,163,184,.35); padding:16px; box-shadow:var(--shadow2); }
.machine img{ width:100%; height:auto; display:block; filter: drop-shadow(0 22px 30px rgba(2,6,23,.22)); }

/* Section base */
.section{ position:relative; z-index:1; padding:0 34px 22px; }
.card{
  background: rgba(255,255,255,.42);
  border:1px solid rgba(255,255,255,.45);
  border-radius:var(--radius);
  box-shadow:0 18px 60px rgba(2,6,23,.10);

  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);

  padding:24px;
}
h2{ margin:0 0 12px; font-size:20px; }
.checklist{ list-style:none; padding:0; margin:0; display:grid; gap:10px; color:var(--muted); font-size:15px; }
.checklist li{ display:flex; gap:10px; align-items:flex-start; }
.check{ width:18px;height:18px;margin-top:2px; flex:0 0 18px; border-radius:6px; background: rgba(30,99,214,.12); display:grid; place-items:center; }
.check svg{ width:14px;height:14px; } .check path{ fill:var(--blue); }

/* IDEALE PER - wrapper card e layout */
.ideal-wrap{ text-align:center; }
.ideal-heading{ margin:0 0 16px; font-size:20px; letter-spacing:-0.01em; }

/* FORZA griglia 4 colonne */
.ideal-grid{
  display:grid !important;
  grid-template-columns: repeat(4, minmax(0,1fr)) !important;
  gap:16px !important;
  width:100%;
  margin:0 auto;
  align-items:stretch;
}

.ideal-card{
  background: rgba(255,255,255,.85);
  border:1px solid rgba(148,163,184,.22);
  border-radius:16px;
  box-shadow:0 12px 26px rgba(2,6,23,.06);
  padding:18px 14px;
  text-align:center;
  min-height:150px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

/* icone più grandi */
.ideal-ico{
  width:72px; height:72px; margin:0 auto 14px; border-radius:18px;
  background: rgba(30,99,214,.12); display:grid; place-items:center;
}
.ideal-ico svg{ width:40px; height:40px; }
.ideal-ico svg *{ stroke:var(--blue); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.ideal-title{ font-weight:900; font-size:15px; color:#0f172a; line-height:1.15; }

/* Grid responsive */
@media (max-width:980px){
  .ideal-grid{ grid-template-columns: repeat(2, minmax(0,1fr)) !important; }
  .hero{ grid-template-columns:1fr; padding:28px 22px 14px; }
  .section{ padding:0 22px 18px; }
  .standard-item{ min-height: unset; }
}
@media (max-width:520px){
  .ideal-grid{ grid-template-columns:1fr !important; }
}

/* split bottom for columns */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.form-card p{ margin:0 0 12px; color:var(--muted); font-size:14px; }
.field{ margin-bottom:10px; }
.input,select{ width:100%; padding:11px 12px; border-radius:12px; border:1px solid rgba(148,163,184,.35); background:#fff; font-size:14px; outline:none; }
.input:focus,select:focus{ border-color: rgba(30,99,214,.55); box-shadow:0 0 0 4px rgba(30,99,214,.10); }
.submit{ width:100%; padding:12px; border:0; border-radius:12px; background:linear-gradient(180deg,var(--blue),var(--blueDark)); color:#fff; font-weight:900; cursor:pointer; box-shadow:0 14px 30px rgba(30,99,214,.18); }

/* Footer trasparente */
footer{
  margin-top:60px; padding:40px 0;
  background:transparent;
  border-top:1px solid rgba(15,23,42,.09);
}
.footer-inner{ display:flex; justify-content:space-between; align-items:flex-end; gap:20px; }
.footer-brand{ display:flex; flex-direction:column; gap:6px; }
.footer-brand img{ height:32px; opacity:.9; }
.footer-small{ font-size:14px; color: rgba(15,23,42,.70); }

/* small screens footer stack */
@media (max-width:700px){
  .footer-inner{ flex-direction:column; align-items:flex-start; gap:10px; }
}

/* ===== Mobile fixes ===== */
@media (max-width: 900px){
  body{
    background: url("../sfondomobile.png") center top / cover no-repeat;
    background-attachment: scroll;
  }
  .split{ grid-template-columns: 1fr !important; }
  .container{ width: calc(100% - 24px); }
  .card{ padding: 16px; }

  h2{ font-size: 18px; }
  .checklist{ font-size: 14px; }
}
/* Instagram dentro menu mobile */
.nav-ig{
  justify-content:center;
  gap:10px;
}

.ig-dot{
  width:12px;
  height:12px;
  border-radius:999px;
  background: linear-gradient(135deg,#f58529,#dd2a7b,#8134af,#515bd4);
  box-shadow: 0 6px 14px rgba(2,6,23,.10);
}
@media (min-width: 861px){
  .only-mobile{ display:none !important; }
  .only-desktop{ display:inline-flex !important; }
}
@media (min-width: 861px){
  .main-nav{
    flex-wrap: nowrap !important;  /* niente a capo */
    gap: 14px;                     /* un filo più compatto */
  }

  .nav-link{
    height: 34px;
    padding: 0 10px;
    font-size: 13px;
  }

  .btn{
    padding: 8px 12px;
    font-size: 13px;
  }
}
/* =========================
   Scopri di più (layout)
   ========================= */
.discover-hero{ padding: 18px; }
.discover-hero__grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 22px;
  padding: 18px;
}
.discover-hero__text h1{ margin:10px 0 12px; }
.discover-hero__text p{ margin:0 0 14px; color: var(--muted); }
.discover-hero__cta{ display:flex; flex-direction:column; gap:10px; align-items:flex-start; }
.discover-hero__link{ font-weight:650; opacity:.9; }
.discover-hero__link:hover{ opacity:1; text-decoration:underline; }

.discover-section{ padding-top: 10px; }

.discover-head{ text-align:center; margin-bottom: 10px; }
.discover-sub{ margin:0; color:var(--muted); font-size:15px; }

.steps-grid{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
}
.step-card{
  border:1px solid rgba(148,163,184,.22);
  border-radius: 16px;
  background: rgba(255,255,255,.85);
  padding: 12px;
  text-align:left;
}
.step-number{ font-weight: 900; font-size: 18px; color: var(--blue); margin-bottom: 8px; }
.step-title{ margin-top: 10px; font-weight: 900; }

.features-row{
  margin-top: 14px;
  display:flex;
  gap: 10px;
  justify-content:center;
  flex-wrap:wrap;
}
.feature-pill{
  display:inline-flex;
  gap:8px;
  align-items:center;
  padding: 10px 12px;
  border-radius: 999px;
  border:1px solid rgba(148,163,184,.22);
  background: rgba(255,255,255,.75);
  font-weight: 700;
  color: rgba(15,23,42,.85);
}
.feature-ico{
  width:22px; height:22px;
  border-radius: 8px;
  display:grid; place-items:center;
  background: rgba(30,99,214,.12);
  color: var(--blue);
  font-weight: 900;
}

.discover-par{ color:var(--muted); font-size:15px; line-height:1.55; }
.mt-24{ margin-top:24px; }

/* Lo standard RiderCare — cards compatte e uniformi */
.standard-row{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
  align-items: stretch;
}

.standard-item{
  display:flex;
  gap: 10px;
  align-items:center;

  padding: 12px 14px;
  border-radius: 14px;

  border:1px solid rgba(148,163,184,.22);
  background: rgba(255,255,255,.55);

  min-height: 72px;              /* tutte uguali */
}

.standard-ico{
  width:34px;
  height:34px;
  border-radius: 12px;
  background: rgba(30,99,214,.12);
  border:1px solid rgba(30,99,214,.18);
  flex: 0 0 34px;
}

.standard-title{
  font-weight: 800;
  line-height: 1.15;
  font-size: 14px;
  margin:0;

  /* niente troncamento */
  white-space: normal;
  overflow: visible;
}

.audience-grid{
  margin-top: 12px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
}
.aud-card{
  background: rgba(255,255,255,.85);
  border:1px solid rgba(148,163,184,.22);
  border-radius: 16px;
  padding: 12px;
  box-shadow: 0 12px 26px rgba(2,6,23,.06);
}
.aud-title{ margin: 10px 0 8px; font-size: 16px; font-weight: 900; }
.aud-list{ margin:0; padding-left: 18px; color: var(--muted); font-size: 14px; display:grid; gap:6px; }

/* Placeholder images */
.ph{
  border-radius: 14px;
  border:1px dashed rgba(148,163,184,.55);
  background: rgba(255,255,255,.55);
  display:grid;
  place-items:center;
  overflow:hidden;
}
.ph__label{
  font-weight: 900;
  letter-spacing: .06em;
  font-size: 12px;
  color: rgba(15,23,42,.45);
}
.ph-hero{ min-height: 260px; }
.ph-step{ height: 120px; }
.ph-side{ min-height: 260px; }
.ph-aud{ height: 140px: 
		overflow:hidden; 
		}

/* Responsive */
@media (max-width: 980px){
  .discover-hero__grid{ grid-template-columns: 1fr; }
  .steps-grid{ grid-template-columns: 1fr; }
  .standard-row{ grid-template-columns: 1fr; }
  .audience-grid{ grid-template-columns: 1fr; }
}
/* HERO SCOPRI */
.hero-scopri{
  grid-template-columns: 1fr 1fr;
  align-items:center;
  padding: 42px 42px 28px;
}

.hero-text p{
  max-width: 520px;
}

/* HERO image: integrata nella card, bordi morbidi */
.hero-image{
  position:relative;
  display:flex;
  justify-content:center;
  align-items:center;

  /* qui teniamo i bordi arrotondati e tagliamo l'overlay dentro */
  border-radius:18px;
  overflow:hidden;

  /* leggero stacco, NON “incollata” */
  box-shadow: 0 10px 30px rgba(2,6,23,.10);
  background: rgba(255,255,255,.18);
}
.hero-image::before{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(circle at 70% 50%, rgba(255,255,255,0) 40%, rgba(255,255,255,.15) 100%);
  pointer-events:none;
}

.hero-image img{
  width:100%;
  max-width:540px;
  height:auto;
  display:block;

  filter: saturate(.92) contrast(.95) brightness(.98);
  opacity:.95;

  transition: all .3s ease;
}


/* Sfumatura morbida ai bordi per fondere con lo sfondo della card */
.hero-image::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;

  /* fade molto soft (niente bianco sparato) */
  background:
    radial-gradient(90% 85% at 20% 50%, rgba(255,255,255,0) 55%, rgba(245,247,255,.22) 100%),
    radial-gradient(90% 85% at 80% 50%, rgba(255,255,255,0) 55%, rgba(245,247,255,.22) 100%);

  /* ancora più “morbido” */
  opacity: .75;
}
/* Mobile */
@media (max-width: 980px){
  .hero-scopri{
    grid-template-columns:1fr;
    text-align:center;
  }
  .hero-text p{
    margin: 0 auto 18px;
  }
}
/* Immagine reale dentro al placeholder della sezione "Perché sanificare" */
.perche-img{
  overflow:hidden;
}

.perche-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;

  filter: saturate(.92) contrast(.95) brightness(.98);
  opacity:.96;
}/* SVG standard icons */
.standard-ico{
  display:grid;
  place-items:center;
}

.std-svg{
  width:22px;
  height:22px;
}

.std-svg path,
.std-svg circle{
  stroke: var(--blue);
  stroke-width: 1.8;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}


/* =========================================
   Scopri: allinea le card alla hero (niente inset laterale)
   (Solo per sezioni con classi "section discover-section")
========================================= */
.discover-section.section{
  padding-left: 0;
  padding-right: 0;
}
.ph img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.ph-aud > img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position: 50% 95% !important;
}