:root{
      /* Light theme */
      --bg: #f6f7fb;
      --bg2:#ffffff;
      --surface: rgba(255,255,255,0.92);
      --surface2: rgba(255,255,255,0.70);
      --stroke: rgba(17,24,39,0.10);

      --text: rgba(17,24,39,0.92);
      --muted: rgba(17,24,39,0.72);
      --subtle: rgba(17,24,39,0.56);

      --accent: #6D28D9;   /* violet */
      --accent2:#0891B2;   /* cyan */
      --warm:   #D97706;   /* amber */
      --good:   #16A34A;

      --radius: 18px;
      --radius2: 24px;
      --shadow: 0 14px 36px rgba(17,24,39,0.10);

      --max: 1120px;
      --pad: 22px;

      --font-sans: "Plus Jakarta Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      --font-display: "Fraunces", Georgia, serif;
    }

    *{ box-sizing: border-box; }
    html{ scroll-behavior: smooth; }
    body{
      margin:0;
      font-family: var(--font-sans);
      background:
        radial-gradient(900px 520px at 10% 0%, rgba(109,40,217,0.12), transparent 60%),
        radial-gradient(820px 520px at 90% 5%, rgba(8,145,178,0.12), transparent 60%),
        radial-gradient(900px 600px at 70% 90%, rgba(217,119,6,0.10), transparent 60%),
        var(--bg);
      color: var(--text);
      line-height: 1.55;
      overflow-x:hidden;
    }
    a{ color: inherit; text-decoration: none; }
    img{ max-width:100%; display:block; }
    .container{ width:100%; max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }

    /* Utilities */
    .sr-only{
      position:absolute; width:1px; height:1px; padding:0; margin:-1px;
      overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
    }

    /* NAV */
    .nav{
      position: sticky; top:0; z-index:100;
      backdrop-filter: blur(12px);
      background: rgba(246,247,251,0.70);
      border-bottom: 1px solid var(--stroke);
    }
    .nav-inner{
      display:flex; align-items:center; justify-content:space-between;
      gap: 14px; padding: 14px 0;
    }
    .brand{ display:flex; align-items:center; gap:12px; min-width: 240px; }
    .brand img{
      width: 52px; height: 52px;
      border-radius: 14px;
      background: rgba(255,255,255,0.85);
      border: 1px solid var(--stroke);
      padding: 6px;
      box-shadow: 0 10px 24px rgba(17,24,39,0.08);
    }
    .brand .name{ display:flex; flex-direction:column; line-height:1.12; }
    .brand .name strong{ font-weight: 900; letter-spacing: 0.2px; font-size: 14px; }
    .brand .name span{ font-size: 12px; color: var(--muted); letter-spacing: 0.2px; }

    .nav-links{ display:flex; align-items:center; gap: 10px; flex-wrap: wrap; }
    .nav-links a{
      font-size: 13px; color: var(--muted);
      padding: 10px 10px; border-radius: 12px;
      transition: background .2s ease, color .2s ease, transform .15s ease;
    }
    .nav-links a:hover{ background: rgba(17,24,39,0.05); color: var(--text); transform: translateY(-1px); }

    .nav-cta{ display:flex; align-items:center; gap: 10px; flex-wrap: wrap; justify-content:flex-end; }
    .btn{
      display:inline-flex; align-items:center; justify-content:center; gap:10px;
      padding: 11px 14px; border-radius: 14px;
      border: 1px solid var(--stroke);
      background: rgba(255,255,255,0.80);
      color: var(--text);
      font-weight: 800; font-size: 13px;
      cursor:pointer;
      transition: transform .15s ease, background .2s ease, border-color .2s ease, filter .2s ease;
      user-select:none;
      box-shadow: 0 10px 24px rgba(17,24,39,0.08);
    }
    .btn:hover{ transform: translateY(-1px); background: rgba(255,255,255,0.95); border-color: rgba(17,24,39,0.16); }
    .btn-primary{
      border: none;
      background: linear-gradient(135deg, var(--accent), var(--accent2));
      color: #fff;
      box-shadow: 0 16px 34px rgba(109,40,217,0.22);
    }
    .btn-primary:hover{ filter: brightness(1.04); }
    .btn-ghost{
      background: transparent;
      box-shadow: none;
    }
    .btn-ghost:hover{ background: rgba(17,24,39,0.05); }
