/* =================== GLOBAL — Padronização =================== */
.container h1 { margin-top: 0; }
.container h3 { text-transform: uppercase; }

/* =================== HEADER ÚNICO =================== */
header.menu-principal{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:10px 40px;
  background:#fff;
  border-bottom:1px solid #ddd;
}

/* Logo (agora é <a><img>) */
header.menu-principal .logo{
  display:inline-block;
  /* Se for imagem, font-size/color não afetam a imagem.
     Mantenha se ainda tiver fallback em texto. */
  font-weight:700;
  font-size:28px;
  color:#739a30;
  -webkit-text-stroke: 0.2px #97C93E; /* contorno verde-claro */
}
header.menu-principal .logo img{
  display:block;
  max-width:100%;
  height:auto;
}

/* ====== Lista de navegação (nível raiz) ====== */
header.menu-principal nav ul{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:2px;
  align-items:center; /* centraliza verticalmente os itens */
}

header.menu-principal nav ul li{
  position:relative;
}

header.menu-principal nav ul li > a{
  display:block;
  text-decoration:none;
  text-transform:uppercase;
  color:#4d4d4d;
  font-weight:700;
  font-size:20px;
  padding:9px 12px; /* ajuste ótico */
  letter-spacing:.02em;
}

/* =================== SEPARADOR ENTRE ITENS (NÍVEL RAIZ) ===================
   Observações:
   - Removemos o separador no <li>::before (causava desalinhamento).
   - Aplicamos no <a>::before apenas para itens irmãos diretos do menu raiz.
   - Submenus NÃO recebem separador. */
   
/* Neutraliza qualquer regra anterior no <li> */
header.menu-principal nav ul li + li::before { content:none; }

/* Espaço para o separador à esquerda do link (a partir do 2º item) */
header.menu-principal nav > ul > li + li > a{
  position:relative;
  padding-left:30px; /* espaço após a barrinha */
}

/* Barrinha vertical centralizada */
header.menu-principal nav > ul > li + li > a::before{
  content:"";
  position:absolute;
  left:8px;             /* distância da borda do link */
  top:50%;
  width:1px;
  height:14px;          /* altura da barrinha */
  background:#c9c9c9;   /* cor do separador */
  transform:translateY(-50%); /* centraliza verticalmente */
  pointer-events:none;
}

/* Garante que itens do SUBMENU não recebam separador */
header.menu-principal nav ul li ul.submenu a::before{ content:none; }

/* ====== Submenu ====== */
header.menu-principal nav ul li.has-submenu{ padding-bottom:0; }

header.menu-principal nav ul li ul.submenu{
  display:none;
  position:absolute;
  top:100%;
  left:0;
  list-style:none;
  margin:0;
  padding:8px;
  min-width:260px;
  background:#fff;
  border:1px solid #E6E6E6;
  border-radius:12px;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
  z-index:1000;
}

/* Itens do submenu */
header.menu-principal nav ul li ul.submenu li{ display:block; }

header.menu-principal nav ul li ul.submenu a{
  display:block;
  padding:12px 10px;
  text-decoration:none;
  text-transform:uppercase; /* escolha final */
  font-weight:400;
  color:#000;
  white-space:nowrap;
  border-radius:8px;
  font-size:17px;
}

/* Separador entre itens do submenu (linha) */
header.menu-principal nav ul li ul.submenu li + li{
  border-top:1px solid #F0F0F0;
}

/* Hover/focus */
header.menu-principal nav ul li ul.submenu a:hover,
header.menu-principal nav ul li ul.submenu a:focus{
  background:rgba(75,0,130,.06);
}

/* Mostrar submenu */
header.menu-principal nav ul li.has-submenu:hover > ul.submenu,
header.menu-principal nav ul li.has-submenu:focus-within > ul.submenu{
  display:block;
}

/* =================== RESPONSIVIDADE =================== */
@media (max-width: 900px){
  header.menu-principal{
    padding:16px 20px;
    flex-direction:column;
    align-items:flex-start;
    gap:12px;
  }

  header.menu-principal nav ul{
    flex-direction:column;
    gap:10px;
    width:100%;
  }

  header.menu-principal nav ul li.has-submenu{ padding-bottom:0; }

  header.menu-principal nav ul li ul.submenu{
    position:static;
    margin:6px 0 0 0;
    min-width:unset;
    width:100%;
    border:1px solid #E6E6E6;
    border-radius:12px;
    box-shadow:0 8px 24px rgba(0,0,0,.12);
    padding:8px;
  }

  /* Observação: no mobile viramos lista vertical; esconda a barrinha */
  header.menu-principal nav > ul > li + li > a::before{ display:none; }
  header.menu-principal nav > ul > li + li > a{ padding-left:12px; }
}

