
:root{
  --ph-bg: rgba(28,28,28,.45);
  --ph-bg-solid: rgba(28,28,28,.92);
  --ph-blur: 18px;
  --ph-border: rgba(255,255,255,.08);
  --ph-accent: #CB1516;
  --ph-pad: 18px;
}

/* HEADER GLASS */
.elementor-location-header.ph-controlled{
  position: fixed;
  top:0; left:0; right:0;
  z-index:9999;
  background: transparent;
  border-bottom:1px solid var(--ph-border);
}
.elementor-location-header.ph-controlled::before{
  content:'';
  position:absolute;
  inset:0;
  background: var(--ph-bg);
  backdrop-filter: blur(var(--ph-blur)) saturate(140%);
  -webkit-backdrop-filter: blur(var(--ph-blur)) saturate(140%);
  z-index:-1;
}
body.ph-compact .elementor-location-header.ph-controlled::before{ background: var(--ph-bg-solid); }

/* spacer */
#ph-header-spacer{ width:100%; }

/* LOGO SWAP (desktop only logic controls ph-compact) */
.elementor-location-header .ph-logo-stack{ position:relative; display:block; height:56px; width:260px; }
.elementor-location-header .ph-logo-stack img{ position:absolute; left:0; top:50%; transform:translateY(-50%); height:56px; transition:opacity .25s ease; }
.elementor-location-header .ph-logo-icon{ height:36px; opacity:0; }
body.ph-compact .elementor-location-header .ph-logo-full{ opacity:0; }
body.ph-compact .elementor-location-header .ph-logo-icon{ opacity:1; }
body.ph-compact .elementor-location-header:hover .ph-logo-full{ opacity:1; }
body.ph-compact .elementor-location-header:hover .ph-logo-icon{ opacity:0; }

/* UNDERLINE */
.elementor-location-header nav a{
  position:relative;
  color:#fff !important;
  text-decoration:none !important;
  padding-bottom:6px !important;
}
.elementor-location-header nav a::after{
  content:'';
  position:absolute;
  left:10px; right:10px;
  bottom:0;
  height:2px;
  background:var(--ph-accent);
  opacity:0;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .25s ease, opacity .25s ease;
}
.elementor-location-header nav a:hover::after,
.elementor-location-header nav .current-menu-item>a::after,
.elementor-location-header nav .current_page_item>a::after{ opacity:1; transform:scaleX(1); }
.elementor-location-header nav li::before,
.elementor-location-header nav li::after{ content:none!important; }

/* MOBILE: desliga dropdown padrão do Elementor */
@media (max-width:1024px){
  .elementor-location-header .elementor-menu-toggle,
  .elementor-location-header .elementor-nav-menu--dropdown,
  .elementor-location-header .elementor-nav-menu__container.elementor-nav-menu--dropdown,
  .elementor-location-header .elementor-nav-menu__container{ display:none !important; }
}

/* HAMBURGER: dentro do header */
#ph-mobile-trigger{
  position:absolute;
  top:50%;
  right: var(--ph-pad);
  transform: translateY(-50%);
  z-index:10001;
  display:none;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  padding:0;
  background: transparent;
  border:0;
  cursor:pointer;
  -webkit-tap-highlight-color: transparent;
}
#ph-mobile-trigger .ph-burger{
  width:26px; height:16px;
  position:relative;
  display:inline-block;
}
#ph-mobile-trigger .ph-burger::before,
#ph-mobile-trigger .ph-burger::after,
#ph-mobile-trigger .ph-burger span{
  content:'';
  position:absolute;
  left:0; right:0;
  height:2px;
  background: var(--ph-accent);
  border-radius:2px;
}
#ph-mobile-trigger .ph-burger::before{ top:0; }
#ph-mobile-trigger .ph-burger span{ top:7px; }
#ph-mobile-trigger .ph-burger::after{ bottom:0; }

@media (max-width:1024px){
  #ph-mobile-trigger{ display:flex; }
}

/* OVERLAY MOBILE */
#ph-mobile-overlay{
  position:fixed;
  inset:0;
  z-index:10000;
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease;
}
body.ph-menu-open #ph-mobile-overlay{ opacity:1; pointer-events:auto; }
#ph-mobile-overlay::before{
  content:'';
  position:absolute;
  inset:0;
  background: rgba(10,10,10,.92);
  backdrop-filter: blur(10px) saturate(120%);
  -webkit-backdrop-filter: blur(10px) saturate(120%);
}

/* topo overlay */
.ph-mo-top{
  position:absolute;
  left:0; right:0; top:0;
  height:96px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:16px;
  padding: calc(env(safe-area-inset-top, 0px) + 8px) var(--ph-pad) 0 var(--ph-pad);
}
.ph-mo-logo img{ height:52px; width:auto; display:block; }

