
/* ============================================================
   TOKEN DI DESIGN
   ============================================================ */
:root {
    --notte: #0B0E14;
    --superficie: #12161F;
    --superficie-alta: #181D29;
    --bordo: #232938;
    --carta: #F5F3ED;
    --carta-soft: #B8BAC2;
    --corallo: #FF6B35;
    --corallo-soft: rgba(255, 107, 53, 0.15);
    --menta: #3DDC97;
    --menta-soft: rgba(61, 220, 151, 0.15);

    --font-display: 'Fraunces', Georgia, serif;
    --font-body: 'Inter', -apple-system, sans-serif;
    --font-mono: 'JetBrains Mono', 'Courier New', monospace;

    --radius: 6px;
    --max-width: 1140px;
    --ease: cubic-bezier(0.16, 1, 0.3, 1);
}

* { box-sizing: border-box; }
img { max-width: 100%; display: block; }

/* ============================================================
   TEMA CHIARO PER PAGINE SPECIFICHE (es. consulenza-lampo)
   Si attiva con <body class="page-light">. Ribalta le variabili
   di colore: tutto il resto del sito (componenti, layout) resta
   identico, perché ogni regola usa già queste variabili.
   ============================================================ */
body.page-light {
    --notte: #FAFAF8;
    --superficie: #FFFFFF;
    --superficie-alta: #F3F1EC;
    --bordo: #E2DFD6;
    --carta: #1A1D24;
    --carta-soft: #5C5F68;
    --corallo: #E2552B;
    --corallo-soft: rgba(226, 85, 43, 0.1);
    --menta: #1E9E68;
    --menta-soft: rgba(30, 158, 104, 0.1);
}
body.page-light .site-header {
    background: rgba(250, 250, 248, 0.9);
    border-bottom-color: var(--bordo);
}
body.page-light .nav-cta { color: #ffffff !important; }
body.page-light .btn-primary { color: #ffffff; }
body.page-light .hero-photo,
body.page-light .step-card,
body.page-light .payment-box,
body.page-light .price-badge-xl,
body.page-light .floating-badge,
body.page-light .cta-finale {
    box-shadow: 0 8px 24px -8px rgba(0,0,0,0.08);
}
body.page-light .btn-stripe {
    background: var(--carta);
    color: #ffffff;
    border-color: var(--carta);
}
body.page-light .btn-stripe:hover { background: #000; }
html { scroll-behavior: smooth; }

@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; }
}

body {
    margin: 0;
    font-family: var(--font-body);
    background: var(--notte);
    color: var(--carta);
    line-height: 1.6;
    font-size: 17px;
    overflow-x: hidden;
}

h1, h2, h3, h4 {
    font-family: var(--font-display);
    color: var(--carta);
    line-height: 1.1;
    margin: 0 0 0.6em;
    font-weight: 600;
}

a { color: var(--corallo); text-decoration: none; }

.skip-link { position: absolute; left: -999px; top: 0; }
.skip-link:focus {
    left: 1rem; top: 1rem; background: var(--corallo); color: var(--notte);
    padding: 0.5rem 1rem; z-index: 999; border-radius: var(--radius);
}
:focus-visible { outline: 2px solid var(--corallo); outline-offset: 3px; }

.wrap { max-width: var(--max-width); margin: 0 auto; padding: 0 1.5rem; }

/* ============================================================
   WAVEFORM — elemento firma, ricorrente, reagisce allo scroll
   ============================================================ */
.waveform {
    display: flex;
    align-items: center;
    gap: 3px;
    height: 28px;
}
.waveform span {
    width: 3px;
    background: var(--corallo);
    border-radius: 2px;
    display: block;
    animation: onda 1.2s ease-in-out infinite;
}
.waveform span:nth-child(1) { height: 30%; animation-delay: -1.1s; }
.waveform span:nth-child(2) { height: 70%; animation-delay: -0.9s; }
.waveform span:nth-child(3) { height: 45%; animation-delay: -0.7s; }
.waveform span:nth-child(4) { height: 90%; animation-delay: -0.5s; }
.waveform span:nth-child(5) { height: 55%; animation-delay: -0.3s; }
.waveform span:nth-child(6) { height: 75%; animation-delay: -0.15s; }
.waveform span:nth-child(7) { height: 35%; animation-delay: 0s; }
@keyframes onda {
    0%, 100% { transform: scaleY(0.4); opacity: 0.6; }
    50% { transform: scaleY(1); opacity: 1; }
}

/* ============================================================
   HEADER
   ============================================================ */
.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(11, 14, 20, 0.85);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--bordo);
}
.header-inner {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0.9rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.logo {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 1.05rem;
    color: var(--carta);
}
.main-nav ul {
    list-style: none;
    display: flex;
    gap: 1.8rem;
    margin: 0;
    padding: 0;
}
.main-nav a {
    color: var(--carta-soft);
    font-weight: 500;
    font-size: 0.85rem;
    letter-spacing: 0.02em;
    transition: color 0.2s var(--ease);
}
.main-nav a:hover { color: var(--corallo); }
.nav-cta {
    background: var(--corallo);
    color: var(--notte) !important;
    padding: 0.55rem 1.2rem;
    border-radius: var(--radius);
    font-weight: 600;
}
.nav-toggle { display: none; background: none; border: 1px solid var(--bordo); color: var(--carta); border-radius: var(--radius); font-size: 1.2rem; padding: 0.3rem 0.7rem; cursor: pointer; }

@media (max-width: 780px) {
    .nav-toggle { display: block; }
    .main-nav { position: absolute; right: 1.5rem; top: 64px; }
    .main-nav ul {
        display: none; flex-direction: column; background: var(--superficie);
        border: 1px solid var(--bordo); border-radius: var(--radius);
        padding: 1.2rem 1.5rem; gap: 1rem;
    }
    .main-nav ul.open { display: flex; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
    position: relative;
    padding: 6rem 1.5rem 5rem;
    text-align: center;
    overflow: hidden;
}
.hero-glow {
    position: absolute;
    top: -200px;
    left: 50%;
    transform: translateX(-50%);
    width: 800px;
    height: 500px;
    background: radial-gradient(circle, rgba(255,107,53,0.18) 0%, transparent 70%);
    pointer-events: none;
    z-index: 0;
}
.hero-content { position: relative; z-index: 1; max-width: 760px; margin: 0 auto; }
.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    font-family: var(--font-mono);
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--menta);
    background: var(--menta-soft);
    border: 1px solid rgba(61,220,151,0.3);
    padding: 0.4rem 0.9rem;
    border-radius: 999px;
    margin-bottom: 1.8rem;
}
.eyebrow-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--menta); animation: pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }

.hero h1 {
    font-size: clamp(2.4rem, 6vw, 4.2rem);
    margin-bottom: 1.2rem;
}
.hero h1 .accent { color: var(--corallo); font-style: italic; }
.hero-sub {
    font-size: 1.15rem;
    color: var(--carta-soft);
    max-width: 540px;
    margin: 0 auto 2.2rem;
}
.hero-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; margin-bottom: 2.5rem; }

.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.85rem 1.7rem;
    border-radius: var(--radius);
    font-weight: 600;
    font-size: 0.95rem;
    cursor: pointer;
    border: 1.5px solid transparent;
    transition: transform 0.2s var(--ease), background 0.2s var(--ease), border-color 0.2s var(--ease);
}
.btn-primary { background: var(--corallo); color: var(--notte); }
.btn-primary:hover { transform: translateY(-2px); background: #FF7E4D; }
.btn-outline { background: transparent; color: var(--carta); border-color: var(--bordo); }
.btn-outline:hover { border-color: var(--corallo); color: var(--corallo); transform: translateY(-2px); }

.hero-waveform { display: flex; justify-content: center; opacity: 0.7; }
.hero-waveform .waveform { height: 36px; gap: 4px; }
.hero-waveform .waveform span { width: 4px; }

/* ============================================================
   REVEAL ON SCROLL
   ============================================================ */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.7s var(--ease), transform 0.7s var(--ease); }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1.visible { transition-delay: 0.1s; }
.reveal-delay-2.visible { transition-delay: 0.2s; }
.reveal-delay-3.visible { transition-delay: 0.3s; }

/* ============================================================
   SEZIONI GENERALI
   ============================================================ */
.section { max-width: var(--max-width); margin: 0 auto; padding: 5rem 1.5rem; }
.section-label {
    font-family: var(--font-mono);
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--corallo);
    margin-bottom: 0.8rem;
    display: block;
}
.section h2 { font-size: clamp(1.7rem, 4vw, 2.6rem); max-width: 600px; }
.section-intro { color: var(--carta-soft); max-width: 540px; font-size: 1.05rem; margin-bottom: 2.5rem; }

blockquote {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.5rem;
    color: var(--carta);
    border-left: 3px solid var(--corallo);
    padding-left: 1.5rem;
    margin: 2rem 0;
}

/* ---------- Servizi a card ---------- */
.servizi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.2rem;
    margin-top: 2rem;
}
.servizio-card {
    background: var(--superficie);
    border: 1px solid var(--bordo);
    border-radius: 12px;
    padding: 1.8rem;
    transition: border-color 0.3s var(--ease), transform 0.3s var(--ease);
}
.servizio-card:hover { border-color: var(--corallo); transform: translateY(-4px); }
.servizio-icon {
    width: 42px; height: 42px; border-radius: var(--radius);
    background: var(--corallo-soft);
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 1.2rem;
    color: var(--corallo);
    font-family: var(--font-mono);
    font-weight: 600;
}
.servizio-card h3 { font-size: 1.15rem; margin-bottom: 0.5rem; }
.servizio-card p { color: var(--carta-soft); font-size: 0.95rem; margin: 0; }

/* ---------- Libri ---------- */
.libri-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.5rem;
    margin-top: 2rem;
}
.libro-card {
    background: var(--superficie);
    border: 1px solid var(--bordo);
    border-radius: 12px;
    overflow: hidden;
    transition: transform 0.3s var(--ease), border-color 0.3s var(--ease);
    display: block;
}
.libro-card:hover { transform: translateY(-4px); border-color: var(--corallo); }
.libro-cover {
    aspect-ratio: 3/4;
    width: 100%;
    background: var(--superficie-alta);
    border-bottom: 1px solid var(--bordo);
    position: relative;
    overflow: hidden;
    display: block;
}
.libro-cover img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
    transition: transform 0.4s var(--ease);
}
.libro-card:hover .libro-cover img { transform: scale(1.04); }
.libro-card .libro-info { padding: 1.2rem; }
.libro-card h3 { font-size: 1rem; margin-bottom: 0.3rem; }
.libro-card p { font-size: 0.85rem; color: var(--carta-soft); margin: 0; }

/* ---------- Numeri / metriche ---------- */
.metriche {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1.5rem;
    margin-top: 2rem;
    padding: 2rem;
    background: var(--superficie);
    border: 1px solid var(--bordo);
    border-radius: 12px;
}
.metrica { text-align: center; }
.metrica .num { font-family: var(--font-display); font-size: 2.4rem; font-weight: 600; color: var(--corallo); display: block; }
.metrica .lbl { font-size: 0.85rem; color: var(--carta-soft); }