/* =================== HARDENING =================== */
header.menu-principal nav ul,
header.menu-principal nav ul li,
header.menu-principal nav ul li a,
header.menu-principal nav ul li ul.submenu{
  background-clip:padding-box;
}

/* Ajuste ótico de 1px para baixo nos links do topo (opcional) */
@supports (translate: 0) {
  header.menu-principal nav ul li > a { translate: 0 1px; }
}
@supports not (translate: 0) {
  header.menu-principal nav ul li > a { position: relative; top: 1px; }
}

/* Botão hamburger – manter só se você realmente usar via JS */
.hamburger{ display:none; background:none; border:none; font-size:22px; }
@media (max-width: 900px){
  .hamburger{ display:block; }
}

/* Bloco logo + código da obra */
.logo-obra-box {
  display: flex;
  align-items: center;
  gap: 10px;
  position: relative;
}

/* Código da obra ao lado do logo, com barrinha */
.obra-tag {
  display: inline-block;
  position: relative;
  padding-left: 16px;          /* espaço depois da barrinha */
  font-size: 18px;
  color: #4d4d4d;
}

/* Barrinha vertical antes do número */
.obra-tag::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 1px;
  height: 16px;
  background: #c9c9c9;
  transform: translateY(-50%);
}

/* ---------- Obra clicável ---------- */
.obra-click {
  cursor: pointer;
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: 600;
}

.obra-arrow {
  font-size: 10px;
  opacity: 0.7;
}

/* ---------- Dropdown das obras ---------- */
.obra-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 80px;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 4px 0;
  box-shadow: 0 4px 16px rgba(0,0,0,.10);
  z-index: 9999;
}

.obra-dropdown.hidden {
  display: none;
}

.obra-dropdown .obra-item {
  display: block;
  width: 100%;
  padding: 8px 16px;
  border: none;
  background: none;
  cursor: pointer;
  font-family: inherit;
  font-size: 14px;
  font-weight: 700;
  color: #1e293b;
  text-align: left;
  transition: background .12s;
}

.obra-dropdown .obra-item:hover {
  background: #f1f5f9;
}

/* =================== ROLE SWITCHER (admin) =================== */
.role-switcher {
  display: inline-block;
  position: relative;
  padding-left: 16px;
}
.role-switcher::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 1px;
  height: 16px;
  background: #c9c9c9;
  transform: translateY(-50%);
}
.role-switcher.hidden { display: none; }
.role-switcher__select {
  font-family: inherit;
  font-size: 18px;
  font-weight: 600;
  color: #4d4d4d;
  border: none;
  background: transparent;
  cursor: pointer;
  padding: 0;
  text-transform: uppercase;
}
.role-switcher__select:focus {
  outline: none;
}
.role-switcher__label-only {
  font-family: inherit;
  font-size: 18px;
  font-weight: 600;
  color: #4d4d4d;
  text-transform: uppercase;
}

/* Avatar do utilizador */
.header-user-wrap {
  position: relative;
  margin-left: 12px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
}
.header-user-avatar {
  width: 29px;
  height: 29px;
  border-radius: 50%;
  background: #22c55e;
  color: #fff;
  font-size: 13px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  text-transform: uppercase;
  line-height: 1;
  padding-top: 1px;
  cursor: pointer;
  user-select: none;
  transition: box-shadow .15s, transform .15s;
  box-shadow: 0 2px 8px rgba(21,128,61,.25);
}
.header-user-avatar:hover {
  box-shadow: 0 3px 12px rgba(21,128,61,.4);
  transform: scale(1.06);
}
.header-user-avatar.hidden { display: none; }

.header-session-timer {
  font-size: 11px;
  font-weight: 600;
  color: #94a3b8;
  margin-left: 8px;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.header-user-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 160px;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  box-shadow: 0 4px 16px rgba(0,0,0,.10);
  z-index: 9999;
  overflow: hidden;
}
.header-user-menu.hidden { display: none; }
.header-user-menu__item {
  display: block;
  padding: 10px 16px;
  font-size: 14px;
  font-weight: 700;
  color: #344054;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
  transition: background .12s;
}
.header-user-menu__item:hover { background: #f3f4f6; }
.header-user-menu__item--sair {
  color: #dc2626;
  border-top: 1px solid #f1f1f1;
}