/* Fechar ao lado da logo */
.ph-mo-close{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border:0;
  background:transparent;
  color:#fff;
  font-size:16px;
  letter-spacing:.02em;
  opacity:.9;
}
.ph-mo-close .x{
  font-size:18px;
  line-height:1;
  opacity:.9;
}
.ph-mo-close:active{ opacity:1; }

/* lista central */
.ph-mo-center{
  position:absolute;
  inset:96px 0 0 0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 0 24px;
}
.ph-mo-nav{
  width:100%;
  max-width:520px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap: 30px;
}
.ph-mo-nav a{
  color:#fff !important;
  text-decoration:none !important;
  font-size: clamp(22px, 6vw, 34px);
  letter-spacing:.20em;
  text-transform: uppercase;
  font-weight: 500;
  opacity:.92;
}
.ph-mo-nav a:hover{ opacity:1; }

/* ESCONDER BOTÕES DE ACESSIBILIDADE QUANDO MENU ABERTO */
body.ph-menu-open #acsb-trigger,
body.ph-menu-open .acsb-trigger,
body.ph-menu-open .acsb-widget,
body.ph-menu-open .acsb-widget-button,
body.ph-menu-open .uwy.userway_p1,
body.ph-menu-open .userway.userway_p1,
body.ph-menu-open .userway_widget,
body.ph-menu-open #pianista-accessibility-advanced,
body.ph-menu-open .pianista-accessibility-advanced,
body.ph-menu-open #paa-trigger,
body.ph-menu-open .paa-trigger,
body.ph-menu-open [id*="pianista-access"],
body.ph-menu-open [class*="pianista-access"],
body.ph-menu-open [aria-label*="Accessibility"],
body.ph-menu-open [aria-label*="Acessibilidade"],
body.ph-menu-open [title*="Accessibility"],
body.ph-menu-open [title*="Acessibilidade"]{
  opacity:0 !important;
  pointer-events:none !important;
  visibility:hidden !important;
}

/* === v4.0.8 Mobile Menu Polish (Pianista) === */

/* Overlay com blur forte + sempre por cima */
#ph-mobile-overlay{
  z-index: 999999 !important;
  background: rgba(0,0,0,.58) !important;
  backdrop-filter: blur(18px) saturate(1.1) !important;
  -webkit-backdrop-filter: blur(18px) saturate(1.1) !important;
}

/* Topo fixo, sem "andar" */
#ph-mobile-overlay .ph-mo-top{
  position: fixed !important;
  left:0 !important;
  right:0 !important;
  top:0 !important;
  height: var(--ph-header-h, 96px) !important;
  padding: 0 !important;
  background: transparent !important;
}

/* Logo: mesma posição do header fechado */
#ph-mobile-overlay .ph-mo-logo{
  position: absolute !important;
  left: var(--ph-logo-left, 20px) !important;
  top: var(--ph-logo-top, calc(env(safe-area-inset-top, 0px) + 16px)) !important;
  transform: none !important;
  margin: 0 !important;
}
#ph-mobile-overlay .ph-mo-logo img{
  height: var(--ph-logo-h, 52px) !important;
  width: auto !important;
  display:block !important;
}

/* Fechar: retângulo SEM curvas + fonte Manrope */
#ph-mobile-overlay .ph-mo-close{
  all: unset;
  box-sizing: border-box;
  position: absolute !important;
  right: var(--ph-pad-right, 20px) !important;
  top: var(--ph-logo-top, calc(env(safe-area-inset-top, 0px) + 16px)) !important;

  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;

  padding: 10px 14px !important;
  border-radius: 0 !important;

  color: rgba(255,255,255,.92) !important;
  font-family: Manrope, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif !important;
  font-weight: 500 !important;
  font-size: 14px !important;
  letter-spacing: .02em !important;

  background: rgba(0,0,0,.22) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;

  cursor: pointer !important;
  user-select: none !important;
  -webkit-tap-highlight-color: transparent !important;
}
#ph-mobile-overlay .ph-mo-close .x{ font-size: 18px !important; line-height:1 !important; opacity:.9 !important; }
#ph-mobile-overlay .ph-mo-close:active{ transform: translateY(1px) !important; }

/* Conteúdo começa abaixo do topo (evita HOME colar na logo) */
#ph-mobile-overlay .ph-mo-center{
  inset: calc(var(--ph-header-h, 96px) + 120px) 0 0 0 !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  padding: 0 24px !important;
}

/* Menu alinhado à esquerda + recuo igual ao da logo */
#ph-mobile-overlay .ph-mo-nav{
  width:100% !important;
  max-width: 520px !important;
  align-items: flex-start !important;
  text-align: left !important;
  padding-left: var(--ph-logo-left, 20px) !important;
  padding-right: var(--ph-pad-right, 20px) !important;
  gap: 26px !important;
}
#ph-mobile-overlay .ph-mo-nav a{
  width:100% !important;
  text-align:left !important;
  font-family: Manrope, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif !important;
  letter-spacing: .22em !important;
}

