/*
 * public/css/style.css | Ultima modifica: 18/05/2026 | v2.1
 *
 * SCOPO:
 *   Foglio di stile unico per il sito Centro Studi Europeo.
 *   Estratto e consolidato dai template HTML di riferimento
 *   in Design/template/ (homepage + Liceo Scientifico).
 *   Mobile-first: base per 320px, breakpoint 600px / 768px / 900px / 1024px.
 *
 * STRUTTURA (14 blocchi numerati):
 *   1. Header (questo blocco)
 *   2. Variabili CSS (palette, font, ombre)
 *   3. Reset e base (box-sizing, body, headings, link, button)
 *   4. Topbar
 *   5. Navbar (default + .scrolled + drawer mobile)
 *   6. Hero slider (homepage)
 *   7. Features strip
 *   8. Sezioni homepage
 *      8a. Section defaults / wrap / eyebrow / pill / btn / logo
 *      8b. Split (Difficoltà scolastiche)
 *      8c. Dashboard preview
 *      8d. Pianificazione
 *      8e. Numeri / Stats strip
 *      8f. Banner strip
 *      8g. Dove siamo
 *      8h. Prof cards
 *      8i. Articoli (blog)
 *      8j. Final CTA gialla
 *      8k. Form contatti / Modal / Field
 *   9. Pagina corso
 *      9a. Breadcrumb
 *      9b. Hero corso
 *      9c. Anchor nav (sticky)
 *      9d. Section base corso (.sez)
 *      9e. Descrizione (.desc, .info-card, .check-list)
 *  10. Quadro orario
 *      10a. Accordion (.accordion, .acc-item, .acc-head, .acc-body, .acc-table)
 *      10b. Badge ore (.ore-badge, .ore-badge.muted)
 *      10c. Foot riepilogo (.acc-foot)
 *  11. Card corsi (.corsi-grid, .corso, .corso.diploma-adulti)
 *  12. Testimonianze e FAQ
 *      12a. Recensioni slider (homepage)
 *      12b. Testimonianze grid (corso)
 *      12c. FAQ accordion + sidebar
 *  13. Footer (footer.site + .foot variant)
 *  14. Utility e animazioni
 *      14a. Float CTA mobile
 *      14b. Toast
 *      14c. Sbocchi grid (.fac, .stat-card)
 *      14d. CTA banner gialla (.cta-banner, .cta-form)
 *      14e. Reveal e reveal-stagger
 *      14f. Icone svg generiche
 *
 * PALETTE (canonical da Docs/CLAUDE.md — non modificare senza aggiornare anche
 * CLAUDE.md e COMMENTA.md regola #12):
 *   --blu:    #1E3A8A
 *   --giallo: #F5C000
 *   --bianco: #FFFFFF
 *   --crema:  #FAF8F2
 *   --testo:  #1A1A2E
 *   --grigio: #888888
 *
 * CRITICITA':
 *   - Esagono logo: orientation pointy-top (punte SU/GIU').
 *     Points: "22,2 40,12 40,32 22,42 4,32 4,12". MAI ruotare via CSS.
 *   - Badge ore quadro orario: .ore-badge default = blu+giallo cliccabile (ha PDF),
 *     .ore-badge.muted = grigio neutro non cliccabile (pdf: null nel YAML).
 *   - Nessun import esterno: i font Google sono caricati dal layout via <link>.
 *   - Nessun framework CSS (no Bootstrap, no Tailwind) per regola COMMENTA.md #6.
 *
 * NOTE:
 *   - Mobile-first: base per 320px, regole desktop in media query min-width.
 *   - Tutti i decori esagonali sono SVG inline base64 nelle url("data:image/svg+xml;...").
 *   - Container .wrap: max-width 1280px (homepage) / 1200px (corso) — uso 1280px.
 *
 * STORICO MODIFICHE:
 *   - 18/05/2026 v2.1: aggiunto blocco 32 FORM LABEL VISIBILI (a11y).
 *                      Stile per <label class="form-label"> + .field
 *                      wrapper + .form-label-required (asterisco rosso)
 *                      + .form-label-hint (suffisso "(facoltativo)"
 *                      sul textarea messaggio). Tranche D2 audit C12,
 *                      coppia con templates/views/contatti.php v2.1.
 *                      Da v2.0 erano stati aggiunti incrementalmente
 *                      i blocchi 23-31 (prose, sidebar card, contatti
 *                      layout, banner, cookie modal, legal pages)
 *                      senza bump del version header — riallineato.
 *   - 09/05/2026 v2.0: estrazione completa dai template Design/, riorganizzato
 *                      in 14 blocchi numerati per COMMENTA.md.
 *   - 09/05/2026 v1.0: prima bozza minimale.
 */


/* =============================================================================
   2. VARIABILI CSS
   Scopo: palette, font, ombre, colori accessori.
   Storage: nessuno (token statici).
   Criticita': i valori --blu / --giallo sono brand inviolabili (CLAUDE.md).
   ============================================================================= */

:root {
  /* Brand canonical (Docs/CLAUDE.md) */
  --blu:        #1E3A8A;
  --blu-2:      #15306f;
  --blu-deep:   #0f2456;
  --giallo:     #F5C000;
  --giallo-2:   #ffd028;
  --giallo-soft:#fff4cc;
  --bianco:     #FFFFFF;
  --crema:      #FAF8F2;
  --crema-2:    #f0ebda;
  --testo:      #1A1A2E;
  --grigio:     #888888;
  --grigio-2:   #444444;
  --linea:      #e6e3d8;

  /* Ombre */
  --ombra:        0 12px 36px -16px rgba(30, 58, 138, 0.22);
  --ombra-hover:  0 22px 50px -18px rgba(30, 58, 138, 0.32);

  /* Tipografia */
  --display: "Barlow Condensed", "Helvetica Neue Condensed", system-ui, sans-serif;
  --body:    "Nunito", system-ui, -apple-system, "Segoe UI", sans-serif;
}


/* =============================================================================
   3. RESET E BASE
   Scopo: normalizza box-model, body, headings, immagini, link, button.
   Criticita': nessuna; rimuove margini default e abilita ::selection brand.
   ============================================================================= */

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html, body { margin: 0; }

body {
  font-family: var(--body);
  color: var(--testo);
  background: var(--bianco);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

img, svg { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; }
::selection { background: var(--giallo); color: var(--blu); }

h1, h2, h3, h4 {
  font-family: var(--display);
  font-weight: 800;
  color: var(--blu);
  letter-spacing: -0.005em;
  line-height: 1;
  margin: 0;
  text-transform: uppercase;
  text-wrap: balance;
}
h1 { font-size: clamp(40px, 9vw, 92px); font-weight: 800; line-height: 0.95; }
h2 { font-size: clamp(32px, 6.5vw, 64px); font-weight: 800; }
h3 { font-size: clamp(22px, 4.5vw, 32px); font-weight: 700; }
h4 { font-size: 20px; font-weight: 700; }

.lede {
  font-size: clamp(15px, 4vw, 18px);
  font-weight: 400;
  color: #3d3d4a;
  line-height: 1.6;
  max-width: 62ch;
}

/* Container */
.wrap { max-width: 1280px; margin: 0 auto; padding: 0 20px; }
@media (min-width: 1024px) { .wrap { padding: 0 32px; } }

/* .container - usato in 404.php, blog.php, blog-post.php (max-width piu' stretta) */
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
@media (max-width: 600px) { .container { padding: 0 16px; } }

section { position: relative; }


/* =============================================================================
   4. TOPBAR
   Scopo: barra superiore #1E3A8A con contatti (telefono, indirizzo, email, social).
   Visibilita': nascosta < 1024px (homepage) / nascosta < 600px (corso).
   ============================================================================= */

.topbar {
  background: var(--blu);
  color: rgba(255,255,255,0.92);
  font-size: 13px;
  font-weight: 500;
  padding: 8px 0;
  display: none;
}
.topbar-inner {
  display: flex; justify-content: space-between; align-items: center; gap: 18px;
  flex-wrap: wrap;
}
.topbar a { color: #fff; transition: color .2s; }
.topbar a:hover { color: var(--giallo); }
.topbar-left, .topbar-right { display: flex; gap: 22px; align-items: center; flex-wrap: wrap; }
.topbar .item { display: inline-flex; align-items: center; gap: 7px; }
.topbar .item svg { color: var(--giallo); flex-shrink: 0; }
.topbar .sep { color: rgba(255,255,255,0.3); }
.topbar .socials { display: flex; gap: 8px; }
.topbar .socials a {
  width: 24px; height: 24px; display: grid; place-items: center;
  border: 1px solid rgba(255,255,255,0.25);
  border-radius: 50%; transition: all .2s;
}
.topbar .socials a:hover { background: var(--giallo); border-color: var(--giallo); color: var(--blu); }
@media (min-width: 1024px) { .topbar { display: block; } }

/* Variant pagina corso (.l/.r al posto di .topbar-left/right) */
.topbar .wrap { display: flex; align-items: center; justify-content: space-between; gap: 18px; width: 100%; }
.topbar .l, .topbar .r { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.topbar .ic { color: var(--giallo); margin-right: 6px; }


/* =============================================================================
   5. NAVBAR
   Scopo: sticky top, logo + menu + CTA.
   Storage: nessuno.
   Criticita': aggiunge classe .scrolled via JS (main.js blocco Navbar).
               Su mobile il menu va in drawer fullscreen.
   ============================================================================= */

.nav {
  position: sticky; top: 0; z-index: 80;
  background: #fff;
  transition: box-shadow .25s ease;
}
.nav.scrolled { box-shadow: 0 2px 14px rgba(30, 58, 138, 0.08); }
.nav-inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px;
  max-width: 1280px; margin: 0 auto;
  gap: 16px;
}
.nav-menu { display: none; list-style: none; margin: 0; padding: 0; }
.nav-cta { display: flex; gap: 10px; align-items: center; }
.nav-cta .btn-giallo { display: none; }

.menu-toggle {
  display: grid; place-items: center;
  width: 44px; height: 44px;
  color: var(--blu);
  border: 1.5px solid var(--blu);
  border-radius: 6px;
  transition: all .2s;
}
.menu-toggle:hover { background: var(--blu); color: #fff; }
.menu-toggle svg { width: 20px; height: 20px; }

@media (min-width: 1024px) {
  .nav-inner { padding: 18px 32px; gap: 32px; }
  .nav-menu { display: flex; gap: 30px; align-items: center; }
  .nav-menu a {
    font-family: var(--body);
    font-size: 14px; font-weight: 700;
    color: var(--testo);
    position: relative; padding: 8px 0;
    transition: color .2s ease;
  }
  .nav-menu a:hover { color: var(--blu); }
  .nav-menu a::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: 0;
    height: 3px; background: var(--giallo);
    transform: scaleX(0); transform-origin: left;
    transition: transform .25s ease;
  }
  .nav-menu a:hover::after,
  .nav-menu a.active::after { transform: scaleX(1); }
  .nav-cta .btn-giallo { display: inline-flex; }
  .menu-toggle { display: none; }
}

/* -----------------------------------------------------------------------------
   Drawer (mobile menu fullscreen)
   ----------------------------------------------------------------------------- */
.drawer {
  position: fixed; inset: 0; background: #fff;
  z-index: 90;
  transform: translateY(-100%);
  transition: transform .4s ease;
  padding: 80px 24px 32px;
  overflow-y: auto;
}
.drawer.open { transform: none; }
.drawer a {
  font-family: var(--display);
  font-weight: 700; font-size: 26px;
  color: var(--blu);
  text-transform: uppercase;
  padding: 18px 0;
  border-bottom: 1px solid var(--linea);
  display: flex; justify-content: space-between; align-items: center;
}
.drawer a::after { content: "→"; color: var(--giallo); }
.drawer-cta { margin-top: 32px; display: flex; flex-direction: column; gap: 12px; }
.drawer-cta .btn { width: 100%; }
.drawer-info {
  margin-top: 32px; padding-top: 24px;
  border-top: 3px solid var(--giallo);
  font-size: 14px; color: var(--grigio); line-height: 1.7;
}
.drawer-info strong {
  color: var(--blu); display: block;
  font-family: var(--display); font-size: 14px;
  letter-spacing: 0.08em; text-transform: uppercase;
}

/* Drawer variant (corso) — overlay laterale */
.drawer-panel {
  position: absolute; right: 0; top: 0; bottom: 0;
  width: min(360px, 86vw);
  background: #fff;
  transform: translateX(100%);
  transition: transform .3s ease;
  padding: 24px 24px 32px;
  display: flex; flex-direction: column; gap: 8px;
}
.drawer.open .drawer-panel { transform: translateX(0); }
.drawer-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }


/* =============================================================================
   6. HERO SLIDER (homepage)
   Scopo: hero principale con immagine slideshow + claim + CTA.
   Storage: nessuno.
   Criticita': decoro esagonale via SVG inline (.hero::before, .hero::after).
               Su mobile l'immagine va sotto, su desktop a destra in 2 colonne.
   Slider: classe .is-active sulla .hslide attiva, dot .is-active.
   ============================================================================= */

.hero {
  background: var(--blu);
  color: #fff;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.hero::before {
  content: ""; position: absolute; pointer-events: none;
  top: -15%; right: -20%; width: 75%; aspect-ratio: 1/1;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><polygon points='50,3 95,28 95,72 50,97 5,72 5,28' fill='none' stroke='%23F5C000' stroke-opacity='0.18' stroke-width='1.2'/></svg>") center/contain no-repeat;
  z-index: 0;
}
.hero::after {
  content: ""; position: absolute; pointer-events: none;
  bottom: -30%; left: -15%; width: 55%; aspect-ratio: 1/1;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><polygon points='50,3 95,28 95,72 50,97 5,72 5,28' fill='none' stroke='%23ffffff' stroke-opacity='0.08' stroke-width='1.5'/></svg>") center/contain no-repeat;
  z-index: 0;
}
.hero-deco {
  position: absolute; pointer-events: none;
  top: 50%; right: -8%; transform: translateY(-50%);
  width: min(560px, 60vw); aspect-ratio: 60/68;
  z-index: 0; opacity: 0.85;
}
.hero-deco svg { width: 100%; height: 100%; display: block; }
@media (max-width: 767px) { .hero-deco { right: -30%; top: 60%; width: 80vw; opacity: 0.55; } }

.hero-inner {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1fr;
  gap: 24px; align-items: center;
  padding: 56px 0 40px;
}
.hero h1 { color: #fff; margin: 18px 0; font-size: clamp(40px, 8vw, 64px); line-height: 1; }
.hero h1 .hl { color: var(--giallo); display: inline; }
.hero p {
  color: rgba(255,255,255,0.85);
  font-size: clamp(15px, 4vw, 18px);
  margin: 0 0 24px;
  max-width: 54ch;
}
.hero-cta { display: flex; flex-direction: column; gap: 12px; margin-bottom: 28px; }
.hero-proof {
  display: flex; align-items: center; gap: 14px;
  font-size: 14px; color: rgba(255,255,255,0.85);
}
.hero-proof .stars { color: var(--giallo); font-size: 18px; letter-spacing: 2px; }
.hero-proof strong { color: var(--giallo); font-weight: 800; }

/* -----------------------------------------------------------------------------
   Slider immagine (.hero-image)
   ----------------------------------------------------------------------------- */
.hero-image {
  position: relative;
  margin: 12px -20px 0;
  aspect-ratio: 1/1;
  max-height: 60vh;
  border-radius: 8px;
  overflow: hidden;
  isolation: isolate;
}
.hero-image img {
  width: 100%; height: 100%; object-fit: cover; object-position: center;
  display: block;
}
.hero-image .hslide {
  position: absolute; inset: 0;
  opacity: 0; transition: opacity 1.1s ease;
  will-change: opacity;
}
.hero-image .hslide.is-active { opacity: 1; z-index: 1; }
.hero-slider-dots {
  position: absolute; left: 0; right: 0; bottom: 14px; z-index: 4;
  display: flex; justify-content: center; gap: 8px;
}
.hero-slider-dots button {
  width: 24px; height: 3px; border-radius: 2px;
  background: rgba(255,255,255,0.45);
  border: 0; padding: 0; cursor: pointer;
  transition: background .25s ease, width .25s ease;
}
.hero-slider-dots button.is-active { background: var(--giallo); width: 34px; }
.hero-slider-arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  z-index: 4;
  width: 38px; height: 38px; border-radius: 50%;
  background: rgba(10, 20, 50, 0.45); color: #fff;
  border: 1px solid rgba(255,255,255,0.25);
  display: grid; place-items: center; cursor: pointer;
  transition: background .2s ease;
  backdrop-filter: blur(4px);
}
.hero-slider-arrow:hover { background: var(--blu); }
.hero-slider-arrow.prev { left: 10px; }
.hero-slider-arrow.next { right: 10px; }
.hero-slider-arrow svg { width: 16px; height: 16px; }

@media (min-width: 768px) {
  .hero-cta { flex-direction: row; gap: 14px; }
  .hero-image { margin: 0; aspect-ratio: 1/1; max-height: 72vh; }
}
@media (min-width: 1024px) {
  .hero-image { aspect-ratio: 1/1; height: auto; max-height: 75vh; }
  .hero-slider-arrow { width: 44px; height: 44px; }
  .hero-inner {
    grid-template-columns: 1.1fr 0.9fr;
    gap: 48px;
    padding: 90px 0 110px;
    min-height: 78vh;
  }
}


/* =============================================================================
   7. FEATURES STRIP
   Scopo: 4 colonne sotto l'hero con icone + titolo + descrizione.
   Storage: nessuno (testi nei partial PHP).
   ============================================================================= */

.features {
  background: var(--crema);
  padding: 50px 0;
  border-bottom: 1px solid var(--crema-2);
}
.features-grid { display: grid; grid-template-columns: 1fr; gap: 14px; }
.feature {
  display: flex; gap: 16px; align-items: flex-start;
  padding: 18px 16px;
  background: #fff;
  border-radius: 8px;
  border-left: 4px solid var(--giallo);
  transition: all .25s ease;
}
.feature:hover { transform: translateY(-3px); box-shadow: var(--ombra); }
.feature .ico {
  width: 44px; height: 44px; flex-shrink: 0;
  background: var(--giallo); color: var(--blu);
  border-radius: 8px;
  display: grid; place-items: center;
}
.feature h4 { font-family: var(--display); font-size: 20px; margin-bottom: 4px; line-height: 1.05; }
.feature p { margin: 0; font-size: 14px; color: #52525a; line-height: 1.5; }
@media (min-width: 600px) { .features-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) {
  .features { padding: 70px 0; }
  .features-grid { grid-template-columns: repeat(4, 1fr); gap: 18px; }
}


/* =============================================================================
   8. SEZIONI HOMEPAGE
   Sub-blocchi: 8a section defaults / 8b split / 8c dashboard / 8d plan
                8e numeri / 8f banner / 8g dove siamo / 8h prof / 8i articoli
                8j final CTA / 8k form contatti
   ============================================================================= */

/* -----------------------------------------------------------------------------
   8a. Section defaults / wrap / eyebrow / pill / btn / logo
   ----------------------------------------------------------------------------- */

.section { padding: 64px 0; }
.section-head { margin-bottom: 36px; max-width: 760px; }
.section-head h2 { margin-bottom: 16px; }
.section-head.center { margin-left: auto; margin-right: auto; text-align: center; }
@media (min-width: 768px) { .section { padding: 96px 0; } .section-head { margin-bottom: 56px; } }
@media (min-width: 1024px) { .section { padding: 120px 0; } }

.eyebrow {
  display: inline-flex; align-items: center; gap: 14px;
  font-family: var(--body);
  font-size: 12px; font-weight: 800;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--blu);
  margin-bottom: 14px;
}
.eyebrow::before {
  content: ""; width: 32px; height: 3px; background: var(--giallo);
}
.eyebrow.invert { color: var(--giallo); }
.eyebrow.invert::before { background: var(--giallo); }
.eyebrow.center { justify-content: center; }
.eyebrow.blu { color: var(--blu); }
.accent-line { width: 48px; height: 3px; background: var(--giallo); margin: 16px 0 22px; }

.pill {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--giallo);
  color: var(--blu);
  padding: 7px 14px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.02em;
  font-family: var(--body);
  text-transform: none;
}

