/* =========================================================
   NEETLY BAR - VERSIONE STICKY PULITA
   Desktop: sticky vero dentro layout.
   Mobile/tablet: drawer laterale.
   Nota: il top corretto con il tuo header attuale è 72px, non 127px.
   ========================================================= */

:root {
    --neetly-layout-max: 1600px;
    --neetly-bar-width: 300px;
    --neetly-bar-top: 72px;
    --neetly-gap-page: 32px;

    --neetly-dark: #08111f;
    --neetly-light: #ffffff;
    --neetly-gold: #d89a16;
    --neetly-muted: rgba(255, 255, 255, 0.72);
    --neetly-line: rgba(255, 255, 255, 0.14);
}

/* =========================================================
   BASE
   ========================================================= */

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    max-width: 100%;
    overflow-x: clip;
}

body {
    max-width: 100%;
    overflow-x: clip;
}

.site-shell {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    overflow: visible !important;
}

.site-main {
    min-width: 0;
}

/* =========================================================
   DESKTOP: LAYOUT A DUE COLONNE
   ========================================================= */

@media (min-width: 1201px) {

    .neetly-page-layout {
        width: min(calc(100% - var(--neetly-gap-page)), var(--neetly-layout-max)) !important;
        max-width: var(--neetly-layout-max) !important;

        margin-left: auto !important;
        margin-right: auto !important;

        display: grid !important;
        grid-template-columns: minmax(0, 1fr) var(--neetly-bar-width) !important;
        gap: 24px !important;
        align-items: start !important;

        overflow: visible !important;
    }

    .neetly-page-layout .site-main {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        overflow: visible !important;
    }

    .neetly-page-layout .main-inner {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;

        margin-left: 0 !important;
        margin-right: 0 !important;

        padding: 2rem 0 4rem !important;

        overflow: visible !important;
    }

    .neetly-page-layout > #neetly-bar.neetly-bar,
    .neetly-page-layout > aside#neetly-bar.neetly-bar,
    .neetly-page-layout > .neetly-bar {
        display: block !important;

        position: sticky !important;
        position: -webkit-sticky !important;

        top: var(--neetly-bar-top) !important;
        right: auto !important;
        bottom: auto !important;
        left: auto !important;

        align-self: start !important;

        width: var(--neetly-bar-width) !important;
        min-width: var(--neetly-bar-width) !important;
        max-width: var(--neetly-bar-width) !important;

        height: calc(100vh - var(--neetly-bar-top) - 24px) !important;
        min-height: 0 !important;
        max-height: calc(100vh - var(--neetly-bar-top) - 24px) !important;

        margin: 28px 0 0 0 !important;
        padding: 0 !important;

        background: var(--neetly-dark) !important;
        color: var(--neetly-light) !important;
        border-left: 1px solid var(--neetly-line) !important;

        opacity: 1 !important;
        visibility: visible !important;
        transform: none !important;

        z-index: 20 !important;

        overflow: hidden !important;
        pointer-events: auto !important;

        box-shadow: -18px 0 50px rgba(0, 0, 0, 0.18) !important;
    }

    body.admin-bar .neetly-page-layout > #neetly-bar.neetly-bar,
    body.admin-bar .neetly-page-layout > aside#neetly-bar.neetly-bar,
    body.admin-bar .neetly-page-layout > .neetly-bar {
        top: calc(var(--neetly-bar-top) + 32px) !important;
        height: calc(100vh - var(--neetly-bar-top) - 56px) !important;
        max-height: calc(100vh - var(--neetly-bar-top) - 56px) !important;
    }

    .neetly-bar-toggle,
    .neetly-bar-backdrop,
    .neetly-bar-close {
        display: none !important;
    }
}

/* =========================================================
   SCROLL INTERNO DELLA BARRA
   ========================================================= */

#neetly-bar .neetly-bar-scroll,
.neetly-bar .neetly-bar-scroll,
.neetly-bar-scroll {
    display: block !important;

    width: 100% !important;
    max-width: 100% !important;

    height: 100% !important;
    min-height: 0 !important;
    max-height: 100% !important;

    margin: 0 !important;
    padding: 24px !important;

    overflow-y: auto !important;
    overflow-x: hidden !important;

    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch !important;
    touch-action: pan-y !important;

    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
}

.neetly-bar-scroll::-webkit-scrollbar {
    width: 0 !important;
    height: 0 !important;
    display: none !important;
}

/* =========================================================
   TESTI E BOX INTERNI
   ========================================================= */

.neetly-bar-head {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 14px !important;

    padding-bottom: 18px !important;
    border-bottom: 1px solid var(--neetly-line) !important;
}

.neetly-bar-head strong {
    display: block !important;
    color: var(--neetly-light) !important;
    font-size: 1.1rem !important;
    line-height: 1.15 !important;
}

.neetly-bar-kicker {
    display: inline-block !important;
    margin-bottom: 6px !important;

    color: var(--neetly-gold) !important;

    font-size: 0.72rem !important;
    font-weight: 900 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
}

.neetly-bar-body {
    display: grid !important;
    gap: 16px !important;

    padding-top: 18px !important;
    padding-bottom: 50px !important;
}

.neetly-bar-panel {
    width: 100% !important;
    max-width: 100% !important;

    padding: 16px !important;

    border: 1px solid var(--neetly-line) !important;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)) !important;
    border-radius: 18px !important;

    overflow: hidden !important;
}

.neetly-bar-panel h2 {
    margin: 0 0 8px !important;

    color: var(--neetly-light) !important;

    font-size: 1rem !important;
    line-height: 1.2 !important;
}

