/* ════════════════════════════════════════════════════════════════
 * ANS Home — foglio di stile dedicato alla front page
 * ════════════════════════════════════════════════════════════════
 * Caricato solo su is_front_page() da functions.php.
 * Per modificare colori globalmente: cambia i custom properties
 * dentro :root (sezione "Variabili di tema" sotto).
 */


/* ─────────── Variabili di tema ─────────── */
:root {
    --ink: #0c0c0c;
    --ink-soft: #2a2a2a;
    --muted: #6b6b6b;
    --line: #e6e8eb;
    --paper: #ffffff;
    --paper-warm: #f4f6f8;
    --accent: #8fc7e0;          /* Celeste — colore principale del brand */
    --accent-ink: #0c0c0c;
    --radius: 28px;
    --radius-sm: 18px;
    --radius-xs: 12px;
    --display: "Plus Jakarta Sans", ui-sans-serif, system-ui, sans-serif;
    --body: "DM Sans", ui-sans-serif, system-ui, sans-serif;
    --serif: "Plus Jakarta Sans", ui-sans-serif, system-ui, sans-serif;
}


/* ─────────── Reset di base e impostazioni body ─────────── */
.home,
.page-template-page-home,
.page-template-page-home * {
    box-sizing: border-box;
}
body.page-template-page-home {
    margin: 0;
    padding: 0;
    font-family: var(--body);
    color: var(--ink);
    background: var(--paper);
    font-size: 16px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
.page-template-page-home img { max-width: 100%; display: block; }
.page-template-page-home a { color: inherit; text-decoration: none; }
.page-template-page-home button { font: inherit; cursor: pointer; }


/* ─────────── Contenitore principale (.wrap) ─────────── */
.wrap {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 64px;
}
@media (max-width: 1024px) { .wrap { padding: 0 28px; } }
@media (max-width: 720px)  { .wrap { padding: 0 20px; } }
@media (max-width: 480px)  { .wrap { padding: 0 16px; } }

/* Evita che elementi che strabordano causino scroll orizzontale su mobile.
   Copre tutti i template ANS-driven: home, macro-area, single corso,
   archive corsi, tassonomia macro-area, 404, e i futuri template istituzionali. */
body.page-template-page-home,
body.page-template-page-macro-area,
body.single-corso,
body.post-type-archive-corso,
body.tax-macro_area,
body.error404 { overflow-x: hidden; }

/* Utility: nascondi un elemento sotto i 920px (es. logo hero, decorazioni). */
@media (max-width: 920px) {
    .hide-on-mobile { display: none !important; }
}


/* ─────────── Barra annunci scorrevole (top) ─────────── */
.announce {
    background: var(--ink);
    color: #fff;
    overflow: hidden;
    white-space: nowrap;
    font-size: 13px;
    letter-spacing: 0.02em;
    height: 38px;
    display: flex;
    align-items: center;
}
.announce-inner {
    display: inline-flex;
    align-items: center;
    gap: 36px;
    animation: marq 48s linear infinite;
    padding-left: 36px;
}
.announce-inner > span {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}
.announce-inner em {
    font-family: var(--serif);
    font-style: italic;
    color: var(--accent);
    font-size: 14px;
}
.announce-inner .sep {
    width: 5px; height: 5px;
    border-radius: 50%;
    background: var(--accent);
    display: inline-block;
}


/* ─────────── Striscia loghi (affiliazioni / partner) ─────────── */
.logos-strip {
    background: var(--paper);
    border-bottom: 1px solid var(--line);
    padding: 2px 0;
}
.logos-row {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
}
/* Loghi: vicini tra loro, allineati a destra. Gap molto stretto
   richiesto esplicitamente: con 2 soli loghi devono apparire
   accostati, non spalmati. */
.logos-items {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    justify-content: flex-end;
}
.logo-slot {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 38px;
    min-width: 0;          /* prima 100px: forzava i loghi distanti tra loro */
    padding: 0 4px;        /* prima 14px: padding stretto = loghi ancora piu vicini */
    border: 0;
    background: transparent;
    color: var(--muted);
    transition: color 0.18s ease;
}
.logo-slot:hover { color: var(--ink); }

/* Mobile: striscia loghi compatta, allineata a destra come desktop. */
@media (max-width: 720px) {
    .logos-row {
        justify-content: flex-end;
        flex-wrap: nowrap;
        overflow-x: auto;
        -ms-overflow-style: none;
        scrollbar-width: none;
    }
    .logos-row::-webkit-scrollbar { display: none; }
    .logos-items {
        flex-wrap: nowrap;
        gap: 4px;
        flex: none;
        justify-content: flex-end;
    }
    .logo-slot {
        min-width: 0;
        padding: 0 2px;
        flex-shrink: 0;
    }
}


/* ─────────── Navbar (sticky) ─────────── */
.nav {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(255, 255, 255, 0.86);
    -webkit-backdrop-filter: blur(18px) saturate(160%);
    backdrop-filter: blur(18px) saturate(160%);
    border-bottom: 1px solid rgba(232, 230, 225, 0.6);
}
.nav-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 88px;
}
@media (max-width: 720px) {
    .nav-row { height: 64px; }
    .logo .logo-image { height: 48px; max-width: 180px; }
    .logo { font-size: 18px; }
}
.logo {
    display: flex;
    align-items: center;
    gap: 10px;
    font-family: var(--display);
    font-weight: 700;
    font-size: 22px;
    letter-spacing: -0.02em;
}
.logo .logo-image {
    height: 72px;
    width: auto;
    max-width: 260px;
    object-fit: contain;
    display: block;
}
.logo-mark {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: var(--accent);
    position: relative;
}
.logo-mark::after {
    content: "";
    position: absolute;
    inset: 6px;
    border-radius: 50%;
    border: 2px solid var(--ink);
}
.logo small {
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
    color: var(--muted);
    font-size: 14px;
    margin-left: 2px;
}

/* Container <nav> a destra */
.nav-links {
    display: flex;
    gap: 6px;
    align-items: center;
}

/* Lista <ul.nav-menu> generata da wp_nav_menu() */
.nav-menu {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    gap: 6px;
    align-items: center;
}
.nav-menu li { list-style: none; }
.nav-menu li a {
    display: inline-block;
    padding: 8px 14px;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 500;
    color: var(--ink-soft);
    transition: background 0.18s ease, color 0.18s ease;
}
.nav-menu li a:hover {
    background: var(--paper-warm);
    color: var(--ink);
}
.nav-menu li.current-menu-item > a,
.nav-menu li.current-menu-parent > a {
    background: var(--ink);
    color: #fff;
}

