/* =========================
   BASE / RESET
   ========================= */
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body {
  font-family: Helvetica, Arial, sans-serif;
  background: #121212;
  color: #e6e6e6;
  line-height: 1.6;
}

a {
  color: #d4b26a;
  text-decoration: none;
}
a:hover { opacity: 0.9; }

/* =========================
   HEADER / NAV
   ========================= */
.site-header {
  background: #0e0e0e;
  border-bottom: 1px solid #222;
}

.nav-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* Logo con occhio */
.logo {
  display: flex;
  align-items: center;
  gap: 10px;
}

.logo-eye {
  height: 38px;
  width: auto;
  display: block;
}

.logo-text {
  font-size: 20px;
  font-weight: 600;
  letter-spacing: 0.3px;
}

.nav-menu {
  list-style: none;
  display: flex;
  gap: 20px;
  align-items: center;
  flex-wrap: wrap;
}

.nav-menu li a { font-size: 14px; }
.nav-menu li a.active { color: #fff; }

.nav-menu .cta a {
  background: #d4b26a;
  color: #000;
  padding: 8px 14px;
  border-radius: 6px;
}

/* =========================
   HERO (generico)
   ========================= */
.hero {
  padding: 120px 20px;
  text-align: center;
  background: radial-gradient(circle at center, #1e1e1e, #0e0e0e);
}

.hero h1 {
  font-size: 40px;
  margin-bottom: 14px;
}

.subtitle {
  font-size: 18px;
  color: #ccc;
  max-width: 820px;
  margin: 0 auto;
}

/* FIX anti-troncamento titolo (tolti !important, di solito non servono) */
.hero h1 {
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  max-width: 100%;
}

.hero-actions { margin-top: 26px; }

.btn-primary,
.btn-secondary {
  padding: 12px 20px;
  margin: 6px;
  display: inline-block;
  border-radius: 6px;
}

.btn-primary {
  background: #d4b26a;
  color: #000;
}

.btn-secondary {
  border: 1px solid #d4b26a;
  color: #d4b26a;
}

/* =========================
   SEZIONI GENERICHE
   ========================= */
.section,
.section-dark {
  padding: 40px 20px;
  text-align: center;
}

.section-dark { background: #0e0e0e; }

.centered {
  max-width: 760px;
  margin: 0 auto;
  color: #cfcfcf;
}

/* =========================
   FEATURES
   ========================= */
.features {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 40px;
  padding: 80px 20px;
  max-width: 1200px;
  margin: 0 auto;
}

.feature h3 { margin-bottom: 10px; }
.feature p { color: #cfcfcf; }

/* =========================
   FOOTER
   ========================= */
.site-footer {
  background: #0e0e0e;
  border-top: 1px solid #222;
  padding: 40px 20px;
}

.footer-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 20px;
}

.footer-inner a {
  display: inline-block;
  margin-top: 6px;
}

/* =========================
   PAGINE INTERNE
   ========================= */
.page-hero {
  padding: 30px 20px 40px 20px;
  text-align: center;
  background: radial-gradient(circle at top, #1b1b1b, #0e0e0e);
  border-bottom: 1px solid #222;
}

.page-hero-inner {
  max-width: 900px;
  margin: 0 auto;
}

/* =========================
   DOCENTI
   ========================= */
.card-wide {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.3fr 0.7fr;
  gap: 30px;
  background: #0e0e0e;
  border: 1px solid #222;
  border-radius: 12px;
  padding: 30px;
}

.card-text h2 { margin-bottom: 12px; }
.card-text p { color: #cfcfcf; margin-top: 10px; }
.actions { margin-top: 18px; }

.card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid #222;
  min-height: 260px;
}

.team-grid {
  max-width: 1200px;
  margin: 40px auto 0 auto;
  padding: 0 20px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 22px;
}

.team-card {
  background: #121212;
  border: 1px solid #222;
  border-radius: 12px;
  padding: 18px;
}

.team-card img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid #222;
  margin-bottom: 14px;
}

.team-card h3 { margin-bottom: 6px; }

.role {
  font-size: 13px;
  color: #d4b26a;
  margin-bottom: 10px;
}

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

/* =========================
   CONTATTI
   ========================= */
.contact-grid {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 22px;
}

.contact-box {
  background: #0e0e0e;
  border: 1px solid #222;
  border-radius: 12px;
  padding: 18px;
  text-align: left;
}

.contact-box h3 { margin-bottom: 8px; }

.note {
  margin-top: 10px;
  color: #bdbdbd;
  font-size: 13px;
}

/* =========================
   IMMAGINI CORSI DAL VIVO
   ========================= */
.image-full img {
  width: 100%;
  max-width: 900px;
  display: block;
  margin: 0 auto;
  border-radius: 14px;
  border: 1px solid #222;
}

.image-grid {
  max-width: 900px;
  margin: 40px auto 0 auto;
  padding: 0 20px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 20px;
}

.image-grid img {
  width: 100%;
  height: 260px;
  object-fit: cover;
  border-radius: 14px;
  border: 1px solid #222;
}

/* =========================
   BANDE VERTICALI DOCENTI (BAUHAUS)
   ========================= */
.section-with-band {
  position: relative;
  overflow: hidden;
}

.section-with-band .band {
  position: absolute;
  top: 0;
  right: 0;
  width: 50;
  height: 100%;
  opacity: 0.95;
  pointer-events: none;
  display: flex;
  align-items: stretch;
}

.section-with-band .band img {
  width: 50%;
  height: 100%;
  object-fit: cover;
}

.section-with-band .band-safe {
  padding-right: 260px; /* 220 + margine */
}

/* =========================
   MEDIA QUERY
   ========================= */
@media (max-width: 900px) {
  .card-wide { grid-template-columns: 1fr; }

  /* su telefono: la banda scende sotto */
  .section-with-band .band {
    position: static;
    width: 100%;
    height: 260px;
    margin-top: 18px;
    border-radius: 14px;
    overflow: hidden;
  }

  .section-with-band .band-safe { padding-right: 0; }
}
/* =========================
   TIPOGRAFIA (base)
   ========================= */
/* Nota: questo influenza tutto il sito. Se preferisci solo HOME, lo scopo in body.home. */
body { font-size: 19px; }
h1 { font-size: 3rem; }
h2 { font-size: 2.1rem; }
h3 { font-size: 1.6rem; }

/* Avvicina "Un metodo umano" al testo sopra */
.un-metodo-umano { margin-top: 10px; }

/* =========================
   IMMAGINE FOCUS (pagine interne / sezione)
   ========================= */
.image-focus img {
  width: 100%;
  max-width: 1100px;
  margin: 70px auto;
  display: block;
  border-radius: 18px;
  opacity: 0.9;

  max-height: 620px;
  object-fit: cover;
}

/* ==============================
   METODO – BANDA VERTICALE (versione unica)
   ============================== */
.metodo-section {
  display: flex;
  align-items: stretch;
  max-width: 900px;
  margin: 80px auto;
  padding: 0 20px;
  gap: 40px;
}

.metodo-band {
  width: 120px;          /* spessore banda (teniamo la versione più “presente”) */
  min-width: 120px;
  min-height: 360px;
  background-size: cover;
  background-position: center;
  border-radius: 12px;
  opacity: 0.95;
}

.metodo-content {
  max-width: 800px;
}

/* testo a bandiera */
.metodo-content h2,
.metodo-content h3,
.metodo-content p {
  text-align: left;
}

.metodo-content h2 { margin-top: 0; }

/* mobile: la banda va sopra */
@media (max-width: 900px) {
  .metodo-section { flex-direction: column; gap: 20px; }

  .metodo-band {
    width: 100%;
    min-width: 0;
    height: 180px;
    min-height: 0;
    border-radius: 14px;
  }

  .metodo-content { padding-top: 10px; }
}

/* =========================
   HOME – BACKGROUND UNICO
   ========================= */
html, body { height: 100%; }

body.home {
  margin: 0;
  background: transparent;
  position: relative;
}

/* immagine unica di fondo */
body.home::before {
  content: "";
  position: fixed;
  inset: 0;
  background: url("../img/home-luce.jpg") center center / cover no-repeat;
  z-index: -2;
}

/* velo leggero */
body.home::after {
  content: "";
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.35);
  z-index: -1;
}

/* nessuna sezione deve avere un proprio background (solo HOME) */
body.home header,
body.home main,
body.home footer,
body.home section {
  background: transparent !important;
}

/* =========================
   HOME – HERO
   ========================= */
body.home .hero.hero-luce {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center; /* se vuoi “alzare tutto”: cambiamo in flex-start */
  text-align: center;
  padding: 100px 110px 90px;
}

body.home .hero-inner {
  max-width: 900px;
  margin: 0 auto;
}

body.home .hero h1 {
  font-size: 3rem;
  margin-bottom: 8px;
}

body.home .hero-claim {
  margin: 6px 0 14px;
  font-family: "Italianno", "Cormorant Garamond", serif;
  font-style: italic;
  font-size: clamp(22px, 2.4vw, 34px);
  letter-spacing: 0.08em;
  color: #c9a86a;
  opacity: 0.95;
}

body.home .hero .subtitle {
  margin: 0;
  font-size: 17px;
  line-height: 1.5;
  color: #d0d0d0;
}

body.home .hero-buttons {
  margin-top: 26px;
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

/* =========================
   HOME – BOTTONI
   ========================= */
body.home .btn {
  padding: 14px 22px;
  border-radius: 10px;
  font-weight: 600;
  text-decoration: none;
}

body.home .btn-gold {
  background: #c9a86a;
  color: #111;
  border: 1px solid #c9a86a;
}

body.home .btn-outline {
  background: transparent;
  color: #c9a86a;
  border: 1px solid #c9a86a;
}

/* =========================
   HOME – SEZIONE 3 COLONNE
   ========================= */
body.home .home-cards {
  max-width: 1200px;
  margin: 0 auto;
  padding: 70px 20px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 48px;
}

body.home .home-cards h3 { margin-bottom: 14px; }

body.home .home-cards p {
  margin: 0;
  color: #cfcfcf;
}

/* Responsive (evita colonnine striminzite e sovrapposizioni) */
@media (max-width: 1100px) {
  body.home .home-cards { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 700px) {
  body.home .home-cards { grid-template-columns: 1fr; gap: 26px; }
}

/* =========================
   HOME – SEZIONE MARA (scope per non toccare altre pagine)
   ========================= */
body.home .section-dark {
  text-align: center;
  padding: 70px 20px;
}

body.home .section-dark h2 { margin-bottom: 18px; }

body.home .section-dark p {
  max-width: 720px;
  margin: 0 auto;
  color: #cfcfcf;
}

body.home .section-dark .hero-actions {
  margin-top: 22px;
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
/* =========================
   FOOTER (rifinitura)
   ========================= */
.site-footer {
  padding: 30px 20px;
  border-top: 1px solid #222;
}

/* (footer-inner già definito nel Blocco 1: NON lo ripetiamo qui) */


/* ==================================================
   HOME – COMPATTAZIONE HERO + INIZIO COLONNE
   (una sola versione, niente doppioni)
   ================================================== */

/* Header un po’ più basso in HOME (guadagna spazio in alto) */
body.home .nav-container {
  padding-top: 12px;
  padding-bottom: 12px;
}

/* Hero: più compatta ma ancora “respira” */
body.home .hero.hero-luce {
  min-height: calc(100vh - 58px);  /* approx header compatto */
  padding-top: 70px;
  padding-bottom: 24px;
}

/* Micro-spazi interni */
body.home .hero h1 { margin-bottom: 6px; }
body.home .hero-claim { margin: 4px 0 10px; }
body.home .hero-buttons { margin-top: 16px; }

/* Claim leggermente più controllata (senza tirarla su troppo) */
body.home .hero-claim {
  font-size: clamp(18px, 2vw, 26px);
  max-width: 100%;
}

/* 3 colonne: padding coerente (no margin-top enorme) */
body.home .home-cards {
  padding-top: 46px;
  padding-bottom: 46px;
  margin-top: 0; /* evita “salti” strani se era stato forzato */
}


/* =========================
   AI per Artisti – pulsanti
   ========================= */
.ai-actions {
  display: flex;
  justify-content: center;
  gap: 14px;
  margin-top: 20px;
}

/* Page hero: centratura contenuti */
.page-hero-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.page-hero .centered {
  display: flex;
  justify-content: center;
  gap: 14px;
}


/* =========================
   GALLERY GRID FIX
   ========================= */
.gallery-wrap { padding: 20px; }

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  align-items: stretch;
}

.gallery-item {
  display: block;
  border-radius: 12px;
  overflow: hidden;
  line-height: 0;
  text-decoration: none;
}

.gallery-item img {
  width: 100%;
  height: 220px; /* regola questa altezza se vuoi */
  object-fit: cover;
  display: block;
}


/* =========================
   DROPDOWN – "I nostri corsi"
   (una sola versione)
   ========================= */
.nav-menu > li { position: relative; }

.has-dropdown .dropdown {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;

  min-width: 280px;
  max-height: 70vh;
  overflow-y: auto;

  list-style: none;
  margin: 0;
  padding: 10px;

  background: rgba(20, 20, 20, 0.92);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);

  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  transition: opacity 0.18s ease, transform 0.18s ease;
  z-index: 9999;
}

/* mostra dropdown */
.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* voci dropdown */
.dropdown a {
  display: block;
  padding: 10px 12px;
  border-radius: 10px;
  text-decoration: none;
  color: rgba(255, 255, 255, 0.92);
  white-space: nowrap;
}

.dropdown a:hover {
  background: rgba(255, 255, 255, 0.08);
}


/* =========================
   RESPONSIVE (unificato)
   ========================= */
@media (max-width: 980px) {
  .gallery-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .gallery-item img { height: 200px; }
}

@media (max-width: 900px) {
  /* HOME cards */
  body.home .home-cards {
    grid-template-columns: 1fr;
    padding: 50px 20px;
  }

  /* HERO home */
  body.home .hero.hero-luce {
    min-height: auto;
    padding-top: 90px;   /* su mobile spesso serve più aria per header */
    padding-bottom: 24px;
    padding-left: 20px;
    padding-right: 20px;
  }

  /* Dropdown mobile: tap-to-open */
  .has-dropdown .dropdown {
    position: static;
    min-width: auto;
    max-height: none;
    opacity: 1;
    transform: none;
    pointer-events: auto;
    display: none;
    margin-top: 8px;
  }
  .has-dropdown.open .dropdown { display: block; }
}

@media (max-width: 560px) {
  .gallery-grid { grid-template-columns: 1fr; }
  .gallery-item img { height: 220px; }
}
/* =================================================
   DROPDOWN MENU – "I nostri corsi"
   (versione unica completa)
   ================================================= */

.nav-menu > li { position: relative; }

/* “ponte” per evitare che il dropdown sparisca mentre passi col mouse */
.has-dropdown::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  height: 12px;
}

.has-dropdown .dropdown {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;

  min-width: 280px;
  max-height: 70vh;
  overflow-y: auto;

  list-style: none;
  margin: 0;
  padding: 10px;

  backdrop-filter: blur(6px);
  background: rgba(15, 15, 15, 0.95);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);

  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  transition: opacity 0.18s ease, transform 0.18s ease;
  z-index: 9999;
}

/* mostra dropdown */
.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* voci dropdown */
.dropdown a {
  display: block;
  padding: 10px 12px;
  border-radius: 10px;
  text-decoration: none;
  color: rgba(255, 255, 255, 0.92);
  white-space: nowrap;
}

.dropdown a:hover {
  background: rgba(255, 255, 255, 0.08);
}

/* voce corrente */
.dropdown a.current {
  background: rgba(255, 215, 120, 0.15);
  color: #ffd778;
}

/* Desktop ampio: 2 colonne */
@media (min-width: 1000px) {
  .has-dropdown .dropdown {
    column-count: 2;
    column-gap: 12px;
    min-width: 420px;
  }

  .dropdown li { break-inside: avoid; }
}

/* Mobile: tap-to-open */
@media (max-width: 900px) {
  .has-dropdown::after { display: none; }

  .has-dropdown .dropdown {
    position: static;
    min-width: auto;
    max-height: none;
    opacity: 1;
    transform: none;
    pointer-events: auto;
    display: none;
    margin-top: 8px;
  }

  .has-dropdown.open .dropdown { display: block; }
}

/* =========================
   PAGINE – Intro centrata
   ========================= */
.page-content .intro {
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}

.page-content .intro h1 { margin-bottom: 20px; }

.page-content .intro p {
  margin: 0 auto;
  line-height: 1.6;
}
/* =========================================
   PAGINE CORSO – IMPAGINAZIONE
   ========================================= */
.page-content.corso {
  max-width: 960px;
  margin: 0 auto;
  padding: 60px 24px;
}

/* HERO corso */
.corso-hero {
  text-align: center;
  margin-bottom: 60px;
}

.corso-hero h1 {
  font-size: clamp(2.2rem, 4vw, 3rem);
  margin-bottom: 20px;
}

.corso-hero .sottotitolo {
  max-width: 720px;
  margin: 0 auto;
  font-size: 1.1rem;
  line-height: 1.6;
  opacity: 0.85;
}

/* SEZIONI corso */
.corso-section { margin-bottom: 48px; }

.corso-section h2 {
  font-size: 1.6rem;
  margin-bottom: 14px;
}

.corso-section p {
  max-width: 720px;
  line-height: 1.7;
}


/* =========================================
   Z-INDEX / OVERFLOW (dropdown sopra tutto)
   ========================================= */
.site-header,
.nav-container,
.nav-menu {
  overflow: visible;
}

.has-dropdown .dropdown { z-index: 99999; }


/* =========================================
   HERO "I NOSTRI CORSI" con immagine + overlay
   ========================================= */
.corsi-hero {
  position: relative;
  width: 100%;
  min-height: 520px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  margin-top: 0;
}

.corsi-hero-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.02);
}

