:root {
  --vme-bg: #0f1318;
  --vme-bg-alt: #0b0f14;
  --vme-border: rgba(255,255,255,.08);
  --vme-text: #e5e7eb;
  --vme-text-muted: #9aa4b2;
  --vme-white: #ffffff;
  --vme-icon: #b3b3b4;
  --vme-accent: #2563eb;
  /* Largura efetiva do menu para deslocar conteúdo (ajustada via JS) */
  --vme-offset-left: 0px;
  /* Cores do spinner (pastel preto em fundo branco) */
  --vme-spinner-bg: #ffffff;
  --vme-spinner-ring: rgba(17, 24, 39, 0.28);
  --vme-spinner-top: rgba(17, 24, 39, 0.72);
}

.vme-vertical-menu {
  position: fixed; /* fora do fluxo no desktop para não somar largura com o offset do body */
  left: 0;
  top: 0;
  bottom: 0;
  width: 260px;
  min-height: 100vh;
  height: 100vh;
  background: var(--vme-bg);
  color: var(--vme-text);
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--vme-border);
  /* Desliga transições por padrão para evitar flicker no primeiro paint */
  transition: none;
  z-index: 0;
}
/* Durante o boot do widget: nenhum sub-elemento deve animar */
.vme-vertical-menu[data-boot="1"],
.vme-vertical-menu[data-boot="1"] * { transition: none !important; }
/* Ativa transições apenas quando o JS sinaliza que está tudo pronto */
.vme-vertical-menu.has-transition { transition: width .20s ease; }
/* Ajustes de velocidade conforme direção, apenas quando transições estiverem ativas */
.vme-vertical-menu.has-transition.is-transition-expanding { transition-duration: .25s; }
.vme-vertical-menu.has-transition.is-transition-collapsing { transition-duration: .18s; }

.vme-header { display:none; }
/* Alternador como item de menu */
.vme-item-toggle .eicon, .vme-item-toggle i, .vme-item-toggle svg { color: var(--vme-white); fill: var(--vme-white); }
.vme-item-toggle a { font-weight: 600; }

.vme-menu { padding: 8px 0 110px; }
.vme-menu ul { list-style: none; margin:0; padding:0; }
.vme-item { position: relative; }
.vme-item a {
  display: flex; gap: 12px; align-items: center;
  padding: 12px 16px; text-decoration: none; color: var(--vme-text);
  margin: 4px 8px; /* respeita o padding lateral do container */
  border-radius: 8px; /* controlado via painel (override) */
}
.vme-item a:hover { color: var(--vme-white); background: rgba(255,255,255,.03); }
/* Estado ativo fixo: mantém visual do hover quando a categoria está ativa */
.vme-item.is-active a { color: var(--vme-white); background: rgba(255,255,255,.03); }
.vme-item.is-active i,
.vme-item.is-active svg { color: var(--vme-white); fill: var(--vme-white); }
/* Remover outline/borda tracejada padrão no hover/focus/active */
.vme-menu a:hover,
.vme-menu a:focus,
.vme-menu a:active { outline: none; box-shadow: none; border-color: transparent; }
/* Alternador: remover hover/click em largura total (bolha apenas) */
.vme-item-toggle a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  padding: 10px;
  margin: 4px 8px;
  border-radius: 8px;
}
/* Hover apenas na área do botão */
.vme-item-toggle a:hover,
.vme-item-toggle a:active,
.vme-item-toggle a:focus { background: rgba(255,255,255,.03); outline: none; box-shadow: none; border-color: transparent; }
.vme-item i, .vme-item svg { color: var(--vme-icon); fill: var(--vme-icon); width: 18px; height: 18px; flex: 0 0 18px; }
.vme-item .vme-text { flex: 1 1 auto; overflow: hidden; white-space: nowrap; transition: opacity .2s ease, width .2s ease, margin .2s ease; }
.vme-item .vme-separator {
  display: block;
  height: 0;
  border-top: 1px solid var(--vme-border);
  margin: 4px 8px; /* alinha com a "bolha" do hover */
}