/* Pulsante CTA "Iscriviti" a destra del menu */
.nav-cta {
    margin-left: 8px;
    padding: 10px 18px;
    border-radius: 999px;
    background: var(--accent);
    color: var(--ink);
    font-weight: 600;
    font-size: 14px;
    border: 1px solid var(--ink);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.nav-cta:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08);
}

/* Burger menu mobile */
/* Specificità rinforzata + !important: alcuni stili di tema/plugin
   (Hello Elementor, Elementor) provavano a forzare display:block o
   inline-flex sui button generici, e il burger ricompariva su desktop. */
.nav .nav-burger { display: none !important; }
@media (max-width: 920px) {
    .nav-links { display: none; }
    .nav .nav-burger {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        width: 42px; height: 42px;
        border-radius: 999px;
        background: var(--paper-warm);
        border: 1px solid var(--line);
    }
    .nav-burger span,
    .nav-burger span::before,
    .nav-burger span::after {
        content: "";
        display: block;
        width: 16px; height: 1.5px;
        background: var(--ink);
        position: relative;
    }
    .nav-burger span::before { position: absolute; top: -5px; }
    .nav-burger span::after  { position: absolute; top:  5px; }
}


/* ─────────── Sezione Hero ─────────── */
.hero {
    position: relative;
    overflow: hidden;
    background: #0a0a0a;
    color: #fff;
    isolation: isolate;
}
.hero-photo {
    position: absolute;
    inset: 0;
    z-index: -2;
    /* L'URL dell'immagine + opacity vengono impostati inline in page-home.php.
       Niente filtri qui: la regolazione visiva è gestita dal campo
       "Visibilità immagine di sfondo (%)" del pannello ACF. */
    background-size: cover;
    background-position: center 38%;
}
.hero-veil {
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
        /* Spot scuro concentrato nell'angolo basso-sinistra (effetto cinematografico).
           L'ellisse parte dall'origine (0% 100%) con il punto più scuro al centro
           e si dissolve a 70% verso il resto della hero. */
        radial-gradient(ellipse 85% 75% at 0% 100%,
            rgba(0,0,0,0.95) 0%,
            rgba(0,0,0,0.55) 35%,
            rgba(0,0,0,0)    70%),
        linear-gradient(180deg, rgba(8,8,8,0.45) 0%, rgba(8,8,8,0.65) 50%, rgba(8,8,8,0.85) 100%),
        linear-gradient(90deg,  rgba(8,8,8,0.70) 0%, rgba(8,8,8,0.40) 55%, rgba(8,8,8,0.55) 100%);
}
.hero-inner {
    /* IMPORTANTE: usare solo padding-top/bottom, non shorthand "padding: ..."
       perché il div ha anche la classe .wrap che dà padding-left/right. */
    padding-top: 96px;
    padding-bottom: 64px;
    position: relative;
}
.hero-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
    align-items: center;
}
.hero-grid > div { max-width: 760px; }

/* Variante con logo grande a destra (toggle ACF "Mostra logo grande nell'hero").
   Torna a 2 colonne: copy/CTA a sinistra (1.2fr), logo a destra (0.8fr). */
.hero-grid.has-hero-logo {
    grid-template-columns: 1.2fr 0.8fr;
    gap: 56px;
}
.hero-grid.has-hero-logo > div { max-width: none; }
.hero-logo-art {
    display: flex;
    align-items: center;
    justify-content: center;
}
.hero-logo-art img {
    max-width: 100%;
    max-height: 440px;
    width: auto;
    height: auto;
    object-fit: contain;
    display: block;
    filter: drop-shadow(0 12px 40px rgba(0,0,0,0.35));
}

@media (max-width: 920px) {
    .hero-grid.has-hero-logo { grid-template-columns: 1fr; gap: 32px; }
    .hero-logo-art img { max-height: 240px; }
    .hero-inner { padding-top: 48px; padding-bottom: 32px; }
}
@media (max-width: 480px) {
    .hero-inner { padding-top: 32px; padding-bottom: 24px; }
    .hero-logo-art img { max-height: 180px; }
}