.corsi-hero-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
}

.corsi-hero-content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 60px 22px;
  max-width: 980px;
}

.corsi-hero-content h1 {
  margin: 0 0 18px;
  font-size: clamp(2.2rem, 5vw, 3.4rem);
}

.corsi-hero-content p {
  margin: 0 auto;
  max-width: 760px;
  line-height: 1.6;
  font-size: 1.1rem;
  opacity: 0.95;
}

@media (max-width: 600px) {
  .corsi-hero { min-height: 420px; }
  .corsi-hero-content { padding: 46px 18px; }
}


/* =========================================
   CONTATTI + MAPPA (versione unica)
   ========================================= */
.contatti-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 26px;
  margin-top: 10px;
}

.contatti-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  padding: 24px;
  backdrop-filter: blur(6px);
}

.contatti-card h2 { margin-top: 0; }

.contatti-row { margin: 12px 0; }

.map-wrap {
  margin-top: 12px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.10);
  background: rgba(255, 255, 255, 0.03);
}

.map-wrap iframe { display: block; }

@media (max-width: 900px) {
  .contatti-layout { grid-template-columns: 1fr; }
}


/* =========================================
   MOBILE NAV FIX (no JS) – max 820px
   (unificato, senza doppioni)
   ========================================= */
@media (max-width: 820px) {

  /* header: meno altezza */
  .site-header { padding: 10px 0; }

  /* container: impila logo + menu */
  .nav-container {
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }

  /* logo: più piccolo e centrato */
  .logo-eye {
    width: 44px;
    height: auto;
  }

  .logo-text { font-size: 22px; }

  /* menu: riga che va a capo */
  .nav-menu {
    width: 100%;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    gap: 6px 8px;
    padding: 4px 8px;
  }

  .nav-menu li { margin: 0; }

  /* link: più compatti */
  .nav-menu a {
    font-size: 13.5px;
    padding: 6px 9px;
    line-height: 1.1;
    white-space: nowrap;
  }

  /* CTA: più piccoli */
  .nav-menu li.cta a {
    padding: 8px 12px;
    font-size: 14px;
    border-radius: 10px;
  }

  /* dropdown: centrato sotto (se si apre) */
  .has-dropdown .dropdown {
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    width: min(92vw, 380px);
    max-height: 60vh;
    overflow: auto;
  }

  /* testo hero */
  .hero h1 {
    font-size: 36px;
    line-height: 1.15;
  }

  .hero p { font-size: 16px; }

  /* se esiste una cta-group */
  .hero .cta-group {
    flex-direction: column;
    gap: 12px;
  }

  .hero .btn {
    width: 100%;
    text-align: center;
  }

  .hero .btn-secondary {
    width: 100%;
    padding: 14px;
    font-size: 16px;
    opacity: 0.9;
  }

  /* spazi tra sezioni */
  section { margin-top: 48px; }

  .home-cards,
  .section-dark { margin-top: 40px; }

  /* tipografia generale */
  h2 {
    font-size: 28px;
    letter-spacing: 0.3px;
  }

  p {
    font-size: 16px;
    line-height: 1.55;
  }
}
/* =========================
   RITMO GLOBALE
   ========================= */