/* Alternador do menu à direita */
.vme-vertical-menu.vme-toggle-right .vme-item-toggle { text-align: right; }
.vme-vertical-menu.vme-toggle-right .vme-item-toggle a .vme-text { order: 1; }
.vme-vertical-menu.vme-toggle-right .vme-item-toggle a i,
.vme-vertical-menu.vme-toggle-right .vme-item-toggle a svg { order: 2; }

/* Alternador centralizado */
.vme-vertical-menu.vme-toggle-center .vme-item-toggle { text-align: center; }
/* Quando o menu estiver recolhido, ignorar o controlador e centralizar SEMPRE */
.vme-vertical-menu.is-collapsed .vme-item-toggle { text-align: center; }
.vme-vertical-menu.is-collapsed .vme-item-toggle a {
  justify-content: center !important;
  display: inline-flex;
  width: auto;
  margin: 4px auto; /* centraliza horizontalmente */
  padding: 10px;    /* hit-area consistente */
  border-radius: 8px;
}
/* Cobertura explícita para classes de posição quando recolhido */
.vme-vertical-menu.is-collapsed.vme-toggle-right .vme-item-toggle a,
.vme-vertical-menu.is-collapsed.vme-toggle-center .vme-item-toggle a { justify-content: center !important; }
/* Garantir centralização já no primeiro paint (durante boot) */
.vme-vertical-menu[data-boot="1"].is-collapsed .vme-item-toggle a { justify-content: center !important; }

/* Área de rodapé fixa: cartão + botão sair */
.vme-footer {
  position: absolute;
  left: 12px; right: 12px; bottom: 12px;
}