/* Eyebrow / pill informativo */
.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 14px 8px 8px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.18);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    font-size: 13px;
    font-weight: 500;
    color: #fff;
}
.eyebrow-dot {
    width: 22px; height: 22px;
    border-radius: 50%;
    background: var(--accent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 700;
    color: var(--ink);
}

/* Titolo principale */
.hero h1 {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(36px, 5vw, 68px);
    line-height: 1.05;
    letter-spacing: -0.03em;
    margin: 16px 0 20px;
    color: #fff;
    text-wrap: balance;
    text-shadow: 0 2px 30px rgba(0, 0, 0, 0.35);
}
@media (max-width: 480px) {
    .hero h1 { font-size: clamp(36px, 10vw, 56px); margin: 12px 0 16px; }
}
.hero h1 em {
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
    letter-spacing: -0.01em;
    color: var(--accent);
}
.hero h1 .stamp {
    display: inline-block;
    background: var(--accent);
    color: var(--ink);
    padding: 0 12px;
    border-radius: 14px;
    transform: rotate(-1.5deg);
}
.hero-sub {
    font-size: 19px;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.82);
    max-width: 520px;
    margin: 0 0 36px;
}
@media (max-width: 480px) {
    .hero-sub { font-size: 16px; margin: 0 0 24px; }
}
.hero .btn-secondary { color: #fff; border-color: rgba(255, 255, 255, 0.6); }
.hero .btn-secondary:hover { background: #fff; color: var(--ink); border-color: #fff; }


/* ─────────── Pulsanti (CTA) ─────────── */
.cta-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
}
.btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 20px;
    border-radius: 999px;
    font-weight: 600;
    font-size: 15px;
    border: 1px solid transparent;
    transition: transform 0.18s ease, box-shadow 0.2s ease, background 0.18s ease;
}
.btn-primary { background: var(--ink); color: #fff; }
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18); }
.btn-secondary { background: transparent; color: var(--ink); border-color: var(--ink); }
.btn-secondary:hover { background: var(--ink); color: #fff; }
.btn-accent { background: var(--accent); color: var(--ink); border-color: var(--ink); }
.btn-accent:hover { transform: translateY(-1px); box-shadow: 0 10px 24px rgba(0, 0, 0, 0.12); }
.btn .arrow { transition: transform 0.2s ease; }
.btn:hover .arrow { transform: translateX(3px); }


/* ─────────── Trust bar (Trustpilot · Google · Trainers) ─────────── */
.trust-bar {
    margin-top: 56px;
    padding-top: 28px;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
}
@media (max-width: 720px) {
    .trust-bar { margin-top: 32px; padding-top: 20px; }
}
.trust-lead {
    font-family: var(--serif);
    font-style: italic;
    font-size: 17px;
    color: rgba(255, 255, 255, 0.7);
    margin: 0 0 18px;
}
.trust-row {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 36px;
    align-items: start;
    max-width: 640px;
}
@media (max-width: 720px) {
    .trust-row { grid-template-columns: 1fr; gap: 20px; }
}
.trust-item {
    display: flex;
    flex-direction: column;
    gap: 8px;
    color: #fff;
}
.trust-head {
    display: flex;
    align-items: center;
    gap: 12px;
}
.trust-brand {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--display);
    font-weight: 600;
    font-size: 18px;
    color: #fff;
}
/* Trustpilot — quadrato verde brand con stella bianca dentro */
.trust-brand .tp-star {
    width: 22px; height: 22px;
    border-radius: 4px;
    background: #00B67A;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
}
/* Google — il logo "G" multicolore è SVG inline nel template */
.trust-brand .g-logo {
    display: inline-flex;
    align-items: center;
    height: 22px;
}
.trust-brand .g-logo svg { display: block; height: 22px; width: auto; }
.trust-brand .icon-grad {
    width: 22px; height: 22px;
    border-radius: 50%;
    background: var(--accent);
    border: 1px solid #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--ink);
    font-size: 12px;
    font-weight: 800;
}
.trust-stars {
    display: inline-flex;
    gap: 2px;
    background: rgba(255, 255, 255, 0.06);
    padding: 4px 6px;
    border-radius: 6px;
}
.trust-stars i {
    display: inline-block;
    width: 18px; height: 18px;
    background: var(--accent);
    clip-path: polygon(50% 0, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
}
/* Stelle Google — giallo oro ufficiale */
.trust-stars.google i { background: #FBBC04; }
/* Stelle Trustpilot — verde ufficiale */
.trust-stars.trustpilot i { background: #00B67A; }
.trust-line {
    font-size: 14px;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.78);
}
.trust-line b { color: #fff; font-weight: 600; }


/* ─────────── Hero — forme decorative (colonna destra) ─────────── */
.hero-art {
    position: relative;
    aspect-ratio: 1 / 1;
    width: 100%;
    max-width: 520px;
    margin-left: auto;
    justify-self: end;
}
.shape { position: absolute; }
.shape-disc {
    width: 70%; height: 70%;
    border-radius: 50%;
    background: var(--accent);
    bottom: 8%; right: 4%;
    opacity: 0.92;
}
.shape-ring {
    width: 56%; height: 56%;
    border-radius: 50%;
    border: 1.5px solid rgba(255, 255, 255, 0.55);
    top: 2%; left: 6%;
}
.shape-pill {
    width: 26%; height: 9%;
    border-radius: 999px;
    background: #fff;
    top: 36%; left: 24%;
    transform: rotate(-22deg);
}
.shape-square {
    width: 16%; height: 16%;
    border-radius: 24%;
    background: transparent;
    border: 1.5px solid rgba(255, 255, 255, 0.65);
    bottom: 14%; left: 8%;
}
.shape-dot {
    width: 8%; height: 8%;
    border-radius: 50%;
    background: #fff;
    top: 12%; right: 22%;
}
.shape-label {
    position: absolute;
    top: 4%; right: -2%;
    font-family: var(--serif);
    font-style: italic;
    font-size: 17px;
    color: rgba(255, 255, 255, 0.78);
    transform: rotate(6deg);
}
.shape-label::before {
    content: "";
    display: inline-block;
    width: 30px; height: 1px;
    background: rgba(255, 255, 255, 0.5);
    vertical-align: middle;
    margin-right: 8px;
}
.shape-stamp {
    position: absolute;
    bottom: 4%; right: 4%;
    width: 110px; height: 110px;
    border-radius: 50%;
    background: var(--accent);
    border: 1.5px solid var(--ink);
    color: var(--ink);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--display);
    font-weight: 700;
    font-size: 13px;
    line-height: 1.1;
    text-align: center;
    padding: 16px;
    letter-spacing: -0.01em;
    transform: rotate(-8deg);
}


/* ─────────── Pattern di intestazione sezioni ─────────── */
/* IMPORTANTE: solo padding-top/bottom (no shorthand) per non sovrascrivere
   padding-left/right di .wrap, classe che molte section hanno in combo. */
.section { padding-top: 88px; padding-bottom: 88px; }
@media (max-width: 920px) { .section { padding-top: 56px; padding-bottom: 56px; } }
@media (max-width: 480px) { .section { padding-top: 40px; padding-bottom: 40px; } }

/* Varianti di sfondo della sezione (controllabili da ACF, es. tab Calendario). */
.section-bg-white  { background: var(--paper); }
.section-bg-warm   {
    background: var(--paper-warm);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}
.section-bg-accent {
    background: var(--accent);
    border-top: 1px solid var(--ink);
    border-bottom: 1px solid var(--ink);
}
.section-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 48px;
    flex-wrap: wrap;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--line);
}
@media (max-width: 720px) {
    .section-header { gap: 12px; margin-bottom: 28px; padding-bottom: 16px; }
}
.section-title {
    font-family: var(--display);
    font-weight: 600;
    font-size: clamp(28px, 5vw, 52px);
    line-height: 1.05;
    letter-spacing: -0.03em;
    margin: 0;
    max-width: 720px;
    text-wrap: balance;
}
.section-title em {
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
}
.section-kicker {
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 14px;
}
/* Etichetta sezione: contrasto leggibile su qualsiasi sfondo */
.section-bg-warm   .section-kicker { color: var(--ink-soft); }
.section-bg-accent .section-kicker { color: var(--ink); }
.section-bg-ink    .section-kicker { color: rgba(255, 255, 255, 0.75); }
.section-action {
    font-size: 14px;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--ink-soft);
    white-space: nowrap;
}
.section-action:hover { color: var(--ink); }
.section-action .arrow { transition: transform 0.2s ease; }
.section-action:hover .arrow { transform: translateX(3px); }


/* ─────────── Macro-aree (Fitness / Olistica / Acquatica) ─────────── */
.macros {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
@media (max-width: 920px) { .macros { grid-template-columns: 1fr; } }

.macro {
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 28px;
    border-radius: var(--radius);
    background: var(--paper-warm);
    border: 1px solid var(--line);
    min-height: 360px;
    transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
    overflow: hidden;
}
.macro:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.06);
}
.macro-num {
    font-family: var(--display);
    font-weight: 500;
    font-size: 13px;
    color: var(--muted);
    letter-spacing: 0.04em;
}
.macro-art {
    height: 140px;
    position: relative;
    margin: 8px 0 24px;
}
/* Quando la card ha un'immagine personalizzata: container più alto e
   rettangolare (formato fotografico ~16:10). L'immagine riempie sempre
   tutto lo spazio mantenendo le proporzioni (cropping centrato),
   indipendentemente dal formato caricato dal cliente. */