.page-content {
  padding-top: 80px;
  padding-bottom: 80px;
}

/* (attenzione: .page-content.corso era già definito altrove.
   Qui manteniamo una versione coerente e compatta.) */
.page-content.corso {
  max-width: 860px;
  margin: 0 auto;
  padding-left: 20px;
  padding-right: 20px;
}

.corso-section { margin-top: 56px; }
.corso-section:first-of-type { margin-top: 32px; }

h2 {
  margin-bottom: 14px;
  line-height: 1.25;
}

p, li { line-height: 1.6; }

@media (max-width: 820px) {
  .page-content {
    padding-top: 60px;
    padding-bottom: 60px;
  }

  .corso-section { margin-top: 42px; }

  h2 { font-size: 28px; }

  p, li { font-size: 16px; }
}


/* =========================
   HEADER – rifinitura (filetto)
   ========================= */
.site-header {
  border-bottom: none;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.06);
}


/* =========================
   HOME – REDESIGN PATCH (scopato)
   ========================= */
/* Overlay leggero sulla hero (solo HOME) */
body.home .hero.hero-luce {
  position: relative;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}

body.home .hero.hero-luce::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.25);
}

/* Manteniamo hero-inner “leggera” e non in conflitto con le definizioni HOME precedenti */
body.home .hero-inner {
  position: relative;
  max-width: 980px;
  margin: 0 auto;
  text-align: center;
}