/* ---------- CTA finale ---------- */
.cta-finale {
    background: linear-gradient(135deg, var(--superficie), var(--superficie-alta));
    border: 1px solid var(--bordo);
    border-radius: 16px;
    padding: 3.5rem 2rem;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.cta-finale::before {
    content: '';
    position: absolute; top: -50%; right: -10%;
    width: 400px; height: 400px;
    background: radial-gradient(circle, rgba(255,107,53,0.15), transparent 70%);
}
.cta-finale h2 { position: relative; z-index: 1; margin: 0 auto 1rem; }
.cta-finale p { position: relative; z-index: 1; color: var(--carta-soft); max-width: 480px; margin: 0 auto 1.8rem; }
.cta-finale .hero-actions { position: relative; z-index: 1; margin-bottom: 0; }

/* ============================================================
   FORM CONTATTI
   ============================================================ */
.form-section {
    background: var(--superficie);
    border: 1px solid var(--bordo);
    border-radius: 16px;
    padding: 2.5rem;
    max-width: 560px;
    margin: 2rem auto 0;
}
label { font-weight: 600; font-size: 0.85rem; display: block; margin: 1.1rem 0 0.4rem; color: var(--carta); }
input[type=text], input[type=email], input[type=tel], textarea {
    width: 100%;
    font-family: var(--font-body);
    font-size: 0.95rem;
    padding: 0.7rem 0.9rem;
    border: 1px solid var(--bordo);
    border-radius: var(--radius);
    background: var(--notte);
    color: var(--carta);
}
input:focus, textarea:focus { border-color: var(--corallo); outline: none; }
.consenso-label {
    display: flex; align-items: flex-start; gap: 0.6rem;
    font-weight: 400; font-size: 0.85rem; color: var(--carta-soft);
    margin-top: 1.3rem;
}
.consenso-label input { margin-top: 0.2rem; width: auto; }
.form-section button { margin-top: 1.4rem; width: 100%; justify-content: center; }
.form-esito { font-weight: 600; margin-top: 0.9rem; font-size: 0.9rem; }
.form-esito.success { color: var(--menta); }
.form-esito.error { color: var(--corallo); }

/* ============================================================
   FOOTER + COOKIE BANNER (requisiti Meta/GDPR)
   ============================================================ */
.site-footer { background: var(--superficie); border-top: 1px solid var(--bordo); margin-top: 4rem; }
.footer-inner {
    max-width: var(--max-width); margin: 0 auto; padding: 3rem 1.5rem;
    display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 2rem;
}
.footer-col h3 { color: var(--carta); font-family: var(--font-body); font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.04em; margin-top: 0; }
.footer-col p { color: var(--carta-soft); font-size: 0.9rem; }
.footer-links { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.6rem; }
.footer-links a, .footer-col a { color: var(--carta-soft); font-size: 0.9rem; }
.footer-links a:hover, .footer-col a:hover { color: var(--corallo); }
.footer-col > a { display: block; margin-bottom: 0.6rem; }
.footer-col > a:last-child { margin-bottom: 0; }
.footer-bottom {
    border-top: 1px solid var(--bordo); text-align: center; padding: 1.2rem;
    font-size: 0.8rem; color: var(--carta-soft);
}

.cookie-banner {
    position: fixed; bottom: 0; left: 0; right: 0;
    background: var(--superficie-alta);
    border-top: 1px solid var(--corallo);
    color: var(--carta);
    padding: 1.2rem 1.5rem;
    display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
    gap: 1rem; z-index: 999;
    transform: translateY(100%);
    transition: transform 0.4s var(--ease);
}
.cookie-banner.show { transform: translateY(0); }
.cookie-banner p { margin: 0; max-width: 600px; font-size: 0.85rem; color: var(--carta-soft); }
.cookie-banner a { color: var(--corallo); }
.cookie-actions { display: flex; gap: 0.7rem; flex-shrink: 0; }
.cookie-actions .btn { padding: 0.6rem 1.2rem; font-size: 0.85rem; }

@media (max-width: 780px) {
    .footer-inner { grid-template-columns: 1fr; }
    .hero-actions { flex-direction: column; align-items: stretch; }
}

/* ============================================================
   PAGINE DI VENDITA (consulenza-lampo, consulenza-ai)
   ============================================================ */

.offer-hero {
    position: relative;
    padding: 5rem 1.5rem 3rem;
    text-align: center;
    overflow: hidden;
}
.price-badge {
    display: inline-flex;
    align-items: baseline;
    gap: 0.4rem;
    background: var(--superficie);
    border: 1px solid var(--bordo);
    border-radius: 999px;
    padding: 0.7rem 1.6rem;
    margin: 1.5rem 0;
}
.price-badge .price-num {
    font-family: var(--font-display);
    font-size: 2rem;
    font-weight: 700;
    color: var(--corallo);
}
.price-badge .price-unit { color: var(--carta-soft); font-size: 0.9rem; }

.price-badge-xl {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.2rem;
    background: linear-gradient(135deg, var(--superficie-alta), var(--superficie));
    border: 1.5px solid var(--corallo);
    border-radius: 20px;
    padding: 1.6rem 2.2rem;
    margin: 1.8rem 0;
    position: relative;
    overflow: hidden;
}
.price-badge-xl::before {
    content: '';
    position: absolute; top: -50%; right: -20%;
    width: 220px; height: 220px;
    background: radial-gradient(circle, rgba(255,107,53,0.25), transparent 70%);
}
.price-num-xl {
    font-family: var(--font-display);
    font-size: clamp(3rem, 7vw, 4.5rem);
    font-weight: 700;
    line-height: 1;
    color: var(--corallo);
    position: relative;
    z-index: 1;
}
.price-badge-xl .price-unit {
    font-size: 0.95rem;
    color: var(--carta-soft);
    position: relative;
    z-index: 1;
}

.scarcity {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--font-mono);
    font-size: 0.75rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--corallo);
    background: var(--corallo-soft);
    border: 1px solid rgba(255,107,53,0.3);
    padding: 0.4rem 0.9rem;
    border-radius: 999px;
    margin-bottom: 1.2rem;
}