.card.featured{
  border: 2px solid rgba(109,40,217,0.35);
  background:
    radial-gradient(420px 220px at 20% 0%, rgba(109,40,217,0.10), transparent 65%),
    rgba(255,255,255,0.92);
  box-shadow: 0 18px 36px rgba(109,40,217,0.14);
  transform: translateY(-2px);
  grid-column: span 8;
}

.card.featured .icon{
  border-color: rgba(109,40,217,0.18);
  background: rgba(109,40,217,0.08);
}

.card.featured h4{
  color: var(--accent);
}
    .burger{
      display:none;
      width: 44px; height: 44px;
      border-radius: 14px;
      border: 1px solid var(--stroke);
      background: rgba(255,255,255,0.80);
      cursor:pointer;
      box-shadow: 0 10px 24px rgba(17,24,39,0.08);
    }
    .burger svg{ width:22px; height:22px; margin:11px; opacity:.9; }

    .mobile-panel{
      display:none;
      border-top: 1px solid var(--stroke);
      padding: 10px 0 16px;
    }
    .mobile-panel a{
      display:block; padding: 12px 12px;
      border-radius: 14px; color: var(--muted);
    }
    .mobile-panel a:hover{ background: rgba(17,24,39,0.05); color: var(--text); }
    .mobile-panel .row{ display:grid; gap: 10px; margin-top: 10px; }

    /* HERO */
    .hero{ padding: 34px 0 10px; }
    .hero-grid{
      display:grid;
      grid-template-columns: 1.15fr 0.85fr;
      gap: 26px;
      align-items:center;
    }
    .kicker{
      display:inline-flex; align-items:center; gap:10px;
      padding: 8px 12px;
      border-radius: 999px;
      background: rgba(255,255,255,0.75);
      border: 1px solid var(--stroke);
      color: var(--muted);
      font-size: 12px;
      letter-spacing: 0.35px;
      box-shadow: 0 10px 24px rgba(17,24,39,0.06);
    }
    .kicker b{ color: var(--text); font-weight: 900; }
    .hero h1{
      margin: 14px 0 10px;
      font-family: var(--font-display);
      font-weight: 700;
      font-size: clamp(34px, 4vw, 54px);
      line-height: 1.02;
      letter-spacing: -0.7px;
    }
    .hero p.lead{
      margin: 0 0 18px;
      color: var(--muted);
      font-size: 16px;
      max-width: 65ch;
    }
    .hero-actions{
      display:flex; flex-wrap:wrap; gap: 12px;
      margin: 16px 0 18px;
    }
    .hero-local{
      margin-top:12px;
      font-size:14px;
      line-height:1.5;
      opacity:.9;
    }
    .meta-row{
      display:flex; flex-wrap:wrap; gap: 12px;
      margin-top: 16px;
      color: var(--subtle);
      font-size: 12px;
    }
    .meta-pill{
      display:inline-flex; align-items:center; gap: 10px;
      padding: 10px 12px;
      border-radius: 14px;
      border: 1px solid var(--stroke);
      background: rgba(255,255,255,0.75);
    }
    .dot{
      width: 9px; height: 9px; border-radius: 999px;
      background: linear-gradient(135deg, var(--accent), var(--accent2));
      box-shadow: 0 0 0 4px rgba(109,40,217,0.12);
      flex: 0 0 auto;
    }

    .hero-media{
      border-radius: var(--radius2);
      overflow:hidden;
      border: 1px solid var(--stroke);
      background: rgba(255,255,255,0.72);
      box-shadow: var(--shadow);
      position: relative;
    }
    .hero-media img{
      width: 100%;
      height: 420px;
      object-fit: cover;
      object-position: center;
      display:block;
    }
    .hero-media .cap{
      position:absolute;
      left:14px; right:14px; bottom:14px;
      padding: 12px 14px;
      border-radius: 16px;
      background: rgba(255,255,255,0.84);
      border: 1px solid var(--stroke);
      color: rgba(17,24,39,0.86);
      font-size: 13px;
      box-shadow: 0 12px 30px rgba(17,24,39,0.10);
    }

    /* MICRO: BAMBINI / ADULTI */
    .micro{ padding: 18px 0 34px; }