/* Epigrafe e azioni */
body.home .hero-epigrafe {
  margin-top: 18px;
  line-height: 1.6;
}

body.home .hero-actions {
  margin-top: 22px;
  display: flex;
  justify-content: center;
}

/* Cards: se usi .home-cards-inner */
body.home .home-cards { padding: 70px 0; }

body.home .home-cards-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 34px;
}

body.home .home-card h2 { margin-bottom: 14px; }

/* Blocco Mara */
body.home .mara-block {
  padding: 70px 0;
  text-align: center;
}

body.home .mara-inner {
  max-width: 820px;
  margin: 0 auto;
  padding: 0 20px;
}

body.home .mara-actions {
  display: flex;
  justify-content: center;
  gap: 14px;
  margin-top: 18px;
}

body.home .mara-actions .btn-cta {
  padding: 12px 18px;
  font-size: 15px;
  border-radius: 12px;
}

body.home .mara-actions .btn-secondary {
  padding: 12px 16px;
  font-size: 14px;
  border-radius: 12px;
  opacity: 0.88;
}

/* Mobile */
@media (max-width: 820px) {
  body.home .hero.hero-luce { background-position: center top; }

  body.home .home-cards-inner {
    grid-template-columns: 1fr;
    gap: 26px;
  }

  body.home .mara-actions {
    flex-direction: row;
    flex-wrap: wrap;
  }
}
/* ===============================
   HOME – GRIGLIA 3 BLOCCHI (versione unica)
   =============================== */