.macro-art.has-image {
    height: 220px;
    overflow: hidden;
    border-radius: 14px;
}
.macro-art .macro-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}
.macro h3 {
    font-family: var(--display);
    font-weight: 600;
    font-size: 32px;
    line-height: 1;
    letter-spacing: -0.025em;
    margin: 0 0 8px;
}
.macro h3 em {
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
}
.macro p {
    color: var(--ink-soft);
    font-size: 15px;
    margin: 0;
    flex: 1;
}
.macro-foot {
    margin-top: 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 18px;
    border-top: 1px solid var(--line);
    font-weight: 500;
    font-size: 14px;
}
.macro-foot .pill {
    background: var(--ink);
    color: #fff;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 11px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.macro:hover .macro-go { background: var(--accent); }
.macro-go {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px; height: 36px;
    border-radius: 50%;
    border: 1px solid var(--ink);
    background: transparent;
    transition: background 0.2s ease;
}

/* Illustrazioni astratte delle macro-aree */
.ma-fitness .d1  { position: absolute; width: 60px; height: 60px; border-radius: 50%; background: var(--accent); top: 10px; left: 20px; }
.ma-fitness .d2  { position: absolute; width: 60px; height: 60px; border-radius: 50%; background: var(--accent); top: 10px; left: 110px; }
.ma-fitness .bar { position: absolute; width: 90px; height: 14px; border-radius: 999px; background: var(--ink); top: 33px; left: 70px; }
.ma-fitness .tag { position: absolute; right: 0; bottom: 0; font-family: var(--serif); font-style: italic; color: var(--muted); font-size: 14px; }

.ma-olistica .c1  { position: absolute; width: 120px; height: 120px; border-radius: 50%; border: 1.5px solid var(--ink); top: 10px; left: 40px; }
.ma-olistica .c2  { position: absolute; width: 80px;  height: 80px;  border-radius: 50%; border: 1.5px solid var(--ink); top: 30px; left: 60px; }
.ma-olistica .c3  { position: absolute; width: 40px;  height: 40px;  border-radius: 50%; background: var(--accent); top: 50px; left: 80px; }
.ma-olistica .tag { position: absolute; right: 0; bottom: 0; font-family: var(--serif); font-style: italic; color: var(--muted); font-size: 14px; }

.ma-acquatica .l1  { position: absolute; width: 160px; height: 12px; border-radius: 999px; background: var(--accent); top: 30px; left: 20px; }
.ma-acquatica .l2  { position: absolute; width: 120px; height: 12px; border-radius: 999px; background: var(--ink); top: 60px; left: 50px; }
.ma-acquatica .l3  { position: absolute; width: 80px;  height: 12px; border-radius: 999px; background: var(--accent); top: 90px; left: 30px; opacity: 0.5; }
.ma-acquatica .tag { position: absolute; right: 0; bottom: 0; font-family: var(--serif); font-style: italic; color: var(--muted); font-size: 14px; }


/* ─────────── Corsi in evidenza ─────────── */
.courses {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
@media (max-width: 920px) { .courses { grid-template-columns: 1fr; } }

.course {
    display: flex;
    flex-direction: column;
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--paper);
    border: 1px solid var(--line);
    color: var(--ink);                  /* forza nero su tutta la card (era ereditato rosa dal tema padre) */
    text-decoration: none;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.course:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 40px rgba(143, 199, 224, 0.18);
    border-color: var(--accent);
}
/* Su hover, titolo e link "Scopri" diventano celeste accent */
.course:hover h3,
.course:hover .course-link { color: var(--accent); }
/* Reset stato base per evitare colore link rosa del tema padre */
.course h3,
.course-link,
.course .price { color: var(--ink); transition: color 0.25s ease; }
.course-cover {
    aspect-ratio: 5/4;
    position: relative;
    background: var(--paper-warm);
    border-bottom: 1px solid var(--line);
    overflow: hidden;
}
.course-cover .stripe-bg {
    position: absolute;
    inset: 0;
    background-image: repeating-linear-gradient(135deg, transparent 0 10px, rgba(0, 0, 0, 0.04) 10px 11px);
}
.course-cover .cv-art {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.course-cover .cv-tag {
    position: absolute;
    top: 16px; left: 16px;
    background: var(--paper);
    color: var(--ink);
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 11px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-weight: 600;
    border: 1px solid var(--ink);
}
.course-cover .cv-tag.accent { background: var(--accent); }
/* cv-meta — etichetta editoriale subito dopo la foto, sopra il titolo */
.course-body .cv-meta {
    display: block;
    font-family: var(--serif);
    font-style: italic;
    font-size: 13px;
    color: var(--muted);
    margin-bottom: 6px;
}
.course-body {
    padding: 22px 22px 24px;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.course h3 {
    font-family: var(--display);
    font-weight: 600;
    font-size: 24px;
    line-height: 1.1;
    letter-spacing: -0.02em;
    margin: 0 0 8px;
}
.course h3 em {
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
}
.course p {
    color: var(--muted);
    font-size: 14px;
    margin: 0 0 18px;
    flex: 1;
}
.course-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-top: 1px solid var(--line);
    padding-top: 16px;
    font-weight: 600;
    font-size: 14px;
}
.course-foot .price { color: var(--ink); }
.course-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.course-link .arrow { transition: transform 0.2s ease; }
.course:hover .course-link .arrow { transform: translateX(3px); }

/* Cover dei corsi (composizioni astratte) */
.cover-1 .blob {
    width: 70%; height: 70%;
    border-radius: 50%;
    background: var(--accent);
}
.cover-1 .ring {
    position: absolute;
    width: 40%; height: 40%;
    border-radius: 50%;
    border: 1.5px solid var(--ink);
    top: 18%; left: 16%;
}
.cover-2 .stack {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.cover-2 .stack > i {
    display: block;
    height: 18px;
    border-radius: 999px;
    background: var(--ink);
}
.cover-2 .stack > i:nth-child(1) { width: 120px; }
.cover-2 .stack > i:nth-child(2) { width: 160px; background: var(--accent); }
.cover-2 .stack > i:nth-child(3) { width: 90px; }
.cover-3 .pill-v {
    width: 90px; height: 160px;
    border-radius: 999px;
    background: var(--accent);
    position: relative;
}
.cover-3 .pill-v::after {
    content: "";
    position: absolute;
    left: 50%; top: 50%;
    width: 32px; height: 32px;
    border-radius: 50%;
    background: var(--ink);
    transform: translate(-50%, -50%);
}


/* ─────────── Social proof (testimonianza) ─────────── */
.social {
    padding: 48px 0;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    background: var(--paper-warm);
    overflow: hidden;
}
.social-inner {
    position: relative;
}
/* Carosello — scroll-snap orizzontale + frecce JS */
.social-carousel {
    position: relative;
}
.social-track {
    display: flex;
    gap: 32px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding: 4px 0 12px;
}
.social-track::-webkit-scrollbar { display: none; }
.social-track:focus { outline: none; }
.social-slide {
    flex: 0 0 100%;
    scroll-snap-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 18px;
    padding: 0 48px;
    text-align: center;
}
.social-slide .stars-mark {
    display: inline-flex;
    gap: 3px;
}
.social-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 42px; height: 42px;
    border-radius: 50%;
    background: var(--paper);
    border: 1px solid var(--line);
    color: var(--ink);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
    transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
    z-index: 2;
}
.social-nav:hover { background: var(--ink); color: #fff; }
.social-nav:disabled { opacity: 0.35; cursor: default; transform: translateY(-50%); }
.social-nav:disabled:hover { background: var(--paper); color: var(--ink); }
.social-prev { left: -8px; }
.social-next { right: -8px; }
@media (max-width: 720px) {
    .social-slide { padding: 0 12px; }
    .social-prev { left: 4px; }
    .social-next { right: 4px; }
    .social-nav { width: 36px; height: 36px; }
}
.social-dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 16px;
}
.social-dots button {
    width: 8px; height: 8px;
    border-radius: 50%;
    border: 0;
    background: var(--line);
    cursor: pointer;
    padding: 0;
    transition: background 0.18s ease, transform 0.18s ease;
}
.social-dots button[aria-current="true"] {
    background: var(--ink);
    transform: scale(1.3);
}
.stars {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    font-size: 16px;
    color: var(--ink);
}
.stars-mark { color: var(--accent-ink); }
.social-quote {
    font-family: var(--serif);
    font-style: italic;
    font-size: 22px;
    line-height: 1.4;
    color: var(--ink);
    margin: 0;
    max-width: 720px;
    min-width: 280px;
    text-wrap: balance;
    margin: 0;
}
.social-author {
    display: flex;
    align-items: center;
    gap: 12px;
}
.social-avatar {
    width: 40px; height: 40px;
    border-radius: 50%;
    background: var(--accent);
    border: 1px solid var(--ink);
    position: relative;
}
.social-avatar::after {
    content: "";
    position: absolute;
    inset: 6px;
    border-radius: 50%;
    background: var(--ink);
}
.social-name { font-weight: 600; font-size: 14px; }
.social-role { font-size: 13px; color: var(--muted); }


/* ─────────── Credenziali (attestati + albo diplomati) ─────────── */
.credentials {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 24px;
}
@media (max-width: 920px) { .credentials { grid-template-columns: 1fr; } }

.panel {
    border-radius: var(--radius);
    padding: 36px;
    background: var(--paper);
    border: 1px solid var(--line);
    position: relative;
}
.panel.dark {
    background: var(--ink);
    color: #fff;
    border-color: var(--ink);
}
.panel.dark .panel-sub { color: rgba(255, 255, 255, 0.65); }
.panel-eyebrow {
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 18px;
}
.panel.dark .panel-eyebrow { color: rgba(255, 255, 255, 0.55); }
.panel h3 {
    font-family: var(--display);
    font-weight: 600;
    font-size: 32px;
    line-height: 1.05;
    letter-spacing: -0.025em;
    margin: 0 0 16px;
}
.panel h3 em {
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
}
.panel-sub {
    color: var(--ink-soft);
    font-size: 15px;
    max-width: 460px;
}

.badges-list {
    list-style: none;
    padding: 0;
    margin: 28px 0 0;
    display: grid;
    gap: 14px;
}
.badge-row {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 0;
    border-top: 1px solid var(--line);
}
.badge-icon {
    width: 36px; height: 36px;
    border-radius: 50%;
    flex: 0 0 36px;
    background: var(--paper-warm);
    border: 1px solid var(--line);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--display);
    font-weight: 700;
    font-size: 13px;
}
.badge-icon.solid {
    background: var(--accent);
    border-color: var(--ink);
}
.badge-icon.has-logo {
    background: var(--paper);
    padding: 4px;
    overflow: hidden;
}
.badge-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}
.badge-name { font-weight: 600; font-size: 15px; }
.badge-meta { font-size: 13px; color: var(--muted); }
.badge-no {
    margin-left: auto;
    font-family: var(--display);
    font-weight: 500;
    color: var(--muted);
    font-size: 13px;
}