.vme-user-card {
  display: flex; align-items: center; gap: 12px;
  background: var(--vme-bg-alt);
  border-top: 1px solid var(--vme-border);
  padding: 12px 16px; border-radius: 8px; margin: 0;
}
.vme-user-card .vme-avatar-wrap { position: relative; display: inline-block; cursor: pointer; line-height: 0; }
.vme-user-card .vme-avatar {
  width: 36px;
  aspect-ratio: 1 / 1;
  height: auto;
  object-fit: cover;
  border-radius: 50%;
  border: 2px solid rgba(37,99,235,.35);
  display: block;
}
.vme-avatar-wrap .vme-avatar-overlay {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,.45);
  border-radius: 50%;
  opacity: 0; transition: opacity .2s ease;
}
.vme-avatar-wrap:hover .vme-avatar-overlay { opacity: 1; }
.vme-avatar-wrap .vme-avatar-overlay svg { width: 18px; height: 18px; fill: #fff; color: #fff; }

 /* Indicador de status online no avatar */
 .vme-avatar-wrap::after{
   content: "";
   position: absolute;
   top: 2px; right: 2px;
   width: 9px; height: 9px;
   background: #22c55e; /* verde */
   border: 2px solid var(--vme-bg); /* anel para contraste no fundo escuro */
   border-radius: 50%;
   z-index: 2; /* acima do overlay da câmera */
 }
 /* Ajuste fino quando o menu estiver recolhido (avatar menor) */
 .vme-vertical-menu.is-collapsed .vme-avatar-wrap::after{
   top: 1px; right: 1px;
   width: 7px; height: 7px;
 }
 /* Garante que o overlay de câmera não cubra o ponto verde */
 .vme-avatar-wrap .vme-avatar-overlay{ z-index: 1; }

/* Modal simples de upload */
.vme-avatar-modal-backdrop {
  position: fixed; inset: 0; background: rgba(0,0,0,.6); z-index: 10040;
  display: none; align-items: center; justify-content: center;
}
.vme-avatar-modal {
  background: var(--vme-bg); color: var(--vme-text); border: 1px solid var(--vme-border);
  padding: 20px; border-radius: 10px; width: 92%; max-width: 420px;
}
.vme-avatar-modal h4 { margin: 0 0 12px; color: var(--vme-white); }
.vme-avatar-modal .vme-file-row { display:flex; align-items:center; gap: 10px; margin-bottom: 12px; }
.vme-avatar-modal .vme-file { display:none; }
.vme-avatar-modal .vme-file-trigger { background: transparent; color: var(--vme-text); border: 1px solid var(--vme-border); padding: 8px 12px; border-radius: 6px; cursor: pointer; transition: all .15s ease; }
.vme-avatar-modal .vme-file-trigger:hover { background: #ffffff; color: #0f1318; border-color: #ffffff; }
.vme-avatar-modal .vme-file-name { color: var(--vme-text-muted); font-size: 14px; }
.vme-avatar-modal .vme-actions { display:flex; gap: 8px; justify-content: flex-end; margin-top: 12px; }
.vme-avatar-modal .vme-actions button {
  background: #2563eb; color: #fff; border: 0; padding: 8px 12px; border-radius: 6px; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
}
.vme-avatar-modal .vme-actions button.vme-cancel { background: transparent; color: var(--vme-text); border: 1px solid var(--vme-border); }
/* Loading visível no botão Enviar */
.vme-avatar-modal .vme-actions .vme-upload.is-loading,
.vme-avatar-modal .vme-actions .vme-upload[disabled]{
  opacity:.95; cursor:not-allowed;
  background: var(--vme-spinner-bg) !important; color:#111827 !important; border-color:#e5e7eb !important;
  min-width: 44px; min-height: 34px; /* garante área visível para o spinner */
}
.vme-avatar-modal .vme-actions .vme-upload .vme-spinner{
  display:inline-block; width:18px; height:18px; border:2px solid var(--vme-spinner-ring); border-top-color: var(--vme-spinner-top); border-radius:50%;
  animation:vmeSpin .8s linear infinite; vertical-align:middle;
}
@keyframes vmeSpin{ to{ transform: rotate(360deg); } }
.vme-user-card .vme-avatar {
  width: 36px;
  aspect-ratio: 1 / 1;
  height: auto;
  object-fit: cover;
  border-radius: 50%;
  border: 2px solid rgba(37,99,235,.35);
  display: block;
}
.vme-user-info { display:flex; flex-direction: column; min-width: 0; }
.vme-user-role { font-size: 12px; color: #7dd3fc; text-transform: lowercase; }
.vme-user-name { font-weight: 700; color: var(--vme-white); line-height: 1.1; }
.vme-user-email { color: var(--vme-text-muted); font-size: 12px; overflow:hidden; text-overflow: ellipsis; }

/* Ação de logout abaixo das informações do usuário */
.vme-footer .vme-user-logout {
  margin-top: 8px;
  color: var(--vme-text);
  font-size: inherit;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  /* Alinhamento horizontal com os itens do menu: margin 8px + padding 16px */
  margin-left: 8px;
  padding-left: 16px;
}
.vme-footer .vme-user-logout:hover {
  color: var(--vme-white);
}
.vme-footer .vme-user-logout i,
.vme-footer .vme-user-logout svg { width: 18px; height: 18px; }

/* Collapsed state */
.vme-vertical-menu.is-collapsed { width: 76px !important; }
.vme-vertical-menu.is-collapsed .vme-text { opacity: 0; width: 0; margin: 0; }
.vme-vertical-menu.is-collapsed .vme-separator { display:none; }
.vme-vertical-menu.is-collapsed .vme-menu a { justify-content: center; padding: 13.2px 0; margin: 4px 8px; border-radius: 8px; }
.vme-vertical-menu.is-collapsed .vme-item { text-align: center; }
.vme-vertical-menu.is-collapsed .vme-item i, .vme-vertical-menu.is-collapsed .vme-item svg { width: 20px; height: 20px; flex: 0 0 20px; }
.vme-vertical-menu.is-collapsed .vme-menu { padding-bottom: 92px; }
.vme-vertical-menu.is-collapsed .vme-footer { display: flex; flex-direction: column; align-items: center; }
.vme-vertical-menu.is-collapsed .vme-user-card { justify-content: center; padding: 0; margin: 0; background: transparent !important; border: 0 !important; box-shadow: none !important; gap: 0; }
.vme-vertical-menu.is-collapsed .vme-user-card .vme-avatar { width: 32px; height: 32px; display: block; }
.vme-vertical-menu.is-collapsed .vme-user-info { display: none !important; }
/* No estado recolhido: mostrar apenas o ícone para Sair */
.vme-vertical-menu.is-collapsed .vme-footer .vme-user-logout .vme-text { display: none; }
.vme-vertical-menu.is-collapsed .vme-footer .vme-user-logout {
  display: flex;
  justify-content: center;
  padding: 8px 0;
  margin-left: 0; /* centralizado no estado recolhido */
}
.vme-vertical-menu.is-collapsed .vme-item-toggle a { justify-content: center; }
.vme-vertical-menu.is-collapsed .vme-avatar { width: 32px; height: 32px; border-radius: 50%; }
.vme-vertical-menu.is-collapsed .vme-user-info { opacity: 0; width: 0; overflow: hidden; }
.vme-vertical-menu.is-collapsed .vme-item .vme-text { display:none; }
.vme-vertical-menu.is-collapsed .vme-item-toggle a { justify-content: center; }

/* Estado inicial sem JS, respeitando preferências responsivas (evita flicker)
   Usa o atributo data-boot="1" diretamente no widget para garantir o estado
   no primeiro paint, antes do JS assumir. */
@media (min-width: 1201px) {
  .vme-vertical-menu[data-boot="1"][data-collapsed-desktop="1"] { width: 76px !important; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-desktop="1"] .vme-text { opacity: 0; width: 0; margin: 0; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-desktop="1"] .vme-separator { display:none; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-desktop="1"] .vme-menu a { justify-content: center; padding: 10px 0; margin: 4px 8px; border-radius: 8px; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-desktop="1"] .vme-item { text-align: center; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-desktop="1"] .vme-item i, .vme-vertical-menu[data-boot="1"][data-collapsed-desktop="1"] .vme-item svg { width: 20px; height: 20px; flex: 0 0 20px; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-desktop="1"] .vme-menu { padding-bottom: 92px; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-desktop="1"] .vme-user-card { justify-content: center; padding: 0; margin: 0; background: transparent !important; border: 0 !important; box-shadow: none !important; gap: 0; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-desktop="1"] .vme-footer { display: flex; flex-direction: column; align-items: center; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-desktop="1"] .vme-user-card .vme-avatar { width: 48px; height: auto; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-desktop="1"] .vme-user-info { display: none !important; opacity: 0; width: 0; overflow: hidden; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-desktop="1"] .vme-item .vme-text { display:none; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-desktop="1"] .vme-item-toggle { text-align: center; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-desktop="1"] .vme-item-toggle a {
    justify-content: center !important;
    display: inline-flex;
    width: auto !important;
    margin: 4px auto !important;
    padding: 10px;
    border-radius: 8px;
  }
}

@media (min-width: 768px) and (max-width: 1200px) {
  .vme-vertical-menu[data-boot="1"][data-collapsed-tablet="1"] { width: 76px !important; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-tablet="1"] .vme-text { opacity: 0; width: 0; margin: 0; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-tablet="1"] .vme-separator { display:none; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-tablet="1"] .vme-menu a { justify-content: center; padding: 10px 0; margin: 4px 8px; border-radius: 8px; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-tablet="1"] .vme-item { text-align: center; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-tablet="1"] .vme-item i, .vme-vertical-menu[data-boot="1"][data-collapsed-tablet="1"] .vme-item svg { width: 20px; height: 20px; flex: 0 0 20px; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-tablet="1"] .vme-menu { padding-bottom: 92px; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-tablet="1"] .vme-user-card { justify-content: center; padding: 0; margin: 0; background: transparent !important; border: 0 !important; box-shadow: none !important; gap: 0; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-tablet="1"] .vme-footer { display: flex; flex-direction: column; align-items: center; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-tablet="1"] .vme-user-card .vme-avatar { width: 48px; height: auto; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-tablet="1"] .vme-user-info { display: none !important; opacity: 0; width: 0; overflow: hidden; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-tablet="1"] .vme-item .vme-text { display:none; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-tablet="1"] .vme-item-toggle { text-align: center; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-tablet="1"] .vme-item-toggle a {
    justify-content: center !important;
    display: inline-flex;
    width: auto !important;
    margin: 4px auto !important;
    padding: 10px;
    border-radius: 8px;
  }
}
/* Layout: aplica o deslocamento como PADDING, evitando empurrar wrappers centralizados (Astra, etc.) */
body.vme-has-offset .site-content {
  padding-left: var(--vme-offset-left);
}
body.vme-has-offset footer,
body.vme-has-offset [data-elementor-type="footer"] {
  padding-left: var(--vme-offset-left);
}

/* Evita "folga" ao lado do menu no Astra/temas similares: remove padding lateral esquerdo
   dos wrappers principais para que o conteúdo encoste no offset. Somente a partir de tablet. */
@media (min-width: 768px) {
  /* Não zerar o padding do .site-content (ele é o offset). Zere apenas wrappers internos */
  body.vme-has-offset .site-content .ast-container,
  body.vme-has-offset .ast-container,
  body.vme-has-offset .content-area,
  body.vme-has-offset .entry-content,
  body.vme-has-offset main.site-main {
    padding-left: 0 !important;
    margin-left: 0 !important;
  }
  /* Garante que o container principal ocupe 100% da largura útil ao lado do menu */
  body.vme-has-offset .ast-container,
  body.vme-has-offset .site-content > .ast-container {
    max-width: 100% !important;
  }
}

/* Responsive behavior */
/* Removido comportamento sticky em 1024px para evitar espaço extra na página.
   Mantemos o padrão (fixed) igual às demais resoluções. */
@media (max-width: 767px) {
   .vme-vertical-menu { position: fixed; left: 0; top: 0; bottom: 0; transform: translateX(-100%); transition: all .3s ease !important; z-index: 1001; }
   .vme-vertical-menu.is-open { transform: translateX(0); z-index: 1001; }
  .vme-vertical-menu.is-collapsed { width: 240px; }
  /* Fallback: abrir via classe no body quando acionado por botões externos */
  body.vme-menu-open .vme-vertical-menu { transform: translateX(0); z-index: 0; }
  /* No mobile, não desloca o conteúdo */
  body.vme-has-offset footer,
  body.vme-has-offset [data-elementor-type="footer"] {
    padding-left: 0 !important;
  }
  body.vme-has-offset .site-content { padding-left: 0 !important; }
  /* Boot mobile recolhido: centralizar de imediato */
  .vme-vertical-menu[data-boot="1"][data-collapsed-mobile="1"] .vme-item-toggle { text-align: center; }
  .vme-vertical-menu[data-boot="1"][data-collapsed-mobile="1"] .vme-item-toggle a {
    justify-content: center !important;
    display: inline-flex;
    width: auto !important;
    margin: 4px auto !important;
    padding: 10px;
    border-radius: 8px;
  }
}

/* Mobile: se preferir começar recolhido no mobile, o menu começa fechado (overlay) e sem transição inicial */
@media (max-width: 767px) {
  body.vme-booting .vme-vertical-menu[data-collapsed-mobile="1"] { transform: translateX(-100%) !important; transition: none !important; }
}

a.vme-toggle.vme-toggle-item {
    padding: 7px !important;
}

@media (min-width: 1280px) {
a.vme-user-logout.vme-logout-link {
    
    padding-bottom: 0px !important;
    
}
}

/* Mobile: reordenação – cartão do usuário no topo, itens abaixo, logout fixo embaixo */
@media (max-width: 767px) {
  /* Garante comportamento de coluna e permite ordenar filhos */
  .vme-vertical-menu { display: flex; flex-direction: column; }

  /* Move o bloco do cartão para o topo e remove posicionamento absoluto padrão */
  .vme-vertical-menu .vme-footer {
    order: -1;
    position: static !important;
    left: auto; right: auto; bottom: auto;
    padding: 0;
    margin: 12px 12px 8px 12px;
  }

  .vme-vertical-menu .vme-user-card {
    margin: 0; /* o card já possui seu próprio padding */
  }

  /* Mantém o botão de sair sempre visível no rodapé do menu */
  .vme-vertical-menu .vme-user-logout {
    position: absolute;
    left: 12px; right: 12px; bottom: 12px;
    margin-left: 0; /* alinha com as bordas do container no mobile */
    padding-left: 16px;
    padding-top: 20px;
         border-top: 1px dashed var(--vme-border);
    background: transparent;
  }

  /* Reserva espaço para o logout posicionado no fundo */
  .vme-vertical-menu .vme-menu { padding-bottom: 110px; }
  .vme-vertical-menu.is-collapsed .vme-menu { padding-bottom: 110px; }
  /* Remover as linhas divisórias dos itens no mobile (mantém o espaçamento dos anchors) */
  .vme-vertical-menu .vme-menu .vme-separator { border-top: 0 !important; }
}


body:not(.rtl) .elementor-19 .elementor-element.elementor-element-65ea4b06 {
    left: 0px;
    z-index: 9999 !important;
}

.vme-vertical-menu.is-collapsed .vme-item-toggle {
    margin-bottom: 25px !important;
}


@media (max-width: 767px) {
a.vme-user-logout.vme-logout-link {
    padding-bottom: 80px !important;
}
}


/* ===== VME Toasts (top-right, tema claro) ===== */
.vme-toast-container{
  position: fixed;
  top: calc(16px + env(safe-area-inset-top, 0px));
  right: calc(16px + env(safe-area-inset-right, 0px));
  display: flex; flex-direction: column; gap: 10px;
  z-index: 10080; /* acima do modal de avatar (10040) */
  pointer-events: none;
}
.vme-toast{
  pointer-events: auto;
  min-width: 220px; max-width: min(92vw, 360px);
  background: #ffffff; color:#111827;
  border: 1px solid #e5e7eb; border-radius: 10px;
  box-shadow: 0 10px 24px rgba(2,6,23,.08), 0 2px 8px rgba(2,6,23,.06);
  overflow: hidden;
  transform: translateX(12px); opacity: 0;
  animation: vmeToastIn .18s ease-out forwards;
}
.vme-toast .vme-toast-body{ display:flex; align-items:center; gap:10px; padding:12px 14px; }
.vme-toast .vme-toast-text{ line-height:1.35; font-size:14px; }
.vme-toast .vme-toast-close{ margin-left:auto; appearance:none; background:transparent; border:0; color:#475569; font-size:18px; line-height:1; cursor:pointer; padding:2px 6px; border-radius:6px; }
.vme-toast .vme-toast-close:hover{ background:#f1f5f9; color:#111827; }
.vme-toast .vme-toast-dot{ width:8px; height:8px; border-radius:999px; display:inline-block; flex:0 0 8px; }
.vme-toast-success{ border-left:3px solid #16a34a; }
.vme-toast-error{ border-left:3px solid #ef4444; }
.vme-toast-success .vme-toast-dot{ background:#16a34a; }
.vme-toast-error .vme-toast-dot{ background:#ef4444; }
.vme-toast.is-leaving{ animation: vmeToastOut .18s ease-in forwards; }
@keyframes vmeToastIn{ from{ transform: translateX(12px); opacity:0; } to{ transform: translateX(0); opacity:1; } }
@keyframes vmeToastOut{ from{ transform: translateX(0); opacity:1; } to{ transform: translateX(12px); opacity:0; } }
@media (max-width: 480px){
  .vme-toast-container{ top: calc(10px + env(safe-area-inset-top, 0px)); right: calc(10px + env(safe-area-inset-right, 0px)); gap: 8px; }
  .vme-toast .vme-toast-body{ padding:10px; }
  .vme-toast{ max-width: min(95vw, 360px); }
}