.micro-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.micro-card.teens::before{
  background:
    radial-gradient(420px 240px at 20% 0%, rgba(8,145,178,0.14), transparent 60%),
    radial-gradient(420px 260px at 80% 40%, rgba(109,40,217,0.10), transparent 70%);
}
    .micro-card{
      border-radius: var(--radius2);
      padding: 18px;
      background: rgba(255,255,255,0.82);
      border: 1px solid var(--stroke);
      overflow:hidden;
      position: relative;
      box-shadow: 0 12px 30px rgba(17,24,39,0.08);
    }
    .micro-card::before{
      content:"";
      position:absolute; inset:-2px;
      opacity:.9; pointer-events:none;
    }
    .micro-card.kids::before{
      background:
        radial-gradient(420px 240px at 20% 0%, rgba(217,119,6,0.14), transparent 60%),
        radial-gradient(420px 260px at 80% 40%, rgba(8,145,178,0.12), transparent 70%);
    }
    .micro-card.adults::before{
      background:
        radial-gradient(420px 240px at 20% 0%, rgba(109,40,217,0.14), transparent 60%),
        radial-gradient(420px 260px at 80% 40%, rgba(8,145,178,0.10), transparent 70%);
    }
    .micro-card > *{ position: relative; }
    .micro-card h3{
      margin: 0 0 8px;
      font-size: 16px;
      font-weight: 900;
      letter-spacing: -0.2px;
    }
    .micro-card p{
      margin: 0 0 12px;
      color: var(--muted);
      font-size: 13px;
      max-width: 75ch;
    }
    .chips{
      display:flex; flex-wrap:wrap; gap: 8px;
      margin: 0; padding: 0; list-style: none;
    }
    .chip{
      font-size: 12px;
      color: rgba(17,24,39,0.82);
      padding: 8px 10px;
      border-radius: 999px;
      border: 1px solid var(--stroke);
      background: rgba(255,255,255,0.70);
    }

    /* Sections */
    section.block{ padding: 56px 0; }
    .section-head{
      display:flex; align-items:flex-end; justify-content:space-between; gap: 18px;
      margin-bottom: 22px;
      flex-wrap: wrap;
    }
    .section-head h2{
      margin: 0;
      font-size: 26px;
      font-weight: 900;
      letter-spacing: -0.2px;
    }
    .section-head p{
      margin: 0;
      color: var(--muted);
      max-width: 68ch;
      font-size: 14px;
    }

    .grid-2{ display:grid; grid-template-columns: 1fr 1fr; gap: 22px; align-items:center; }
    .panel{
      border-radius: var(--radius2);
      background: rgba(255,255,255,0.84);
      border: 1px solid var(--stroke);
      padding: 22px;
      box-shadow: 0 12px 30px rgba(17,24,39,0.08);
    }
    .panel h3{ margin:0 0 10px; font-size: 20px; font-weight: 900; letter-spacing: -0.2px; }
    .panel p{ margin:0; color: var(--muted); font-size: 14px; }
    .panel .mini{ margin-top: 12px; color: var(--subtle); font-size: 12px; }

    .photo{
      border-radius: var(--radius2);
      overflow:hidden;
      border: 1px solid var(--stroke);
      background: rgba(255,255,255,0.72);
      box-shadow: var(--shadow);
    }
    .photo img{
      width:100%;
      height: 320px;
      object-fit: cover;
      object-position: center;
    }
    .photo .label{
      padding: 12px 14px;
      border-top: 1px solid var(--stroke);
      background: rgba(255,255,255,0.86);
      color: rgba(17,24,39,0.80);
      font-size: 13px;
    }

    /* Cards: corsi */
    .cards{
      display:grid;
      grid-template-columns: repeat(12, 1fr);
      gap: 14px;
    }
    .card{
      grid-column: span 4;
      border-radius: var(--radius2);
      padding: 18px;
      background: rgba(255,255,255,0.84);
      border: 1px solid var(--stroke);
      position: relative;
      overflow:hidden;
      box-shadow: 0 12px 30px rgba(17,24,39,0.08);
    }
    .card .icon{
      width: 42px; height: 42px;
      border-radius: 14px;
      display:grid; place-items:center;
      border: 1px solid var(--stroke);
      background: rgba(255,255,255,0.72);
      margin-bottom: 10px;
      font-size: 18px;
    }
    .card h4{ margin:0 0 8px; font-weight: 900; font-size: 15px; letter-spacing: -0.2px; }
    .card p{ margin:0; color: var(--muted); font-size: 13px; }
    .card .mini{ margin-top: 10px; color: var(--subtle); font-size: 12px; }

    /* Method steps */
    .steps{
      display:grid;
      grid-template-columns: repeat(12, 1fr);
      gap: 14px;
    }
    .step{
      grid-column: span 3;
      border-radius: var(--radius2);
      padding: 18px;
      background: rgba(255,255,255,0.84);
      border: 1px solid var(--stroke);
      box-shadow: 0 12px 30px rgba(17,24,39,0.08);
    }
    .step .num{
      width: 34px; height: 34px;
      border-radius: 12px;
      display:grid; place-items:center;
      font-weight: 900;
      border: 1px solid var(--stroke);
      background: rgba(255,255,255,0.72);
      margin-bottom: 10px;
    }
    .step h4{ margin:0 0 8px; font-weight: 900; font-size: 14px; }
    .step p{ margin:0; color: var(--muted); font-size: 13px; }

    /* Pricing */
    .pricing{ display:grid; grid-template-columns: repeat(12, 1fr); gap: 14px; align-items: stretch; }
    .price{
      grid-column: span 4;
      border-radius: var(--radius2);
      padding: 18px;
      background: rgba(255,255,255,0.84);
      border: 1px solid var(--stroke);
      position: relative;
      overflow:hidden;
      box-shadow: 0 12px 30px rgba(17,24,39,0.08);
    }
    .price.featured{
      border: 1px solid rgba(8,145,178,0.28);
      background:
        radial-gradient(520px 280px at 50% 0%, rgba(8,145,178,0.14), transparent 65%),
        rgba(255,255,255,0.84);
    }
    .badge{
      position:absolute; top: 14px; right: 14px;
      font-size: 11px; font-weight: 900; letter-spacing: 0.3px;
      padding: 7px 10px; border-radius: 999px;
      background: rgba(8,145,178,0.12);
      border: 1px solid rgba(8,145,178,0.22);
      color: rgba(17,24,39,0.86);
    }
    .price h3{ margin:0 0 6px; font-size: 16px; font-weight: 900; }
    .price p{ margin:0 0 12px; color: var(--muted); font-size: 13px; }
    .list{ margin:0; padding:0; list-style:none; display:grid; gap: 10px; color: rgba(17,24,39,0.86); font-size: 13px; }
    .list li{ display:flex; gap:10px; align-items:flex-start; }
    .check{
      width: 18px; height: 18px;
      border-radius: 6px;
      background: rgba(22,163,74,0.12);
      border: 1px solid rgba(22,163,74,0.22);
      display:grid; place-items:center;
      flex: 0 0 auto;
      margin-top: 2px;
    }
    .check svg{ width: 12px; height: 12px; opacity: .9; }

    /* CTA strip */
    .cta-strip{
      border-radius: calc(var(--radius2) + 2px);
      border: 1px solid var(--stroke);
      background:
        radial-gradient(700px 260px at 20% 0%, rgba(109,40,217,0.14), transparent 60%),
        radial-gradient(700px 260px at 80% 0%, rgba(8,145,178,0.12), transparent 60%),
        rgba(255,255,255,0.86);
      padding: 22px;
      display:grid;
      grid-template-columns: 1.2fr 0.8fr;
      gap: 14px;
      align-items:center;
      box-shadow: 0 12px 30px rgba(17,24,39,0.08);
    }
    .cta-strip h3{ margin:0 0 6px; font-size: 18px; font-weight: 900; }
    .cta-strip p{ margin:0; color: var(--muted); font-size: 13px; max-width: 66ch; }
    .cta-strip .actions{ display:flex; justify-content:flex-end; gap: 10px; flex-wrap:wrap; }

    /* Footer / contact */
    .footer{
      padding: 54px 0 34px;
      border-top: 1px solid var(--stroke);
      background: rgba(255,255,255,0.60);
      backdrop-filter: blur(10px);
    }
    .footer-grid{
      display:grid;
      grid-template-columns: 1.2fr 0.8fr 1fr;
      gap: 18px;
      align-items:start;
    }
    .footer h4{
      margin:0 0 10px;
      font-size: 12px;
      letter-spacing: 0.35px;
      color: rgba(17,24,39,0.78);
      font-weight: 900;
    }
    .footer a.link{
      color: var(--muted);
      display:inline-block;
      padding: 6px 0;
    }
    .footer a.link:hover{ color: var(--text); }
    .contact-lines{ display:grid; gap: 10px; color: var(--muted); font-size: 13px; }
    .contact-lines b{ color: var(--text); font-weight: 900; }
    .map{
      width: 100%;
      aspect-ratio: 16 / 10;
      border-radius: var(--radius2);
      border: 1px solid var(--stroke);
      overflow:hidden;
      background: rgba(255,255,255,0.72);
      box-shadow: var(--shadow);
    }
    .fineprint{
      margin-top: 18px;
      padding-top: 18px;
      border-top: 1px solid var(--stroke);
      color: rgba(17,24,39,0.55);
      font-size: 12px;
      display:flex;
      flex-wrap:wrap;
      gap: 10px;
      justify-content:space-between;
    }

    /* Modal */
    .modal-overlay{
      position: fixed; inset: 0;
      background: rgba(17,24,39,0.55);
      backdrop-filter: blur(10px);
      display:none;
      align-items:center;
      justify-content:center;
      padding: 18px;
      z-index: 200;
    }
    .testimonials{
  padding:64px 0;
}
.faq-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