/* Wrapper */
body.home .home-cards {
  padding: 48px 0;
  margin-top: 0;
}

/* Griglia */
body.home .home-cards-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 24px;

  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 28px;

  align-items: start;
}

/* Tipografia card */
body.home .home-card h2 {
  font-size: 1.25rem;
  line-height: 1.2;
  margin: 0 0 10px 0;
}

body.home .home-card p {
  font-size: 0.98rem;
  line-height: 1.55;
  margin: 0;
  max-width: 34ch;
}

/* Tablet: 2 colonne */
@media (max-width: 1100px) {
  body.home .home-cards-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Mobile: 1 colonna */
@media (max-width: 900px) {
  body.home .home-cards {
    padding: 34px 0;
  }

  body.home .home-cards-inner {
    grid-template-columns: 1fr;
    gap: 22px;
    padding: 0 18px;
  }

  body.home .home-card p { max-width: 52ch; }
}

/* Extra small: (opzionale) se vuoi spazi ancora più stretti */
@media (max-width: 700px) {
  body.home .home-card h2 { font-size: 1.35rem; }
}
/* =========================
   HEADER / MENU – rifinitura (generale)
   ========================= */
.nav-menu {
  display: flex;
  flex-wrap: wrap;   /* va a capo ordinato */
  align-items: center;
  gap: 10px 16px;
}

/* CTA: non devono “spingere” tutto */
.nav-menu .cta a {
  padding: 10px 14px;
  border-radius: 12px;
  white-space: nowrap;
}

@media (max-width: 900px) {
  .nav-menu {
    justify-content: center;
    gap: 10px 14px;
  }

  .nav-menu .cta a {
    padding: 9px 12px;
    font-size: 0.95rem;
  }
}


/* =========================
   HOME – pulizia separatori indesiderati (soft)
   ========================= */
/* Nota: non azzero box-shadow dell’header perché può essere utile come separatore sottile.
   Se vuoi eliminarlo davvero, lo faremo dopo la verifica finale. */
body.home .hero,
body.home .home-cards,
body.home .section-dark {
  border: none;
  box-shadow: none;
}
/* Disattiva dropdown (non lo usiamo più) */
.dropdown { display: none !important; }
/* =========================
   I NOSTRI CORSI – INDICE (2 colonne centrato)
   ========================= */
.corsi-indice{
  padding: 22px 0 44px;
}

.corsi-indice-inner{
  max-width: 860px;
  margin: 0 auto;
  padding: 0 20px;

  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 34px;
}

.corsi-link{
  display: block;
  padding: 10px 12px;
  border-radius: 12px;
  text-decoration: none;

  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.10);
  color: rgba(230,230,230,0.92);
}

