
:root{
  --black:#050505;
  --panel:#0d0f13;
  --line:#242a32;
  --gold:#f5b400;
  --blue:#098cff;
  --white:#ffffff;
  --muted:#c9ced6;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background: radial-gradient(circle at 70% 10%, #142033 0, #050505 34%, #000 100%);
  color:var(--white);
  font-family: Arial, Helvetica, sans-serif;
}
a{color:inherit;text-decoration:none}
.header{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 34px;
  background:rgba(0,0,0,.88);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,.10);
}
.logo-small{width:86px;height:86px;object-fit:contain;background:#000;border-radius:12px}
.nav{display:flex;gap:28px;align-items:center;font-weight:800;letter-spacing:.04em}
.nav a{color:#eee}
.nav a:hover,.nav .active{color:var(--gold)}
.cta{
  display:inline-flex;gap:10px;align-items:center;justify-content:center;
  background:linear-gradient(180deg,#ffd15b,#f2a900);
  color:#000;font-weight:900;
  padding:14px 22px;border-radius:10px;
  border:1px solid rgba(255,198,0,.85);
  box-shadow:0 0 18px rgba(245,180,0,.18);
  text-transform:uppercase;
}
.cta.outline{background:rgba(0,0,0,.35);color:white;border:1px solid var(--gold)}
.hero{
  min-height:620px;
  display:grid;
  grid-template-columns: 1fr 1.35fr;
  gap:28px;
  align-items:center;
  padding:54px 44px 30px;
  background:
    linear-gradient(90deg,rgba(0,0,0,.98),rgba(0,0,0,.62),rgba(0,0,0,.88)),
    radial-gradient(circle at 75% 42%,rgba(9,140,255,.34),transparent 28%),
    radial-gradient(circle at 55% 38%,rgba(245,180,0,.28),transparent 24%);
  border-bottom:1px solid rgba(255,255,255,.10);
}
.hero h1{
  margin:0;
  font-size:clamp(44px,6vw,86px);
  line-height:.96;
  font-weight:1000;
  letter-spacing:-.04em;
  text-transform:uppercase;
}
.blue{color:var(--blue);text-shadow:0 0 16px rgba(9,140,255,.35)}
.hero .sub{font-size:clamp(22px,2.4vw,34px);font-weight:900;margin:22px 0 14px}
.hero p{font-size:20px;line-height:1.55;color:#e8edf5;max-width:620px}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap;margin-top:28px}
.hero-art{
  position:relative;
  min-height:420px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.hero-art img{
  width:min(520px,88%);
  object-fit:contain;
  filter:drop-shadow(0 0 34px rgba(245,180,0,.28));
}
.moto-shape{
  position:absolute;right:0;top:20px;width:42%;height:78%;
  border:2px solid rgba(9,140,255,.35);
  border-radius:34% 66% 48% 52% / 47% 42% 58% 53%;
  background:linear-gradient(135deg,rgba(255,255,255,.12),rgba(0,0,0,.05));
  opacity:.55;
}
.strip{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-bottom:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.82);
}
.strip .item{padding:30px 42px;border-right:1px solid rgba(255,255,255,.14);display:flex;gap:18px;align-items:center}
.strip .icon{font-size:44px;color:var(--blue)}
.strip h3{margin:0;font-size:25px}
.strip p{margin:5px 0 0;color:var(--muted);font-size:16px}
.section{padding:52px 44px}
.section h2{font-size:42px;margin:0 0 16px;text-transform:uppercase}
.section .lead{color:var(--muted);font-size:19px;margin:0 0 28px}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{
  background:linear-gradient(180deg,rgba(18,21,27,.94),rgba(4,5,7,.96));
  border:1px solid rgba(255,255,255,.17);
  border-radius:16px;overflow:hidden;
  box-shadow:0 12px 30px rgba(0,0,0,.34);
}
.card img{width:100%;height:230px;object-fit:cover;display:block;background:#111}
.card .body{padding:20px}
.card h3{margin:0 0 10px;font-size:24px;text-transform:uppercase}
.card p{color:#d5d9df;font-size:17px;line-height:1.45}
.arrow{color:var(--gold);font-size:28px;font-weight:900}
.contact-card{padding:26px}
.contact-card p{margin:12px 0;color:#e8edf5}
.banner{
  margin:0 44px 52px;
  border:1px solid rgba(9,140,255,.7);
  background:linear-gradient(90deg,rgba(8,22,45,.75),rgba(0,0,0,.95));
  border-radius:18px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:28px;
}
.banner h2{margin:0;font-size:31px;text-transform:uppercase;color:var(--gold)}
.banner p{font-size:19px;color:#e9edf6;margin:8px 0 0}
.footer{padding:34px;text-align:center;color:#9ea7b4;border-top:1px solid rgba(255,255,255,.10);background:#030303}
.whatsapp{
  position:fixed;right:28px;bottom:28px;z-index:80;
  background:#17b74e;color:#fff;border-radius:999px;padding:17px 22px;
  font-weight:900;box-shadow:0 0 0 10px rgba(23,183,78,.16),0 12px 30px rgba(0,0,0,.42);
}
.page-hero{padding:74px 44px 36px;background:linear-gradient(90deg,#000,#07111d);border-bottom:1px solid rgba(255,255,255,.1)}
.page-hero h1{font-size:clamp(42px,6vw,72px);margin:0;text-transform:uppercase}
.page-hero p{font-size:20px;color:var(--muted);max-width:900px}
.event-feature{display:grid;grid-template-columns:360px 1fr;gap:34px;align-items:center;background:#090b10;border:1px solid #252c36;border-radius:18px;padding:22px;margin-bottom:38px}
.event-feature img{width:100%;border-radius:12px}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.gallery-grid a{display:block;background:#0a0c10;border:1px solid #252c36;border-radius:12px;padding:10px}
.gallery-grid img{width:100%;display:block;border-radius:8px}
.simple-panel{background:#0b0d12;border:1px solid #252c36;border-radius:18px;padding:28px;margin:20px 0}
@media(max-width:1000px){
  .header{flex-direction:column;gap:14px;padding:12px}
  .nav{gap:13px;flex-wrap:wrap;justify-content:center;font-size:14px}
  .hero{grid-template-columns:1fr;text-align:center;padding:36px 18px}
  .hero p{margin-left:auto;margin-right:auto}
  .hero-actions{justify-content:center}
  .strip,.cards{grid-template-columns:1fr}
  .strip .item{border-right:0;border-bottom:1px solid rgba(255,255,255,.14)}
  .section{padding:36px 18px}
  .banner{margin:0 18px 36px;flex-direction:column;text-align:center}
  .event-feature{grid-template-columns:1fr}
}



/* HOME HERO SEO - testo vivo sopra immagine */
.hero{
  min-height:620px!important;
  position:relative;
  display:flex!important;
  align-items:center;
  justify-content:flex-start;
  padding:70px 70px 40px!important;
  background:url('sfondo-hero-clean.png') center/cover no-repeat!important;
  border-bottom:1px solid rgba(255,255,255,.10)!important;
  overflow:hidden;
}

.hero-overlay{
  max-width:690px;
  position:relative;
  z-index:2;
  background:transparent!important;
  padding:0!important;
  margin-top:-10px;
}

.hero h1{
  font-family: Impact, Haettenschweiler, 'Arial Black', sans-serif;
  font-size:clamp(58px,6.8vw,104px);
  line-height:.92;
  margin:0;
  font-weight:900;
  letter-spacing:.01em;
  text-transform:uppercase;
  color:#f4f4f4;
  text-shadow:0 4px 0 rgba(0,0,0,.55), 0 0 14px rgba(0,0,0,.85);
}

.hero h1 span{
  color:#087bff;
  text-shadow:0 4px 0 rgba(0,0,0,.55), 0 0 18px rgba(0,80,255,.45);
}

.hero-tags{
  margin-top:22px;
  font-size:clamp(22px,2.2vw,39px);
  font-weight:700;
  color:#fff;
  text-shadow:0 3px 8px rgba(0,0,0,.9);
}

.hero-tags .dot{
  color:#f5b400;
  padding:0 .18em;
}

.hero p{
  margin-top:28px;
  font-size:clamp(18px,1.45vw,29px);
  line-height:1.55;
  max-width:650px;
  color:#f1f1f1;
  text-shadow:0 3px 8px rgba(0,0,0,.95);
}

.hero-buttons{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:22px;
  flex-wrap:wrap;
  padding:24px 18px 34px;
  background:#000;
  border-bottom:1px solid rgba(255,255,255,.10);
}

.hero-buttons .cta{
  min-width:230px;
}

@media(max-width:1200px){
  .hero{
    min-height:560px!important;
    padding:55px 40px 35px!important;
    background-position:center!important;
  }
  .hero-overlay{max-width:560px}
}

@media(max-width:800px){
  .hero{
    min-height:520px!important;
    align-items:flex-start;
    padding:42px 24px 30px!important;
    background-position:58% center!important;
  }
  .hero-overlay{max-width:72%;}
  .hero h1{font-size:clamp(42px,10vw,76px)}
  .hero-tags{font-size:clamp(18px,4vw,28px)}
  .hero p{font-size:clamp(16px,3.2vw,22px);max-width:420px}
}

@media(max-width:600px){
  .hero{
    min-height:470px!important;
    padding:30px 16px 24px!important;
    background-position:64% center!important;
  }
  .hero-overlay{max-width:78%;}
  .hero h1{font-size:clamp(34px,11.5vw,58px)}
  .hero-tags{margin-top:14px;font-size:17px;line-height:1.25}
  .hero p{margin-top:18px;font-size:15px;line-height:1.45;max-width:300px}
  .hero-buttons{padding:18px 14px 26px;}
  .hero-buttons .cta{width:100%;min-width:0;}
}


/* Aggiornamenti home, istruttori, Corrado e mappa */
.map-embed{margin:16px 0 22px;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.16);background:#111}
.map-embed iframe{width:100%;height:210px;border:0;display:block;filter:grayscale(.15) contrast(1.05)}
.instructor-feature h2,.corrado-page h2{color:var(--gold);text-transform:uppercase}
.instructors-page .simple-panel h3{font-size:30px;color:#fff;margin-bottom:8px}
.instructors-page .simple-panel p{font-size:20px;color:#e8edf5}
.doc-links{display:flex;gap:14px;flex-wrap:wrap;margin-top:24px}
.video-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-top:28px}
.video-grid video{width:100%;border-radius:14px;background:#000;border:1px solid rgba(255,255,255,.16)}
.moto-grid img{height:240px;object-fit:cover}
@media(max-width:900px){.map-embed iframe{height:240px}.doc-links .cta{width:100%}}