/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 14px 24px;
  font-family: var(--body);
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.02em;
  border: 2px solid transparent;
  border-radius: 6px;
  transition: all .25s ease;
  cursor: pointer;
  background: transparent;
  min-height: 48px;
  white-space: nowrap;
}
.btn .arrow,
.btn .btn-arrow { transition: transform .25s ease; }
.btn:hover .arrow,
.btn:hover .btn-arrow { transform: translateX(4px); }
.btn-giallo { background: var(--giallo); color: var(--blu); border-color: var(--giallo); }
.btn-giallo:hover {
  background: var(--giallo-2); border-color: var(--giallo-2);
  transform: translateY(-2px);
  box-shadow: 0 12px 24px -10px rgba(245, 192, 0, 0.6);
}
.btn-blu { background: var(--blu); color: #fff; border-color: var(--blu); }
.btn-blu:hover {
  background: var(--blu-2); border-color: var(--blu-2);
  transform: translateY(-2px);
  box-shadow: 0 12px 24px -10px rgba(30, 58, 138, 0.5);
}
.btn-out-blu { color: var(--blu); border-color: var(--blu); }
.btn-out-blu:hover { background: var(--blu); color: #fff; }
.btn-out-bianco { color: #fff; border-color: rgba(255,255,255,0.6); }
.btn-out-bianco:hover { background: #fff; color: var(--blu); border-color: #fff; }
.btn-link {
  color: var(--blu); padding: 6px 0; min-height: auto;
  font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase;
  border-bottom: 2px solid var(--giallo); border-radius: 0;
}
.btn-link:hover { color: var(--blu-2); border-color: var(--blu); }

/* Logo (esagono pointy-top + wordmark) */
.logo { display: flex; align-items: center; gap: 14px; text-decoration: none; }
.logo-mark {
  width: 44px; height: 44px; flex-shrink: 0;
  background: transparent;
  display: grid; place-items: center;
}
.logo-mark svg { width: 44px; height: 44px; display: block; }
.logo .hex { width: 44px; height: 44px; flex-shrink: 0; }
.logo .hex svg { width: 100%; height: 100%; display: block; }
.logo-text { line-height: 1.05; display: flex; flex-direction: column; gap: 3px; }
.logo-name {
  font-family: var(--display); font-weight: 700;
  font-size: 20px; color: var(--blu);
  letter-spacing: 0.01em; line-height: 1;
  text-transform: none;
  white-space: nowrap;
}
.logo-sub {
  font-family: "Nunito", var(--body); font-weight: 400;
  font-size: 12px; letter-spacing: 0.01em;
  color: #888;
}
.footer-brand .logo-divider { display: none; }
@media (min-width: 600px) {
  .logo-mark, .logo-mark svg, .logo .hex { width: 44px; height: 44px; }
}

/* -----------------------------------------------------------------------------
   8b. Split (Difficolta' scolastiche)
   Note v3 (11/05/2026): la foto modella (PNG transparent) e' incorniciata
   in un esagono blu centrato (.split-hex), con clip-path che da' la forma
   al PNG e ::after che disegna il bordo blu sopra. Brand-coerente.
   ----------------------------------------------------------------------------- */
.split-inner { display: grid; grid-template-columns: 1fr; gap: 32px; align-items: stretch; }
.split-img {
  border-radius: 8px;
  position: relative;
  overflow: hidden;
  background-color: var(--giallo);
  aspect-ratio: 4/3;
  min-height: 320px;
}

/* Wrapper esagono centrale.
   width 70% del box: lascia margine giallo attorno per "respiro" visivo.
   aspect-ratio 100/94 = proporzioni del polygon hex (vertici x: 5-95 = 90,
   y: 3-97 = 94). Cosi' il PNG quadrato clippato non si deforma. */
.split-hex {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 72%;
  aspect-ratio: 100/94;
  z-index: 1;
}

/* PNG modella clippato in forma esagonale (pointy-top).
   Polygon: stessi punti del decoro originale (50,3 95,28 95,72 50,97 5,72 5,28)
   in percentuali. object-position 50% 30% per centrare il viso nel hex. */
.split-hex .split-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 30%;
  display: block;
  clip-path: polygon(50% 3%, 95% 28%, 95% 72%, 50% 97%, 5% 72%, 5% 28%);
}

/* Stroke esagonale blu sovrapposto al PNG clippato.
   stroke-width 2 su viewBox 100x100 -> visivamente ~3-4px a seconda della
   dimensione renderizzata. stroke-opacity 1 = bordo pieno brand. */
.split-hex::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><polygon points='50,3 95,28 95,72 50,97 5,72 5,28' fill='none' stroke='%231E3A8A' stroke-width='2' stroke-linejoin='miter'/></svg>") center/contain no-repeat;
  pointer-events: none;
}
.split-img .badge {
  position: absolute; left: 20px; bottom: 20px;
  background: var(--blu); color: #fff;
  padding: 14px 18px;
  border-radius: 8px;
  font-family: var(--display);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  line-height: 1;
  box-shadow: 0 12px 30px -8px rgba(0,0,0,0.3);
  z-index: 2; /* sopra all'<img> */
}
.split-img .badge .num { color: var(--giallo); font-weight: 900; font-size: 36px; display: block; }
.split-img .badge .txt { font-size: 11px; letter-spacing: 0.14em; font-weight: 700; opacity: 0.9; }
.split-text h2 { margin-bottom: 18px; }
.split-text .bullets {
  list-style: none; padding: 0; margin: 24px 0 28px;
  display: flex; flex-direction: column; gap: 14px;
}
.split-text .bullets li {
  display: flex; gap: 14px; align-items: flex-start;
  font-size: 16px; color: var(--testo); font-weight: 600;
}
.split-text .bullets li .check {
  width: 26px; height: 26px; flex-shrink: 0;
  background: var(--giallo); color: var(--blu);
  display: grid; place-items: center;
  border-radius: 50%; font-weight: 900; font-size: 14px;
  margin-top: 1px;
}
@media (min-width: 1024px) {
  .split-inner { grid-template-columns: 1fr 1fr; gap: 48px; align-items: stretch; }
  /* Desktop: rimosso aspect-ratio, il box prende l'altezza naturale della
     colonna testo grazie ad align-items: stretch della griglia. */
  .split-img { aspect-ratio: auto; min-height: 0; height: 100%; }
}

/* -----------------------------------------------------------------------------
   8c. Dashboard preview
   Scopo: mockup piattaforma online su sfondo blu.
   Inline removed: la barra dashboard si valorizza con .dash-bar > div[width].
   ----------------------------------------------------------------------------- */
.dash {
  background: var(--blu);
  color: #fff;
  overflow: hidden;
  position: relative;
}
.dash::before {
  content: ""; position: absolute; pointer-events: none;
  top: -30%; right: -15%; width: 55%; aspect-ratio: 1/1;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><polygon points='50,3 95,28 95,72 50,97 5,72 5,28' fill='none' stroke='%23F5C000' stroke-opacity='0.16' stroke-width='2'/></svg>") center/contain no-repeat;
}
.dash h2 { color: #fff; margin-bottom: 18px; }
.dash p.lede { color: rgba(255,255,255,0.85); }
.dash-inner {
  display: grid; grid-template-columns: 1fr; gap: 36px; align-items: center;
  position: relative; z-index: 1;
}
.dash-mock {
  background: linear-gradient(180deg, #ffffff 0%, #f5f6fb 100%);
  color: var(--testo);
  border-radius: 14px;
  padding: 18px;
  box-shadow: 0 30px 80px -30px rgba(0,0,0,0.5);
  position: relative;
}
.dash-mock-bar {
  display: flex; gap: 6px; align-items: center; padding-bottom: 14px;
  border-bottom: 1px solid #eee;
}
.dash-mock-bar .dot { width: 10px; height: 10px; border-radius: 50%; }
.dash-mock-bar .dot:nth-child(1) { background: #fc625d; }
.dash-mock-bar .dot:nth-child(2) { background: #fdbc40; }
.dash-mock-bar .dot:nth-child(3) { background: #34c749; }
.dash-mock-bar .url {
  margin-left: 14px; font-size: 11px; color: var(--grigio);
  background: #f0f0f5; padding: 4px 12px; border-radius: 6px;
  font-family: ui-monospace, monospace;
}
.dash-mock-body {
  display: grid; grid-template-columns: 80px 1fr; gap: 14px; padding-top: 14px;
}
.dash-side {
  background: var(--blu);
  border-radius: 8px;
  padding: 14px 8px;
  color: #fff;
  display: flex; flex-direction: column; gap: 10px;
}
.dash-side .si-logo { width: 24px; height: 28px; margin: 0 auto 10px; }
.dash-side .si {
  height: 32px; border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700;
  color: rgba(255,255,255,0.6);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.dash-side .si.active { background: var(--giallo); color: var(--blu); }
.dash-main { display: grid; gap: 10px; grid-template-columns: 1fr; }
.dash-card {
  background: #fff;
  border: 1px solid #eaeaef;
  border-radius: 8px;
  padding: 12px 14px;
}
.dash-card .label { font-size: 10px; color: var(--grigio); text-transform: uppercase; letter-spacing: 0.1em; font-weight: 700; }
.dash-card .value { font-family: var(--display); font-size: 24px; font-weight: 800; color: var(--blu); margin-top: 4px; }
.dash-card.cal {
  background: linear-gradient(135deg, var(--blu), var(--blu-2));
  color: #fff; border-color: transparent;
}
.dash-card.cal .label { color: rgba(255,255,255,0.7); }
.dash-card.cal .value { color: #fff; font-size: 18px; }
.dash-card.cal-grid-card { grid-column: 1 / -1; }
.dash-card .label-mt { margin-top: 6px; }
.dash-cal-grid {
  margin-top: 10px;
  display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px;
}
.dash-cal-grid div {
  aspect-ratio: 1/1; border-radius: 3px;
  background: rgba(255,255,255,0.12);
  font-size: 9px; display: grid; place-items: center;
  color: rgba(255,255,255,0.6);
}
.dash-cal-grid div.on { background: var(--giallo); color: var(--blu); font-weight: 800; }
.dash-bar { background: #f0f0f5; height: 6px; border-radius: 3px; margin-top: 8px; overflow: hidden; }
.dash-bar > div { height: 100%; background: var(--giallo); border-radius: 3px; }
/* Larghezze mockup statiche (sostituiscono inline style="width:NN%") */
.dash-bar > .w-72 { width: 72%; }
.dash-bar > .w-88 { width: 88%; }

@media (min-width: 600px) {
  .dash-main { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 1024px) {
  .dash-inner { grid-template-columns: 0.95fr 1.05fr; gap: 64px; }
  .dash-mock-body { grid-template-columns: 110px 1fr; gap: 18px; padding-top: 18px; }
  .dash-mock { padding: 22px; }
}

/* Bullet list (lista feature dashboard) — sostituisce inline style="..." */
.dash-bullets { display: flex; flex-direction: column; gap: 14px; margin-top: 28px; }
.dash-bullets-row { display: flex; gap: 14px; align-items: center; }
.dash-bullets-row .dot {
  width: 8px; height: 8px; background: var(--giallo); border-radius: 50%;
  flex-shrink: 0;
}
.dash-bullets-row .text { color: rgba(255,255,255,0.85); font-size: 15px; }

/* -----------------------------------------------------------------------------
   8d. Pianificazione (.plan)
   ----------------------------------------------------------------------------- */
.plan { background: var(--crema); overflow: hidden; }
.plan-inner { display: grid; grid-template-columns: 1fr; gap: 36px; align-items: center; }
.plan-icon {
  aspect-ratio: 1/1;
  max-width: 340px; width: 100%; margin: 0 auto;
  position: relative;
}
.plan-icon .hex-bg {
  position: absolute; inset: 0;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><polygon points='50,3 95,28 95,72 50,97 5,72 5,28' fill='%23F5C000'/></svg>") center/contain no-repeat;
}
.plan-icon .inner {
  position: absolute; inset: 18%;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><polygon points='50,3 95,28 95,72 50,97 5,72 5,28' fill='%231E3A8A'/></svg>") center/contain no-repeat;
  display: grid; place-items: center;
  color: #fff;
}
.plan-icon .inner svg { width: 50%; height: 50%; }
.plan-text h2 { margin-bottom: 18px; }
.plan-stats {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  margin: 28px 0;
  padding: 20px 0;
  border-top: 2px solid var(--linea);
  border-bottom: 2px solid var(--linea);
}
.plan-stat .v {
  font-family: var(--display); font-weight: 900;
  font-size: 36px; color: var(--blu); line-height: 1;
}
.plan-stat .l { font-size: 12px; color: var(--grigio); margin-top: 6px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; }
@media (min-width: 1024px) {
  .plan-inner { grid-template-columns: 0.4fr 0.6fr; gap: 80px; }
  .plan-stats { grid-template-columns: repeat(3, 1fr); }
}

/* -----------------------------------------------------------------------------
   8e. Numeri / Stats strip (#1E3A8A)
   Scopo: 4 statistiche con counter animato (data-target via JS).
   ----------------------------------------------------------------------------- */
.stats-strip {
  background: var(--blu);
  padding: 56px 0;
  position: relative; overflow: hidden;
}
.stats-strip::before {
  content: ""; position: absolute; pointer-events: none;
  top: 50%; left: -4%; transform: translateY(-50%);
  width: 280px; aspect-ratio: 60/68;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 68' fill='none'><polygon points='30,3 56,17.5 56,50.5 30,65 4,50.5 4,17.5' stroke='%23ffffff' stroke-opacity='0.08' stroke-width='1.2' fill='none'/></svg>") no-repeat center / contain;
}
.stats-grid {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1fr 1fr; gap: 32px 0;
  text-align: center;
}
.stats-item { position: relative; padding: 8px 16px; }
.stats-item .num {
  font-family: var(--display);
  font-weight: 700;
  font-size: clamp(44px, 10vw, 60px);
  color: var(--giallo);
  line-height: 1;
  letter-spacing: 0.01em;
  display: inline-flex; align-items: baseline;
}
.stats-item .num .suffix { font-size: 0.55em; margin-left: 2px; font-weight: 600; }
.stats-item .lbl {
  font-family: var(--body);
  font-weight: 600;
  font-size: 13px;
  color: #fff;
  letter-spacing: 0.04em;
  margin-top: 12px;
  text-transform: uppercase;
  opacity: 0.95;
}
@media (min-width: 768px) {
  .stats-grid { grid-template-columns: repeat(4, 1fr); gap: 0; }
  .stats-item + .stats-item::before {
    content: ""; position: absolute; left: 0; top: 50%;
    transform: translateY(-50%);
    width: 1px; height: 70%;
    background: rgba(255,255,255,0.22);
  }
}
@media (max-width: 767px) {
  .stats-item:nth-child(odd) + .stats-item::before {
    content: ""; position: absolute; left: 0; top: 50%;
    transform: translateY(-50%);
    width: 1px; height: 70%;
    background: rgba(255,255,255,0.22);
  }
}
@media (min-width: 1024px) { .stats-strip { padding: 76px 0; } }

/* -----------------------------------------------------------------------------
   8f. Banner strip (immagine full-width)
   ----------------------------------------------------------------------------- */
.banner-strip { background: #FBC926; padding: 0; }
.banner-strip-link { display: block; line-height: 0; }
.banner-strip img { width: 100%; height: auto; display: block; }

/* -----------------------------------------------------------------------------
   8g. Dove siamo (mappa + indirizzo)
   ----------------------------------------------------------------------------- */
.dove-siamo { background: var(--crema); }
.dove-grid { display: grid; grid-template-columns: 1fr; gap: 32px; align-items: center; }
.dove-card-img {
  display: block; line-height: 0; border-radius: 10px; overflow: hidden;
  box-shadow: 0 18px 48px -28px rgba(15, 36, 86, 0.45);
  transition: transform .3s ease, box-shadow .3s ease;
}
.dove-card-img:hover { transform: translateY(-3px); box-shadow: 0 22px 56px -28px rgba(15, 36, 86, 0.55); }
.dove-card-img img { width: 100%; height: auto; display: block; }
.dove-info h3 {
  font-family: var(--display); font-weight: 800;
  color: var(--blu); font-size: clamp(28px, 4vw, 36px);
  margin: 0 0 4px;
}
.dove-city { color: var(--grigio); margin: 0 0 22px; font-size: 15px; }
.dove-list {
  list-style: none; padding: 0; margin: 0 0 28px;
  display: flex; flex-direction: column; gap: 12px;
}
.dove-list li {
  position: relative; padding-left: 30px;
  font-size: 15px; line-height: 1.55; color: var(--testo);
}
.dove-list li::before {
  content: ""; position: absolute; left: 0; top: 8px;
  width: 18px; height: 3px; background: var(--giallo); border-radius: 2px;
}
.dove-list strong { color: var(--blu); font-weight: 800; }
.dove-cta { display: flex; flex-direction: column; gap: 10px; }
.dove-section-title { text-align: center; margin: 8px 0 32px; }
@media (min-width: 768px) { .dove-cta { flex-direction: row; gap: 14px; } }
@media (min-width: 900px) { .dove-grid { grid-template-columns: 1fr 1fr; gap: 56px; } }

/* -----------------------------------------------------------------------------
   8h. Prof cards (homepage — docenti)
   ----------------------------------------------------------------------------- */
.prof { background: var(--crema); }
.prof-grid { display: grid; grid-template-columns: 1fr; gap: 20px; }
.prof-card {
  background: #fff;
  border-radius: 8px;
  padding: 28px 24px;
  text-align: center;
  transition: all .3s ease;
  border: 1.5px solid transparent;
}
.prof-card:hover { transform: translateY(-4px); box-shadow: var(--ombra-hover); border-color: var(--giallo); }
.prof-card .photo {
  width: 96px; height: 96px;
  border-radius: 50%;
  margin: 0 auto 16px;
  background-color: var(--blu);
  background-size: cover; background-position: center;
  color: var(--giallo);
  display: grid; place-items: center;
  font-family: var(--display);
  font-weight: 800; font-size: 32px;
  border: 4px solid var(--giallo);
  overflow: hidden;
}
.prof-card h4 { margin-bottom: 4px; font-size: 22px; line-height: 1.1; }
.prof-card .mat {
  color: var(--grigio); font-size: 13px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.08em;
  margin-bottom: 14px;
}
.prof-card p { margin: 0 0 16px; font-size: 14px; color: #52525a; line-height: 1.5; }
.prof-card .badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--blu); color: #fff;
  padding: 5px 12px; border-radius: 999px;
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
}
.prof-card .badge svg { color: var(--giallo); }
@media (min-width: 600px) { .prof-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .prof-grid { grid-template-columns: repeat(4, 1fr); gap: 24px; } }

/* -----------------------------------------------------------------------------
   8i. Articoli (blog cards) — homepage section
   ----------------------------------------------------------------------------- */
.articoli { background: var(--crema); }
.art-grid { display: grid; grid-template-columns: 1fr; gap: 24px; }
.art-card {
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  transition: all .3s ease;
  display: flex; flex-direction: column;
  border: 1.5px solid transparent;
}
.art-card:hover { transform: translateY(-4px); box-shadow: var(--ombra-hover); border-color: var(--giallo); }
.art-card .img {
  aspect-ratio: 16/10;
  background-color: var(--blu);
  background-size: cover; background-position: center;
  position: relative;
}
.art-card .tag {
  position: absolute; top: 14px; left: 14px;
  background: var(--giallo); color: var(--blu);
  padding: 5px 12px; border-radius: 4px;
  font-size: 11px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase;
}
.art-card .body { padding: 22px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.art-card .date { font-size: 12px; color: var(--grigio); font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; }
.art-card h3 { font-size: 22px; line-height: 1.1; }
.art-card p { margin: 0; font-size: 14px; color: #52525a; line-height: 1.5; }
.art-card .more { margin-top: auto; padding-top: 6px; }
@media (min-width: 768px) { .art-grid { grid-template-columns: repeat(3, 1fr); } }

/* -----------------------------------------------------------------------------
   8j. Final CTA (sfondo giallo full-width)
   ----------------------------------------------------------------------------- */
.final {
  background: var(--giallo);
  position: relative; overflow: hidden;
}
.final::before {
  content: ""; position: absolute; pointer-events: none;
  top: 50%; left: -15%; transform: translateY(-50%);
  width: 45%; aspect-ratio: 1/1;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><polygon points='50,3 95,28 95,72 50,97 5,72 5,28' fill='none' stroke='%231E3A8A' stroke-opacity='0.18' stroke-width='2'/></svg>") center/contain no-repeat;
}
.final::after {
  content: ""; position: absolute; pointer-events: none;
  bottom: -30%; right: -10%;
  width: 45%; aspect-ratio: 1/1;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><polygon points='50,3 95,28 95,72 50,97 5,72 5,28' fill='none' stroke='%231E3A8A' stroke-opacity='0.18' stroke-width='2'/></svg>") center/contain no-repeat;
}
.final-inner { position: relative; z-index: 1; text-align: center; padding: 64px 0; }
.final h2 { color: var(--blu); font-size: clamp(36px, 8vw, 80px); margin-bottom: 18px; }
.final p { color: var(--blu-2); font-size: clamp(15px, 4vw, 18px); margin: 0 auto 28px; max-width: 50ch; }
.final .btns { display: flex; flex-direction: column; gap: 12px; align-items: center; }
.final .phone { margin-top: 24px; color: var(--blu); font-size: 14px; font-weight: 600; }
.final .phone strong { font-family: var(--display); font-size: 18px; letter-spacing: 0.02em; }
@media (min-width: 768px) {
  .final-inner { padding: 96px 0; }
  .final .btns { flex-direction: row; justify-content: center; }
}

/* -----------------------------------------------------------------------------
   8k. Form contatti / Modal / Field
   ----------------------------------------------------------------------------- */
.modal-bg {
  position: fixed; inset: 0; background: rgba(15, 36, 86, 0.7);
  backdrop-filter: blur(6px);
  z-index: 300;
  opacity: 0; pointer-events: none;
  transition: opacity .3s ease;
  display: grid; place-items: end;
  padding: 0;
}
.modal-bg.show { opacity: 1; pointer-events: auto; }
.modal {
  background: #fff;
  width: 100%;
  max-height: 92vh; overflow: auto;
  padding: 32px 24px 24px;
  transform: translateY(50px);
  transition: transform .35s ease;
  position: relative;
  border-top: 4px solid var(--giallo);
  border-radius: 12px 12px 0 0;
}
.modal-bg.show .modal { transform: none; }
.modal h3 { font-size: 30px; margin-bottom: 6px; }
.modal .sub { color: #3d3d4a; margin-bottom: 24px; font-size: 14px; }
.modal-close {
  position: absolute; top: 14px; right: 14px;
  width: 36px; height: 36px;
  border: 1.5px solid var(--linea); color: var(--blu);
  display: grid; place-items: center; border-radius: 50%;
  transition: all .2s;
}
.modal-close:hover { background: var(--blu); color: #fff; border-color: var(--blu); }

.form-row { display: grid; grid-template-columns: 1fr; gap: 14px; margin-bottom: 14px; }
.field label {
  display: block;
  font-family: var(--body);
  font-size: 11px; font-weight: 800; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--blu); margin-bottom: 6px;
}
.field input, .field select, .field textarea {
  width: 100%;
  border: 1.5px solid var(--linea);
  background: #fff;
  padding: 12px 14px;
  font: 16px/1.4 var(--body);
  color: var(--testo);
  border-radius: 6px;
  transition: border-color .2s ease, box-shadow .2s ease;
  min-height: 48px;
}
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none; border-color: var(--blu);
  box-shadow: 0 0 0 3px rgba(30, 58, 138, 0.12);
}
.field textarea { resize: vertical; min-height: 80px; }
.modal .btn-blu { width: 100%; }
.modal .small { font-size: 12px; color: var(--grigio); margin-top: 14px; line-height: 1.5; }
@media (min-width: 600px) {
  .modal-bg { place-items: center; padding: 24px; }
  .modal { max-width: 580px; padding: 48px; border-top: none; border-left: 4px solid var(--giallo); border-radius: 8px; }
  .form-row { grid-template-columns: 1fr 1fr; }
  .form-row.single { grid-template-columns: 1fr; }
}


/* =============================================================================
   9. PAGINA CORSO
   Sub-blocchi: 9a breadcrumb / 9b hero corso / 9c anchor nav / 9d sez / 9e desc
   ============================================================================= */

/* -----------------------------------------------------------------------------
   9a. Breadcrumb
   ----------------------------------------------------------------------------- */
.crumbs { background: #fff; padding: 14px 0; border-bottom: 1px solid var(--linea); }
.crumbs ol {
  display: flex; flex-wrap: wrap; gap: 6px;
  list-style: none; padding: 0; margin: 0;
  font-size: 13px; color: var(--grigio);
}
.crumbs li:not(:last-child)::after { content: "›"; margin-left: 6px; color: var(--grigio); }
.crumbs a { color: var(--grigio); transition: color .2s; }
.crumbs a:hover { color: var(--blu); }
.crumbs li:last-child { color: var(--blu); font-weight: 700; }

/* -----------------------------------------------------------------------------
   9b. Hero corso (.hero-corso)
   Note: rinominato da .hero (template) per evitare conflitto con homepage.
   Applicare all'<header> della pagina corso.
   ----------------------------------------------------------------------------- */
.hero-corso {
  background: var(--blu);
  color: #fff;
  position: relative; overflow: hidden;
  padding: 64px 0 72px;
}
.hero-corso::before {
  content: ""; position: absolute; pointer-events: none;
  left: -6%; top: 50%; transform: translateY(-50%);
  width: 280px; height: 280px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 44 44' fill='none'><polygon points='22,2 40,12 40,32 22,42 4,32 4,12' stroke='%23ffffff' stroke-opacity='0.08' stroke-width='2' fill='none'/></svg>") center/contain no-repeat;
}
.hero-corso-grid {
  position: relative; z-index: 1;
  display: grid; gap: 40px;
  grid-template-columns: 1fr;
  align-items: center;
}
.hero-pill {
  display: inline-flex; align-items: center;
  background: var(--giallo); color: var(--blu);
  font-family: var(--body);
  font-weight: 800; font-size: 12px;
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 8px 14px; border-radius: 999px;
  margin-bottom: 20px;
}
.hero-corso h1 {
  color: #fff;
  font-size: clamp(40px, 7vw, 58px);
  line-height: 1; margin-bottom: 18px;
}
.hero-corso p.sub {
  font-size: 17px;
  color: rgba(255,255,255,0.85);
  max-width: 560px;
  margin: 0 0 26px;
  line-height: 1.55;
}
.hero-corso .hero-cta { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 24px; }
.hero-info {
  display: flex; flex-wrap: wrap; align-items: center;
  gap: 14px;
  font-size: 13px; color: rgba(255,255,255,0.92);
}
.hero-info .it { display: inline-flex; align-items: center; gap: 6px; }
.hero-info .it .ic { color: var(--giallo); }
.hero-info .sep { width: 1px; height: 14px; background: rgba(255,255,255,0.4); }

.hero-art {
  position: relative;
  aspect-ratio: 4/3;
  background: rgba(245, 192, 0, 0.2);
  border-radius: 14px;
  overflow: hidden;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 18px;
}
.hero-art svg.hex-deco { width: 200px; height: 200px; opacity: 0.85; }
.hero-art .hex-label {
  font-family: var(--display);
  font-weight: 700;
  font-size: 24px;
  color: rgba(255,255,255,0.7);
  text-transform: none;
  letter-spacing: 0.01em;
  line-height: 1;
}
.hero-art::after {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 70% 30%, rgba(245, 192, 0, 0.18), transparent 60%);
  pointer-events: none;
}

/* Variante con immagine custom (campo hero_image nel YAML).
   - Disabilita aspect-ratio 4/3 e altezza fissa: il box si adatta all'immagine.
   - L'immagine occupa il 100% di larghezza con altezza proporzionale (no crop).
   - Disabilita il radial-gradient ::after che sporcherebbe la foto.
   Funziona per qualsiasi proporzione immagine (1:1, 4:3, 16:9 ecc.). */
.hero-art.has-image {
  background: transparent;
  padding: 0;
  aspect-ratio: auto;
  height: auto;
  display: block;
}
.hero-art.has-image::after { display: none; }
.hero-art.has-image img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: inherit;
}
@media (min-width: 900px) {
  .hero-corso-grid { grid-template-columns: 55% 45%; gap: 48px; }
  .hero-corso { padding: 80px 0 96px; }
}

/* -----------------------------------------------------------------------------
   9c. Anchor nav (sticky)
   ----------------------------------------------------------------------------- */
.anchor-nav {
  position: sticky; top: 78px; z-index: 80;
  background: #fff;
  border-bottom: 3px solid var(--giallo);
  box-shadow: 0 2px 12px -8px rgba(15, 30, 80, 0.18);
}
.anchor-nav .wrap { display: flex; align-items: center; }
.anchor-list {
  display: flex; gap: 32px;
  list-style: none; padding: 0; margin: 0;
  overflow-x: auto;
  scrollbar-width: none;
}
.anchor-list::-webkit-scrollbar { display: none; }
.anchor-list a {
  display: inline-block; padding: 18px 0;
  font-family: var(--body);
  font-size: 14px; font-weight: 700;
  color: var(--grigio-2);
  letter-spacing: 0.04em;
  border-bottom: 3px solid transparent;
  margin-bottom: -3px;
  transition: color .2s ease, border-color .2s ease;
  white-space: nowrap;
}
.anchor-list a:hover { color: var(--blu); }
.anchor-list a.active {
  color: var(--blu); font-weight: 800;
  border-bottom-color: var(--giallo);
}
.anchor-select { display: none; }
@media (max-width: 768px) {
  .anchor-list { display: none; }
  .anchor-nav { border-bottom: none; padding: 10px 0; }
  .anchor-select {
    display: block; width: 100%;
    padding: 14px 18px;
    font-family: var(--body); font-weight: 700; font-size: 14px;
    color: #fff;
    background: var(--blu);
    border: 2px solid var(--giallo); border-radius: 8px;
    outline: none;
    appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23F5C000' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
    background-repeat: no-repeat; background-position: right 18px center; background-size: 16px;
    background-color: var(--blu);
  }
  .anchor-select option { color: #fff; background: var(--blu); }
}

/* -----------------------------------------------------------------------------
   9d. Section base corso (.sez)
   ----------------------------------------------------------------------------- */
section.sez { padding: 64px 0; }
@media (min-width: 900px) { section.sez { padding: 80px 0; } }
.sez h2 { font-size: clamp(28px, 4vw, 36px); margin: 8px 0 0; }

/* -----------------------------------------------------------------------------
   9e. Descrizione (.desc, .desc-grid, .desc-sidebar, .info-card, .check-list)
   Layout desktop 65/35 (1fr + 300px) con sidebar sticky.
   Mobile <=1024px: colonna unica, sidebar statica con margine.
   ----------------------------------------------------------------------------- */
.desc { background: #fff; }

/* ===== DESC GRID CORSO ===== */
.desc-grid {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 48px;
  align-items: start;
}
.corso-prose {
  min-width: 0; /* evita overflow grid quando il prose contiene testo lungo */
}
.desc-sidebar {
  position: sticky;
  top: 100px;
}

/* Sez-label: variante della .eyebrow usata nella sezione descrizione corso.
   Definita come selettore esplicito per restare conforme al markup richiesto. */
.sez-label {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--display);
  font-weight: 700; font-size: 14px;
  color: var(--blu);
  text-transform: uppercase; letter-spacing: 0.18em;
  margin: 0 0 14px;
}
.sez-label::before {
  content: ''; width: 24px; height: 3px; background: var(--giallo);
}

.check-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.check-list li {
  display: flex; gap: 12px; align-items: flex-start;
  color: var(--testo); font-size: 15px;
}
.check-list .check {
  width: 24px; height: 24px; flex-shrink: 0;
  border-radius: 50%;
  background: var(--giallo);
  color: var(--blu); font-weight: 900; font-size: 14px;
  display: grid; place-items: center;
  margin-top: 2px;
}

.info-card {
  background: var(--blu);
  border-radius: 12px;
  padding: 24px;
  color: #fff;
}
.info-card-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 16px;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--giallo);
  margin: 0 0 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255,255,255,0.15);
}
/* .info-line: riga di contenuto (icona + testo) dentro .info-card.
   NB: il vecchio significato (linea decorativa gialla) e' stato rimosso
   contestualmente al refactor del markup desc-sidebar. */
.info-line {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 12px;
  font-size: 14px;
  line-height: 1.5;
}
.info-line .ti {
  color: var(--giallo);
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 2px;
}

/* Pulsante "Richiedi info" giallo nella info-card, a piena larghezza. */
.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--giallo);
  color: var(--blu);
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 16px;
  font-weight: 700;
  text-transform: uppercase;
  padding: 12px 24px;
  border-radius: 6px;
  text-decoration: none;
  transition: background 0.2s;
}
.btn-primary:hover { background: #e0b000; }
.btn-full { width: 100%; box-sizing: border-box; }
.mt-16 { margin-top: 16px; }

@media (max-width: 1024px) {
  .desc-grid {
    grid-template-columns: 1fr;
  }
  .desc-sidebar {
    position: static;
    margin-top: 32px;
  }
}


/* =============================================================================
   10. QUADRO ORARIO
   Scopo: accordion 5 anni con tabella materie/ore + badge programma PDF.
   Storage: dati YAML del corso (campo quadro_orario).
   Criticita': Badge ore (COMMENTA.md regola #12):
     - .ore-badge          => default blu+giallo cliccabile (PDF disponibile)
     - .ore-badge.muted    => grigio neutro non cliccabile (pdf: null nel YAML)
   ============================================================================= */

/* -----------------------------------------------------------------------------
   10a. Accordion (.accordion, .acc-item, .acc-head, .acc-body, .acc-table)
   ----------------------------------------------------------------------------- */
.piano { background: var(--crema); }
.accordion { display: flex; flex-direction: column; gap: 12px; margin-top: 32px; }
.acc-item {
  background: #fff;
  border: 1px solid var(--linea);
  border-radius: 10px;
  overflow: hidden;
  transition: border-color .2s ease;
}
.acc-item.open { border-color: var(--blu); }
.acc-head {
  width: 100%;
  display: flex; align-items: center; gap: 14px;
  padding: 18px 20px;
  background: #fff; color: var(--testo);
  text-align: left;
  transition: background .2s ease, color .2s ease;
}
.acc-item.open .acc-head { background: var(--blu); color: #fff; }
.acc-badge {
  flex-shrink: 0;
  background: var(--giallo); color: var(--blu);
  font-family: var(--display); font-weight: 700;
  font-size: 13px; letter-spacing: 0.06em;
  padding: 6px 12px; border-radius: 6px;
  text-transform: uppercase;
}
.acc-label {
  flex: 1;
  font-family: var(--display); font-weight: 700;
  font-size: 18px;
  color: inherit;
  text-transform: uppercase; letter-spacing: 0.04em;
}
.acc-hours {
  font-family: var(--display); font-weight: 700;
  font-size: 14px; opacity: 0.7;
}
.acc-item.open .acc-hours { opacity: 0.95; }
.acc-chevron {
  width: 24px; height: 24px;
  display: grid; place-items: center;
  transition: transform .25s ease;
  color: var(--blu);
}
.acc-item.open .acc-chevron { transform: rotate(180deg); color: var(--giallo); }
.acc-body { max-height: 0; overflow: hidden; transition: max-height .35s ease; }
.acc-item.open .acc-body { max-height: 1500px; }

.acc-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.acc-table tr { border-bottom: 1px solid var(--linea); }
.acc-table tr:last-child { border-bottom: none; }
.acc-table td { padding: 12px 16px; }
.acc-table td.materia { color: var(--testo); }
.acc-table td.ore { width: 90px; text-align: right; }
.acc-table td.act { width: 60px; text-align: right; padding-right: 20px; }

/* -----------------------------------------------------------------------------
   10b. Badge ore (regola COMMENTA.md #12)
   ----------------------------------------------------------------------------- */
.ore-badge {
  display: inline-block;
  background: var(--blu);
  color: var(--giallo);
  font-family: var(--display); font-weight: 700;
  font-size: 12px;
  padding: 4px 10px; border-radius: 4px;
  transition: background .2s ease, color .2s ease;
}
a.ore-badge:hover { background: var(--giallo); color: var(--blu); }
.ore-badge.muted { background: #f0ece1; color: #a8a59a; cursor: default; }

/* -----------------------------------------------------------------------------
   10c. Foot riepilogo (.acc-foot)
   ----------------------------------------------------------------------------- */
.acc-foot {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 20px;
  background: var(--blu);
  color: #fff;
  font-family: var(--display); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em;
  font-size: 14px;
}
.acc-foot .totale { color: var(--giallo); font-size: 22px; }
.piano-note {
  margin-top: 18px;
  font-size: 13px; color: var(--grigio); font-style: italic;
}


/* =============================================================================
   11. CARD CORSI (.corsi-grid, .corso, .corso.diploma-adulti)
   Scopo: griglia corsi homepage / pagina /corsi.
   Storage: dati YAML (slug, titolo, badge_tipo, iniziali, sottotitolo).
   Criticita': badge .liceo (#1E3A8A) vs .tecnico (#F5C000).
              .wm = watermark iniziali in alto a destra.
   ============================================================================= */

.corsi-grid { display: grid; grid-template-columns: 1fr; gap: 18px; }
.corso {
  background: #fff;
  border: 1.5px solid var(--linea);
  border-radius: 8px;
  padding: 24px;
  transition: transform .3s ease, border-color .25s ease, box-shadow .25s ease, padding .2s ease;
  display: flex; flex-direction: column; gap: 14px;
  position: relative; overflow: hidden;
}
.corso::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: var(--giallo);
  transform: scaleX(0); transform-origin: left;
  transition: transform .35s ease;
}
.corso:hover {
  transform: translateY(-4px);
  border: 2px solid var(--giallo);
  padding: 23.5px;
  box-shadow: 0 10px 24px -14px rgba(30, 58, 138, 0.22);
}
.corso:hover::before { transform: scaleX(1); }
.corso .badge-tipo {
  align-self: flex-start;
  font-family: var(--display);
  font-weight: 700;
  font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 6px 12px; border-radius: 999px;
  line-height: 1;
}
.corso .badge-tipo.liceo   { background: var(--blu); color: #fff; }
.corso .badge-tipo.tecnico { background: var(--giallo); color: var(--blu); }
.corso .wm {
  position: absolute;
  top: 14px; right: 18px;
  font-family: var(--display);
  font-weight: 800;
  font-size: 48px;
  line-height: 1;
  letter-spacing: -0.01em;
  color: var(--blu);
  opacity: 0.10;
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease;
}
.corso:hover .wm { opacity: 0.18; transform: translateY(-2px); }
.corso h3 { font-size: 24px; line-height: 1.05; }
.corso .meta {
  font-size: 11px; font-weight: 800; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--blu);
  background: var(--giallo-soft);
  padding: 4px 10px; border-radius: 4px; align-self: flex-start;
}
.corso p { margin: 0; color: var(--grigio); font-size: 14px; line-height: 1.55; flex: 1; }
.corso .more { margin-top: auto; align-self: flex-start; }

/* Card speciale Diploma Adulti */
.corso.diploma-adulti {
  background: var(--giallo);
  border-color: var(--giallo);
  color: var(--blu);
  grid-column: span 1;
}
.corso.diploma-adulti::before { background: var(--blu); transform: scaleX(1); }
.corso.diploma-adulti h3 { font-size: 28px; color: var(--blu); }
.corso.diploma-adulti .meta { background: var(--blu); color: var(--giallo); }
.corso.diploma-adulti p { color: var(--blu-2); font-weight: 600; font-size: 15px; }
.corso.diploma-adulti:hover { border-color: var(--blu); }
.corso.diploma-adulti .ico svg polygon { fill: rgba(30, 58, 138, 0.1); stroke: var(--blu); }
.corso.diploma-adulti .ico .num { color: var(--blu); }
.corso.diploma-adulti .more { color: var(--blu); border-color: var(--blu); }

@media (min-width: 600px) { .corsi-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) {
  .corsi-grid { grid-template-columns: repeat(3, 1fr); gap: 24px; }
  .corso { padding: 30px; }
  .corso.diploma-adulti {
    grid-column: span 3; flex-direction: row; align-items: center;
    gap: 32px; padding: 36px 40px;
  }
  .corso.diploma-adulti > * { margin: 0; }
  .corso.diploma-adulti .ico { width: 80px; height: 92px; }
  .corso.diploma-adulti .head { display: flex; flex-direction: column; gap: 8px; }
  .corso.diploma-adulti h3 { font-size: 38px; }
  .corso.diploma-adulti p { flex: 1; max-width: 500px; }
}


/* =============================================================================
   12. TESTIMONIANZE E FAQ
   Sub-blocchi: 12a recensioni slider (homepage)
                12b testimonianze grid (corso)
                12c FAQ accordion + sidebar
   ============================================================================= */

/* -----------------------------------------------------------------------------
   12a. Recensioni slider (homepage)
   ----------------------------------------------------------------------------- */
.recensioni { background: var(--blu); color: #fff; overflow: hidden; position: relative; }
.recensioni::before {
  content: ""; position: absolute; pointer-events: none;
  top: 50%; left: -25%; transform: translateY(-50%);
  width: 50%; aspect-ratio: 1/1;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><polygon points='50,3 95,28 95,72 50,97 5,72 5,28' fill='none' stroke='%23F5C000' stroke-opacity='0.14' stroke-width='2'/></svg>") center/contain no-repeat;
}
.recensioni h2 { color: #fff; }
.recensioni .lede { color: rgba(255,255,255,0.8); }
.rec-track-wrap { overflow: hidden; position: relative; }
.rec-track { display: flex; transition: transform .5s ease; will-change: transform; }
.rec-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-left: 4px solid var(--giallo);
  border-radius: 8px;
  padding: 28px;
  flex: 0 0 100%;
  margin-right: 18px;
  box-sizing: border-box;
}
.rec-stars { color: var(--giallo); font-size: 18px; letter-spacing: 2px; margin-bottom: 14px; }
.rec-card blockquote {
  margin: 0 0 22px;
  font-size: 17px; line-height: 1.55;
  color: rgba(255,255,255,0.92);
  font-weight: 500;
}
.rec-who {
  display: flex; align-items: center; gap: 14px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,0.15);
}
.rec-photo {
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--giallo); color: var(--blu);
  display: grid; place-items: center;
  font-family: var(--display); font-weight: 800; font-size: 16px;
  flex-shrink: 0;
}
.rec-name {
  font-weight: 800; font-size: 15px; color: #fff;
  font-family: var(--display); text-transform: uppercase; letter-spacing: 0.04em;
}
.rec-corso { font-size: 12px; color: rgba(255,255,255,0.6); margin-top: 2px; }
.rec-controls { display: flex; justify-content: space-between; align-items: center; margin-top: 30px; }
.rec-dots { display: flex; gap: 8px; }
.rec-dots button {
  width: 10px; height: 10px; border-radius: 50%;
  background: rgba(255,255,255,0.25);
  transition: all .25s ease;
}
.rec-dots button.active { background: var(--giallo); width: 32px; border-radius: 5px; }
.rec-arrows { display: flex; gap: 10px; }
.rec-arrows button {
  width: 44px; height: 44px; border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,0.3);
  color: #fff;
  display: grid; place-items: center;
  transition: all .25s ease;
}
.rec-arrows button:hover { background: var(--giallo); color: var(--blu); border-color: var(--giallo); }
@media (min-width: 768px) { .rec-card { flex-basis: calc(50% - 9px); } }
@media (min-width: 1024px) { .rec-card { flex-basis: calc(33.333% - 12px); padding: 32px; } }

/* -----------------------------------------------------------------------------
   12b. Testimonianze grid (pagina corso)
   ----------------------------------------------------------------------------- */
.test { background: var(--blu); color: #fff; }
.test h2 { color: #fff; }
.test .accent-line { background: var(--giallo); }
.test-grid { display: grid; gap: 18px; margin-top: 32px; grid-template-columns: 1fr; }
.test-card {
  background: #fff;
  color: var(--testo);
  border-radius: 12px;
  padding: 24px;
}
.test-head { display: flex; gap: 14px; align-items: center; margin-bottom: 14px; }
.avatar {
  width: 48px; height: 48px; flex-shrink: 0;
  background: var(--giallo); color: var(--blu);
  border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--display); font-weight: 800; font-size: 16px;
  letter-spacing: 0.02em;
}
.test-meta .nome {
  font-family: var(--display); font-weight: 700;
  color: var(--blu); font-size: 16px; line-height: 1;
  text-transform: none;
}
.test-meta .corso { font-size: 13px; color: var(--grigio); margin-top: 4px; }
.stars { color: var(--giallo); font-size: 14px; letter-spacing: 1.5px; margin-bottom: 12px; }
.test-card p { margin: 0; color: var(--grigio-2); font-size: 14px; line-height: 1.6; }
@media (min-width: 768px) { .test-grid { grid-template-columns: repeat(3, 1fr); gap: 22px; } }

/* -----------------------------------------------------------------------------
   12c. FAQ accordion + sidebar (pagina corso)
   ----------------------------------------------------------------------------- */
.faq { background: #fff; }
.faq-grid { display: grid; gap: 32px; grid-template-columns: 1fr; margin-top: 32px; align-items: start; }
.faq-list { display: flex; flex-direction: column; gap: 10px; }
.faq-item {
  border: 1px solid var(--linea);
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
  transition: border-color .2s ease;
}
.faq-item.open { border-color: var(--blu); }
.faq-q {
  width: 100%; text-align: left;
  display: flex; justify-content: space-between; align-items: center;
  gap: 14px;
  padding: 18px 20px;
  font-family: var(--display); font-weight: 700;
  font-size: 17px; color: var(--blu);
  text-transform: none; letter-spacing: 0.005em;
}
.faq-icon {
  width: 24px; height: 24px; flex-shrink: 0;
  display: grid; place-items: center;
  color: var(--giallo);
  font-size: 22px; font-weight: 700;
  transition: transform .25s ease;
}
.faq-item.open .faq-icon { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .35s ease; }
.faq-item.open .faq-a { max-height: 600px; }
.faq-a-inner {
  padding: 0 20px 20px;
  color: var(--grigio-2);
  font-size: 15px; line-height: 1.65;
}

.faq-side {
  background: var(--crema);
  border-radius: 12px;
  padding: 28px;
}
.faq-side h3 {
  font-family: var(--display); font-weight: 800;
  font-size: 22px; color: var(--blu);
  margin: 0 0 10px;
}
.faq-side p { margin: 0 0 22px; color: var(--grigio-2); font-size: 14px; line-height: 1.6; }
.faq-side .row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--linea);
  font-size: 14px; color: var(--grigio-2);
}
.faq-side .row:last-of-type { border-bottom: none; margin-bottom: 18px; }
.faq-side .row .ic { color: var(--giallo); flex-shrink: 0; }
.faq-side .row strong { color: var(--blu); font-weight: 700; }
.faq-side .btn { width: 100%; }
@media (min-width: 900px) { .faq-grid { grid-template-columns: 65% 35%; gap: 36px; } }


/* =============================================================================
   13. FOOTER (footer.site + .foot variant)
   Scopo: footer #1E3A8A con 4 colonne (brand, navigazione, corsi, contatti).
   ============================================================================= */

footer.site {
  background: var(--blu);
  color: rgba(255,255,255,0.78);
  padding: 50px 0 24px;
  border-top: 6px solid var(--giallo);
  position: relative;
}
.footer-grid {
  display: grid; grid-template-columns: 1fr; gap: 36px;
  padding-bottom: 8px;
}
.footer-brand .logo-name { color: #fff; }
.footer-brand .logo-sub  { color: rgba(255,255,255,0.6); }
.footer-brand p {
  margin: 18px 0;
  font-size: 14px; line-height: 1.6;
  color: rgba(255,255,255,0.7);
  max-width: 36ch;
}
.footer-brand .addr {
  font-size: 13.5px; color: rgba(255,255,255,0.7); line-height: 1.7;
  border-top: 1px solid rgba(245, 192, 0, 0.25);
  padding-top: 14px;
}
.footer-brand .addr strong {
  color: var(--giallo); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  font-weight: 800; display: block; margin-bottom: 4px;
  font-family: var(--body);
}
footer.site h4 {
  color: var(--giallo); font-size: 13px; letter-spacing: 0.14em;
  text-transform: uppercase; font-weight: 800;
  margin-bottom: 16px;
  font-family: var(--body);
}
footer.site ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 9px; }
footer.site ul a {
  color: rgba(255,255,255,0.78);
  font-size: 14px; transition: color .2s;
  display: inline-flex; align-items: center; gap: 8px;
}
footer.site ul a:hover { color: var(--giallo); }
footer.site ul a svg { color: var(--giallo); flex-shrink: 0; }
.footer-bottom {
  padding-top: 22px;
  display: flex; flex-direction: column; gap: 14px;
  font-size: 12px; color: rgba(255,255,255,0.5);
}
.footer-bottom .legal { display: flex; gap: 18px; flex-wrap: wrap; }
.footer-socials { display: flex; gap: 10px; }
.footer-socials a {
  width: 36px; height: 36px; border-radius: 50%;
  border: 1.5px solid rgba(245, 192, 0, 0.5);
  color: var(--giallo);
  display: grid; place-items: center;
  transition: all .2s;
}
.footer-socials a:hover { background: var(--giallo); color: var(--blu); border-color: var(--giallo); }
@media (min-width: 600px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) {
  footer.site { padding: 80px 0 32px; }
  .footer-grid { grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 48px; padding-bottom: 48px; }
  .footer-bottom { flex-direction: row; justify-content: space-between; align-items: center; }
}

/* Variant footer pagina corso (foot-grid) */
footer.foot, footer.foot-default { background: var(--blu); color: rgba(255,255,255,0.72); padding: 60px 0 22px; }
.foot-grid { display: grid; gap: 36px; grid-template-columns: 1fr; }
.foot h4 {
  color: #fff; font-family: var(--display);
  font-size: 14px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.12em;
  margin: 0 0 16px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255,255,255,0.12);
}
.foot a { color: rgba(255,255,255,0.72); transition: color .2s ease; }
.foot a:hover { color: var(--giallo); }
.foot ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; font-size: 14px; }
.foot-brand .logo-name { color: #fff; }
.foot-brand .logo-sub  { color: rgba(255,255,255,0.6); }
.foot-brand p { font-size: 14px; margin: 18px 0 0; line-height: 1.6; }
.foot-info-row {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 14px; line-height: 1.55;
  margin-bottom: 12px;
}
.foot-info-row .ic { color: var(--giallo); flex-shrink: 0; margin-top: 3px; }
.socials { display: flex; gap: 10px; margin-top: 18px; }
.socials a {
  width: 38px; height: 38px; display: grid; place-items: center;
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 50%;
  transition: all .2s ease;
}
.socials a:hover { background: var(--giallo); border-color: var(--giallo); color: var(--blu); }
.foot-bottom {
  border-top: 1px solid rgba(245, 192, 0, 0.3);
  margin-top: 48px; padding-top: 22px;
  font-size: 12px; color: rgba(255,255,255,0.55);
  text-align: center;
}
.foot-bottom a { color: rgba(255,255,255,0.7); }
@media (min-width: 768px) { .foot-grid { grid-template-columns: repeat(4, 1fr); gap: 32px; } }


/* =============================================================================
   14. UTILITY E ANIMAZIONI
   Sub-blocchi: 14a float CTA / 14b toast / 14c sbocchi grid /
                14d cta-banner gialla / 14e reveal / 14f icone svg
   ============================================================================= */

/* -----------------------------------------------------------------------------
   14a. Float CTA mobile (telefono fisso bottom-right)
   ----------------------------------------------------------------------------- */
.float-cta {
  position: fixed; bottom: 18px; right: 18px; z-index: 70;
  background: var(--giallo); color: var(--blu);
  width: 56px; height: 56px; border-radius: 50%;
  display: grid; place-items: center;
  box-shadow: 0 16px 40px -12px rgba(0,0,0,0.35);
  transition: transform .25s;
}
.float-cta:hover { transform: scale(1.05); }
@media (min-width: 1024px) { .float-cta { display: none; } }

/* -----------------------------------------------------------------------------
   14b. Toast notification
   ----------------------------------------------------------------------------- */
.toast {
  position: fixed; left: 16px; right: 16px; bottom: 16px;
  background: var(--blu); color: #fff;
  border-left: 4px solid var(--giallo);
  padding: 16px 20px; font-size: 14px;
  z-index: 200;
  display: flex; gap: 14px; align-items: center;
  box-shadow: 0 30px 60px -20px rgba(0,0,0,0.5);
  transform: translateY(150%); opacity: 0;
  transition: transform .4s ease, opacity .4s ease;
  border-radius: 8px;
}
.toast.show { transform: none; opacity: 1; }
.toast .icon {
  width: 32px; height: 32px;
  background: var(--giallo); color: var(--blu);
  display: grid; place-items: center;
  border-radius: 50%;
  flex-shrink: 0;
}
.toast strong { color: var(--giallo); display: block; font-weight: 800; margin-bottom: 2px; }
@media (min-width: 600px) { .toast { left: auto; right: 24px; bottom: 24px; max-width: 380px; } }

/* -----------------------------------------------------------------------------
   14c. Sbocchi grid (pagina corso)
   ----------------------------------------------------------------------------- */
.sbocchi { background: #fff; }
.sbocchi-grid { display: grid; gap: 28px; grid-template-columns: 1fr; align-items: start; margin-top: 32px; }
.fac-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.fac {
  background: #fff;
  border: 1.5px solid var(--linea);
  border-bottom: 3px solid var(--linea);
  border-radius: 10px;
  padding: 20px 18px;
  display: flex; flex-direction: column; gap: 12px;
  align-items: flex-start;
  height: 100%;
  min-height: 130px;
  transition: transform .25s ease, border-color .2s ease, box-shadow .2s ease;
}
.fac:hover {
  border-color: var(--linea);
  border-bottom-color: var(--giallo);
  transform: translateY(-2px);
  box-shadow: 0 12px 24px -16px rgba(30, 58, 138, 0.18);
}
.fac .ic {
  width: auto; height: auto;
  background: transparent;
  border-radius: 0;
  color: var(--blu);
  display: inline-flex; align-items: center; justify-content: flex-start;
}
.fac .ic svg {
  width: 32px; height: 32px;
  stroke: var(--blu);
  stroke-width: 1.8; fill: none;
  stroke-linecap: round; stroke-linejoin: round;
}
.fac .nome {
  font-family: var(--display); font-weight: 700;
  font-size: 15px; color: var(--blu);
  text-transform: uppercase; letter-spacing: 0.04em;
  line-height: 1.2;
  margin-top: auto;
}
.stat-card {
  background: var(--blu);
  color: #fff;
  border-radius: 12px;
  padding: 28px;
}
.stat-card .lead { font-size: 18px; line-height: 1.5; margin: 0 0 24px; }
.stat-row {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
  text-align: center;
  border-top: 1px solid rgba(255,255,255,0.15);
  padding-top: 24px;
}
.stat-row .v {
  font-family: var(--display); font-weight: 800;
  font-size: 36px; color: var(--giallo);
  line-height: 1;
}
.stat-row .l {
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: rgba(255,255,255,0.85);
  margin-top: 8px;
}
@media (min-width: 900px) {
  .sbocchi-grid { grid-template-columns: 60% 40%; gap: 36px; }
  .fac-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; }
  .fac { padding: 22px; }
}

/* -----------------------------------------------------------------------------
   14d. CTA banner gialla (pagina corso, form inline)
   ----------------------------------------------------------------------------- */
.cta-banner {
  background: var(--giallo);
  color: var(--blu);
  padding: 60px 0;
  text-align: center;
}
.cta-banner h2 {
  color: var(--blu);
  font-size: clamp(28px, 5vw, 40px);
  margin-bottom: 10px;
}
.cta-banner .sub {
  color: var(--blu);
  opacity: 0.8;
  font-size: 16px;
  margin: 0 auto 28px;
  max-width: 560px;
}
.cta-form {
  display: grid; gap: 10px;
  grid-template-columns: 1fr;
  max-width: 760px; margin: 0 auto;
}
.cta-form input {
  font: inherit;
  font-family: var(--body);
  padding: 14px 16px;
  border: 2px solid transparent;
  border-radius: 6px;
  background: #fff;
  color: var(--testo);
  outline: none;
  transition: border-color .15s ease;
}
.cta-form input::placeholder { color: #a3a3a3; }
.cta-form input:focus { border-color: var(--blu); }
.cta-form input.invalid { border-color: #d63b3b; background: #fff5f5; }
.cta-form input.valid { border-color: #2a8c4a; }
.cta-form .btn-blu { padding: 14px 22px; }
.cta-foot { margin-top: 18px; font-size: 14px; color: var(--blu); font-weight: 600; }
.cta-foot .ic { color: var(--blu); margin-right: 6px; }
.cta-privacy-link { color: var(--blu); text-decoration: underline; }
@media (min-width: 768px) {
  .cta-form { grid-template-columns: 1fr 1fr 1fr auto; }
}

/* -----------------------------------------------------------------------------
   14e. Reveal e reveal-stagger
   Scopo: scroll-reveal animazioni via Intersection Observer (main.js).
   Criticita': Disattivato in prefers-reduced-motion: nessuna animazione,
              gli elementi sono sempre visibili.
   ----------------------------------------------------------------------------- */
@media (prefers-reduced-motion: no-preference) {
  .reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s ease, transform .8s ease; }
  .reveal.visible { opacity: 1; transform: none; }
  .reveal-stagger > * { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
  .reveal-stagger.visible > * { opacity: 1; transform: none; }
  .reveal-stagger.visible > *:nth-child(2) { transition-delay: .07s; }
  .reveal-stagger.visible > *:nth-child(3) { transition-delay: .14s; }
  .reveal-stagger.visible > *:nth-child(4) { transition-delay: .21s; }
  .reveal-stagger.visible > *:nth-child(5) { transition-delay: .28s; }
  .reveal-stagger.visible > *:nth-child(6) { transition-delay: .35s; }
  .reveal-stagger.visible > *:nth-child(7) { transition-delay: .42s; }
}

/* -----------------------------------------------------------------------------
   14f. Icone SVG generiche
   Scopo: dimensioni standard per <svg class="icn" />.
   ----------------------------------------------------------------------------- */
.ic { display: inline-flex; align-items: center; justify-content: center; }
svg.icn    { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
svg.icn-sm { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
svg.icn-lg { width: 22px; height: 22px; stroke: currentColor; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }

/* Privacy link inline (era inline style="color:var(--blu); text-decoration:underline;") */
.privacy-link { color: var(--blu); text-decoration: underline; }

/* sr-only utility (per label nascoste accessibili) */
.sr-only {
  position: absolute !important; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}


/* ============================================================================
 *  AGGIUNTE v2.1 — blocchi per refactor view files (10/05/2026)
 *
 *  Append-only. Nessuna modifica ai blocchi 1-14 sopra.
 *  Riferimenti: Docs/CLAUDE.md, Docs/COMMENTA.md (sez. 6.2 stile commenti).
 * ============================================================================ */


/* =============================================================================
   15. SEZIONI BASE .sez
   Scopo:
     Padding standard verticale per le sezioni della homepage e della pagina
     corso, piu' modificatori di sfondo per ogni variante.
   Storage: nessuno.
   Criticita': il padding mobile (768px) compatta a 48px per evitare scroll
     eccessivo su schermi piccoli; il padding 80px desktop garantisce respiro
     visivo coerente con le altezze hero/footer.
   ============================================================================= */

/* ===== Base ===== */
.sez { padding: 80px 0; }
@media (max-width: 768px) {
  .sez { padding: 48px 0; }
}

/* ===== Modificatori homepage ===== */

/* Sezione 2: tre modelli (in presenza/online/tutor) — sfondo crema */
.sez.models { background: var(--crema); }

/* Sezione 3: features strip — sfondo bianco */
.sez.features { background: #fff; }

/* Sezione 4: split "Difficolta' scolastiche" — sfondo bianco, layout 60/40 */
.sez.split { background: #fff; }
.sez.split .split-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  align-items: center;
}
@media (min-width: 1024px) {
  .sez.split .split-inner {
    grid-template-columns: 60% 40%;
    gap: 64px;
  }
}

/* Sezione 5: dashboard preview — sfondo blu, testo bianco */
.sez.dashboard { background: var(--blu); color: #fff; }
.sez.dashboard h2,
.sez.dashboard h3,
.sez.dashboard h4 { color: #fff; }
.sez.dashboard .lede { color: rgba(255,255,255,0.85); }
.sez.dashboard .eyebrow { color: var(--giallo); }
.sez.dashboard .eyebrow::before { background: var(--giallo); }

/* Sezione 7: corsi grid — sfondo bianco */
.sez.corsi { background: #fff; }

/* Sezione 8: banner diploma adulti — sfondo blu, layout 55/45 */
.sez.diploma-banner { background: var(--blu); color: #fff; }
.sez.diploma-banner h2,
.sez.diploma-banner h3 { color: #fff; }
.sez.diploma-banner .lede { color: rgba(255,255,255,0.85); }
.sez.diploma-banner .eyebrow { color: var(--giallo); }
.sez.diploma-banner .eyebrow::before { background: var(--giallo); }
.sez.diploma-banner .dash-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 36px;
  align-items: center;
}
@media (min-width: 1024px) {
  .sez.diploma-banner .dash-inner {
    grid-template-columns: 55% 45%;
    gap: 48px;
  }
}

/* Sezione 9: metodo CSE — sfondo crema */
.sez.metodo { background: var(--crema); }

/* Sezione 10: citazione Montesquieu — sfondo giallo */
.sez.quote {
  background: var(--giallo);
  padding: 64px 0;
  text-align: center;
}
@media (max-width: 768px) {
  .sez.quote { padding: 40px 0; }
}
.sez.quote blockquote {
  max-width: 720px;
  margin: 0 auto;
  font-family: var(--display);
  font-weight: 700;
  font-size: clamp(22px, 4vw, 36px);
  line-height: 1.25;
  color: var(--blu);
  text-transform: uppercase;
  letter-spacing: -0.005em;
}
.sez.quote blockquote p {
  margin: 0 0 18px;
  quotes: "\201C" "\201D";
}
.sez.quote blockquote p::before { content: open-quote; color: var(--blu-2); }
.sez.quote blockquote p::after  { content: close-quote; color: var(--blu-2); }
.sez.quote cite {
  display: block;
  font-family: var(--body);
  font-style: normal;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--blu-2);
}

/* ===== Modificatori pagina corso ===== */

/* Sezione 1 corso: descrizione + info card — sfondo bianco */
.sez.desc { background: #fff; }

/* Sezione 2 corso (NEW): modalita' di frequenza — sfondo crema */
.sez.modalita { background: var(--crema); }

/* Sezione 3 corso: piano di studi (accordion) — sfondo crema */
.sez.piano { background: var(--crema); }

/* Sezione 4 corso: sbocchi professionali — sfondo bianco */
.sez.sbocchi { background: #fff; }

/* Sezione 5 corso: testimonianze — sfondo blu, testo bianco */
.sez.test-section { background: var(--blu); color: #fff; }
.sez.test-section h2,
.sez.test-section h3 { color: #fff; }
.sez.test-section .eyebrow { color: var(--giallo); }
.sez.test-section .eyebrow::before { background: var(--giallo); }
.sez.test-section .accent-line { background: var(--giallo); }

/* Sezione 6 corso: FAQ — sfondo bianco */
.sez.faq-section { background: #fff; }


/* =============================================================================
   16. MODELLI .modelli-grid + .modello-card[.highlight]
   Scopo:
     Griglia di 3 card che descrivono le modalita' di frequenza (in presenza,
     online, streaming assenze, tutor). Usata sia in homepage (sezione models
     site-level) sia nella pagina corso (sezione modalita per-corso).
   Storage: la card .highlight e' marcata da YAML (corso) o array inline (home).
   Criticita':
     - .highlight aggiunge badge "Esclusivo CSE" via ::before — vedi spec
       Design/template per posizionamento (top -10px right 16px).
     - icona Tabler 36px richiede webfont caricato in templates/base.php.
   ============================================================================= */

.modelli-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 32px;
}
@media (max-width: 768px) {
  .modelli-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

.modello-card {
  position: relative;
  background: #fff;
  border: 1.5px solid #e0e4ee;
  border-radius: 10px;
  padding: 28px 24px;
  text-align: center;
  transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.modello-card:hover {
  border-color: var(--giallo);
  transform: translateY(-3px);
  box-shadow: 0 12px 28px -16px rgba(30, 58, 138, 0.18);
}

.modello-card i {
  display: block;
  font-size: 36px;
  color: var(--blu);
  margin-bottom: 12px;
  line-height: 1;
}

.modello-card h3 {
  font-family: var(--display);
  font-weight: 700;
  font-size: 18px;
  color: var(--blu);
  margin: 0 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  line-height: 1.2;
}

.modello-card p {
  font-family: var(--body);
  font-size: 14px;
  line-height: 1.55;
  color: var(--grigio);
  margin: 0;
}

/* ===== Variante highlight — differenziatore "Esclusivo CSE" ===== */
.modello-card.highlight {
  border-color: var(--giallo);
  border-width: 2px;
  padding: 27px 23px; /* compensa il +0.5px di border per allineamento visivo */
}
.modello-card.highlight::before {
  content: "Esclusivo CSE";
  position: absolute;
  top: -10px;
  right: 16px;
  background: var(--giallo);
  color: var(--blu);
  font-family: var(--body);
  font-weight: 800;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
  box-shadow: 0 4px 10px -4px rgba(245, 192, 0, 0.55);
}
.modello-card.highlight i {
  color: var(--giallo);
}
.modello-card.highlight:hover {
  /* hover gia' definito da .modello-card:hover; manteniamo border-color giallo */
  border-color: var(--giallo-2);
}


/* =============================================================================
   17. DASHBOARD PREVIEW — overrides per uso diretto su sfondo blu
   Scopo:
     Adattare le card .dash-card al nuovo uso (cards translucide su sfondo
     blu della .sez.dashboard / .sez.diploma-banner) preservando il layout
     originale del mock browser nel blocco 8c.
   Storage: nessuno.
   Criticita': sovrascrive solo all'interno di .sez.dashboard / .diploma-banner
     per non rompere il mock browser usato nelle versioni storiche.
   ============================================================================= */

.sez.dashboard .dash-card,
.sez.diploma-banner .dash-card {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  padding: 20px;
  color: #fff;
}
.sez.dashboard .dash-card .label,
.sez.diploma-banner .dash-card .label {
  color: rgba(255, 255, 255, 0.6);
}
.sez.dashboard .dash-card .value,
.sez.diploma-banner .dash-card .value {
  color: #fff;
}
.sez.dashboard .dash-card .label-mt,
.sez.diploma-banner .dash-card .label-mt {
  margin-top: 8px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.6);
}

/* Calendar card — full width nella dash-main grid */
.sez.dashboard .dash-card.cal-grid-card {
  grid-column: 1 / -1;
  background: linear-gradient(135deg, var(--blu-2), var(--blu-deep));
  border-color: rgba(255, 255, 255, 0.18);
}

/* Bar progresso — sfondo translucido coerente con sfondo blu */
.sez.dashboard .dash-bar,
.sez.diploma-banner .dash-bar {
  height: 8px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.2);
  margin-top: 10px;
  overflow: hidden;
}
.sez.dashboard .dash-bar > div,
.sez.diploma-banner .dash-bar > div {
  height: 100%;
  background: var(--giallo);
  border-radius: 4px;
}


/* =============================================================================
   18. SCROLL REVEAL — overrides v2.1 (transition speed + stagger nth-child)
   Scopo:
     Il blocco 14e definisce le regole base .reveal/.reveal.visible. Qui
     applichiamo:
       - speed 0.5s al posto di 0.8s (UX piu' rapida);
       - stagger alternativo via .reveal-stagger .reveal:nth-child(N) per i
         casi in cui i figli .reveal vengono osservati singolarmente dal JS.
   Storage: nessuno.
   Criticita':
     - public/js/main.js blocco 5 usa classList.add("visible") sia su
       .reveal sia su .reveal-stagger (entrambi sono target dell'IO).
     - prefers-reduced-motion: reduce neutralizza ogni animazione.
     - Cascade: la transizione 0.5s di questo blocco vince sullo 0.8s del
       blocco 14e perche' append-only.
   ============================================================================= */

@media (prefers-reduced-motion: no-preference) {
  .reveal {
    transition: opacity 0.5s ease, transform 0.5s ease;
  }
  /* Stagger alternativo: applicato ai figli .reveal di un .reveal-stagger
     quando ciascun figlio viene osservato singolarmente dal JS. Coesiste
     col paradigma "container riceve .visible" del blocco 14e. */
  .reveal-stagger .reveal:nth-child(2) { transition-delay: 0.1s; }
  .reveal-stagger .reveal:nth-child(3) { transition-delay: 0.2s; }
  .reveal-stagger .reveal:nth-child(4) { transition-delay: 0.3s; }
}

@media (prefers-reduced-motion: reduce) {
  .reveal,
  .reveal.visible {
    opacity: 1;
    transform: none;
    transition: none;
  }
}


/* =============================================================================
   19. ANCHOR NAV CORSO — verifica supporto data-id="modalita"
   Stato:
     Il blocco 9c gia' definisce .anchor-list a.active in modo generico:
       .anchor-list a.active { color: var(--blu); font-weight: 800;
                               border-bottom-color: var(--giallo); }
     La regola si applica automaticamente a QUALUNQUE link col className
     "active", incluso <a data-id="modalita"> (il JS blocco 7 di main.js
     aggiunge la classe .active dinamicamente in base alla sezione visibile).
   Conclusione:
     Nessuna regola CSS aggiuntiva necessaria — il supporto esiste gia'.
   ============================================================================= */
/* (intenzionalmente vuoto — vedi blocco 9c per la regola attiva) */


/* =============================================================================
   20. FORM CONTATTI (.contact-form)
   Scopo:
     Layout 2 colonne per i campi del form di /contatti, con classe .full
     per i campi che occupano l'intera riga (telefono, messaggio, submit).
     Mobile: 1 sola colonna.
   Storage: nessuno.
   Criticita':
     - input/textarea/select condividono lo stile (border, radius, focus).
     - .btn-submit e' rule-set autonomo (non usa .btn) per stile esplicito
       coerente con lo spec.
   ============================================================================= */

.contact-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  max-width: 640px;
}

.contact-form .full {
  grid-column: 1 / -1;
}

.contact-form input,
.contact-form textarea,
.contact-form select {
  width: 100%;
  padding: 12px 16px;
  border: 1.5px solid #e0e4ee;
  border-radius: 8px;
  font-family: 'Nunito', sans-serif;
  font-size: 15px;
  color: var(--testo);
  background: #fff;
  transition: border-color 0.2s;
}

.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus {
  outline: none;
  border-color: var(--blu);
  box-shadow: 0 0 0 3px rgba(30, 58, 138, 0.1);
}

.contact-form textarea {
  min-height: 120px;
  resize: vertical;
  font-family: 'Nunito', sans-serif;
}

.contact-form .btn-submit {
  grid-column: 1 / -1;
  background: var(--blu);
  color: #fff;
  border: none;
  padding: 14px 32px;
  border-radius: 8px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 18px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background 0.2s;
}

.contact-form .btn-submit:hover {
  background: #162d6e;
}

@media (max-width: 768px) {
  .contact-form {
    grid-template-columns: 1fr;
  }
}

/* ----- Honeypot anti-bot: input fuori dal viewport (rimane focusabile da bot
   che ignorano lo stile, invisibile per utenti reali). Regola universale,
   applicabile a qualsiasi form. ----- */
.hp-field {
  position: absolute !important;
  left: -9999px !important;
  top: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
  visibility: hidden;
}


/* =============================================================================
   21. MAP EMBED (.map-embed)
   Scopo:
     Iframe della mappa OpenStreetMap nella pagina contatti — full width,
     altezza fissa 320px, bordi arrotondati. Sostituisce gli inline
     width/height piu' piccoli del v1.
   Storage: nessuno.
   ============================================================================= */

.map-embed {
  width: 100%;
  height: 320px;
  border-radius: 12px;
  border: none;
  margin: 24px 0;
  display: block;
}


/* =============================================================================
   22. CARD CORSO (griglia /corsi) — .corso-card + .card-adulti
   Scopo:
     Card per la pagina /corsi (corsi-list.php). Stile autonomo dalle card
     .corso usate nell'homepage (blocco 11): qui usiamo h2 invece di h3,
     watermark piu' tenue, badge piu' piccolo. Visivamente coerente ma con
     un naming dedicato (.corso-card) per evitare conflitti.
   Storage: nessuno.
   Criticita':
     - .corsi-grid e' selettore condiviso col blocco 11 (homepage). I nostri
       .corso-card vivono dentro .corsi-grid e funzionano in cascade.
     - .card-adulti occupa l'intera larghezza con grid-column: 1 / -1.
     - Mobile: 1 colonna sola, .card-adulti diventa flex-column.
   ============================================================================= */

/* Override .corsi-grid spacing per coerenza con spec /corsi */
.corsi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 32px;
}

.corso-card {
  background: #fff;
  border: 1.5px solid #e0e4ee;
  border-radius: 10px;
  padding: 24px;
  position: relative;
  overflow: hidden;
  transition: border-color 0.2s, transform 0.2s;
}

.corso-card:hover {
  border-color: var(--giallo);
  transform: translateY(-3px);
}

/* ----- Watermark iniziali corso (es. "LS", "LC") ----- */
.corso-card .watermark {
  position: absolute;
  top: -8px;
  right: 8px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 52px;
  font-weight: 700;
  color: var(--blu);
  opacity: 0.06;
  line-height: 1;
  pointer-events: none;
}

/* ----- Badge tipo corso (Liceo / Tecnico / Speciale) ----- */
.corso-card .badge {
  display: inline-block;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 2px 8px;
  border-radius: 4px;
  margin-bottom: 10px;
}
.corso-card .badge.liceo    { background: var(--blu);    color: #fff; }
.corso-card .badge.tecnico  { background: var(--giallo); color: var(--blu); }
.corso-card .badge.speciale { background: var(--blu);    color: var(--giallo); }

/* ----- Heading + lead ----- */
.corso-card h2 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--blu);
  text-transform: uppercase;
  margin: 0 0 8px;
  line-height: 1.2;
}

.corso-card p {
  font-size: 14px;
  color: var(--grigio);
  line-height: 1.6;
  margin-bottom: 16px;
}

/* ----- Link "Scopri" ----- */
.corso-card .link-scopri {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--giallo);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  text-decoration: none;
  transition: color 0.2s;
}
.corso-card .link-scopri:hover { color: var(--blu); }

/* ----- Card speciale Diploma Adulti (.card-adulti) ----- */
.corso-card.card-adulti {
  background: var(--giallo);
  border-color: var(--giallo);
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.corso-card.card-adulti h2,
.corso-card.card-adulti p          { color: var(--blu); }
.corso-card.card-adulti .link-scopri { color: var(--blu); }
.corso-card.card-adulti:hover      { border-color: var(--blu); }

/* ----- Mobile ----- */
@media (max-width: 768px) {
  .corsi-grid { grid-template-columns: 1fr; }
  .corso-card.card-adulti { flex-direction: column; }
}


/* =============================================================================
   23. PAGINE PROSE — typography Markdown condivisa
                      (.chi-siamo-prose / .metodo-prose / .metodo-cornell-prose
                       / .corso-prose)
   Scopo:
     Layout per pagine prose alimentate da Markdown (chi-siamo, metodo,
     metodo-cornell, MD esteso pagine corso, e potenzialmente privacy/
     cookie/blog-post). Tipografia condivisa per <h2>, <h3>, <p>, <ul>,
     <strong>, <hr>, <a> applicata ai quattro selettori prose con
     selettori discendenti corretti.
   Storage: nessuno.
   Criticita':
     - h2/h3 dentro .prose NON sono uppercase (override del reset globale
       blocco 3) per leggibilita' del corpo articolo.
     - Bordo giallo superiore sul <h2> = separatore visivo tra macro-sezioni.
     - .chi-siamo-sidebar e .metodo-sidebar sono position:sticky su desktop
       (top 100px per compensare la navbar), su mobile tornano statiche.
     - Layout: chi-siamo 70/30, metodo 65/35 (vedi blocco 24).
   ============================================================================= */

.chi-siamo-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 36px;
}
@media (min-width: 900px) {
  .chi-siamo-grid {
    grid-template-columns: 70% 30%;
    gap: 48px;
    align-items: start;
  }
  .chi-siamo-sidebar {
    position: sticky;
    top: 100px;
  }
}

/* ----- Prose — markdown rendering (condiviso chi-siamo + metodo + cornell + corso) ----- */
/* La larghezza e' gestita dalla griglia (.desc-grid, .chi-siamo-grid),
   non da un max-width fisso sul prose container. */
.chi-siamo-prose,
.metodo-prose,
.metodo-cornell-prose,
.corso-prose {
  max-width: none;
  line-height: 1.8;
  color: var(--testo);
  font-family: 'Nunito', sans-serif;
  font-size: 16px;
}

/* H2 — display block + linea decorativa gialla SOTTO il titolo via ::after.
   La linea e' un elemento separato (48px fissi), cosi' resta corta a
   prescindere dalla lunghezza del titolo e non si "spezza" rispetto al testo. */
.chi-siamo-prose h2,
.metodo-prose h2,
.metodo-cornell-prose h2,
.corso-prose h2 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 24px;
  font-weight: 700;
  color: var(--blu);
  text-transform: uppercase;
  letter-spacing: 0.02em;
  line-height: 1.2;
  margin: 40px 0 8px;
  padding-bottom: 0;
  border-bottom: none;
  display: block;
}
.chi-siamo-prose h2::after,
.metodo-prose h2::after,
.metodo-cornell-prose h2::after,
.corso-prose h2::after {
  content: '';
  display: block;
  width: 48px;
  height: 3px;
  background: var(--giallo);
  margin-top: 6px;
  margin-bottom: 16px;
}
.chi-siamo-prose h2:first-child,
.metodo-prose h2:first-child,
.metodo-cornell-prose h2:first-child,
.corso-prose h2:first-child {
  margin-top: 0;
}

.chi-siamo-prose h3,
.metodo-prose h3,
.metodo-cornell-prose h3,
.corso-prose h3 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 19px;
  font-weight: 700;
  color: var(--blu);
  text-transform: uppercase;
  letter-spacing: 0.02em;
  line-height: 1.3;
  margin: 28px 0 6px;
}

.chi-siamo-prose p,
.metodo-prose p,
.metodo-cornell-prose p,
.corso-prose p {
  margin: 0 0 18px;
  color: #2D2D2D;
}

.chi-siamo-prose ul,
.metodo-prose ul,
.metodo-cornell-prose ul,
.corso-prose ul {
  margin: 0 0 18px 20px;
  padding: 0;
  list-style: disc;
}
.chi-siamo-prose ol,
.metodo-prose ol,
.metodo-cornell-prose ol,
.corso-prose ol {
  margin: 0 0 18px 20px;
  padding: 0;
  list-style: decimal;
}

.chi-siamo-prose li,
.metodo-prose li,
.metodo-cornell-prose li,
.corso-prose li {
  margin-bottom: 8px;
  color: #2D2D2D;
  line-height: 1.7;
}

.chi-siamo-prose strong,
.metodo-prose strong,
.metodo-cornell-prose strong,
.corso-prose strong {
  font-weight: 700;
  color: var(--blu);
}

.chi-siamo-prose em,
.metodo-prose em,
.metodo-cornell-prose em,
.corso-prose em {
  font-style: italic;
}

.chi-siamo-prose hr,
.metodo-prose hr,
.metodo-cornell-prose hr,
.corso-prose hr {
  border: 0;
  border-top: 1px solid var(--linea);
  margin: 48px 0;
}

.chi-siamo-prose a,
.metodo-prose a,
.metodo-cornell-prose a,
.corso-prose a {
  color: var(--blu);
  text-decoration: underline;
  text-decoration-color: var(--giallo);
  text-underline-offset: 3px;
}
.chi-siamo-prose a:hover,
.metodo-prose a:hover,
.metodo-cornell-prose a:hover,
.corso-prose a:hover { color: var(--blu-2); }

/* ----- Sidebar info-card (riusa stile .info-card del blocco 9e) ----- */
.chi-siamo-sidebar.info-card,
.metodo-sidebar .info-card {
  /* base ereditata dal blocco 9e (.info-card) */
}
.chi-siamo-sidebar.info-card .btn,
.metodo-sidebar .info-card .btn {
  width: 100%;
  justify-content: center;
  margin-top: 8px;
}


/* =============================================================================
   24. PAGINA METODO — .metodo-grid (65/35) + .profili-card + .cta-colloquio
   Scopo:
     Layout pagina /metodo: prose 65% + sidebar 35% con due card sovrapposte:
       1. .profili-card (sfondo crema): visualizza i due profili
          umanistico 85% e scientifico 15% come due barre orizzontali colorate.
       2. .cta-colloquio (sfondo blu): card CTA con bottone giallo "Prenota
          colloquio" che porta a /contatti.
   Storage: nessuno.
   Criticita':
     - .profili-card barre = .profilo-row con .profilo-bar (track grigio) +
       .profilo-bar > div (fill colorato con width inline % via classe).
     - .profilo-bar.umanistico  = riempimento blu, width 85%
     - .profilo-bar.scientifico = riempimento giallo, width 15%
     - Sidebar sticky desktop (top 100px), statica mobile (sotto 900px).
   ============================================================================= */

.metodo-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 36px;
}
@media (min-width: 900px) {
  .metodo-grid {
    grid-template-columns: 65% 35%;
    gap: 48px;
    align-items: start;
  }
  .metodo-sidebar {
    position: sticky;
    top: 100px;
    display: flex;
    flex-direction: column;
    gap: 20px;
  }
}
.metodo-sidebar {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* ----- Card profili (barre 85/15) ----- */
.profili-card {
  background: var(--crema);
  border: 1px solid var(--linea);
  border-radius: 12px;
  padding: 24px;
}
.profili-card h3 {
  font-family: var(--display);
  font-weight: 700;
  font-size: 18px;
  color: var(--blu);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 6px;
}
.profili-card .profili-sub {
  font-family: var(--body);
  font-size: 13px;
  color: var(--grigio);
  margin: 0 0 20px;
  line-height: 1.45;
}

.profilo-row {
  margin-bottom: 16px;
}
.profilo-row:last-child {
  margin-bottom: 0;
}
.profilo-row .profilo-label {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 6px;
}
.profilo-row .profilo-label .nome {
  font-family: var(--body);
  font-weight: 700;
  font-size: 14px;
  color: var(--testo);
}
.profilo-row .profilo-label .perc {
  font-family: var(--display);
  font-weight: 700;
  font-size: 18px;
  color: var(--blu);
  letter-spacing: -0.01em;
}

.profilo-bar {
  height: 12px;
  background: rgba(30, 58, 138, 0.08);
  border-radius: 6px;
  overflow: hidden;
}
.profilo-bar > div {
  height: 100%;
  border-radius: 6px;
  transition: width .6s ease-out;
}
.profilo-bar.umanistico  > div { background: var(--blu);    width: 85%; }
.profilo-bar.scientifico > div { background: var(--giallo); width: 15%; }

/* ----- Card CTA colloquio (sfondo blu, bottone giallo) ----- */
.cta-colloquio {
  background: var(--blu);
  color: #fff;
  border-radius: 12px;
  padding: 28px 24px;
  text-align: center;
}
.cta-colloquio h3 {
  font-family: var(--display);
  font-weight: 700;
  font-size: 22px;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin: 0 0 10px;
  line-height: 1.2;
}
.cta-colloquio p {
  font-family: var(--body);
  font-size: 14px;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.85);
  margin: 0 0 18px;
}
.cta-colloquio .btn {
  width: 100%;
  justify-content: center;
}


/* =============================================================================
   25. PAGINA METODO CORNELL + LINK-CARD su /metodo
   Scopo:
     Stili specifici della pagina /metodo-cornell (sidebar con foglio SVG,
     lista "quando usarlo", CTA, banner citazione giallo, sezione link a
     /metodo) + la card "Esplora il Metodo Cornell" mostrata in fondo alla
     pagina /metodo.
   Storage: nessuno.
   Criticita':
     - .cornell-sheet-svg: SVG inline che riproduce visivamente il foglio
       Cornell con 3 zone (B sinistra crema/giallo, A destra bianca/blu,
       C fondo blu chiaro/blu).
     - .cornell-quote-section: sfondo crema con dentro un .cornell-quote-card
       giallo (citazione blu). Layout doppio.
     - .cornell-link-back: sezione bianca semplice con titolo + paragrafo +
       link sottolineato che riporta a /metodo.
     - .metodo-cornell-link: card riusabile in fondo a /metodo che porta a
       /metodo-cornell. Layout flex con icona + testo + freccia.
   ============================================================================= */

/* ----- .cornell-sheet-card: sidebar card con SVG schema foglio ----- */
.cornell-sheet-card {
  background: var(--crema);
  border: 1px solid var(--linea);
  border-radius: 12px;
  padding: 20px;
}
.cornell-sheet-card h3 {
  font-family: var(--display);
  font-weight: 700;
  font-size: 16px;
  color: var(--blu);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 12px;
  text-align: center;
}
.cornell-sheet-svg {
  display: block;
  width: 100%;
  height: auto;
  max-height: 240px;
}
.cornell-sheet-card .legenda {
  margin-top: 14px;
  font-size: 12px;
  color: var(--grigio);
  line-height: 1.5;
}
.cornell-sheet-card .legenda b {
  color: var(--blu);
  font-weight: 700;
}

/* ----- .cornell-uses-card: lista "Quando usarlo" ----- */
.cornell-uses-card {
  background: #fff;
  border: 1px solid var(--linea);
  border-radius: 12px;
  padding: 24px;
}
.cornell-uses-card h3 {
  font-family: var(--display);
  font-weight: 700;
  font-size: 18px;
  color: var(--blu);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 14px;
}
.cornell-uses-card ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.cornell-uses-card ul li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  line-height: 1.45;
  color: var(--testo);
}
.cornell-uses-card ul li i {
  color: var(--giallo);
  flex-shrink: 0;
  margin-top: 2px;
  font-size: 18px;
}

/* ----- .cornell-quote-section: sfondo crema con card gialla citazione ----- */
.cornell-quote-section {
  background: var(--crema);
}
.cornell-quote-card {
  background: var(--giallo);
  color: var(--blu);
  border-radius: 16px;
  padding: 40px 32px;
  max-width: 920px;
  margin: 0 auto;
  text-align: center;
  box-shadow: 0 8px 24px -16px rgba(245, 192, 0, 0.5);
}
.cornell-quote-card blockquote {
  font-family: var(--display);
  font-weight: 700;
  font-size: clamp(20px, 3vw, 28px);
  line-height: 1.3;
  letter-spacing: -0.005em;
  margin: 0 0 14px;
  color: var(--blu);
  quotes: "\201C" "\201D";
}
.cornell-quote-card blockquote::before { content: open-quote; opacity: 0.55; }
.cornell-quote-card blockquote::after  { content: close-quote; opacity: 0.55; }
.cornell-quote-card cite {
  display: block;
  font-family: var(--body);
  font-style: normal;
  font-weight: 700;
  font-size: 12px;
  color: var(--blu);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.7;
}

/* ----- .cornell-link-back: sezione bianca con link a /metodo ----- */
.cornell-link-back {
  background: #fff;
  text-align: center;
}
.cornell-link-back .wrap {
  max-width: 720px;
}
.cornell-link-back h2 {
  font-family: var(--display);
  font-weight: 700;
  font-size: clamp(24px, 3vw, 32px);
  color: var(--blu);
  text-transform: none;       /* override global h2 uppercase */
  margin: 0 0 16px;
  letter-spacing: -0.005em;
}
.cornell-link-back p {
  font-family: var(--body);
  font-size: 16px;
  line-height: 1.7;
  color: var(--testo);
  margin: 0 auto 20px;
  max-width: 60ch;
}
.cornell-link-back a.link-back {
  font-family: var(--body);
  font-weight: 700;
  font-size: 14px;
  color: var(--blu);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-bottom: 2px solid var(--giallo);
  padding-bottom: 4px;
  transition: color 0.2s, border-color 0.2s;
}
.cornell-link-back a.link-back:hover {
  color: var(--blu-2);
  border-bottom-color: var(--blu);
}

/* ----- .metodo-cornell-link: card "Esplora Metodo Cornell" in fondo a /metodo ----- */
.metodo-cornell-link {
  background: var(--blu);
  color: #fff;
  border-radius: 16px;
  padding: 32px;
  display: flex;
  align-items: center;
  gap: 24px;
  text-decoration: none;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.metodo-cornell-link:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 40px -20px rgba(30, 58, 138, 0.4);
}
.metodo-cornell-link .icona {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  background: var(--giallo);
  color: var(--blu);
  border-radius: 12px;
  display: grid;
  place-items: center;
  font-size: 32px;
}
.metodo-cornell-link .testo {
  flex: 1;
}
.metodo-cornell-link .eyebrow {
  color: var(--giallo);
  margin-bottom: 6px;
}
.metodo-cornell-link .eyebrow::before {
  background: var(--giallo);
}
.metodo-cornell-link h3 {
  font-family: var(--display);
  font-weight: 700;
  font-size: clamp(22px, 2.5vw, 28px);
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  margin: 0 0 8px;
  line-height: 1.2;
}
.metodo-cornell-link p {
  font-family: var(--body);
  font-size: 14px;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.85);
  margin: 0;
}
.metodo-cornell-link .freccia {
  flex-shrink: 0;
  font-family: var(--display);
  font-weight: 700;
  font-size: 14px;
  color: var(--giallo);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  white-space: nowrap;
}
.metodo-cornell-link .freccia::after {
  content: " \2192";
  display: inline-block;
  margin-left: 4px;
  transition: transform 0.25s ease;
}
.metodo-cornell-link:hover .freccia::after {
  transform: translateX(4px);
}
@media (max-width: 768px) {
  .metodo-cornell-link {
    flex-direction: column;
    text-align: center;
    padding: 24px;
  }
  .metodo-cornell-link .freccia { margin-top: 8px; }
}


/* =============================================================================
   26. FIX DESC GRID CORSO v2 (10/05/2026 - append-only override)
   Scopo: forzare il layout 65/35 della sezione #descrizione con sidebar
   sticky e prose senza max-width fisso. Le regole usano !important per
   "vincere" la cascata contro le regole del blocco 9e in caso di conflitto.
   Riferimento: TODO.md sezione "Fix forzato pagine corso (revisione 3)".
   ============================================================================= */

/* ===== FIX DESC GRID CORSO v2 ===== */

.desc-grid {
  display: grid !important;
  grid-template-columns: 1fr 300px !important;
  gap: 48px !important;
  align-items: start !important;
}

.corso-prose {
  min-width: 0;
  max-width: none;
  font-family: 'Nunito', sans-serif;
  font-size: 16px;
  line-height: 1.8;
  color: #2D2D2D;
}

.corso-prose h2 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: #1E3A8A;
  text-transform: uppercase;
  margin: 36px 0 0;
  padding: 0;
  border: none;
  display: block;
}

.corso-prose h2::after {
  content: '';
  display: block;
  width: 40px;
  height: 3px;
  background: #F5C000;
  margin: 6px 0 14px;
}

.corso-prose h2:first-child {
  margin-top: 0;
}

.corso-prose h3 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: #1E3A8A;
  text-transform: uppercase;
  margin: 24px 0 6px;
}

.corso-prose p {
  margin: 0 0 16px;
}

.corso-prose ul {
  margin: 0 0 16px 20px;
}

.corso-prose li {
  margin-bottom: 8px;
  line-height: 1.7;
}

.corso-prose strong {
  color: #1E3A8A;
  font-weight: 700;
}

.desc-sidebar {
  position: sticky;
  top: 100px;
}

.info-card {
  background: #1E3A8A;
  border-radius: 12px;
  padding: 24px;
  color: #fff;
}

.info-card-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 15px;
  font-weight: 700;
  text-transform: uppercase;
  color: #F5C000;
  margin: 0 0 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255,255,255,0.15);
}

.info-line {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 12px;
  font-size: 14px;
  line-height: 1.5;
}

.info-line .ti {
  color: #F5C000;
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 1px;
}

.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #F5C000;
  color: #1E3A8A;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 16px;
  font-weight: 700;
  text-transform: uppercase;
  padding: 12px 24px;
  border-radius: 6px;
  text-decoration: none;
  transition: background 0.2s;
  cursor: pointer;
}
.btn-primary:hover { background: #e0b000; }
.btn-full {
  width: 100%;
  box-sizing: border-box;
  text-align: center;
}
.mt-16 { margin-top: 16px; }

@media (max-width: 1024px) {
  .desc-grid {
    grid-template-columns: 1fr !important;
  }
  .desc-sidebar {
    position: static !important;
    margin-top: 32px;
  }
}

/* ===== FINE FIX DESC GRID CORSO v2 ===== */


/* =============================================================================
   27. SIDEBAR CARD (variante per /diploma-online e altre pagine SEO)
   Scopo: 3 card stack nella sidebar destra (desc-sidebar) con stili
   differenziati: crema, blu, white-bordered.
   Usata in: templates/views/diploma-online.php
   ============================================================================= */

.diploma-online-sidebar {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.sidebar-card {
  border-radius: 12px;
  padding: 20px;
}

.sidebar-card-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 16px;
  font-weight: 700;
  text-transform: uppercase;
  margin: 0 0 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid currentColor;
  border-color: rgba(0,0,0,0.1);
}

.sidebar-card-text {
  font-size: 14px;
  line-height: 1.5;
  margin: 0 0 14px;
}

/* Variante crema (Card 1: "Inizia da qui" / "La nostra sede") */
.sidebar-card--crema {
  background: var(--crema);
  color: var(--testo);
}
.sidebar-card--crema .sidebar-card-title { color: var(--blu); }
/* Riuso .info-line dentro .sidebar-card--crema: icone blu (non giallo
   come nel blocco 9e dove la card padre e' blu), link in colore testo. */
.sidebar-card--crema .info-line .ti { color: var(--blu); }
.sidebar-card--crema .info-line a {
  color: var(--testo);
  text-decoration: none;
}
.sidebar-card--crema .info-line a:hover {
  color: var(--blu);
  text-decoration: underline;
}

.sidebar-checks {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.sidebar-checks li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: 14px;
  line-height: 1.45;
}
.sidebar-checks .check {
  width: 22px; height: 22px;
  flex-shrink: 0;
  border-radius: 50%;
  background: var(--giallo);
  color: var(--blu);
  display: grid; place-items: center;
  font-size: 12px;
  margin-top: 1px;
}
.sidebar-checks .check .ti { font-size: 14px; }

/* Variante blu (Card 2: "Hai domande?") */
.sidebar-card--blu {
  background: var(--blu);
  color: #fff;
}
.sidebar-card--blu .sidebar-card-title {
  color: #fff;
  border-color: rgba(255,255,255,0.18);
}
.sidebar-card--blu .sidebar-card-text { color: rgba(255,255,255,0.9); }
.sidebar-card-tel {
  margin: 12px 0 0;
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 8px;
  color: rgba(255,255,255,0.85);
}
.sidebar-card-tel .ti { color: var(--giallo); font-size: 15px; }
.sidebar-card-tel a {
  color: #fff;
  text-decoration: none;
  font-weight: 700;
}
.sidebar-card-tel a:hover { text-decoration: underline; }

/* Variante white-bordered (Card 3: "Percorsi correlati") */
.sidebar-card--white {
  background: #fff;
  color: var(--testo);
  border: 1px solid var(--crema-2);
}
.sidebar-card--white .sidebar-card-title {
  color: var(--blu);
  border-color: var(--crema-2);
}

.sidebar-links {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.sidebar-links li {
  border-bottom: 1px solid var(--crema-2);
}
.sidebar-links li:last-child { border-bottom: none; }
.sidebar-links a {
  display: block;
  padding: 10px 0;
  color: var(--blu);
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  transition: color 0.15s;
}
.sidebar-links a:hover {
  color: var(--blu-2);
  text-decoration: underline;
}

/* ===== FINE SIDEBAR CARD ===== */


/* =============================================================================
   28. PAGINA /contatti — override layout
   Scopo: stringere la colonna info+mappa, allargare la colonna form.
   La regola base `.desc-grid` (blocco 26 con !important) imposta 1fr 300px,
   pensato per pagine corso/SEO dove la sidebar e' una info-card stretta.
   Su /contatti il form e' la conversione principale: deve essere prominente.
   Specificita': #id + .class batte la regola base anche con !important.
   ============================================================================= */

#contatti-info .desc-grid {
  /* Form a destra ~55% piu' largo della colonna info+mappa. */
  grid-template-columns: 0.9fr 1.1fr !important;
  gap: 40px !important;
}

/* Mappa: altezza ridotta da auto (puo' diventare alta) a fissa moderata. */
#contatti-info .map-embed {
  height: 280px;
  width: 100%;
  border: 0;
  border-radius: 8px;
  margin-top: 16px;
}

/* Mobile: torna a colonna unica (form sotto info+mappa, ordine naturale). */
@media (max-width: 900px) {
  #contatti-info .desc-grid {
    grid-template-columns: 1fr !important;
  }
}

/* ===== FINE CONTATTI OVERRIDE ===== */


/* =============================================================================
   29. FORM BANNER - feedback post-submit
   Mostrato in /contatti dopo POST: verde se ?ok=1, rosso se errori validation.
   Markup: <div class="form-banner form-banner--{success|error}">...</div>
   ============================================================================= */

.form-banner {
  border-radius: 8px;
  padding: 14px 18px;
  margin-bottom: 18px;
  font-size: 14px;
  line-height: 1.5;
  font-family: 'Nunito', sans-serif;
}
.form-banner strong { display: block; margin-bottom: 4px; font-size: 15px; }
.form-banner ul {
  margin: 6px 0 0 18px;
  padding: 0;
  list-style: disc;
}
.form-banner--success {
  background: #d6f5dd;
  color: #14532d;
  border: 1px solid #86d399;
}
.form-banner--error {
  background: #fde2e1;
  color: #7f1d1d;
  border: 1px solid #f5a8a4;
}

/* ===== FINE FORM BANNER ===== */


/* =============================================================================
   30. COOKIE CONSENT MODAL (GDPR + GA4 Consent Mode v2)
   Modal centrato bloccante mostrato al primo accesso.
   JS: main.js blocco 12. Stato persistente: localStorage['cse_cookie_consent']
   = 'granted' | 'denied'. Brand-coerente blu/giallo CSE.
   ============================================================================= */

.cookie-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.cookie-modal.show { display: flex; }

.cookie-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 36, 86, 0.72); /* var(--blu-deep) at 72% */
  backdrop-filter: blur(4px);
}

.cookie-modal__card {
  position: relative;
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 32px 64px -16px rgba(0,0,0,0.4);
  padding: 32px 28px;
  max-width: 520px;
  width: 100%;
  font-family: 'Nunito', sans-serif;
  color: var(--testo);
}

.cookie-modal__card h2 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 24px;
  font-weight: 700;
  color: var(--blu);
  text-transform: uppercase;
  letter-spacing: 0.02em;
  margin: 0 0 14px;
  position: relative;
  padding-bottom: 12px;
}
.cookie-modal__card h2::after {
  content: '';
  position: absolute;
  left: 0; bottom: 0;
  width: 40px; height: 3px;
  background: var(--giallo);
}

.cookie-modal__card p {
  font-size: 14px;
  line-height: 1.6;
  margin: 0 0 14px;
}

.cookie-modal__links { font-size: 13px; }
.cookie-modal__links a {
  color: var(--blu);
  text-decoration: underline;
}
.cookie-modal__links a:hover { color: var(--blu-2); }

.cookie-modal__actions {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  margin-top: 20px;
  flex-wrap: wrap;
}

.cookie-modal__btn {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 12px 22px;
  border-radius: 6px;
  border: none;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.cookie-modal__btn--primary {
  background: var(--giallo);
  color: var(--blu);
}
.cookie-modal__btn--primary:hover { background: #e0b000; }

.cookie-modal__btn--secondary {
  background: transparent;
  color: var(--blu);
  border: 1.5px solid var(--blu);
}
.cookie-modal__btn--secondary:hover {
  background: var(--blu);
  color: #fff;
}

@media (max-width: 480px) {
  .cookie-modal__card { padding: 24px 20px; }
  .cookie-modal__card h2 { font-size: 20px; }
  .cookie-modal__actions { flex-direction: column-reverse; }
  .cookie-modal__btn { width: 100%; }
}

/* ===== FINE COOKIE MODAL ===== */


/* =============================================================================
   31. LEGAL PAGES (/privacy, /cookie)
   Shared view: templates/views/legal.php. Riusa .corso-prose per la
   typography del testo MD, vincolato a max-width 760px per leggibilita'
   del testo legale lungo. Bottone "Modifica preferenze cookie" centrato
   in fondo alla pagina /cookie.
   ============================================================================= */

.legal-page { background: #fff; }

.legal-content {
  max-width: 760px;
  margin: 0 auto;
  padding-top: 8px;
}

.legal-cookie-customize {
  margin-top: 40px;
  padding-top: 24px;
  border-top: 1px solid var(--crema-2);
  text-align: center;
}
.legal-cookie-customize .btn-primary {
  display: inline-flex;
}

/* ===== FINE LEGAL PAGES ===== */


/* =============================================================================
   32. FORM LABEL VISIBILI (a11y)
   Scopo:
     Stile per le <label class="form-label"> aggiunte al form di /contatti
     (Tranche D2, audit C12). Le label sono SEMPRE visibili (non
     aria-label) e collegate via for/id agli input/select/textarea.
     Ogni coppia (label + input) e' wrappata in <div class="field">; il
     wrapper diventa la cella della grid .contact-form (che ha
     grid-template-columns: 1fr 1fr) al posto dell'input diretto.
   Storage: nessuno (puro CSS).
   Criticita':
     - .field e' figlio diretto del form: la grid lo posiziona, NON
       l'input al suo interno. Le regole esistenti .contact-form input
       (blocco 20) continuano a funzionare per descendant selector.
     - .field.full estende grid-column: 1 / -1 (analogo a .contact-form
       .full del blocco 20). Usato per il <select> corso e la <textarea>
       messaggio (full width).
     - Asterisco rosso .form-label-required ha aria-hidden="true" lato
       HTML: lo screen reader gia' annuncia "required" dall'attributo
       nativo dell'input.
   ============================================================================= */

.contact-form > .field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.contact-form > .field.full {
  grid-column: 1 / -1;
}

.contact-form .form-label {
  display: block;
  font-family: 'Nunito', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--testo);
  line-height: 1.3;
  letter-spacing: 0.01em;
}

.contact-form .form-label-required {
  color: #c0392b;
  font-weight: 700;
  margin-left: 2px;
}

.contact-form .form-label-hint {
  color: var(--grigio);
  font-weight: 400;
  font-size: 12px;
  margin-left: 4px;
}

/* ===== FINE FORM LABEL VISIBILI ===== */