/* ---------- Step numerati (qui ha senso: è un vero processo in 3 passi) ---------- */
.steps-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.2rem;
    margin: 2.5rem 0;
}
.step-card {
    background: var(--superficie);
    border: 1px solid var(--bordo);
    border-radius: 12px;
    padding: 1.8rem;
    position: relative;
    transition: border-color 0.3s var(--ease), transform 0.3s var(--ease);
}
.step-card:hover { border-color: var(--corallo); transform: translateY(-3px); }
.step-num {
    font-family: var(--font-display);
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--notte);
    background: var(--corallo);
    width: 30px; height: 30px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 1rem;
}
.step-card h3 { font-size: 1.05rem; margin-bottom: 0.4rem; }
.step-card p { color: var(--carta-soft); font-size: 0.9rem; margin: 0; }

/* ---------- Box pagamento ---------- */
.payment-box {
    background: var(--superficie);
    border: 1px solid var(--bordo);
    border-radius: 16px;
    padding: 2.2rem;
    max-width: 480px;
    margin: 2rem auto 0;
    text-align: center;
}
.payment-box .payment-label {
    font-family: var(--font-mono);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--menta);
    margin-bottom: 0.6rem;
    display: block;
}

/* ---------- Mini-form "Richiedi call gratuita" + alternativa WhatsApp ---------- */
.call-gratuita-layout {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 1.6rem;
    align-items: start;
    margin-top: 1.5rem;
}
.call-gratuita-alternativa {
    background: var(--superficie);
    border: 1px solid var(--bordo);
    border-radius: 16px;
    padding: 1.8rem;
    text-align: center;
    align-self: stretch;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.call-gratuita-alternativa .payment-label {
    font-family: var(--font-mono);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--menta);
    margin-bottom: 0.6rem;
    display: block;
}

