/* =====================================================================
   SISTEMA DE ALOJAMENTO CBMAP — Identidade visual institucional militar
   Display: Oswald (condensado, institucional) | Corpo: Inter
   Comando: vermelho-bombeiro #C8102E usado com parcimônia
   Base: azul-marinho de farda / superfícies claras densas
   ===================================================================== */

:root {
  --vermelho:      #C8102E;
  --vermelho-esc:  #9E0C24;
  --marinho:       #0F1C2E;
  --marinho-med:   #16263D;
  --marinho-claro: #25405F;
  --aco:           #5A7290;
  --tinta:         #1A2433;
  --texto:         #2B3648;
  --texto-suave:   #5E6B7E;
  --linha:         #E2E7EE;
  --fundo:         #F4F6F9;
  --branco:        #FFFFFF;
  --dourado:       #C9A227;
  --verde:         #1C7A4D;
  --ambar:         #B7791F;
  --sombra:        0 1px 2px rgba(15,28,46,.06), 0 4px 14px rgba(15,28,46,.05);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  background: var(--fundo);
  color: var(--texto);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

h1,h2,h3,h4 { font-family: 'Oswald', 'Inter', sans-serif; font-weight: 500; letter-spacing: .3px; color: var(--tinta); margin: 0; }

a { color: var(--vermelho); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---------------- LAYOUT ---------------- */
.app { display: flex; min-height: 100vh; }

.sidebar {
  width: 248px;
  background: var(--marinho);
  color: #C7D4E4;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0; bottom: 0; left: 0;
  z-index: 40;
  transition: transform .25s ease;
}

.sidebar-brasao {
  padding: 20px 18px;
  border-bottom: 1px solid rgba(255,255,255,.07);
  display: flex;
  align-items: center;
  gap: 12px;
}
.sidebar-brasao .escudo {
  width: 40px; height: 40px; border-radius: 7px;
  background: var(--vermelho);
  display: grid; place-items: center;
  font-family: 'Oswald'; font-size: 19px; font-weight: 600; color: #fff;
  flex-shrink: 0;
  border: 1px solid rgba(255,255,255,.15);
}
.sidebar-brasao .titulo { font-family:'Oswald'; font-size: 15px; color:#fff; line-height:1.15; text-transform: uppercase; letter-spacing:.5px;}
.sidebar-brasao .sub { font-size: 11px; color: var(--aco); margin-top: 2px; }

.nav { padding: 10px 0; overflow-y: auto; flex: 1; }
.nav-grupo { padding: 14px 18px 6px; font-size: 10.5px; text-transform: uppercase; letter-spacing: 1.2px; color: var(--aco); font-weight: 600; }
.nav a {
  display: flex; align-items: center; gap: 11px;
  padding: 9px 18px; color: #B4C4D8; font-size: 13.5px; text-decoration: none;
  border-left: 3px solid transparent; transition: all .15s;
}
.nav a:hover { background: rgba(255,255,255,.04); color: #fff; }
.nav a.ativo { background: rgba(200,16,46,.14); color: #fff; border-left-color: var(--vermelho); font-weight: 500; }
.nav a svg { width: 17px; height: 17px; flex-shrink: 0; opacity: .85; }

.sidebar-rodape { padding: 14px 18px; border-top: 1px solid rgba(255,255,255,.07); font-size: 11px; color: var(--aco); }

/* ---------------- CONTEÚDO ---------------- */
.conteudo { flex: 1; margin-left: 248px; display: flex; flex-direction: column; min-width: 0; }

.topbar {
  height: 60px; background: var(--branco); border-bottom: 1px solid var(--linha);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 26px; position: sticky; top: 0; z-index: 30;
}
.topbar .menu-btn { display: none; background: none; border: 0; cursor: pointer; color: var(--tinta); }
.topbar .breadcrumb { font-family:'Oswald'; font-size: 17px; text-transform: uppercase; letter-spacing:.5px; color: var(--tinta); }
.usuario-chip { display: flex; align-items: center; gap: 10px; }
.usuario-chip .avatar { width: 34px; height: 34px; border-radius: 50%; background: var(--marinho-claro); color:#fff; display: grid; place-items: center; font-weight: 600; font-size: 13px; }
.usuario-chip .nome { font-size: 13px; font-weight: 600; color: var(--tinta); }
.usuario-chip .perfil { font-size: 11px; color: var(--texto-suave); text-transform: capitalize; }

.pagina { padding: 26px; flex: 1; }

/* ---------------- CABEÇALHO DE PÁGINA ---------------- */
.page-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 22px; gap: 16px; flex-wrap: wrap; }
.page-head h1 { font-size: 26px; text-transform: uppercase; }
.page-head .desc { color: var(--texto-suave); font-size: 13px; margin-top: 3px; }

/* ---------------- BOTÕES ---------------- */
.btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 9px 16px; border-radius: 7px; border: 1px solid transparent;
  font-size: 13.5px; font-weight: 600; cursor: pointer; text-decoration: none;
  font-family: 'Inter'; transition: all .15s; line-height: 1;
}
.btn svg { width: 16px; height: 16px; }
.btn-primario { background: var(--vermelho); color: #fff; }
.btn-primario:hover { background: var(--vermelho-esc); text-decoration: none; }
.btn-neutro { background: var(--branco); color: var(--tinta); border-color: var(--linha); }
.btn-neutro:hover { background: var(--fundo); text-decoration: none; }
.btn-perigo { background: #fff; color: var(--vermelho); border-color: #f0c4cb; }
.btn-perigo:hover { background: #fdf0f2; text-decoration: none; }
.btn-sm { padding: 6px 11px; font-size: 12.5px; }
.btn-bloco { width: 100%; justify-content: center; }

/* ---------------- CARDS / KPIs ---------------- */
.grid-kpi { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px,1fr)); gap: 16px; margin-bottom: 24px; }
.kpi {
  background: var(--branco); border: 1px solid var(--linha); border-radius: 11px;
  padding: 18px 20px; box-shadow: var(--sombra); position: relative; overflow: hidden;
}
.kpi::before { content:''; position:absolute; left:0; top:0; bottom:0; width:4px; background: var(--marinho-claro); }
.kpi.vermelho::before { background: var(--vermelho); }
.kpi.verde::before { background: var(--verde); }
.kpi.dourado::before { background: var(--dourado); }
.kpi .rotulo { font-size: 12px; color: var(--texto-suave); text-transform: uppercase; letter-spacing: .6px; font-weight: 600; }
.kpi .valor { font-family:'Oswald'; font-size: 32px; color: var(--tinta); margin-top: 6px; line-height: 1; }
.kpi .nota { font-size: 12px; color: var(--texto-suave); margin-top: 7px; }
.kpi .nota.sobe { color: var(--verde); }
.kpi .nota.desce { color: var(--vermelho); }

.card { background: var(--branco); border: 1px solid var(--linha); border-radius: 11px; box-shadow: var(--sombra); margin-bottom: 20px; }
.card-head { padding: 15px 20px; border-bottom: 1px solid var(--linha); display:flex; justify-content:space-between; align-items:center; }
.card-head h2 { font-size: 16px; text-transform: uppercase; }
.card-corpo { padding: 20px; }
.card-corpo.sem-pad { padding: 0; }

/* ---------------- TABELAS ---------------- */
.tabela-wrap { overflow-x: auto; }
table.dados { width: 100%; border-collapse: collapse; font-size: 13.5px; }
table.dados thead th {
  text-align: left; padding: 11px 16px; background: #FAFBFC;
  font-size: 11.5px; text-transform: uppercase; letter-spacing: .5px;
  color: var(--texto-suave); font-weight: 700; border-bottom: 1px solid var(--linha);
  white-space: nowrap;
}
table.dados tbody td { padding: 12px 16px; border-bottom: 1px solid #EEF1F5; vertical-align: middle; }
table.dados tbody tr:hover { background: #FAFBFD; }
table.dados tbody tr:last-child td { border-bottom: 0; }
.col-acoes { text-align: right; white-space: nowrap; }
.col-acoes a { margin-left: 4px; }

/* ---------------- BADGES ---------------- */
.badge { display: inline-block; padding: 3px 10px; border-radius: 20px; font-size: 11.5px; font-weight: 600; letter-spacing:.2px; }
.badge.verde { background: #E3F4EB; color: var(--verde); }
.badge.vermelho { background: #FBE3E7; color: var(--vermelho-esc); }
.badge.ambar { background: #FBF0DC; color: var(--ambar); }
.badge.azul { background: #E3ECF7; color: #1E5AA8; }
.badge.cinza { background: #ECEFF3; color: var(--texto-suave); }

/* ---------------- FORMULÁRIOS ---------------- */
.form-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px 20px; }
.campo { display: flex; flex-direction: column; }
.campo.full { grid-column: 1 / -1; }
.campo label { font-size: 12.5px; font-weight: 600; color: var(--texto); margin-bottom: 6px; }
.campo label .obrig { color: var(--vermelho); }
.campo input, .campo select, .campo textarea {
  padding: 10px 12px; border: 1px solid var(--linha); border-radius: 8px;
  font-size: 14px; font-family: 'Inter'; color: var(--texto); background: var(--branco); transition: border .15s, box-shadow .15s;
}
.campo input:focus, .campo select:focus, .campo textarea:focus {
  outline: none; border-color: var(--marinho-claro); box-shadow: 0 0 0 3px rgba(37,64,95,.1);
}
.campo textarea { resize: vertical; min-height: 80px; }
.form-acoes { display: flex; gap: 10px; margin-top: 22px; padding-top: 18px; border-top: 1px solid var(--linha); }

/* ---------------- FLASH ---------------- */
.flash { padding: 13px 18px; border-radius: 9px; margin-bottom: 18px; font-size: 13.5px; display:flex; align-items:center; gap:10px; }
.flash.sucesso { background: #E3F4EB; color: var(--verde); border: 1px solid #BFE6CF; }
.flash.erro { background: #FBE3E7; color: var(--vermelho-esc); border: 1px solid #F2C4CC; }
.flash.aviso { background: #FBF0DC; color: var(--ambar); border: 1px solid #ECD9B0; }

/* ---------------- VAZIO ---------------- */
.vazio { text-align: center; padding: 50px 20px; color: var(--texto-suave); }
.vazio svg { width: 46px; height: 46px; opacity: .3; margin-bottom: 12px; }
.vazio h3 { color: var(--texto); font-size: 18px; margin-bottom: 6px; }

/* ---------------- FILTROS ---------------- */
.barra-filtro { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 18px; align-items: center; }
.barra-filtro input, .barra-filtro select { padding: 9px 12px; border: 1px solid var(--linha); border-radius: 8px; font-size: 13.5px; background:#fff; }
.barra-filtro .busca { flex: 1; min-width: 200px; }

/* ---------------- PAGINAÇÃO ---------------- */
.paginacao { display: flex; gap: 5px; justify-content: center; padding: 16px; }
.paginacao a, .paginacao span { padding: 7px 12px; border: 1px solid var(--linha); border-radius: 7px; font-size: 13px; color: var(--texto); }
.paginacao a:hover { background: var(--fundo); text-decoration:none; }
.paginacao .atual { background: var(--marinho); color: #fff; border-color: var(--marinho); }

/* ---------------- OVERLAY MOBILE ---------------- */
.overlay-mobile { display: none; position: fixed; inset: 0; background: rgba(15,28,46,.5); z-index: 39; }

/* ---------------- RESPONSIVO ---------------- */
@media (max-width: 900px) {
  .sidebar { transform: translateX(-100%); }
  .sidebar.aberta { transform: translateX(0); }
  .conteudo { margin-left: 0; }
  .topbar .menu-btn { display: block; }
  .overlay-mobile.visivel { display: block; }
  .form-grid { grid-template-columns: 1fr; }
  .page-head h1 { font-size: 22px; }
  .pagina { padding: 18px; }
}

/* ---------------- IMPRESSÃO ---------------- */
@media print {
  .sidebar, .topbar, .form-acoes, .btn, .barra-filtro { display: none !important; }
  .conteudo { margin-left: 0; }
  body { background: #fff; }
  .card { box-shadow: none; border: 1px solid #ccc; }
}

/* =====================================================================
   QUARTOS — Painel de portas (elemento-assinatura)
   Cada quarto é uma cela/alojamento com porta que reflete o estado real.
   ===================================================================== */
.painel-quartos { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px,1fr)); gap: 18px; }

.cela {
  background: var(--branco); border: 1px solid var(--linha); border-radius: 12px;
  box-shadow: var(--sombra); overflow: hidden; display: flex; flex-direction: column;
}
.cela-topo {
  display: flex; align-items: center; justify-content: space-between;
  padding: 13px 16px; border-bottom: 1px solid var(--linha);
}
.cela-topo .num { font-family:'Oswald'; font-size: 19px; color: var(--tinta); text-transform: uppercase; letter-spacing:.5px; }
.cela-topo .num small { display:block; font-family:'Inter'; font-size: 11.5px; color: var(--texto-suave); letter-spacing:0; text-transform:none; margin-top:1px; }

/* Tarjeta de estado (placa) */
.placa { font-size: 11px; font-weight: 700; letter-spacing:.7px; text-transform: uppercase; padding: 4px 10px; border-radius: 5px; }
.placa.disponivel { background:#E3F4EB; color:var(--verde); }
.placa.reservado  { background:#FBF0DC; color:var(--ambar); }
.placa.parcial    { background:#E3ECF7; color:#1E5AA8; }
.placa.ocupado    { background:#FBE3E7; color:var(--vermelho-esc); }
.placa.manutencao,.placa.interditado { background:#ECEFF3; color:var(--texto-suave); }

/* Cena da porta */
.porta-cena {
  position: relative; height: 168px; display: grid; place-items: center;
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(15,28,46,.04), transparent 60%),
    repeating-linear-gradient(90deg, #F7F8FA 0 22px, #F2F4F7 22px 24px); /* piso sutil */
  border-bottom: 1px solid var(--linha);
  perspective: 720px;
}
/* Batente / vão da porta */
.vao {
  position: relative; width: 96px; height: 134px; border-radius: 6px 6px 0 0;
  background: linear-gradient(180deg, #1A2433, #0F1C2E); /* interior escuro do quarto */
  box-shadow: inset 0 0 0 3px rgba(255,255,255,.04);
}
/* Luz do batente — cor conforme estado */
.vao::before {
  content:''; position:absolute; inset:-3px; border-radius: 8px 8px 0 0;
  padding: 3px; z-index:0; pointer-events:none;
}
/* A folha da porta */
.folha {
  position:absolute; top:0; left:0; width:100%; height:100%;
  border-radius: 5px 5px 0 0;
  background:
    linear-gradient(180deg, #C8102E 0%, #A50D26 100%);
  transform-origin: left center; transition: transform .55s cubic-bezier(.4,.1,.2,1), filter .3s;
  box-shadow: inset -6px 0 12px rgba(0,0,0,.18), inset 2px 0 0 rgba(255,255,255,.12);
  border-right: 2px solid rgba(0,0,0,.25);
}
/* Almofadas da porta (painéis) */
.folha::before, .folha::after {
  content:''; position:absolute; left:14px; right:14px; border-radius:3px;
  border:1.5px solid rgba(0,0,0,.18); box-shadow: inset 0 1px 0 rgba(255,255,255,.1);
}
.folha::before { top:12px; height:44px; }
.folha::after  { bottom:12px; height:44px; }
/* Maçaneta */
.macaneta { position:absolute; right:9px; top:50%; width:8px; height:8px; border-radius:50%;
  background: radial-gradient(circle at 35% 35%, #FFE9A8, #C9A227); transform: translateY(-50%);
  box-shadow: 0 0 0 2px rgba(0,0,0,.15); z-index:3; }
/* Placa numérica na porta */
.folha .chapa { position:absolute; top:8px; left:50%; transform:translateX(-50%);
  font-family:'Oswald'; font-size:12px; color:#fff; opacity:.92; letter-spacing:1px; z-index:3;
  background:rgba(0,0,0,.18); padding:1px 7px; border-radius:3px; }

/* ESTADOS */
/* Disponível: porta entreaberta + luz verde no vão */
.cela[data-estado="disponivel"] .folha { transform: rotateY(-58deg); filter:brightness(1.02); }
.cela[data-estado="disponivel"] .vao  { box-shadow: inset 0 0 26px rgba(28,122,77,.55), inset 0 0 0 3px rgba(28,122,77,.25); }
.cela[data-estado="disponivel"] .vao::after {
  content:'LIVRE'; position:absolute; bottom:14px; left:0; right:0; text-align:center;
  font-family:'Oswald'; font-size:12px; letter-spacing:2px; color:#7EE2A8; z-index:1;
}
/* Parcial: porta entreaberta, luz azul (há vaga, mas alguém dentro) */
.cela[data-estado="parcial"] .folha { transform: rotateY(-34deg); }
.cela[data-estado="parcial"] .vao  { box-shadow: inset 0 0 24px rgba(30,90,168,.5), inset 0 0 0 3px rgba(30,90,168,.22); }

/* Reservado: porta fechada + faixa âmbar */
.cela[data-estado="reservado"] .folha { transform: rotateY(0); }
.cela[data-estado="reservado"] .vao  { box-shadow: inset 0 0 0 3px rgba(183,121,31,.5); }
.cela[data-estado="reservado"] .fita {
  position:absolute; z-index:4; top:54%; left:-6px; right:-6px; transform:translateY(-50%) rotate(-7deg);
  background: repeating-linear-gradient(45deg,#B7791F 0 12px,#8a5a14 12px 24px);
  color:#fff; font-family:'Oswald'; font-size:11px; letter-spacing:1px; text-align:center; padding:3px 0;
  box-shadow:0 2px 6px rgba(0,0,0,.3); text-transform:uppercase;
}
/* Ocupado: porta fechada, sombra vermelha, sem brecha */
.cela[data-estado="ocupado"] .folha { transform: rotateY(0); filter:brightness(.94); }
.cela[data-estado="ocupado"] .vao  { box-shadow: inset 0 0 0 3px rgba(200,16,46,.55); }
.cela[data-estado="ocupado"] .selo-ocup {
  position:absolute; z-index:4; bottom:16px; left:50%; transform:translateX(-50%);
  background:var(--vermelho); color:#fff; font-family:'Oswald'; font-size:11px; letter-spacing:1.5px;
  padding:3px 11px; border-radius:4px; box-shadow:0 3px 8px rgba(200,16,46,.4);
}
/* Bloqueado (manutenção/interditado): fita diagonal de bloqueio */
.cela[data-estado="manutencao"] .folha,
.cela[data-estado="interditado"] .folha { transform: rotateY(0); filter:grayscale(.6) brightness(.85); }
.cela[data-estado="manutencao"] .vao,
.cela[data-estado="interditado"] .vao { box-shadow: inset 0 0 0 3px rgba(94,107,126,.5); }
.cela[data-estado="manutencao"] .fita-bloq,
.cela[data-estado="interditado"] .fita-bloq {
  position:absolute; z-index:5; inset:0; pointer-events:none;
  background: repeating-linear-gradient(-45deg, rgba(20,20,20,.0) 0 14px, rgba(60,60,60,.0) 14px 16px);
}
.cela[data-estado="manutencao"] .fita-bloq::after,
.cela[data-estado="interditado"] .fita-bloq::after {
  content:''; position:absolute; top:50%; left:-10%; right:-10%; height:18px; transform:translateY(-50%) rotate(-10deg);
  background: repeating-linear-gradient(45deg,#3a4252 0 14px,#FFC400 14px 28px); opacity:.92;
}

/* Hover discreto: a cena "acende" levemente */
.cela:hover .porta-cena { background-color: #fbfcfe; }
.cela:hover .folha { filter: brightness(1.05); }

@media (prefers-reduced-motion: reduce) {
  .folha { transition: none; }
}

/* Rodapé da cela: leitos + ações */
.cela-corpo { padding: 14px 16px; display:flex; flex-direction:column; gap:12px; flex:1; }
.cela-meta { display:flex; justify-content:space-between; font-size:12.5px; color:var(--texto-suave); }
.cela-meta strong { color: var(--tinta); }
.leitos-chips { display:flex; flex-wrap:wrap; gap:6px; }
.leito-chip { display:inline-flex; align-items:center; gap:5px; font-size:11.5px; font-weight:600; padding:3px 9px; border-radius:20px; }
.leito-chip .pt { width:7px; height:7px; border-radius:50%; }
.leito-chip.livre   { background:#E3F4EB; color:var(--verde); }
.leito-chip.livre .pt   { background:var(--verde); }
.leito-chip.ocupado { background:#FBE3E7; color:var(--vermelho-esc); }
.leito-chip.ocupado .pt { background:var(--vermelho); }
.leito-chip.manut   { background:#FBF0DC; color:var(--ambar); }
.leito-chip.manut .pt   { background:var(--ambar); }
.cela-rodape { display:flex; gap:7px; border-top:1px solid var(--linha); padding-top:12px; margin-top:auto; }

/* Legenda dos estados */
.legenda { display:flex; flex-wrap:wrap; gap:16px; margin-bottom:20px; padding:13px 18px; background:var(--branco); border:1px solid var(--linha); border-radius:10px; }
.legenda .it { display:flex; align-items:center; gap:8px; font-size:12.5px; color:var(--texto); }
.legenda .mini { width:26px; height:20px; border-radius:3px 3px 0 0; position:relative; flex-shrink:0; box-shadow:inset 0 0 0 2px rgba(0,0,0,.06); }
.legenda .mini.disp { background:linear-gradient(180deg,#1A2433,#0F1C2E); box-shadow:inset 0 0 0 2px rgba(28,122,77,.6); }
.legenda .mini.disp::after{ content:''; position:absolute; left:2px; top:2px; bottom:2px; width:9px; background:var(--vermelho); transform:perspective(40px) rotateY(-40deg); transform-origin:left; border-radius:2px; }
.legenda .mini.res { background:#0F1C2E; box-shadow:inset 0 0 0 2px rgba(183,121,31,.7); }
.legenda .mini.res::after{ content:''; position:absolute; inset:2px; background:var(--vermelho); border-radius:2px; }
.legenda .mini.ocu { background:#0F1C2E; box-shadow:inset 0 0 0 2px rgba(200,16,46,.7); }
.legenda .mini.ocu::after{ content:''; position:absolute; inset:2px; background:var(--vermelho); filter:brightness(.85); border-radius:2px; }
.legenda .mini.blo { background:#0F1C2E; }
.legenda .mini.blo::after{ content:''; position:absolute; top:50%; left:-2px; right:-2px; height:5px; transform:translateY(-50%) rotate(-12deg); background:repeating-linear-gradient(45deg,#3a4252 0 4px,#FFC400 4px 8px); }

/* Brasão na sidebar */
.brasao-side { width: 46px; height: auto; flex-shrink:0; filter: drop-shadow(0 2px 4px rgba(0,0,0,.4)); }

/* =====================================================================
   SIDEBAR RETRÁTIL (desktop) — recolhe para faixa de ícones
   ===================================================================== */
.conteudo { transition: margin-left .22s ease; }
.sidebar { transition: width .22s ease, transform .25s ease; }

@media (min-width: 901px) {
  .app.sidebar-recolhida .sidebar { width: 74px; }
  .app.sidebar-recolhida .conteudo { margin-left: 74px; }

  /* Esconde textos, mantém ícones centralizados */
  .app.sidebar-recolhida .sidebar-brasao { justify-content: center; padding: 18px 0; }
  .app.sidebar-recolhida .sidebar-brasao > div,
  .app.sidebar-recolhida .nav-grupo,
  .app.sidebar-recolhida .sidebar-rodape { display: none; }
  .app.sidebar-recolhida .brasao-side { width: 40px; }

  .app.sidebar-recolhida .nav a {
    justify-content: center; padding: 12px 0; position: relative;
  }
  .app.sidebar-recolhida .nav a span.rotulo { display: none; }
  .app.sidebar-recolhida .nav a svg { width: 19px; height: 19px; }

  /* Tooltip ao passar o mouse no item recolhido */
  .app.sidebar-recolhida .nav a::after {
    content: attr(data-rotulo);
    position: absolute; left: calc(100% + 10px); top: 50%; transform: translateY(-50%);
    background: var(--tinta); color: #fff; font-size: 12.5px; font-weight: 600;
    padding: 6px 11px; border-radius: 6px; white-space: nowrap; pointer-events: none;
    opacity: 0; transition: opacity .12s; z-index: 60; box-shadow: 0 4px 14px rgba(0,0,0,.25);
  }
  .app.sidebar-recolhida .nav a:hover::after { opacity: 1; }
}

/* Botão de menu também visível no desktop (vira o toggle de recolher) */
@media (min-width: 901px) {
  .topbar .menu-btn { display: block; }
}