@media (max-width: 980px){
  .faq-grid{
    grid-template-columns: 1fr;
  }
}
.testimonials-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}

.testimonial-card{
  padding:24px;
  border-radius:20px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
}

.testimonial-card p{
  margin:0 0 12px;
}

@media (max-width: 980px){
  .testimonials-grid{
    grid-template-columns:1fr;
  }
}
    .modal{
      width: min(760px, 100%);
      border-radius: calc(var(--radius2) + 2px);
      background: rgba(255,255,255,0.95);
      border: 1px solid rgba(17,24,39,0.14);
      box-shadow: 0 18px 45px rgba(17,24,39,0.18);
      overflow:hidden;
    }
    .modal-head{
      display:flex; align-items:center; justify-content:space-between;
      padding: 14px 16px;
      border-bottom: 1px solid var(--stroke);
    }
    .modal-head strong{ font-weight: 900; letter-spacing: -0.2px; }
    .xbtn{
      width: 42px; height: 42px;
      border-radius: 14px;
      border: 1px solid var(--stroke);
      background: rgba(255,255,255,0.70);
      cursor:pointer;
    }
    .xbtn:hover{ background: rgba(255,255,255,0.95); }
    .xbtn svg{ width: 18px; height: 18px; margin: 12px; opacity: 0.9; }

    .modal-body{ padding: 16px; display:grid; gap: 12px; }
    .form-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 12px; }
    label{
      font-size: 12px;
      color: rgba(17,24,39,0.78);
      font-weight: 800;
      display:block;
      margin-bottom: 8px;
    }
    input, textarea, select{
      width: 100%;
      padding: 12px 12px;
      border-radius: 14px;
      border: 1px solid rgba(17,24,39,0.14);
      background: rgba(255,255,255,0.90);
      color: var(--text);
      outline: none;
      font-family: inherit;
      font-size: 14px;
    }
    input:focus, textarea:focus, select:focus{
      border-color: rgba(8,145,178,0.55);
      box-shadow: 0 0 0 4px rgba(8,145,178,0.14);
    }
    textarea{ min-height: 120px; resize: vertical; }
    .modal-foot{
      padding: 14px 16px;
      border-top: 1px solid var(--stroke);
      display:flex;
      gap: 10px;
      justify-content:flex-end;
      flex-wrap:wrap;
    }
    .hint{ color: rgba(17,24,39,0.60); font-size: 12px; margin: 0; }

    .toast{
      position: fixed;
      left: 50%;
      transform: translateX(-50%);
      bottom: 18px;
      padding: 12px 14px;
      border-radius: 14px;
      border: 1px solid rgba(17,24,39,0.16);
      background: rgba(255,255,255,0.95);
      box-shadow: 0 18px 45px rgba(17,24,39,0.18);
      color: rgba(17,24,39,0.90);
      font-size: 13px;
      display:none;
      z-index: 300;
    }
    .toast.good{ border-color: rgba(22,163,74,0.35); }
    .toast.bad{ border-color: rgba(217,119,6,0.35); }