@media (max-width: 860px) {
    .call-gratuita-layout { grid-template-columns: 1fr; }
}
.payment-methods {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    margin-top: 1.4rem;
}
.btn-paypal {
    background: #FFC439;
    color: #142C8E;
    border-color: #FFC439;
    justify-content: center;
    font-weight: 700;
}
.btn-paypal:hover { background: #ffcf5c; transform: translateY(-2px); }
.btn-stripe {
    background: var(--carta);
    color: var(--notte);
    border-color: var(--carta);
    justify-content: center;
    font-weight: 700;
}
.btn-stripe:hover { background: #fff; transform: translateY(-2px); }
.payment-note { font-size: 0.8rem; color: var(--carta-soft); margin-top: 1rem; }
.payment-note a { color: var(--carta-soft); text-decoration: underline; }

.calendar-embed-wrap {
    background: var(--superficie);
    border: 1px solid var(--bordo);
    border-radius: 16px;
    padding: 1.5rem;
    max-width: 720px;
    margin: 2rem auto 0;
}
.calendar-embed-wrap iframe { width: 100%; min-height: 600px; border: none; border-radius: 8px; }

/* Isola bianca per il calendario Google: il resto della pagina resta dark
   come tutte le altre pagine del sito, ma qui dentro forziamo sempre lo
   sfondo chiaro così il testo di Google Calendar resta sempre leggibile,
   indipendentemente dal tema scuro di sistema/browser dell'utente. */
.calendar-white-area {
    background: #ffffff !important;
    border-radius: 20px;
    padding: 1.8rem;
    max-width: 760px;
    margin: 2rem auto 0;
    box-shadow: 0 30px 60px -20px rgba(0,0,0,0.5);
    color-scheme: light;
}
.calendar-white-area .calendar-embed-wrap {
    background: transparent;
    border: none;
    padding: 0;
    margin: 0;
    max-width: none;
}
.calendar-white-area iframe {
    background: #ffffff !important;
    color-scheme: light;
    border-radius: 12px;
}

.benefit-list { list-style: none; padding: 0; margin: 1.5rem 0; display: grid; gap: 0.8rem; }
.benefit-list li {
    display: flex; align-items: flex-start; gap: 0.7rem;
    color: var(--carta-soft); font-size: 0.98rem;
}
.benefit-list .check {
    color: var(--menta); font-weight: 700; flex-shrink: 0;
    background: var(--menta-soft); width: 22px; height: 22px;
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    font-size: 0.75rem; margin-top: 0.1rem;
}

.audience-tags { display: flex; flex-wrap: wrap; gap: 0.6rem; margin: 1.5rem 0; }
.audience-tag {
    background: var(--superficie); border: 1px solid var(--bordo);
    color: var(--carta-soft); font-size: 0.85rem;
    padding: 0.5rem 1rem; border-radius: 999px;
}

/* ============================================================
   PAGINA LIBRI (editoriale, più calma)
   ============================================================ */
.editorial-section { max-width: 720px; margin: 0 auto; padding: 4rem 1.5rem; }
.editorial-section p.lead { font-size: 1.2rem; color: var(--carta-soft); }

.copertine-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 1.1rem;
    margin: 1.5rem 0 2rem;
}
.copertina {
    aspect-ratio: 2/3;
    background: var(--superficie-alta);
    border: 1px solid var(--bordo);
    border-radius: 10px;
    overflow: hidden;
    display: block;
    position: relative;
    transition: transform 0.3s var(--ease), border-color 0.3s var(--ease);
}
.copertina img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.copertina:hover { transform: translateY(-4px) rotate(-1deg); border-color: var(--corallo); }

.process-list { list-style: none; padding: 0; margin: 1.5rem 0; display: grid; gap: 0.9rem; }
.process-list li {
    display: flex; align-items: flex-start; gap: 0.8rem;
    color: var(--carta-soft); font-size: 1rem; padding-bottom: 0.9rem;
    border-bottom: 1px solid var(--bordo);
}
.process-list .check {
    color: var(--menta); flex-shrink: 0; margin-top: 0.15rem;
}

.tipologie-pills { display: flex; flex-wrap: wrap; gap: 0.6rem; margin-top: 1.5rem; }
.tipologia-pill {
    background: var(--superficie); border: 1px solid var(--bordo);
    color: var(--carta); font-size: 0.85rem;
    padding: 0.55rem 1.1rem; border-radius: var(--radius);
}

/* ---------- WhatsApp pill (usato in consulenza-ai) ---------- */
.btn-whatsapp {
    background: #25D366;
    color: #06210F;
    border-color: #25D366;
    font-weight: 700;
}
.btn-whatsapp:hover { background: #2eea75; transform: translateY(-2px); }

/* ============================================================
   PAGINE LEGALI (Privacy Policy, Termini, Note Legali)
   ============================================================ */
.legal-page { max-width: 760px; }
.legal-update { color: var(--carta-soft); font-style: italic; margin-bottom: 2rem; font-size: 0.9rem; }
.legal-page h2 { font-size: 1.4rem; margin-top: 2.2em; }
.legal-page ul { color: var(--carta-soft); }
.legal-page li { margin-bottom: 0.4rem; }
.legal-table {
    width: 100%;
    border-collapse: collapse;
    margin: 1rem 0 2rem;
    background: var(--superficie);
    border-radius: 8px;
    overflow: hidden;
}
.legal-table th, .legal-table td {
    border: 1px solid var(--bordo);
    padding: 0.7rem 1rem;
    text-align: left;
    vertical-align: top;
    color: var(--carta-soft);
}
.legal-table th { background: var(--superficie-alta); color: var(--carta); font-weight: 600; }
address { font-style: normal; line-height: 1.8; margin-bottom: 1.5rem; color: var(--carta-soft); }
address strong { color: var(--carta); }

/* ============================================================
   HERO con foto reale (home + pagine interne)
   ============================================================ */
.hero-grid {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: 3rem;
    align-items: center;
    text-align: left;
    padding: 4.5rem 1.5rem 2rem;
}
.hero-grid .hero-content { margin: 0; max-width: none; }
.hero-grid .hero-sub { margin: 0 0 2rem; }
.hero-grid .hero-actions { justify-content: flex-start; }

.hero-stats { display: flex; gap: 2rem; margin-top: 0.5rem; }
.hero-stat { display: flex; flex-direction: column; }
.hero-stat .n { font-family: var(--font-display); font-size: 1.7rem; font-weight: 700; color: var(--carta); }
.hero-stat .l { font-size: 0.78rem; color: var(--carta-soft); }

.hero-art { position: relative; height: 460px; display: flex; align-items: center; justify-content: center; }
.hero-photo-wrap { position: relative; width: 340px; height: 420px; }
.hero-photo {
    width: 100%; height: 100%;
    object-fit: cover;
    border-radius: 28px;
    border: 1px solid var(--bordo);
    position: relative; z-index: 2;
    box-shadow: 0 30px 60px -20px rgba(0,0,0,0.6);
}
.hero-ring {
    position: absolute;
    top: -22px; left: -22px; right: -22px; bottom: -22px;
    border: 1.5px dashed var(--bordo);
    border-radius: 40px;
    animation: spin 18s linear infinite;
    z-index: 1;
}
.floating-badge {
    position: absolute;
    display: flex; align-items: center; gap: 0.5rem;
    background: var(--superficie-alta);
    border: 1px solid var(--bordo);
    border-radius: 999px;
    padding: 0.6rem 1rem;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--carta);
    box-shadow: 0 14px 30px -10px rgba(0,0,0,0.5);
    z-index: 3;
    white-space: nowrap;
    animation: float1 5s ease-in-out infinite;
}
.badge-1 { top: 8%; right: -14%; }
.badge-2 { bottom: 10%; left: -16%; animation: float3 4.5s ease-in-out infinite; }
@media (max-width: 1050px) {
    .badge-1 { right: -4%; }
    .badge-2 { left: -4%; }
}
@keyframes float1 { 0%,100% { transform: translateY(0px); } 50% { transform: translateY(-10px); } }
@keyframes float3 { 0%,100% { transform: translateY(0px); } 50% { transform: translateY(-14px); } }
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

/* ---------- Ritratto "chi sono" ---------- */
.about-grid { display: grid; grid-template-columns: 1fr 280px; gap: 3rem; align-items: center; }
.about-art { display: flex; justify-content: center; }
.about-photo-wrap { position: relative; width: 220px; height: 220px; margin: 0 auto; }
.about-photo {
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: top center;
    border-radius: 50%;
    border: 1px solid var(--bordo);
    position: relative; z-index: 2;
}
.about-ring {
    position: absolute;
    top: -16px; left: -16px; right: -16px; bottom: -16px;
    border: 2.5px dashed var(--corallo);
    border-radius: 50%;
    opacity: 0.7;
    animation: spin 16s linear infinite;
}

@media (max-width: 900px) {
    .hero-grid { grid-template-columns: 1fr; text-align: center; }
    .hero-grid .hero-content { display: flex; flex-direction: column; align-items: center; }
    .hero-grid .hero-actions, .hero-stats { justify-content: center; }
    .hero-art { height: 320px; order: -1; }
    .about-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   GALLERIA RECENSIONI + LIGHTBOX
   ============================================================ */
.review-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 0.9rem;
    margin-top: 1rem;
}
.review-thumb {
    background: var(--superficie);
    border: 1px solid var(--bordo);
    border-radius: 10px;
    overflow: hidden;
    padding: 0;
    cursor: pointer;
    aspect-ratio: 1 / 1;
    display: block;
    transition: border-color 0.25s var(--ease), transform 0.25s var(--ease);
}
.review-thumb:hover { border-color: var(--corallo); transform: translateY(-3px); }
.review-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.lightbox {
    position: fixed;
    inset: 0;
    background: rgba(11, 14, 20, 0.94);
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
}
.lightbox[hidden] { display: none; }
.lightbox-img {
    max-width: min(720px, 90vw);
    max-height: 85vh;
    object-fit: contain;
    border-radius: 12px;
    border: 1px solid var(--bordo);
    box-shadow: 0 30px 60px -20px rgba(0,0,0,0.7);
}
.lightbox-close, .lightbox-nav {
    position: absolute;
    background: var(--superficie-top);
    border: 1px solid var(--bordo);
    color: var(--carta);
    border-radius: 50%;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    cursor: pointer;
    transition: border-color 0.2s var(--ease), background 0.2s var(--ease);
}
.lightbox-close:hover, .lightbox-nav:hover { border-color: var(--corallo); color: var(--corallo); }
.lightbox-close { top: 1.5rem; right: 1.5rem; }
.lightbox-prev { left: 1.5rem; top: 50%; transform: translateY(-50%); }
.lightbox-next { right: 1.5rem; top: 50%; transform: translateY(-50%); }

@media (max-width: 600px) {
    .review-gallery { grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: 0.6rem; }
    .lightbox { padding: 1rem; }
    .lightbox-close, .lightbox-nav { width: 38px; height: 38px; font-size: 1.1rem; }
    .lightbox-close { top: 0.8rem; right: 0.8rem; }
    .lightbox-prev { left: 0.5rem; }
    .lightbox-next { right: 0.5rem; }
    .section { padding: 3rem 1.2rem; }
    .servizi-grid { grid-template-columns: 1fr; }
    .libri-grid { grid-template-columns: repeat(2, 1fr); }
    .metriche-band { grid-template-columns: repeat(2, 1fr); padding: 2rem 1.2rem; }
    .cta-finale { padding: 2.5rem 1.2rem; }
    .hero-stats { gap: 1.2rem; flex-wrap: wrap; justify-content: center; }
    .hero-photo-wrap { width: 100%; max-width: 300px; height: 360px; }
    .floating-badge { font-size: 0.7rem; padding: 0.5rem 0.8rem; }
}

/* ============================================================
   GALLERIA FORMAZIONE LIVE
   ============================================================ */
.gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1rem;
    margin-top: 1.5rem;
}
.gallery img {
    width: 100%;
    aspect-ratio: 4/3;
    object-fit: cover;
    border-radius: 12px;
    border: 1px solid var(--bordo);
    transition: transform 0.3s var(--ease), border-color 0.3s var(--ease);
}
.gallery img:hover { transform: translateY(-4px); border-color: var(--corallo); }