.albo-meta {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-top: 28px;
}
.albo-stat {
    padding: 22px;
    border-radius: var(--radius-sm);
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.15);
}
.albo-stat-num {
    font-family: var(--display);
    font-weight: 600;
    font-size: 44px;
    letter-spacing: -0.03em;
    line-height: 1;
}
.albo-stat-num em {
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
}
.albo-stat-lbl {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.6);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-top: 8px;
}
.albo-link {
    margin-top: 28px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 20px;
    border-radius: 999px;
    background: var(--accent);
    color: var(--ink);
    font-weight: 600;
    font-size: 14px;
}
.albo-link:hover { transform: translateY(-1px); }


/* ─────────── Calendar teaser (prossime date) ─────────── */
.calendar-wrap {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 28px;
    align-items: end;
}
@media (max-width: 920px) {
    .calendar-wrap { grid-template-columns: 1fr; }
}
.calendar-list {
    border-top: 1px solid var(--ink);
}
.cal-row {
    display: grid;
    grid-template-columns: 110px 1fr 140px 120px;
    align-items: center;
    gap: 24px;
    padding: 22px 0;
    border-bottom: 1px solid var(--line);
    transition: padding 0.2s ease, background 0.2s ease;
    position: relative;
}
.cal-row::before {
    content: "";
    position: absolute;
    left: -32px;
    top: 0; bottom: 0;
    width: 4px;
    background: var(--accent);
    opacity: 0;
    transition: opacity 0.2s ease;
}
.cal-row:hover { padding-left: 12px; }
.cal-row:hover::before { opacity: 1; }

@media (max-width: 720px) {
    .cal-row { grid-template-columns: 64px 1fr; gap: 14px; }
    .cal-cat, .cal-cta { display: none; }
}