.badge {
  position: absolute;
  top: 14px;
  right: 14px;
  padding: 4px 10px;
  font-size: 0.7rem;
  border-radius: 20px;
  background: rgba(0,0,0,0.08);
  color: var(--accent);
  font-weight: 600;
}
/* ===== Affinità quiz modal ===== */
.aff-modal-overlay{
  position: fixed; inset: 0;
  background: rgba(17,24,39,0.55);
  backdrop-filter: blur(10px);
  display:none;
  align-items:center;
  justify-content:center;
  padding: 18px;
  z-index: 220;
}

.aff-modal{
  width: min(900px, 100%);
  max-height: min(90vh, 920px);
  overflow: hidden;
  border-radius: 24px;
  background: rgba(255,255,255,0.97);
  border: 1px solid rgba(17,24,39,0.12);
  box-shadow: 0 18px 45px rgba(17,24,39,0.18);
  display:flex;
  flex-direction:column;
}

.aff-head{
  display:flex; align-items:center; justify-content:space-between;
  gap:10px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--stroke);
}

.aff-body{
  padding: 16px;
  overflow:auto;
  display:grid;
  gap: 14px;
}

.aff-progress-wrap{
  display:grid; gap:8px;
}
.aff-progress-top{
  display:flex; justify-content:space-between; align-items:center;
  font-size: 12px; color: var(--muted);
}
.aff-progress{
  height: 10px;
  border-radius: 999px;
  background: rgba(17,24,39,0.08);
  overflow:hidden;
}
.aff-progress > span{
  display:block;
  height:100%;
  width:0%;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  transition: width .25s ease;
}