@media (max-width: 600px) {
    .gallery { grid-template-columns: repeat(2, 1fr); gap: 0.7rem; }
}

/* ============================================================
   SEZIONE BIOGRAFIA
   ============================================================ */
.bio-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.4rem;
    margin-top: 2rem;
}
.bio-card {
    background: linear-gradient(165deg, var(--superficie-alta), var(--superficie));
    border: 1px solid var(--bordo);
    border-radius: 16px;
    padding: 1.6rem;
}
.bio-card-label {
    font-family: var(--font-mono);
    font-size: 0.72rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--corallo);
    display: block;
    margin-bottom: 1rem;
}
.bio-card p { color: var(--carta-soft); font-size: 0.92rem; margin: 0 0 0.8rem; }
.bio-card p:last-child { margin-bottom: 0; }
.bio-roles { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.7rem; }
.bio-roles li { color: var(--carta-soft); font-size: 0.9rem; padding-bottom: 0.7rem; border-bottom: 1px solid var(--bordo); }
.bio-roles li:last-child { border-bottom: none; padding-bottom: 0; }
.bio-roles strong { color: var(--carta); }
.bio-events { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.55rem; }
.bio-events li {
    color: var(--carta-soft); font-size: 0.88rem; padding-left: 1rem; position: relative;
}
.bio-events li::before { content: '—'; position: absolute; left: 0; color: var(--corallo); }

.bio-narrative {
    background: var(--superficie);
    border: 1px solid var(--bordo);
    border-radius: 16px;
    padding: 2rem 2.2rem;
    margin-top: 1.4rem;
    max-width: 760px;
}
.bio-narrative p { color: var(--carta-soft); font-size: 0.98rem; margin: 0 0 1.1rem; }
.bio-narrative p:last-child { margin-bottom: 0; }

@media (max-width: 600px) {
    .bio-narrative { padding: 1.4rem 1.2rem; }
}

/* ============================================================
   WIZARD "COSTRUISCI IL TUO CORSO"
   ============================================================ */

/* ---------- Anteprima step nell'hero ---------- */
.wizard-preview { display: flex; flex-direction: column; gap: 0.9rem; width: 220px; }
.wizard-preview-row { display: flex; align-items: center; gap: 0.7rem; }
.wp-dot { width: 14px; height: 14px; border-radius: 50%; background: var(--superficie-alta); border: 2px solid var(--bordo); flex-shrink: 0; }
.wp-dot.done { background: var(--corallo); border-color: var(--corallo); }
.wp-dot.active { border-color: var(--corallo); background: var(--notte); box-shadow: 0 0 0 4px var(--corallo-soft); }
.wp-bar { height: 6px; flex: 1; border-radius: 4px; background: var(--superficie-alta); }
.wp-bar.done { background: var(--corallo); }

/* ---------- Layout principale: form + sidebar riepilogo ---------- */
.wizard-layout {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 2rem;
    align-items: start;
}
.wizard-form { display: flex; flex-direction: column; gap: 1.6rem; }

/* ---------- Barra di progresso ---------- */
.progress-track {
    height: 8px;
    background: var(--superficie-alta);
    border-radius: 999px;
    overflow: hidden;
    position: sticky;
    top: 76px;
    z-index: 20;
}
.progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--corallo), var(--corallo-luce, var(--corallo)));
    border-radius: 999px;
    transition: width 0.4s var(--ease);
}

/* ---------- Step (fieldset) ---------- */
.wizard-step {
    background: linear-gradient(165deg, var(--superficie), var(--superficie-alta));
    border: 1px solid var(--bordo);
    border-radius: 20px;
    padding: 2.2rem;
    margin: 0;
}
.wizard-step legend {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    font-family: var(--font-display);
    font-size: clamp(1.35rem, 2.2vw, 1.7rem);
    line-height: 1.2;
    font-weight: 600;
    color: var(--carta);
    padding: 0 0 1.4rem;
    width: 100%;
}
.step-pill {
    font-family: var(--font-mono);
    font-size: 0.74rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    background: var(--corallo-soft);
    color: var(--corallo);
    padding: 0.35rem 0.8rem;
    border-radius: 999px;
    flex-shrink: 0;
}
.wizard-step .hint { color: var(--carta-soft); font-size: 1rem; line-height: 1.55; margin: 0 0 1.4rem; }

