.sl-itinerary{
    --bg:#fff;
    --ink:#151515;
    --muted:#5b5f66;
    --soft:#f6f7f8;
    --soft2:#f1f2f3;
    --line: rgba(20,20,20,.10);
    --gold:#b8933b;
    --card:#fff;
    --shadow: 0 10px 30px rgba(0,0,0,.08);
    --radius:16px;
    --radius2:22px;
    --max:1180px;
    --sidebarW:360px;
    --gap:22px;

    color: var(--ink);
}

.sl-itinerary *{ box-sizing:border-box; }

/* === BREAK OUT FULL WIDTH (CSS per uscire dal contenitore del tema) === */
.single-post .sl-itinerary,
.single .sl-itinerary,
.sl-itinerary {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}

.sl-itinerary{
    background:
            radial-gradient(900px 380px at 20% 0%, rgba(184,147,59,.10), transparent 60%),
            radial-gradient(900px 380px at 85% 15%, rgba(216,192,123,.08), transparent 55%),
            var(--bg);
}

.sl-wrap{
    max-width: var(--max);
    margin: 0 auto;
    padding: 22px 16px 90px;
}

.sl-topbar{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    padding: 10px 0 16px;
    border-bottom: 1px solid var(--line);
    margin-bottom: 18px;
}

.sl-brand{
    display:flex;
    gap:10px;
    align-items:center;
    text-decoration:none;
}