.aff-question-card{
  border: 1px solid var(--stroke);
  border-radius: 18px;
  background: rgba(255,255,255,0.88);
  padding: 14px;
}
.aff-question-card h4{
  margin:0 0 10px;
  font-size: 16px;
  line-height:1.3;
}
.aff-options{
  display:grid;
  gap: 8px;
}
.aff-option{
  border:1px solid rgba(17,24,39,0.12);
  background: rgba(255,255,255,0.9);
  border-radius: 14px;
  padding: 10px 12px;
  cursor: pointer;
  text-align:left;
  font: inherit;
  color: var(--text);
  transition: .15s ease;
}
.aff-option:hover{
  border-color: rgba(8,145,178,0.45);
  background: rgba(8,145,178,0.05);
}
.aff-option.selected{
  border-color: rgba(109,40,217,0.45);
  background: rgba(109,40,217,0.08);
  box-shadow: 0 0 0 3px rgba(109,40,217,0.10);
}

.aff-foot{
  padding: 14px 16px;
  border-top: 1px solid var(--stroke);
  display:flex; justify-content:space-between; align-items:center;
  gap:10px; flex-wrap:wrap;
}

.aff-results{
  display:grid; gap:10px;
}
.aff-result-item{
  border:1px solid var(--stroke);
  border-radius: 14px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.9);
}
.aff-result-row{
  display:flex; justify-content:space-between; align-items:center; gap:10px;
  margin-bottom: 6px;
}
.aff-result-name{
  font-weight: 800; font-size: 14px;
}
.aff-result-score{
  font-weight: 900; font-size: 13px; color: var(--accent);
}
.aff-bar{
  height: 8px;
  border-radius: 999px;
  background: rgba(17,24,39,0.08);
  overflow:hidden;
}
.aff-bar > span{
  display:block; height:100%; width:0;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
}