/* ================================
   PIANISTA MOBILE MENU — FINAL PACK (v4.1.0)
   - z-index acima do Maestro
   - blur premium
   - logo fixa (mesmo pixel do header)
   - fechar retângulo sem curvas (padrão)
   - menu alinhado à esquerda + Space Grotesk
   - menu começa abaixo da logo (sem sobrepor)
   ================================ */

/* Overlay acima de QUALQUER coisa */
#ph-mobile-overlay{ z-index: 2147483000 !important; }

/* Blur / fundo */
#ph-mobile-overlay::before{
  background: rgba(10,10,10,.78) !important;
  backdrop-filter: blur(18px) saturate(140%) !important;
  -webkit-backdrop-filter: blur(18px) saturate(140%) !important;
}

/* Maestro SEMPRE atrás quando menu abre (pega várias variações) */
body.ph-menu-open [id*="maestro" i],
body.ph-menu-open .maestro,
body.ph-menu-open .maestro-toggle,
body.ph-menu-open .maestro-button,
body.ph-menu-open .maestro-fab{
  z-index: 1 !important;
}

/* Topo do overlay: sem flex (evita deslocar) */
#ph-mobile-overlay .ph-mo-top{
  position: fixed !important;
  left: 0 !important;
  right: 0 !important;
  top: 0 !important;
  height: var(--ph-header-h, 96px) !important;
  padding: 0 !important;
}

/* Logo no MESMO pixel do header fechado (JS injeta vars) */
#ph-mobile-overlay .ph-mo-logo{
  position: absolute !important;
  left: var(--ph-logo-left, 20px) !important;
  top: var(--ph-logo-top, calc(env(safe-area-inset-top, 0px) + 18px)) !important;
  transform: none !important;
  margin: 0 !important;
}
#ph-mobile-overlay .ph-mo-logo img{
  height: var(--ph-logo-h, 52px) !important;
  width: auto !important;
  display: block !important;
}

/* Fechar — retângulo sem curvas, clean */
#ph-mobile-overlay .ph-mo-close{
  all: unset;
  box-sizing: border-box;
  position: absolute !important;
  right: var(--ph-pad-right, 20px) !important;
  top: var(--ph-logo-top, calc(env(safe-area-inset-top, 0px) + 18px)) !important;

  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;

  padding: 10px 14px !important;
  border-radius: 0 !important;

  color: rgba(255,255,255,.92) !important;
  font: 500 14px/1.1 "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif !important;
  letter-spacing: .02em !important;

  background: rgba(0,0,0,.20) !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  cursor: pointer !important;
  -webkit-tap-highlight-color: transparent !important;
}
#ph-mobile-overlay .ph-mo-close .x{ font-size:18px !important; line-height:1 !important; opacity:.9 !important; }

/* Área do menu: começa abaixo da logo/topo */
#ph-mobile-overlay .ph-mo-center{
  position: absolute !important;
  inset: 0 !important;
  display: flex !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  padding: 0 !important;
}
#ph-mobile-overlay .ph-mo-nav{
  width: 100% !important;
  max-width: none !important;

  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  text-align: left !important;

  /* desce o menu para não encostar na logo */
  padding-top: calc(var(--ph-header-h, 96px) + 64px) !important;

  /* recuo alinhado ao grid da logo */
  padding-left: var(--ph-logo-left, 20px) !important;
  padding-right: var(--ph-pad-right, 20px) !important;

  gap: 30px !important;
}

/* Tipografia do menu: Space Grotesk */
#ph-mobile-overlay .ph-mo-nav a{
  font-family: "Space Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif !important;
  font-weight: 400 !important;
  letter-spacing: .22em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  width: 100% !important;
}

/* ================================
   FIX FINAL: MENU MAIS ABAIXO (4.1.3)
   - sem mexer no resto
   ================================ */
#ph-mobile-overlay .ph-mo-center{
  /* empurra o bloco do menu para baixo, fora da área da logo */
  inset: calc(var(--ph-header-h, 96px) + 120px) 0 0 0 !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  padding: 0 24px !important;
}

#ph-mobile-overlay .ph-mo-nav{
  /* remove empurrões internos duplicados */
  padding-top: 0 !important;
}

#ph-mobile-overlay .ph-mo-nav a{
  font-family: "Space Grotesk", Manrope, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif !important;
}

/* ================================
   4.1.6 FIX – mover o BLOCO do menu (ph-mo-center), não o nav
   Isso garante que HOME nunca encoste na logo.
   ================================ */
#ph-mobile-overlay .ph-mo-center{
  position: absolute !important;
  inset: auto 0 0 0 !important;
  top: calc(var(--ph-header-h, 96px) + 200px) !important; /* <- AJUSTE REAL */
  bottom: 0 !important;
  display: flex !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  padding: 0 24px !important;
}

#ph-mobile-overlay .ph-mo-nav{
  padding-top: 0 !important;
  margin-top: 0 !important;
}