.cal-date {
    font-family: var(--display);
    font-weight: 600;
    font-size: 14px;
    letter-spacing: -0.01em;
    display: flex;
    flex-direction: column;
}
.cal-day { font-size: 36px; line-height: 1; }
.cal-mo {
    font-size: 13px;
    color: var(--muted);
    margin-top: 4px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-weight: 500;
}
.cal-title {
    font-family: var(--display);
    font-weight: 500;
    font-size: 20px;
    letter-spacing: -0.015em;
}
.cal-loc { font-size: 13px; color: var(--muted); margin-top: 4px; }
.cal-cat {
    font-size: 12px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--ink-soft);
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.cal-cat::before {
    content: "";
    width: 10px; height: 10px;
    border-radius: 50%;
    background: var(--accent);
    display: inline-block;
}
.cal-cat.olistica::before  { background: #b8c2cc; }
.cal-cat.acquatica::before { background: #9ec9de; }
.cal-cta {
    text-align: right;
    font-weight: 600;
    font-size: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 6px;
}
.cal-cta .arrow { transition: transform 0.2s ease; }
.cal-row:hover .cal-cta .arrow { transform: translateX(3px); }

.cal-side {
    padding: 32px;
    border-radius: var(--radius);
    background: var(--accent);
    color: var(--ink);
    border: 1.5px solid var(--ink);
    align-self: stretch;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 260px;
}
@media (max-width: 720px) {
    .cal-side { padding: 22px; border-radius: 22px; min-height: auto; }
    .cal-side h4 { font-size: 22px; }
}
.cal-side h4 {
    font-family: var(--display);
    font-weight: 600;
    font-size: 28px;
    line-height: 1.05;
    letter-spacing: -0.02em;
    margin: 0 0 12px;
}
.cal-side h4 em {
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
}
.cal-side p { font-size: 14px; margin: 0; }


/* ─────────── About strip (chi siamo) ─────────── */
.about {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 64px;
    align-items: start;
}
@media (max-width: 920px) {
    .about { grid-template-columns: 1fr; gap: 32px; }
}
.about-tag {
    font-family: var(--serif);
    font-style: italic;
    font-size: 22px;
    color: var(--muted);
    line-height: 1.3;
}
.about-img {
    margin-top: 28px;
    border-radius: 16px;
    overflow: hidden;
}
.about-img img {
    display: block;
    width: 100%;
    height: auto;
    max-height: 380px;
    object-fit: cover;
}
.about h2 {
    font-family: var(--display);
    font-weight: 600;
    font-size: clamp(28px, 5.5vw, 52px);
    line-height: 1.08;
    letter-spacing: -0.03em;
    margin: 0 0 24px;
    text-wrap: balance;
}
.about h2 em {
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
}
.about h2 .hl {
    background: var(--accent);
    padding: 0 10px;
    border-radius: 12px;
    display: inline-block;
    transform: rotate(-1deg);
}
.about p {
    font-size: 17px;
    color: var(--ink-soft);
    line-height: 1.55;
    max-width: 600px;
}
.about-foot {
    margin-top: 28px;
    display: flex;
    gap: 20px;
    align-items: center;
    flex-wrap: wrap;
}
.signature {
    font-family: var(--serif);
    font-style: italic;
    font-size: 18px;
    color: var(--ink-soft);
    display: inline-flex;
    align-items: center;
    gap: 12px;
}
.signature::before {
    content: "";
    width: 36px;
    height: 1px;
    background: var(--ink-soft);
}


/* ─────────── Blog preview (ultime dal blog) ─────────── */
.blog-grid {
    display: grid;
    grid-template-columns: 1.3fr 1fr 1fr;
    gap: 20px;
}
@media (max-width: 920px) { .blog-grid { grid-template-columns: 1fr; } }

.post {
    display: flex;
    flex-direction: column;
    background: var(--paper);
    border-radius: var(--radius);
    overflow: hidden;
    border: 1px solid var(--line);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.post:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.06);
}
.post.feature { background: var(--paper-warm); }
.post-cover {
    aspect-ratio: 16/10;
    position: relative;
    border-bottom: 1px solid var(--line);
    overflow: hidden;
}
.post.feature .post-cover { aspect-ratio: 16/12; }
.post-cover .pc-art { position: absolute; inset: 0; }
.post-body {
    padding: 22px 22px 26px;
    flex: 1;
    display: flex;
    flex-direction: column;
}
@media (max-width: 720px) {
    .post-body { padding: 18px 18px 22px; }
    .post.feature h3 { font-size: 22px; }
}
.post-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
    font-size: 12px;
    color: var(--muted);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-weight: 500;
}
.post-meta::after {
    content: "";
    flex: 1;
    height: 1px;
    background: var(--line);
}
.post h3 {
    font-family: var(--display);
    font-weight: 600;
    font-size: 22px;
    line-height: 1.15;
    letter-spacing: -0.02em;
    margin: 0 0 8px;
    text-wrap: balance;
}
.post.feature h3 { font-size: 28px; }
.post h3 em {
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
}
.post p {
    font-size: 14px;
    color: var(--muted);
    margin: 0;
    flex: 1;
}
.post-read {
    margin-top: 16px;
    font-weight: 600;
    font-size: 13px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.post-read .arrow { transition: transform 0.2s ease; }
.post:hover .post-read .arrow { transform: translateX(3px); }

/* Cover degli articoli (composizioni astratte) */
.pc-1 { background: var(--paper); }
.pc-1 .d { position: absolute; width: 140px; height: 140px; border-radius: 50%; background: var(--accent); left: 30%; top: 25%; }
.pc-1 .r { position: absolute; width: 90px;  height: 90px;  border-radius: 50%; border: 1.5px solid var(--ink); left: 18%; top: 18%; }
.pc-1 .b { position: absolute; width: 60%; height: 12px; border-radius: 999px; background: var(--ink); right: 6%; bottom: 14%; transform: rotate(-6deg); }
.pc-2 { background: var(--paper-warm); }
.pc-2 .grid {
    position: absolute;
    inset: 20px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
}
.pc-2 .grid i { display: block; border-radius: 8px; background: var(--line); }
.pc-2 .grid i:nth-child(2) { background: var(--accent); }
.pc-2 .grid i:nth-child(5) { background: var(--ink); }
.pc-2 .grid i:nth-child(8) { background: var(--accent); opacity: 0.6; }
.pc-3 { background: var(--ink); }
.pc-3 .wave {
    position: absolute;
    left: 0; right: 0;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 0 20px;
}
.pc-3 .wave i {
    display: block;
    height: 8px;
    border-radius: 999px;
    background: var(--accent);
}
.pc-3 .wave i:nth-child(2) { width: 70%; background: rgba(255, 255, 255, 0.4); }
.pc-3 .wave i:nth-child(3) { width: 90%; }
.pc-3 .wave i:nth-child(4) { width: 50%; background: rgba(255, 255, 255, 0.6); }


/* ─────────── Footer (contatti + WhatsApp) ─────────── */
.footer {
    background: var(--ink);
    color: #fff;
    padding: 80px 0 0;
    margin-top: 60px;
}
.footer-top {
    display: grid;
    grid-template-columns: 1.3fr 1fr 1fr 1fr;
    gap: 32px;
    padding-bottom: 60px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}
@media (max-width: 920px) { .footer-top { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .footer-top { grid-template-columns: 1fr; } }

.footer h4 {
    font-family: var(--display);
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.55);
    margin: 0 0 18px;
}
.footer h2 {
    font-family: var(--display);
    font-weight: 600;
    font-size: 44px;
    line-height: 1;
    letter-spacing: -0.03em;
    margin: 0 0 18px;
    text-wrap: balance;
}
.footer h2 em {
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
}
.footer-tag {
    color: rgba(255, 255, 255, 0.7);
    font-size: 15px;
    max-width: 380px;
}
.footer ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.footer li a {
    font-size: 14px;
    color: rgba(255, 255, 255, 0.78);
    transition: color 0.18s ease;
}
.footer li a:hover { color: var(--accent); }

.wa-button {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px 14px 14px;
    border-radius: 999px;
    background: var(--accent);
    color: var(--ink);
    font-weight: 600;
    font-size: 15px;
    margin-top: 18px;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.wa-button:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(143, 199, 224, 0.3);
}
.wa-icon {
    width: 34px; height: 34px;
    border-radius: 50%;
    background: var(--ink);
    color: var(--accent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 16px;
}
.wa-icon svg {
    width: 20px;
    height: 20px;
    display: block;
}

/* Varianti responsive del pulsante WhatsApp:
   - .wa-button-claim   → visibile su mobile/tablet (≤ 920px), sotto il claim "Parliamone su WhatsApp."
   - .wa-button-contact → visibile su desktop (≥ 921px), dentro il box CONTATTO sotto l'indirizzo
   A ogni breakpoint un solo bottone è renderizzato, evitando duplicati visivi. */
.wa-button-contact { display: none; }
@media (min-width: 921px) {
    .wa-button-claim   { display: none; }
    .wa-button-contact { display: inline-flex; margin-top: 14px; }
}

.contact-line {
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-size: 14px;
    color: rgba(255, 255, 255, 0.78);
}
.contact-line b { color: #fff; font-weight: 500; }

.footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 28px 0;
    gap: 20px;
    flex-wrap: wrap;
    font-size: 12px;
    color: rgba(255, 255, 255, 0.5);
    letter-spacing: 0.04em;
}
.footer-bottom-marks { display: flex; gap: 20px; }

/* Maxi-tipografia decorativa in fondo al footer */
.mega {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(80px, 16vw, 240px);
    line-height: 0.85;
    letter-spacing: -0.05em;
    color: rgba(255, 255, 255, 0.06);
    text-align: center;
    padding: 40px 0 20px;
    user-select: none;
}
.mega em {
    font-family: var(--serif);
    font-style: italic;
    font-weight: 400;
    color: rgba(255, 255, 255, 0.1);
}


/* ─────────── Ticker (parole chiave scorrevoli) ─────────── */
.ticker {
    overflow: hidden;
    white-space: nowrap;
    display: flex;
    gap: 36px;
    align-items: center;
    padding: 14px 0;
    font-family: var(--display);
    font-weight: 500;
    font-size: 14px;
    letter-spacing: -0.01em;
    color: var(--ink);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    background: var(--paper);
}
.ticker-inner {
    display: inline-flex;
    gap: 36px;
    align-items: center;
    animation: marq 36s linear infinite;
}
.ticker-inner em {
    font-family: var(--serif);
    font-style: italic;
    color: var(--muted);
    font-weight: 400;
}
.ticker-inner .dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--accent-ink);
    display: inline-block;
}