.aff-top3{
  border:1px solid rgba(8,145,178,0.22);
  background: rgba(8,145,178,0.06);
  border-radius: 16px;
  padding: 12px;
}
.aff-top3 h5{
  margin:0 0 6px; font-size: 13px; font-weight: 900;
}
.aff-top3 p{
  margin:0; color: var(--muted); font-size: 13px;
}

.aff-contact-box{
  border:1px solid var(--stroke);
  border-radius: 18px;
  padding: 14px;
  background: rgba(255,255,255,0.9);
  display:grid; gap:12px;
}
.aff-contact-grid{
  display:grid; grid-template-columns: 1fr 1fr; gap: 10px;
}
.aff-disclaimer{
  margin: 2px 0 0;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(217,119,6,0.22);
  background: rgba(217,119,6,0.06);
  color: rgba(17,24,39,0.78);
  font-size: 12px;
  line-height: 1.45;
}
@media (max-width: 720px){
  .aff-contact-grid{ grid-template-columns: 1fr; }
}
    /* Responsive (verticale su mobile) */
    @media (max-width: 980px){
      .hero-grid{ grid-template-columns: 1fr; }
      .hero-media img{ height: 360px; }
      .micro-grid{ grid-template-columns: 1fr; }
      .grid-2{ grid-template-columns: 1fr; }
      .cta-strip{ grid-template-columns: 1fr; }
      .cta-strip .actions{ justify-content:flex-start; }
      .footer-grid{ grid-template-columns: 1fr; }
      .cards .card{ grid-column: span 6; }
      .steps .step{ grid-column: span 6; }
      .pricing .price{ grid-column: span 6; }
    }
    @media (max-width: 720px){
      .nav-inner{ flex-wrap: wrap; align-items:center; gap: 10px; }
      .brand{ min-width: 0; flex: 1 1 auto; }
      .brand img{ width: 44px; height: 44px; }

      /* su mobile: CTA in pannello verticale, header pulito */
      .nav-cta .btn{ display:none; }
      .burger{ display:inline-block; margin-left:auto; }

      .nav-links{ display:none; }
      .mobile-panel.open{ display:block; }

      .mobile-panel .row{ grid-template-columns: 1fr; }
      .mobile-panel .row .btn{ width:100%; justify-content:center; }

      .hero-actions{ flex-direction: column; align-items: stretch; }
      .hero-actions .btn{ width: 100%; justify-content:center; }

      .meta-row{ flex-direction: column; align-items: stretch; }
      .meta-pill{ width: 100%; }

      .form-grid{ grid-template-columns: 1fr; }
      .cards .card{ grid-column: span 12; }
      .steps .step{ grid-column: span 12; }
      .pricing .price{ grid-column: span 12; }
    }
    @media (prefers-reduced-motion: reduce){
      html{ scroll-behavior:auto; }
      .btn{ transition:none; }
    }
.footer-courses{
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px solid var(--stroke);
}

.footer-courses h4{
  margin: 0 0 12px;
  font-size: 12px;
  letter-spacing: 0.35px;
  color: rgba(17,24,39,0.78);
  font-weight: 900;
}

.footer-courses-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px 22px;
}

.footer-courses-col{
  display: grid;
  gap: 2px;
}

.footer-courses-col .link{
  padding: 4px 0;
  font-size: 13px;
  color: var(--muted);
}

.footer-courses-col .link:hover{
  color: var(--text);
}

@media (max-width: 980px){
  .footer-courses-grid{
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 560px){
  .footer-courses-grid{
    grid-template-columns: 1fr;
  }
}