.corsi-link:hover{
  background: rgba(212,178,106,0.07);
  border-color: rgba(212,178,106,0.45);
}

/* Mobile: 1 colonna */
@media (max-width: 820px){
  .corsi-indice-inner{
    grid-template-columns: 1fr;
    gap: 10px;
  }
}
.corsi-indice{
  padding: 26px 0 50px;
}

.corsi-indice-inner{
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  padding: 22px 20px;
  border-radius: 16px;
  background: rgba(0,0,0,0.18);
}
/* =========================================
   I NOSTRI CORSI – COMPATTAZIONE VERTICALE
   ========================================= */

/* 1) HERO più “su” (meno aria sopra e sotto) */
.corsi-hero{
  min-height: 420px;      /* prima 520: riduce il “vuoto” */
}

.corsi-hero-content{
  padding-top: 34px;      /* prima 60: avvicina al menu */
  padding-bottom: 34px;   /* prima 60 */
}

/* 2) Meno spazio tra HERO e INDICE */
.corsi-indice{
  padding-top: 12px;      /* prima ~22 */
  padding-bottom: 24px;   /* prima ~44 */
}

/* 3) Indice: righe più vicine tra loro */
.corsi-indice-inner{
  gap: 8px 22px;          /* prima 12px 34px */
  padding-top: 16px;      /* se hai messo cornice/box, questo compatta */
  padding-bottom: 16px;
}

/* 4) Pill: meno “altezza” interna */
.corsi-link{
  padding: 8px 11px;      /* prima 10px 12px */
  border-radius: 11px;
}

/* Mobile: compatta anche lì */
@media (max-width: 820px){
  .corsi-hero{ min-height: 360px; }
  .corsi-hero-content{ padding-top: 26px; padding-bottom: 26px; }
  .corsi-indice{ padding-top: 10px; padding-bottom: 18px; }
  .corsi-indice-inner{ gap: 8px; }
}
/* =========================================
   I NOSTRI CORSI – COMPATTAZIONE (solo pagina corsi)
   ========================================= */

.corsi-page{
  padding-top: 40px;      /* prima era più alto: avvicina al menu */
  padding-bottom: 70px;
}

/* HERO più vicino al menu e meno alto */
.corsi-page .corsi-hero{
  min-height: 0;          /* elimina “altezza fissa” */
  padding: 0;
  margin: 0;
}

.corsi-page .corsi-hero-content{
  padding: 28px 20px 18px;  /* metà circa dello spazio attuale */
  max-width: 980px;
  margin: 0 auto;
  text-align: center;
}

/* Riduce distanza HERO → INDICE */
.corsi-page .corsi-indice{
  padding: 10px 0 18px;     /* metà circa */
}

/* Indice: righe più vicine e box meno “gonfio” */
.corsi-page .corsi-indice-inner{
  max-width: 860px;
  margin: 0 auto;
  padding: 14px 18px;
  gap: 8px 22px;            /* metà circa */
}