/* ─────────── Animazione marquee condivisa ─────────── */
@keyframes marq {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}


/* ─────────── Banner scorrevole loghi affiliazioni (tra macro-aree e corsi) ─────────── */
.logos-marquee {
    background: var(--paper-warm);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    padding: 10px 0;
    overflow: hidden;
    white-space: nowrap;
}
/* Varianti di sfondo del banner scorrevole (controllabili da ACF). */
.logos-marquee-bg-white  { background: var(--paper); }
.logos-marquee-bg-warm   { background: var(--paper-warm); }
.logos-marquee-bg-ink    {
    background: var(--ink);
    border-top-color: var(--ink);
    border-bottom-color: var(--ink);
}
.logos-marquee-bg-ink .logos-marquee-text,
.logos-marquee-bg-ink .logos-marquee-text small { color: rgba(255,255,255,0.85); }
.logos-marquee-bg-accent {
    background: var(--accent);
    border-top-color: var(--ink);
    border-bottom-color: var(--ink);
}
.logos-marquee-bg-accent .logos-marquee-text,
.logos-marquee-bg-accent .logos-marquee-text small { color: var(--ink); }
.logos-marquee-inner {
    display: inline-flex;
    align-items: center;
    gap: 40px;
    animation: marq 60s linear infinite;
    padding-left: 40px;
}
.logos-marquee-item {
    display: inline-flex;
    align-items: center;
    height: 30px;
    flex-shrink: 0;
}
.logos-marquee-item img {
    max-height: 30px;
    width: auto;
    display: block;
    object-fit: contain;
}
.logos-marquee-text {
    display: inline-flex;
    align-items: baseline;
    gap: 6px;
    font-family: var(--display);
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--muted);
}
.logos-marquee-text small {
    font-family: var(--body);
    font-weight: 400;
    font-size: 11px;
    letter-spacing: 0;
    text-transform: none;
    color: var(--muted);
}


/* ─────────── Corsivo celeste — tutti i titoli/testi editoriali ───────────
 * Le parole tra *asterischi* vengono convertite in <em> da ans_format_inline().
 * Le regole base (font-family/italic/font-weight) sono già definite per ogni
 * sezione: qui aggiungiamo solo il colore accent in modo centralizzato.
 * Esclusi volutamente: .ticker-inner em (grigio voluto) e .mega em (bianco trasparente).
 */
.section-title em,
.macro h3 em,
.course h3 em,
.panel h3 em,
.albo-stat-num em,
.about h2 em,
.post h3 em,
.footer h2 em,
.hero h1 em,
.hero-sub em {
    color: var(--accent);
}