/* ---------- Choice cards (radio/checkbox come card cliccabili) ---------- */
.choice-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.9rem;
}
.choice-grid-2col { grid-template-columns: repeat(2, 1fr); }
.choice-card {
    display: flex;
    align-items: center;
    gap: 1.1rem;
    background: var(--superficie-alta);
    border: 1.5px solid var(--bordo);
    border-radius: 14px;
    padding: 1.15rem 1.3rem;
    cursor: pointer;
    transition: border-color 0.2s var(--ease), background 0.2s var(--ease), transform 0.15s var(--ease);
    position: relative;
    min-height: 64px;
}
.choice-card:hover { border-color: var(--corallo); transform: translateY(-2px); }
.choice-card input { position: absolute; opacity: 0; width: 0; height: 0; }
.choice-card:has(input:checked) {
    border-color: var(--corallo);
    background: var(--corallo-soft);
}
.choice-card.is-checked {
    border-color: var(--corallo);
    background: var(--corallo-soft);
}
.choice-card:has(input:focus-visible) { outline: 2px solid var(--corallo); outline-offset: 2px; }
.choice-icon {
    width: 42px; height: 42px;
    border-radius: 11px;
    background: var(--superficie);
    border: 1px solid var(--bordo);
    display: flex; align-items: center; justify-content: center;
    color: var(--carta-soft);
    flex-shrink: 0;
    font-family: var(--font-mono);
    font-size: 0.8rem;
    font-weight: 700;
    transition: color 0.2s var(--ease), border-color 0.2s var(--ease);
}
.choice-card:has(input:checked) .choice-icon {
    color: var(--corallo);
    border-color: var(--corallo);
    background: var(--superficie);
}
.choice-card.is-checked .choice-icon {
    color: var(--corallo);
    border-color: var(--corallo);
    background: var(--superficie);
}
.choice-text {
    font-size: 1.02rem;
    color: var(--carta);
    line-height: 1.4;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}
.choice-text strong { font-family: var(--font-display); font-size: 1.1rem; font-weight: 600; }
.choice-desc { display: block; font-size: 0.9rem; color: var(--carta-soft); font-weight: 400; }
.choice-card-lg { padding: 1.35rem 1.4rem; }

/* Checkmark visivo sulle card selezionate */
.choice-card::after {
    content: '';
    position: absolute;
    top: 0.9rem; right: 0.9rem;
    width: 20px; height: 20px;
    border-radius: 50%;
    border: 1.5px solid var(--bordo);
    background: var(--superficie);
    transition: border-color 0.2s var(--ease), background 0.2s var(--ease);
}
.choice-card:has(input:checked)::after {
    border-color: var(--corallo);
    background: var(--corallo);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpath d='M5 13l4 4L19 7' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 12px;
}
.choice-card.is-checked::after {
    border-color: var(--corallo);
    background: var(--corallo);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpath d='M5 13l4 4L19 7' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 12px;
}

/* ---------- Moduli (Step 4, generati via JS) ---------- */
.moduli-area { margin-bottom: 1.3rem; }
.moduli-area:last-child { margin-bottom: 0; }
.moduli-area h4 {
    font-family: var(--font-mono);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--corallo);
    margin: 0 0 0.7rem;
}
.modulo-card .choice-text { font-size: 0.95rem; }
.modulo-meta { font-size: 0.8rem; color: var(--carta-soft); font-family: var(--font-mono); }

/* ---------- Slider ore (Step 5) ---------- */
.slider-block { background: var(--superficie-alta); border-radius: 14px; padding: 1.4rem 1.3rem; }
.slider-value {
    font-family: var(--font-display);
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--corallo);
    margin-bottom: 0.8rem;
}
.slider-unit { font-size: 1rem; color: var(--carta-soft); font-family: var(--font-body); font-weight: 400; }
.slider-block input[type="range"] {
    width: 100%;
    height: 8px;
    border-radius: 999px;
    background: var(--bordo);
    accent-color: var(--corallo);
    cursor: pointer;
}
.slider-labels { display: flex; justify-content: space-between; font-size: 0.8rem; color: var(--carta-soft); margin-top: 0.5rem; }
.error-text {
    color: var(--corallo);
    background: var(--corallo-soft);
    border: 1px solid rgba(255,107,53,0.3);
    border-radius: 10px;
    padding: 0.8rem 1rem;
    font-size: 0.9rem;
    font-weight: 600;
    margin-top: 1rem;
}

/* ---------- Step finale (dati contatto) ---------- */
.wizard-step-final label:not(.consenso-label) {
    display: block;
    font-weight: 600;
    font-size: 0.9rem;
    margin: 1.1rem 0 0.4rem;
    color: var(--carta);
}
.wizard-step-final input[type=text],
.wizard-step-final input[type=email],
.wizard-step-final input[type=tel],
.wizard-step-final textarea {
    width: 100%;
    font-family: var(--font-body);
    font-size: 1rem;
    padding: 0.8rem 1rem;
    border: 1.5px solid var(--bordo);
    border-radius: 10px;
    background: var(--superficie-alta);
    color: var(--carta);
}
.wizard-step-final input:focus, .wizard-step-final textarea:focus { border-color: var(--corallo); outline: none; }
.btn-block { width: 100%; justify-content: center; margin-top: 1.4rem; font-size: 1.02rem; padding: 1rem; }