/* Pulsanti/righe indice: un filo più compatti */
.corsi-page .corsi-link{
  padding: 8px 11px;
}

/* Riduce distanza INDICE → INTRO */
.corsi-page .intro{
  margin-top: 18px;         /* metà circa rispetto a prima */
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

/* Mobile */
@media (max-width: 820px){
  .corsi-page{ padding-top: 30px; padding-bottom: 60px; }
  .corsi-page .corsi-hero-content{ padding-top: 22px; padding-bottom: 14px; }
  .corsi-page .corsi-indice{ padding: 8px 0 14px; }
  .corsi-page .corsi-indice-inner{ gap: 8px; padding: 12px 14px; }
  .corsi-page .intro{ margin-top: 14px; }
}
/* =========================================
   I NOSTRI CORSI – COMPATTAZIONE VERTICALE
   ========================================= */

/* meno aria generale nella pagina corsi */
body.corsi-page .page-content{
  padding-top: 24px !important;
  padding-bottom: 56px !important;
}

/* hero più vicino al menu */
body.corsi-page .corsi-hero{
  min-height: 440px;          /* era più alto */
}

body.corsi-page .corsi-hero-content{
  padding: 34px 22px !important;  /* riduce aria sopra/sotto testo */
}

/* meno spazio tra hero e indice */
body.corsi-page .corsi-indice{
  padding: 10px 0 18px !important;
}

/* link indice più vicini */
body.corsi-page .corsi-indice-inner{
  gap: 8px 22px !important;       /* metà circa */
  padding: 14px 18px !important;
}

/* pill leggermente più compatti */
body.corsi-page .corsi-link{
  padding: 8px 11px !important;
}

/* intro più vicino all’indice */
body.corsi-page .intro{
  margin-top: 14px !important;
}
/* =========================================
   I NOSTRI CORSI – SPACING & RITMO (PATCH FINALE)
   incollare in fondo a style.css
   ========================================= */

/* HERO: meno alto e più vicino al menu */
.corsi-hero{
  min-height: 360px;       /* prima 520 */
}

/* Indice: più vicino alla hero */
.corsi-indice{
  margin-top: -40px;       /* tira su l’indice */
  padding-top: 20px;
  padding-bottom: 40px;
}

/* Indice: due colonne centrato e più compatto */
.corsi-indice-inner{
  max-width: 980px;
  margin: 0 auto;
  padding: 0 24px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px 24px;          /* meno “aria” */
}

/* Mobile: una colonna */
@media (max-width: 820px){
  .corsi-indice{ margin-top: -18px; }
  .corsi-indice-inner{ grid-template-columns: 1fr; }
}

/* Sezione esperienza: più vicina all’indice */
.corsi-page .esperienza{
  margin-top: 40px;
  padding-top: 10px;
}
/* =========================
   PAGINA "I NOSTRI CORSI" – SPAZIATURA FINE
   ========================= */

/* HERO: meno “aria” sopra/sotto */
.corsi-hero{
  min-height: 420px;           /* prima era troppo alto */
}

/* Se il contenuto del hero ha troppo padding */
.corsi-hero-content{
  padding: 40px 22px 34px;     /* riduce distanza verso menu e verso sotto */
}

/* INDICE: avvicinalo alla hero e impedisci overlap brutto */
.corsi-indice{
  margin-top: -34px;           /* tira su l’indice (metà circa dello stacco) */
  padding: 24px 0 34px;        /* meno aria totale */
  position: relative;
  z-index: 3;                  /* sta sopra l’immagine/overlay del hero */
}

/* Contenitore indice: 2 colonne, più compatto */
.corsi-indice-inner{
  max-width: 980px;
  margin: 0 auto;
  padding: 0 24px;
  display: grid;
  grid-template-columns: repeat(2, minmax(280px, 1fr));
  gap: 12px 18px;              /* righe più vicine tra loro */
}

/* “Pill” link */
.corsi-link{
  display: block;
  padding: 14px 16px;
  border-radius: 14px;
  background: rgba(0,0,0,0.28);
  border: 1px solid rgba(255,255,255,0.10);
  color: rgba(255,255,255,0.92);
}

/* Spazio tra indice e blocco “Un’esperienza…” dimezzato */
.page-content.corsi-page{
  padding-top: 34px;
  padding-bottom: 64px;
}

/* Intro più vicino */
.page-content.corsi-page .intro{
  margin-top: 0;
}

/* Responsive */
@media (max-width: 900px){
  .corsi-hero{ min-height: 380px; }
  .corsi-hero-content{ padding: 34px 18px 26px; }

  .corsi-indice{
    margin-top: -18px;
    padding: 18px 0 26px;
  }

  .corsi-indice-inner{
    grid-template-columns: 1fr;
    gap: 10px;
  }
}
/* =========================================
   HOME – OVERRIDE PULITO (SOLO HOMEPAGE)
   - immagine SOLO nella hero
   - sotto: fondo pieno uniforme
   - 3 colonne allineate a bandiera sinistra
   ========================================= */

/* 0) Home: niente immagini globali */
body.home{
  background: #121212;
}

body.home main{
  background: #121212;
}

/* Spegne qualunque background-image messo per errore su altre sezioni */
body.home section{
  background-image: none !important;
}

/* 1) HERO: qui e solo qui c’è l’immagine */
body.home .hero.hero-luce{
  position: relative;
  min-height: 72vh;                 /* regolabile */
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 90px 20px 70px;          /* distanza interna */

  background-image: url("../img/home-luce.jpg") !important;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

body.home .hero.hero-luce::before{
  content:"";
  position:absolute;
  inset:0;
  background: rgba(0,0,0,0.35);
  z-index:0;
}

body.home .hero.hero-luce .hero-inner{
  position: relative;
  z-index: 1;
  max-width: 980px;
  margin: 0 auto;
  text-align: center;
}

/* 2) 3 COLONNE: sfondo pieno (non trasparente) */
body.home .home-cards{
  background: #121212 !important;
  padding: 56px 0;
  margin: 0;
  border-top: 1px solid rgba(255,255,255,0.06);
}

body.home .home-cards-inner{
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 28px;

  display: grid;
  grid-template-columns: repeat(3, minmax(240px, 1fr));
  gap: 34px;

  align-items: start;
  justify-items: start; /* bandiera sinistra */
}

body.home .home-card,
body.home .home-card h2,
body.home .home-card p{
  text-align: left;
}

body.home .home-card p{
  max-width: 38ch;
  margin: 0;
  line-height: 1.55;
}

/* 3) Footer sempre “pieno” sotto (niente immagine che traspare) */
body.home .site-footer{
  background: #121212 !important;
}

/* responsive */
@media (max-width: 980px){
  body.home .home-cards-inner{
    grid-template-columns: repeat(2, minmax(260px, 1fr));
  }
  body.home .home-card p{ max-width: 52ch; }
}

@media (max-width: 700px){
  body.home .hero.hero-luce{
    min-height: 66vh;
    padding: 76px 18px 58px;
  }

  body.home .home-cards-inner{
    grid-template-columns: 1fr;
    padding: 0 18px;
    gap: 18px;
  }

  body.home .home-card p{ max-width: 60ch; }
}
/* === FIX GALLERIA: mostra TUTTI gli elementi (no limite a 9) === */
.gallery-grid{
  overflow: visible !important;
  max-height: none !important;
}

.gallery-item{
  display: block !important;
}

/* nel caso qualcuno stia nascondendo i figli oltre il 9° */
.gallery-grid .gallery-item:nth-child(n+10){
  display: block !important;
}
.gallery-item img {
  transition: transform 0.4s ease, opacity 0.4s ease;
}

.gallery-item:hover img {
  transform: scale(1.03);
  opacity: 0.92;
}
/* =========================
   TEST AREA (NON TOCCARE)
   Qui mettiamo solo prove temporanee
   ========================= */
.gallery-intro {
  max-width: 720px;
  margin: 0 auto 40px;
  font-size: 0.95rem;
  line-height: 1.6;
  color: #aaa;
}
.gallery-wrap h2 {
  text-align: center;
}
.gallery-wrap h2 {
  text-align: center;
}

.gallery-wrap .gallery-intro {
  max-width: 720px;
  margin: 16px auto 40px;
  text-align: left;
}
/* =========================
   BACK TO TOP BUTTON
   ========================= */

#backToTop {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: none;
  background: rgba(30, 30, 30, 0.85);
  color: #fff;
  font-size: 20px;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease, transform 0.3s ease;
  z-index: 999;
}

#backToTop.show {
  opacity: 1;
  pointer-events: auto;
}