.neetly-bar-panel p {
    margin: 0 !important;

    color: var(--neetly-muted) !important;

    font-size: 0.92rem !important;
    line-height: 1.5 !important;
}

/* =========================================================
   TABLET / MOBILE: DRAWER
   ========================================================= */

@media (max-width: 1200px) {

    .neetly-page-layout {
        width: calc(100% - 24px) !important;
        max-width: calc(100% - 24px) !important;

        margin-left: auto !important;
        margin-right: auto !important;

        display: block !important;
    }

    .neetly-page-layout .main-inner {
        width: 100% !important;
        max-width: 100% !important;

        margin-left: auto !important;
        margin-right: auto !important;

        padding-right: 0 !important;
    }

    #neetly-bar.neetly-bar,
    aside#neetly-bar.neetly-bar,
    .neetly-bar {
        display: block !important;
        position: fixed !important;

        top: 0 !important;
        right: 0 !important;
        bottom: auto !important;
        left: auto !important;

        width: min(var(--neetly-bar-width), 86vw) !important;
        min-width: 0 !important;
        max-width: 86vw !important;

        height: 100vh !important;
        min-height: 100vh !important;
        max-height: 100vh !important;

        margin: 0 !important;
        padding: 0 !important;

        background: var(--neetly-dark) !important;
        color: var(--neetly-light) !important;

        opacity: 1 !important;
        visibility: visible !important;

        transform: translate3d(105%, 0, 0) !important;
        transition: transform 0.36s cubic-bezier(0.22, 1, 0.36, 1) !important;

        z-index: 2147482500 !important;

        overflow: hidden !important;
        pointer-events: auto !important;

        box-shadow: -24px 0 70px rgba(0, 0, 0, 0.42) !important;
    }

    body.admin-bar #neetly-bar.neetly-bar,
    body.admin-bar aside#neetly-bar.neetly-bar,
    body.admin-bar .neetly-bar {
        top: 46px !important;

        height: calc(100vh - 46px) !important;
        min-height: calc(100vh - 46px) !important;
        max-height: calc(100vh - 46px) !important;
    }

    body.neetly-bar-open #neetly-bar.neetly-bar,
    body.neetly-bar-open aside#neetly-bar.neetly-bar,
    body.neetly-bar-open .neetly-bar {
        transform: translate3d(0, 0, 0) !important;
    }

    .neetly-bar-toggle {
        display: flex !important;
        position: fixed !important;

        right: 0 !important;
        top: 50% !important;
        transform: translateY(-50%) !important;

        z-index: 2147483000 !important;

        width: 42px !important;
        height: 58px !important;

        border: 0 !important;
        border-radius: 16px 0 0 16px !important;

        background: var(--neetly-dark) !important;
        box-shadow: -10px 0 30px rgba(0, 0, 0, 0.32) !important;

        cursor: pointer !important;

        align-items: center !important;
        justify-content: center !important;
        flex-direction: column !important;
        gap: 5px !important;
    }

    .neetly-bar-toggle span {
        display: block !important;

        width: 21px !important;
        height: 2px !important;

        border-radius: 999px !important;
        background: #ffffff !important;

        transition: transform 0.25s ease, opacity 0.25s ease !important;
    }

    body.neetly-bar-open .neetly-bar-toggle span:nth-child(1) {
        transform: translateY(7px) rotate(45deg) !important;
    }

    body.neetly-bar-open .neetly-bar-toggle span:nth-child(2) {
        opacity: 0 !important;
    }

    body.neetly-bar-open .neetly-bar-toggle span:nth-child(3) {
        transform: translateY(-7px) rotate(-45deg) !important;
    }

    .neetly-bar-backdrop {
        display: block !important;
        position: fixed !important;
        inset: 0 !important;

        z-index: 2147482000 !important;

        background: rgba(8, 17, 31, 0.34) !important;
        backdrop-filter: blur(0) !important;

        opacity: 0 !important;
        visibility: hidden !important;
        pointer-events: none !important;

        transition: opacity 0.32s ease, backdrop-filter 0.32s ease, visibility 0.32s ease !important;
    }

    body.neetly-bar-open .neetly-bar-backdrop {
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
        backdrop-filter: blur(8px) !important;
    }

    .neetly-bar-close {
        display: inline-flex !important;

        width: 34px !important;
        height: 34px !important;

        border: 0 !important;
        border-radius: 999px !important;

        align-items: center !important;
        justify-content: center !important;
        flex: 0 0 auto !important;

        background: rgba(255, 255, 255, 0.12) !important;
        color: var(--neetly-light) !important;

        font-size: 24px !important;
        line-height: 1 !important;

        cursor: pointer !important;
    }
}

/* =========================================================
   BLOCCO BODY QUANDO DRAWER MOBILE APERTO
   ========================================================= */

body.neetly-body-locked {
    overflow: hidden !important;
    position: fixed !important;
    width: 100% !important;
}

/* =========================================================
   MOBILE MINIMO
   ========================================================= */

@media (max-width: 799px) {

    .neetly-page-layout {
        width: 100% !important;
        max-width: 100% !important;

        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .main-inner,
    .header-inner,
    .footer-inner {
        width: 100% !important;
        max-width: 100% !important;

        padding-left: 20px !important;
        padding-right: 20px !important;

        box-sizing: border-box !important;
    }

    .site-logo img {
        max-height: 30px !important;
        width: auto !important;
        display: block !important;
    }
}

/* =========================================================
   ACCESSIBILITÀ
   ========================================================= */

@media (prefers-reduced-motion: reduce) {

    .neetly-bar,
    .neetly-bar-backdrop,
    .neetly-bar-toggle span {
        transition: none !important;
    }
}