:root{
  --bl-blue:#0f6fb3;
  --bl-text:#1e293b;
  --bl-bg:#ffffff;

  --header-h-desk: 90px;
  --header-h-desk-scrolled: 72px;
  --header-h-mob: 70px;

  --wp-admin-bar: 0px;
  --ease:cubic-bezier(0.4,0,0.2,1);
}


/* ======================================================
   FIX #2: elimina la X “intrusa” di Blocksy SOLO nel tuo drawer
   (la tua .bl-mobile-close resta)
====================================================== */
@media (max-width: 991px) {

  /* Qualunque close Blocksy che finisca dentro il tuo menu */
  #blMobileMenu .ct-panel-close,
  #blMobileMenu .ct-drawer__close,
  #blMobileMenu .ct-panel__close,
  #blMobileMenu .ct-offcanvas-close,
  #blMobileMenu [class*="ct-panel"] [class*="close"],
  #blMobileMenu [class*="ct-drawer"] [class*="close"]{
    display: none !important;
    opacity: 0 !important;
    pointer-events: none !important;
    visibility: hidden !important;
  }

  /* Extra: se Blocksy appiccica un close "floating" sopra al drawer,
     lo sterilizziamo solo quando il tuo menu è aperto */
  .bl-mobile-drawer.open ~ .ct-panel-close,
  .bl-mobile-drawer.open ~ .ct-drawer__close,
  .bl-mobile-drawer.open ~ .ct-offcanvas-close{
    display:none !important;
  }
}

/* Header fixed: parte sotto admin bar */
.bl-header{
  position: fixed;
  top: var(--wp-admin-bar);
  left: 0;
  width: 100%;
  z-index: 9999;

  background: transparent;
  transition: background .35s var(--ease), box-shadow .35s var(--ease), transform .35s var(--ease);
}

.bl-header.is-scrolled{
  background: rgba(255,255,255,.96);
  box-shadow: 0 10px 30px rgba(0,0,0,.08);
}

/* Spacer anti-jump */
.bl-header-spacer{
  height: calc(var(--header-h-desk) + var(--wp-admin-bar));
}

/* Anchor offset (link interni) */
html{
  scroll-padding-top: calc(var(--header-h-desk) + var(--wp-admin-bar));
}

.bl-header-inner{
  max-width: 1200px;
  margin: 0 auto;
  height: var(--header-h-desk);
  padding: 0 24px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  transition: height .35s var(--ease);
}

.bl-header.is-scrolled .bl-header-inner{
  height: var(--header-h-desk-scrolled);
}

.bl-logo{ display:flex; align-items:center; }
.bl-logo img{
  height:56px; width:auto; display:block;
  transition: height .35s var(--ease);
}
.bl-header.is-scrolled .bl-logo img{ height:48px; }

.bl-nav{
  display:flex; align-items:center; gap:32px;
}
.bl-nav a{
  position:relative;
  font-size:16px;
  font-weight:600;
  color:var(--bl-text);
  text-decoration:none;
  padding:6px 0;
  transition:color .25s ease;
}
.bl-nav a:hover{ color:var(--bl-blue); }
.bl-nav a::after{
  content:"";
  position:absolute;
  left:0; bottom:0;
  height:2px; width:100%;
  background:var(--bl-blue);
  transform:scaleX(0);
  transform-origin:right;
  transition:transform .3s var(--ease);
}
.bl-nav a:hover::after{
  transform:scaleX(1);
  transform-origin:left;
}

.bl-actions{ display:flex; align-items:center; }

.bl-btn-header{
  position:relative;
  background:var(--bl-blue);
  color:#fff !important;
  padding:14px 28px;
  border-radius:8px;
  font-size:14px;
  font-weight:700;
  text-decoration:none;
  white-space:nowrap;
  overflow:hidden;
  transition: transform .25s ease, box-shadow .25s ease;
}
.bl-btn-header::before{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(circle, rgba(255,255,255,.35) 0%, rgba(255,255,255,0) 70%);
  opacity:0;
  transition:opacity .3s ease;
}
.bl-btn-header:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 20px rgba(15,111,179,.3);
}
.bl-btn-header:hover::before{ opacity:1; }

/* Desktop: elementi mobile nascosti */
.bl-mobile-toggle,
.bl-mobile-close,
.bl-mobile-drawer,
.bl-mobile-overlay{
  display:none;
}