.sl-logo{
    width:36px;height:36px;border-radius:999px;
    border: 1px solid var(--line);
    display:grid;place-items:center;
    background: linear-gradient(180deg, #fff, #fafafa);
    box-shadow: 0 8px 20px rgba(0,0,0,.06);
    color: var(--gold);
    font-weight: 800;
    letter-spacing:.2px;
}

.sl-brand b{ display:block; font-size: 14px; letter-spacing:.4px; }
.sl-brand span{ display:block; font-size: 12.5px; color: var(--muted); margin-top:2px; }

.sl-top-actions{ display:flex; gap:10px; flex-wrap:wrap; }

.sl-btn{
    display:inline-flex; align-items:center; justify-content:center; gap:8px;
    padding: 10px 14px;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: #fff;
    text-decoration:none;
    box-shadow: 0 10px 22px rgba(0,0,0,.06);
    transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
    white-space: nowrap;
    font-weight: 650;
    font-size: 14px;
    color: var(--ink);
}

.sl-btn:hover{
    transform: translateY(-1px);
    border-color: rgba(184,147,59,.35);
    box-shadow: 0 14px 26px rgba(0,0,0,.08);
}

.sl-primary{
    border-color: rgba(184,147,59,.55);
    background: linear-gradient(180deg, rgba(184,147,59,.12), rgba(255,255,255,1));
}

.sl-mini{ padding: 9px 12px; font-size: 13.5px; }

/* LAYOUT BASE (Mobile First approccio, ma qui è desktop di base) */
.sl-layout{
    display:grid;
    /* Rimosso grid-template-columns fisso qui, lo gestiamo sotto */
    gap: var(--gap);
    align-items:start;
    margin-top: 18px;
}

.sl-content{ min-width:0; }

/* STILI CONTENUTO */
.sl-hero{
    border-radius: var(--radius2);
    border: 1px solid var(--line);
    background: linear-gradient(180deg, #fff, var(--soft));
    box-shadow: var(--shadow);
    overflow:hidden;
}

.sl-hero-inner{ padding: 22px 18px; }

.sl-kicker{
    display:inline-flex;
    gap:10px;
    align-items:center;
    border: 1px solid var(--line);
    background: #fff;
    padding: 7px 10px;
    border-radius: 999px;
    color: var(--muted);
    font-size: 12.5px;
    width: fit-content;
}

.sl-dot{
    width:8px;height:8px;border-radius:999px;
    background: var(--gold);
    box-shadow: 0 0 0 4px rgba(184,147,59,.15);
}

.sl-itinerary h1{
    margin: 12px 0 8px;
    font-size: clamp(26px, 3.2vw, 44px);
    line-height: 1.12;
    letter-spacing:.2px;
}

.sl-subtitle{
    margin: 0;
    color: var(--muted);
    max-width: 75ch;
}

.sl-hero-note{
    margin-top: 12px;
    color: rgba(0,0,0,.60);
    font-size: 13px;
}

.sl-mt12{ margin-top: 12px; }
.sl-mt14{ margin-top: 14px; }

.sl-badges{ display:flex; flex-wrap:wrap; gap:8px; margin-top: 10px; }
.sl-badge{
    font-size: 12px;
    color: rgba(0,0,0,.62);
    border: 1px solid var(--line);
    background: #fff;
    padding: 6px 10px;
    border-radius: 999px;
}

.sl-section{
    margin-top: 18px;
    border: 1px solid var(--line);
    border-radius: var(--radius2);
    background: #fff;
    box-shadow: var(--shadow);
    overflow:hidden;
}

.sl-section.sl-alt{ background: linear-gradient(180deg, #fff, var(--soft2)); }

.sl-hd{
    padding: 14px 16px 10px;
    border-bottom: 1px solid var(--line);
    display:flex; align-items:baseline; justify-content:space-between; gap:12px; flex-wrap:wrap;
}

.sl-itinerary h2{ margin:0; font-size: 16px; letter-spacing:.25px; }

.sl-hint{ color: var(--muted); font-size: 12.5px; }
.sl-bd{ padding: 14px 16px 16px; }

.sl-two{ display:grid; grid-template-columns: 1fr 1fr; gap: 14px; }

.sl-card{
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 14px;
    background: var(--card);
}

.sl-itinerary h3{ margin:0 0 8px; font-size: 14.5px; letter-spacing:.2px; }
.sl-card p{ margin:0; color: var(--muted); }

.sl-ul{ margin: 10px 0 0; padding-left: 18px; color: var(--muted); }
.sl-ul li{ margin: 6px 0; }

.sl-note{ margin-top:10px; color: rgba(0,0,0,.55); font-size:12.5px; }

.sl-timeline{ display:grid; gap: 12px; }

.sl-step{
    display:grid;
    grid-template-columns: 34px 1fr;
    gap: 12px;
    padding: 14px;
    border: 1px solid var(--line);
    background: #fff;
    border-radius: var(--radius);
}

.sl-num{
    width:34px;height:34px;border-radius: 12px;
    display:grid; place-items:center;
    border: 1px solid rgba(184,147,59,.55);
    background: rgba(184,147,59,.10);
    color: var(--gold);
    font-weight: 850;
}

.sl-itinerary h4{ margin:0; font-size: 14.5px; }
.sl-meta{ margin-top: 4px; font-size: 12.5px; color: rgba(0,0,0,.55); }
.sl-desc{ margin-top: 8px; color: var(--muted); }

.sl-menu-grid{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-top: 10px;
}

.sl-menu-item{
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 12px;
    background: #fff;
}

.sl-menu-item b{ display:block; font-size: 12.5px; color: rgba(0,0,0,.55); letter-spacing:.2px; }
.sl-menu-item span{ display:block; margin-top: 4px; font-weight: 750; }
.sl-menu-item small{ display:block; margin-top: 4px; color: var(--muted); }

.sl-fineprint{
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--line);
    color: var(--muted);
    font-size: 12.5px;
}

.sl-pricing{ display:grid; grid-template-columns: 1.1fr .9fr; gap: 12px; }

.sl-pricebox{
    border-radius: var(--radius2);
    border: 1px solid rgba(184,147,59,.55);
    background: linear-gradient(180deg, rgba(184,147,59,.12), #fff);
    padding: 16px;
}

.sl-mini-muted{ color: var(--muted); font-size: 12.5px; }

.sl-big{
    margin-top: 6px;
    font-size: 44px;
    font-weight: 900;
    line-height: 1;
    letter-spacing:.2px;
}

.sl-big sup{ font-size: 18px; vertical-align: top; color: rgba(0,0,0,.55); }

.sl-p-muted{ margin:0; color: var(--muted); max-width: 85ch; }
.sl-pricebox .sl-p-muted{ margin-top: 10px; }

.sl-price-list .sl-row{
    display:flex; justify-content:space-between; align-items:baseline;
    gap: 10px;
    padding: 12px 12px;
    border-radius: var(--radius);
    border: 1px solid var(--line);
    background: #fff;
    margin-bottom: 10px;
}

.sl-price-list .sl-row b{ font-weight: 800; }
.sl-price-list .sl-row span{ display:block; margin-top:2px; color: var(--muted); font-size: 12.5px; }
.sl-price-list .sl-row i{ font-style: normal; font-weight: 900; }

.sl-footer{
    margin-top: 18px;
    border-top: 1px solid var(--line);
    padding-top: 14px;
    color: rgba(0,0,0,.55);
    font-size: 12.5px;
}

/* Sidebar */
.sl-sidebar{
    position: sticky;
    top: 18px;
    align-self: start;
}

.sl-side-card{
    border: 1px solid var(--line);
    border-radius: var(--radius2);
    background: #fff;
    box-shadow: var(--shadow);
    overflow:hidden;
}

.sl-side-hd{
    padding: 14px 14px 10px;
    border-bottom: 1px solid var(--line);
    background: linear-gradient(180deg, #fff, var(--soft));
}

.sl-side-hd b{ display:block; font-size: 14px; letter-spacing:.2px; }
.sl-side-hd span{ display:block; margin-top: 2px; font-size: 12.5px; color: var(--muted); }

.sl-side-bd{ padding: 14px; }

.sl-contact{ display:grid; gap: 10px; margin-bottom: 12px; }
.sl-divider{ height:1px; background: var(--line); margin: 12px 0; }

.sl-form label{
    display:block; font-size: 12.5px; color: rgba(0,0,0,.62); margin: 10px 0 6px;
}

.sl-form input, .sl-form textarea, .sl-form select{
    width: 100%;
    padding: 11px 12px;
    border-radius: 12px;
    border: 1px solid var(--line);
    background: #fff;
    font: inherit;
    outline:none;
}
.sl-form textarea{ min-height: 92px; resize: vertical; }

.sl-form input:focus, .sl-form textarea:focus, .sl-form select:focus{
    border-color: rgba(184,147,59,.55);
    box-shadow: 0 0 0 4px rgba(184,147,59,.12);
}

.sl-full{ width: 100%; margin-top: 12px; }
.sl-side-note{ margin-top: 10px; font-size: 12.5px; color: var(--muted); }

/* Mobile bar (hidden default) */
.sl-mobile-bar{ display:none; }

/* === OVERRIDE E FIX PER LA STRUTTURA === */

/* 1. FORCE TWO COLUMNS (ONLY DESKTOP) */
/* Questa regola ora si applica SOLO se lo schermo è > 861px */
@media (min-width: 861px) {
    .sl-itinerary .sl-layout{
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) var(--sidebarW) !important;
        gap: var(--gap) !important;
        align-items: start !important;
    }
}

/* 2. FORCE SINGLE COLUMN (MOBILE) */
/* Questa regola si applica su schermi piccoli */
@media (max-width: 860px){
    .sl-itinerary .sl-layout{
        grid-template-columns: 1fr !important; /* Forza 1 colonna */
        display: block !important; /* Fallback sicuro */
    }

    .sl-sidebar{
        position: static !important;
        margin-top: 30px; /* Spazio tra contenuto e sidebar */
        width: 100% !important;
    }

    .sl-itinerary{ --sidebarW: 100%; }
    .sl-two{ grid-template-columns: 1fr; }
    .sl-pricing{ grid-template-columns: 1fr; }
    .sl-menu-grid{ grid-template-columns: 1fr; }
    .sl-top-actions{ display:none; }
    .sl-wrap{ padding-bottom: 90px; }

    /* Mobile bar visibile */
    .sl-mobile-bar{
        display:flex;
        position: fixed;
        left: 0; right: 0; bottom: 0;
        padding: 10px 12px;
        background: rgba(255,255,255,.92);
        border-top: 1px solid var(--line);
        backdrop-filter: blur(10px);
        gap: 10px;
        z-index: 9999;
    }
    .sl-mobile-bar .sl-btn{
        flex:1;
        box-shadow: 0 10px 22px rgba(0,0,0,.08);
    }
}

/* 3. NEUTRALIZE THEME STYLES (ALWAYS) */
.sl-itinerary .sl-content,
.sl-itinerary .sl-sidebar{
    float: none !important;
    max-width: none !important;
    clear: none !important;
    width: auto !important;
}

.sl-itinerary .sl-content{ min-width: 0 !important; }

/* Rimuovi bordi rossi di debug se non ti servono più */
/* .sl-itinerary .sl-content{ outline:3px solid red !important; } */
/* .sl-itinerary .sl-sidebar{ outline:3px solid blue !important; } */


/* === FIX STICKY SIDEBAR === */
/* Rende visibile l'overflow dei contenitori padre di Wordpress per permettere lo sticky */
.entry-content,
.post-entry,
article,
.container,
.penci-container,
.site-content,
#content {
    overflow: visible !important;
}

/* Previene che la sidebar si allunghi al 100% dell'altezza (rompendo lo sticky) */
.sl-itinerary .sl-sidebar {
    height: auto !important;
    align-self: start !important;
}

/* Assicuriamo che il contenitore body gestisca l'eventuale scroll orizzontale */
body {
    overflow-x: hidden;
}