/* ---------- Riepilogo sticky (sidebar desktop) ---------- */
.riepilogo-sidebar { position: sticky; top: 100px; }
.riepilogo-card {
    background: linear-gradient(165deg, var(--superficie-alta), var(--superficie));
    border: 1px solid var(--bordo);
    border-radius: 18px;
    padding: 1.6rem;
}
.riepilogo-label {
    font-family: var(--font-mono);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--menta);
    display: block;
    margin-bottom: 1.2rem;
}
.riepilogo-stats { display: flex; gap: 1.2rem; margin-bottom: 1.2rem; }
.riepilogo-stat { flex: 1; text-align: center; background: var(--superficie); border-radius: 10px; padding: 0.9rem 0.5rem; border: 1px solid var(--bordo); }
.riepilogo-stat-num { display: block; font-family: var(--font-display); font-size: 1.8rem; font-weight: 700; color: var(--carta); }
.riepilogo-stat-lbl { font-size: 0.78rem; color: var(--carta-soft); text-transform: uppercase; letter-spacing: 0.03em; }
.riepilogo-prezzo-box {
    background: var(--corallo);
    border-radius: 12px;
    padding: 1.1rem 1.2rem;
    margin-bottom: 1.3rem;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
}
.riepilogo-prezzo-lbl { font-size: 0.82rem; color: var(--notte); font-weight: 600; }
.riepilogo-prezzo-val { font-family: var(--font-display); font-size: 1.6rem; font-weight: 700; color: var(--notte); }
.riepilogo-moduli-title { font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.03em; color: var(--carta-soft); margin: 0 0 0.6rem; }
.riepilogo-lista { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.5rem; max-height: 220px; overflow-y: auto; }
.riepilogo-lista li {
    font-size: 0.88rem;
    color: var(--carta);
    padding: 0.5rem 0.7rem;
    background: var(--superficie);
    border-radius: 8px;
    border: 1px solid var(--bordo);
}
.riepilogo-lista:empty::after {
    content: 'Ancora nessun modulo selezionato';
    font-size: 0.85rem;
    color: var(--carta-soft);
    font-style: italic;
}

/* ============================================================
   RESPONSIVE — mobile first per il wizard
   ============================================================ */
@media (max-width: 980px) {
    .wizard-layout { grid-template-columns: 1fr; }
    .riepilogo-sidebar {
        position: static;
        order: -1;
    }
    .riepilogo-card { margin-bottom: 0.5rem; }
}

@media (max-width: 600px) {
    .wizard-step { padding: 1.3rem 1.1rem; border-radius: 14px; }
    .wizard-step legend { font-size: 1.05rem; flex-wrap: wrap; gap: 0.5rem; }
    .choice-grid-2col { grid-template-columns: 1fr; }
    .choice-card { padding: 0.85rem 0.95rem; }
    .choice-icon { width: 34px; height: 34px; }
    .choice-text { font-size: 0.95rem; }
    .progress-track { top: 60px; }
    .riepilogo-stats { gap: 0.7rem; }
    .riepilogo-stat-num { font-size: 1.5rem; }
    .slider-value { font-size: 1.8rem; }
}

/* ============================================================
   WIZARD 2.0 — Step durata/disponibilità, advisor note, riepilogo focus
   ============================================================ */

/* ---------- Nota informativa (es. modalità del percorso) ---------- */
.advisor-note {
    background: var(--menta-soft);
    border: 1px solid rgba(61, 220, 151, 0.25);
    border-radius: 16px;
    padding: 1.4rem 1.5rem;
    margin-bottom: 1.6rem;
}
.advisor-note strong {
    display: block;
    color: var(--menta);
    font-family: var(--font-display);
    font-size: 1.2rem;
    margin-bottom: 0.4rem;
}
.advisor-note p {
    margin: 0;
    color: var(--carta-soft);
    font-size: 0.98rem;
    line-height: 1.55;
}

/* ---------- Griglia a due colonne (urgenza + budget) ---------- */
.wizard-subgrid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.6rem;
    margin-top: 1.8rem;
}
.wizard-subgrid > div > label {
    display: block;
    font-weight: 600;
    font-size: 0.92rem;
    margin-bottom: 0.7rem;
    color: var(--carta);
}

/* ---------- Card compatte (Step 7: "Quando vuoi iniziare?") ---------- */
.choice-card.compact {
    min-height: auto;
    padding: 1rem 1.2rem;
}
.choice-card.compact .choice-text { font-size: 0.96rem; }
.choice-card.compact::after { top: 50%; transform: translateY(-50%); }
.choice-card.compact:has(input:checked)::after { transform: translateY(-50%); }

/* ---------- Select stile coerente con gli input ---------- */
.wizard-select {
    width: 100%;
    font-family: var(--font-body);
    font-size: 1rem;
    padding: 0.95rem 1.1rem;
    border: 1.5px solid var(--bordo);
    border-radius: 10px;
    background: var(--superficie-alta);
    color: var(--carta);
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23B8BAC2' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 18px;
}
.wizard-select:focus { border-color: var(--corallo); outline: none; }

/* ---------- Focus obiettivo nella sidebar riepilogo ---------- */
.riepilogo-focus {
    background: var(--superficie);
    border: 1px solid var(--bordo);
    border-radius: 12px;
    padding: 1.1rem 1.2rem;
    margin-bottom: 1.3rem;
}
.riepilogo-focus-label {
    display: block;
    font-family: var(--font-mono);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--carta-soft);
    margin-bottom: 0.4rem;
}
.riepilogo-focus strong {
    display: block;
    font-family: var(--font-display);
    color: var(--carta);
    font-size: 1.05rem;
    line-height: 1.3;
}

@media (max-width: 780px) {
    .wizard-step { padding: 1.6rem; }
    .wizard-step legend { font-size: 1.25rem; }
    .wizard-subgrid { grid-template-columns: 1fr; gap: 1.2rem; }
}

@media (max-width: 600px) {
    .wizard-step { padding: 1.3rem 1.1rem; border-radius: 16px; }
    .advisor-note { padding: 1.1rem 1.2rem; }
}