/* MOBILE */
@media (max-width: 991px){

  .bl-header{
    background:#fff;
    box-shadow:0 6px 18px rgba(0,0,0,.06);
  }

  .bl-header-inner{
    display:grid;
    grid-template-columns:44px 1fr 44px;
    align-items:center;

    height: var(--header-h-mob);
    padding: 0 16px;
  }

  .bl-header.is-scrolled .bl-header-inner{ height: var(--header-h-mob); }

  .bl-nav,
  .bl-actions{ display:none !important; }

  .bl-logo{
    grid-column:2;
    justify-self:center;
  }
  .bl-logo img{ height:40px; }

  .bl-mobile-toggle{
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:flex-end;
    gap:6px;

    grid-column:3;
    justify-self:end;

    width:44px;
    height:44px;
    padding:0;
    background:none;
    border:0;
    cursor:pointer;

    touch-action:manipulation;
    -webkit-tap-highlight-color:transparent;
    will-change:transform;
  }

  .bl-mobile-toggle span{
    width:26px;
    height:2px;
    background:var(--bl-text);
    border-radius:2px;
    transition: transform .35s cubic-bezier(.4,0,.2,1), opacity .25s ease, width .25s ease;
    will-change:transform,opacity,width;
  }
  .bl-mobile-toggle span:nth-child(2){ width:20px; }

  .bl-mobile-toggle.active span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
  .bl-mobile-toggle.active span:nth-child(2){ opacity:0; }
  .bl-mobile-toggle.active span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

  /* Spacer mobile */
  .bl-header-spacer{
    height: calc(var(--header-h-mob) + var(--wp-admin-bar));
  }
  html{
    scroll-padding-top: calc(var(--header-h-mob) + var(--wp-admin-bar));
  }

  .bl-mobile-drawer,
  .bl-mobile-overlay{
    display:block;
    overscroll-behavior:contain;
    will-change:transform,opacity;
  }

  .bl-mobile-drawer{
    position:fixed;
    top: calc(var(--header-h-mob) + var(--wp-admin-bar));
    right:0;

    width:85%;
    max-width:360px;
    height: calc(100dvh - var(--header-h-mob) - var(--wp-admin-bar));

    background:#fff;
    z-index:2000;

    transform:translateX(100%) translateZ(0);
    transition: transform .45s cubic-bezier(.4,0,.2,1);

    display:flex;
    flex-direction:column;
    padding:24px;

    box-shadow:-12px 0 30px rgba(0,0,0,.12);
  }
  .bl-mobile-drawer.open{ transform:translateX(0) translateZ(0); }

  .bl-mobile-header{
    display:flex;
    align-items:center;
    justify-content:flex-end;
    padding-bottom:16px;
    margin-bottom:24px;
    border-bottom:1px solid #e5e7eb;
  }

  .bl-mobile-close{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:44px;
    height:44px;
    background:none;
    border:0;
    font-size:34px;
    line-height:1;
    color:var(--bl-text);
    cursor:pointer;
    transition: transform .3s ease, color .3s ease;
    -webkit-tap-highlight-color:transparent;
  }
  .bl-mobile-close:hover{
    transform:rotate(90deg);
    color:var(--bl-blue);
  }

  .bl-mobile-nav{
    display:flex;
    flex-direction:column;
    gap:22px;
    font-size:20px;
    font-weight:700;
  }
  .bl-mobile-nav a{
    color:var(--bl-text);
    text-decoration:none;
    padding-bottom:12px;
    border-bottom:1px solid #f1f5f9;
    transition: transform .25s ease, color .25s ease;
  }
  .bl-mobile-nav a:hover{
    transform:translateX(6px);
    color:var(--bl-blue);
  }

  .bl-mobile-footer{
    margin-top:auto;
    padding-top:24px;
    border-top:1px solid #e5e7eb;
  }
  .bl-mobile-cta{
    display:block;
    background:var(--bl-blue);
    color:#fff;
    text-align:center;
    padding:16px;
    border-radius:10px;
    font-size:16px;
    font-weight:700;
    text-decoration:none;
  }

  .bl-mobile-overlay{
    position:fixed;
    top: calc(var(--header-h-mob) + var(--wp-admin-bar));
    left:0; right:0; bottom:0;

    background:rgba(30,41,59,.55);
    backdrop-filter:blur(4px);

    opacity:0;
    pointer-events:none;
    z-index:1999;

    transition: opacity .35s ease;
  }
  .bl-mobile-overlay.open{
    opacity:1;
    pointer-events:auto;
  }
}

/* Scroll lock */
html.bl-menu-open,
body.bl-menu-open{
  overflow:hidden;
  height:100%;
}

html.bl-scroll-lock,
body.bl-scroll-lock {
  overflow: hidden !important;
  height: 100%;
}


/* Nasconde eventuali close aggiunti da Blocksy dentro overlay/drawer mobile */
#blMobileMenu .ct-close,
#blMobileMenu .ct-panel-close,
#blMobileMenu .ct-drawer-close,
#blMobileMenu button[aria-label*="Close"],
#blMobileMenu button[aria-label*="Chiudi"] {
  display: none !important;
}

/* ===== SCROLL LOCK HARD FIX (mettilo in fondo) ===== */
html.bl-scroll-lock{
  overflow: visible !important;   /* NON bloccare html: causa jump su mobile */
  height: auto !important;
}

body.bl-scroll-lock{
  position: fixed !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  overflow: hidden !important;
  height: auto !important;
}