#backToTop:hover {
  transform: translateY(-4px);
}
/* Immagine sotto il titolo – corsi */
.course-hero img,
.course-header img,
.page-corso img {
  display: block;
  max-width: 720px;
  width: 100%;
  height: auto;
  margin: 24px auto 40px;
}
/* Corso: immagine subito dopo il titolo (H1) */
main h1 + img,
main h1 + figure,
main h1 + picture,
main h1 + figure img,
main h1 + picture img{
  display: block !important;
  width: 100% !important;
  max-width: 820px !important;
  height: auto !important;
  margin: 24px auto 40px !important;
}
main h1 + a img{
  display: block !important;
  width: 100% !important;
  max-width: 820px !important;
  height: auto !important;
  margin: 24px auto 40px !important;
}
main h1 + img,
main h1 + figure img,
main h1 + picture img,
main h1 + a img{
  outline: 4px solid red !important;
}
main img{
  max-width: 820px;
  height: auto;
}
main img{ margin: 24px auto 40px; display: block; }
/* CORSI – immagine iniziale responsive */
.corso-image img {
  width: 100%;
  height: auto;
  display: block;
}

/* MOBILE: riduce l’impatto visivo */
@media (max-width: 768px){
  .corso-image {
    margin: 0;
  }

  .corso-image img {
    max-height: 240px;      /* regola a gusto: 200–280 */
    object-fit: cover;
  }
}