/* Card laterale "Come funziona?" → sfondo celeste,
   quindi gli *asterischi* devono diventare BIANCHI per essere visibili. */
.cal-side em {
    color: #fff;
    font-weight: 500;
}


/* ─────────── Tesserino — banner rinnovo/equiparazione ─────────── */
/* Sezione informativa subito sopra al blog. Layout a 2 colonne:
   copy a sinistra (titolo + descrizione), card scura a destra
   (badge + prezzo + validità + CTA). Su mobile diventa colonna unica.
   Lo sfondo è gestito dalle classi .section-bg-* (white/warm/accent)
   pilotate dal campo ACF "tesserino_sfondo". */
.tesserino-wrap {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(280px, 1fr);
    gap: 48px;
    align-items: center;
}
@media (max-width: 920px) {
    .tesserino-wrap { grid-template-columns: 1fr; gap: 32px; }
}

.tesserino-copy .section-kicker { color: var(--ink-soft); }
.tesserino-copy .section-title  { max-width: 560px; margin-bottom: 16px; }

/* Override contrasto su sfondo celeste: il corsivo del titolo è già celeste
   accent, quindi su sfondo accent diventa invisibile -> lo porto a bianco. */
.section-tesserino.section-bg-accent .section-title em { color: #fff; font-weight: 500; }
.tesserino-desc {
    font-family: var(--display);
    font-size: clamp(15px, 1.4vw, 17px);
    line-height: 1.55;
    color: var(--ink-soft);
    margin: 0;
    max-width: 560px;
}

/* Card prezzo/CTA — stile scuro coerente col pannello "Albo diplomati" */
.tesserino-card {
    background: var(--ink);
    color: #fff;
    border-radius: 18px;
    padding: 32px 28px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    border: 1px solid var(--ink);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.08);
}
.tesserino-badge {
    display: inline-block;
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--accent);
    background: rgba(143, 199, 224, 0.12);
    border: 1px solid rgba(143, 199, 224, 0.35);
    padding: 6px 10px;
    border-radius: 999px;
    margin-bottom: 8px;
}
.tesserino-prezzo {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(40px, 5vw, 56px);
    line-height: 1;
    letter-spacing: -0.02em;
    color: #fff;
}
.tesserino-validita {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.7);
    margin-bottom: 18px;
}
.tesserino-cta {
    margin-top: 4px;
    align-self: stretch;
    justify-content: center;
}
@media (max-width: 480px) {
    .tesserino-card { padding: 24px 20px; }
}


/* ─────────── BLSD — corso trasversale obbligatorio ─────────── */
/* Strip orizzontale con icona cuore a sinistra, copy+meta al centro,
   prezzo+CTA a destra. Sfondo bianco con bordi netti — si stacca dalla
   sezione Tesserino (sfondo grigio chiaro) che la segue. */
.section-blsd {
    background: var(--paper);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}
.blsd-wrap {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 36px;
    align-items: center;
}
@media (max-width: 920px) {
    .blsd-wrap { grid-template-columns: 1fr; gap: 24px; text-align: left; }
}

.blsd-icon {
    color: var(--accent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 88px;
    height: 88px;
    border-radius: 50%;
    background: rgba(143, 199, 224, 0.10);
    border: 1px solid var(--line);
    flex-shrink: 0;
}
@media (max-width: 920px) {
    .blsd-icon { width: 64px; height: 64px; }
    .blsd-icon svg { width: 40px; height: 40px; }
}

.blsd-copy .section-kicker { color: var(--accent); margin-bottom: 8px; }
.blsd-copy .section-title  {
    font-size: clamp(24px, 3.4vw, 36px);
    margin: 0 0 10px;
    max-width: 620px;
}
.blsd-desc {
    font-size: clamp(14px, 1.3vw, 16px);
    line-height: 1.55;
    color: var(--ink-soft);
    margin: 0 0 16px;
    max-width: 620px;
}

/* Meta riga: durata · validità · ente */
.blsd-meta {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 18px 28px;
}
.blsd-meta li {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}
.blsd-meta-lbl {
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--muted);
}
.blsd-meta-val {
    font-size: 14px;
    font-weight: 600;
    color: var(--ink);
}

/* Colonna destra: prezzo placeholder + CTA */
.blsd-action {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 12px;
    flex-shrink: 0;
}
@media (max-width: 920px) {
    .blsd-action { align-items: flex-start; }
}
.blsd-prezzo {
    font-family: var(--display);
    font-weight: 700;
    font-size: clamp(22px, 2.4vw, 28px);
    line-height: 1;
    letter-spacing: -0.02em;
    color: var(--ink);
}
.blsd-cta { white-space: nowrap; }


/* ─────────── Coming Soon / 404 — pagina in costruzione ─────────── */
/* Sezione mostrata su:
   - 404 (URL inesistenti, es. /fitness prima che la pagina esista)
   - Pagine che usano il template "In Costruzione"
   Layout centrato verticalmente, icona decorativa + copy + 2 CTA. */
.section-coming-soon {
    background: var(--paper-warm);
    min-height: calc(100vh - 320px);          /* riempie viewport meno header/footer */
    display: flex;
    align-items: center;
    padding-top: 80px;
    padding-bottom: 80px;
}
@media (max-width: 720px) {
    .section-coming-soon { min-height: auto; padding-top: 48px; padding-bottom: 48px; }
}

.coming-soon-wrap {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 40px;
    align-items: center;
    max-width: 880px;
    margin: 0 auto;
}
@media (max-width: 720px) {
    .coming-soon-wrap { grid-template-columns: 1fr; gap: 20px; text-align: left; }
}

.coming-soon-icon {
    color: var(--accent);
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: rgba(143, 199, 224, 0.12);
    border: 1px solid var(--line);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
@media (max-width: 720px) {
    .coming-soon-icon { width: 80px; height: 80px; }
    .coming-soon-icon svg { width: 48px; height: 48px; }
}

.coming-soon-copy .section-kicker {
    color: var(--accent);
    margin-bottom: 12px;
}
.coming-soon-copy .section-title {
    margin: 0 0 16px;
    max-width: 560px;
}

.coming-soon-sub {
    font-family: var(--display);
    font-size: clamp(15px, 1.4vw, 17px);
    font-weight: 500;
    line-height: 1.45;
    color: var(--ink);
    margin: 0 0 12px;
    max-width: 560px;
}
.coming-soon-msg {
    font-size: clamp(14px, 1.2vw, 15px);
    line-height: 1.6;
    color: var(--ink-soft);
    margin: 0 0 24px;
    max-width: 560px;
}

.coming-soon-cta {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
