/* Portal Staff — Villela Stay. Paleta alinhada ao site público. */
:root {
  --petroleo: #0c3644;
  --creme: #f2ecd8;
  --lago: #1c6e8c;
  --lago-escuro: #145066;
  --cerrado: #d9a441;
  --areia: #f7f4ee;
  --concreto: #2b2d2f;
  --concreto-claro: #6b7075;
  --borda: #e3ddd0;
  --ok: #2e7d32;
  --alerta: #b3261e;
  --branco: #fff;
}
* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
  color: var(--concreto); background: var(--areia); line-height: 1.55;
}
.hidden { display: none !important; }
a { color: var(--lago); text-decoration: none; }
a:hover { text-decoration: underline; }
.marca { font-size: 1.25rem; font-weight: 800; letter-spacing: -.5px; color: var(--creme); }
.tag { font-size: .7rem; background: var(--cerrado); color: var(--petroleo); padding: 2px 8px; border-radius: 10px; vertical-align: middle; font-weight: 800; }
.erro { color: var(--alerta); font-size: .9rem; min-height: 1.2em; margin: 6px 0 0; }
.ok-msg { color: var(--ok); font-size: .9rem; }

/* ---------- login ---------- */
.login { min-height: 100vh; display: grid; place-items: center; padding: 24px;
  background: linear-gradient(160deg, var(--petroleo) 0%, var(--lago-escuro) 100%); }
.login-card { background: var(--branco); width: 100%; max-width: 380px; padding: 32px 28px;
  border-radius: 16px; box-shadow: 0 18px 50px rgba(0,0,0,.3); display: flex; flex-direction: column; gap: 14px; }
.login-card .marca { color: var(--petroleo); text-align: center; font-size: 1.5rem; }
.login-sub { text-align: center; color: var(--concreto-claro); margin: -6px 0 6px; font-size: .92rem; }
.login-card label, .form label { display: flex; flex-direction: column; gap: 5px; font-size: .85rem; font-weight: 600; color: var(--concreto); }
input, select, textarea { font: inherit; padding: 10px 12px; border: 1px solid var(--borda); border-radius: 9px; background: #fff; color: var(--concreto); }
input:focus, select:focus, textarea:focus { outline: 2px solid var(--lago); border-color: var(--lago); }

.btn { display: inline-block; background: var(--lago); color: #fff; font-weight: 700; border: none;
  padding: 11px 18px; border-radius: 24px; cursor: pointer; font-size: .95rem; }
.btn:hover { background: var(--lago-escuro); }
.btn.secund { background: #fff; color: var(--lago); border: 1.5px solid var(--lago); }
.btn.perigo { background: #fff; color: var(--alerta); border: 1.5px solid var(--alerta); }
.btn.peq { padding: 6px 12px; font-size: .82rem; }

/* ---------- app ---------- */
.topo { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 12px 4vw;
  background: var(--petroleo); border-bottom: 3px solid var(--cerrado); position: sticky; top: 0; z-index: 10; }
.btn-menu { display: none; background: none; border: 1px solid rgba(242,236,216,.4); color: var(--creme);
  border-radius: 10px; font-size: 1.2rem; line-height: 1; padding: 4px 11px; cursor: pointer; }
.topo-dir { display: flex; align-items: center; gap: 14px; color: var(--creme); font-size: .9rem; }
.link-sair { background: none; border: 1px solid var(--creme); color: var(--creme); border-radius: 18px; padding: 5px 14px; cursor: pointer; font-size: .85rem; }
.btn-inicio { background: rgba(242,236,216,.12); border: 1px solid var(--creme); color: var(--creme); border-radius: 18px; padding: 5px 12px; cursor: pointer; font-size: .85rem; display: inline-flex; align-items: center; gap: 4px; white-space: nowrap; }
.btn-inicio:hover { background: rgba(242,236,216,.24); }
/* Visor de relatório/arquivo embutido no app (dashboard HTML, PDF, imagem), com botão Voltar */
.visor-topo { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 10px; }
.visor-arquivo { width: 100%; height: calc(100vh - 195px); min-height: 380px; border: 1px solid var(--borda); border-radius: 12px; background: #fff; }
.link-sair:hover { background: rgba(255,255,255,.12); }
.link-site { color: var(--creme); border: 1px solid rgba(242,236,216,.5); border-radius: 18px; padding: 5px 14px; font-size: .85rem; white-space: nowrap; }
.link-site:hover { background: rgba(255,255,255,.12); border-color: var(--cerrado); }
.login-voltar { display: block; text-align: center; margin-top: 14px; color: var(--lago); font-size: .88rem; }
.login-voltar:hover { text-decoration: underline; }
.corpo { display: flex; min-height: calc(100vh - 56px); }
/* Sidebar escura na identidade da marca (petróleo + cerrado), fixa na rolagem */
.menu { width: 248px; background: linear-gradient(180deg, var(--petroleo) 0%, var(--lago-escuro) 100%);
  padding: 12px 0 24px; flex-shrink: 0; position: sticky; top: 56px; align-self: flex-start;
  max-height: calc(100vh - 56px); overflow-y: auto; }
.menu::-webkit-scrollbar { width: 8px; }
.menu::-webkit-scrollbar-thumb { background: rgba(255,255,255,.18); border-radius: 4px; }
.menu button { display: flex; align-items: center; gap: 8px; width: calc(100% - 16px); margin: 1px 8px; text-align: left;
  background: none; border: none; cursor: pointer; padding: 9px 14px; font-size: .9rem; color: var(--creme);
  border-radius: 9px; opacity: .92; }
.menu button:hover { background: rgba(255,255,255,.08); opacity: 1; }
.menu button.ativo { background: rgba(217,164,65,.18); box-shadow: inset 3px 0 0 var(--cerrado); font-weight: 700; color: #fff; opacity: 1; }
.menu a.link-externo { display: block; margin: 1px 8px; padding: 9px 14px; font-size: .88rem; color: var(--creme);
  text-decoration: none; opacity: .8; border-radius: 9px; }
.menu a.link-externo:hover { background: rgba(255,255,255,.08); opacity: 1; text-decoration: none; }
.menu .grupo { font-size: .68rem; text-transform: uppercase; letter-spacing: .8px; color: var(--cerrado); padding: 16px 22px 5px; font-weight: 800; }
.badge-menu { margin-left: auto; background: var(--cerrado); color: var(--petroleo); font-size: .68rem; font-weight: 800; border-radius: 10px; padding: 1px 7px; }
.conteudo { flex: 1; padding: 28px 4vw; max-width: 1180px; }
h1.titulo { font-size: 1.5rem; margin: 0 0 4px; color: var(--petroleo); }
.sub { color: var(--concreto-claro); margin: 0 0 22px; }

/* ---------- Home-lançador (grade de ícones, estilo app) ---------- */
.launcher { background: linear-gradient(160deg, var(--petroleo) 0%, var(--lago-escuro) 100%);
  border-radius: 16px; padding: 18px 16px 20px; margin-bottom: 24px; display: flex; flex-direction: column; gap: 18px;
  box-shadow: 0 6px 20px rgba(12,54,68,.16); }
.launcher:empty { display: none; }
.lc-grupo { display: flex; flex-direction: column; gap: 10px; }
.lc-titulo { font-size: .72rem; font-weight: 800; text-transform: uppercase; letter-spacing: .6px; color: var(--cerrado); padding-left: 2px; }
.lc-itens { display: grid; grid-template-columns: repeat(auto-fill, minmax(84px, 1fr)); gap: 14px 6px; }
.lc-tile { background: none; border: none; padding: 4px 2px; cursor: pointer; display: flex; flex-direction: column;
  align-items: center; gap: 7px; color: inherit; text-decoration: none; }
.lc-ico { position: relative; width: 58px; height: 58px; border-radius: 17px; background: rgba(242,236,216,.10);
  display: flex; align-items: center; justify-content: center; font-size: 1.7rem; transition: background .15s, transform .1s; }
.lc-tile:hover .lc-ico { background: rgba(242,236,216,.20); }
.lc-tile:active .lc-ico { transform: scale(.93); }
.lc-rot { font-size: .72rem; color: #e7eef0; text-align: center; line-height: 1.2; max-width: 88px; }
.lc-tile:hover .lc-rot { text-decoration: none; color: #fff; }
.lc-badge { position: absolute; top: -4px; right: -4px; background: var(--cerrado); color: var(--petroleo);
  font-size: .64rem; font-weight: 800; border-radius: 10px; padding: 0 6px; min-width: 16px; text-align: center; }

/* cards */
.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 14px; margin-bottom: 26px; }
.card { background: #fff; border: 1px solid var(--borda); border-radius: 14px; padding: 16px 18px;
  box-shadow: 0 1px 3px rgba(12,54,68,.06); transition: box-shadow .15s, transform .15s; }
.card:hover { box-shadow: 0 4px 14px rgba(12,54,68,.12); transform: translateY(-1px); }
.card .n { font-size: 1.9rem; font-weight: 800; color: var(--lago); }
.card .rot { color: var(--concreto-claro); font-size: .85rem; }

/* listas / tabelas */
.lista { display: flex; flex-direction: column; gap: 10px; }
.item { background: #fff; border: 1px solid var(--borda); border-radius: 12px; padding: 14px 16px; }
.item h3 { margin: 0 0 4px; font-size: 1.02rem; }
.item .meta { font-size: .8rem; color: var(--concreto-claro); display: flex; gap: 10px; flex-wrap: wrap; }
.chip { display: inline-block; background: var(--areia); border: 1px solid var(--borda); border-radius: 20px; padding: 2px 10px; font-size: .76rem; color: var(--concreto); }
.chip.tipo-produto { background: #eef6ee; border-color: #cfe6cf; }
.chip.tipo-servico { background: #fff4e0; border-color: #f0dca6; }
.acoes { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 10px; }

table { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--borda); border-radius: 12px; overflow: hidden; }
th, td { text-align: left; padding: 9px 12px; border-bottom: 1px solid var(--borda); font-size: .88rem; vertical-align: top; }
th { background: var(--areia); font-size: .76rem; text-transform: uppercase; letter-spacing: .4px; color: var(--concreto-claro); }
tr:last-child td { border-bottom: none; }

.barra { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 18px; }
.barra select, .barra input { padding: 8px 11px; }
.vazio { color: var(--concreto-claro); background: #fff; border: 1px dashed var(--borda); border-radius: 12px; padding: 24px; text-align: center; }

/* leitor de relatório (markdown) */
.doc { background: #fff; border: 1px solid var(--borda); border-radius: 12px; padding: 24px 28px; }
.doc h1, .doc h2, .doc h3 { color: var(--petroleo); }
.doc h1 { font-size: 1.4rem; } .doc h2 { font-size: 1.15rem; } .doc h3 { font-size: 1rem; }
.doc code { background: var(--areia); padding: 1px 5px; border-radius: 5px; font-size: .9em; }
.doc table { margin: 12px 0; }
.doc iframe { width: 100%; height: 78vh; border: 1px solid var(--borda); border-radius: 8px; }
.doc blockquote { margin: 12px 0; padding: 10px 16px; background: var(--areia); border-left: 4px solid var(--cerrado); border-radius: 0 8px 8px 0; color: var(--concreto); }
.doc blockquote p, .doc blockquote { font-size: .92rem; }
.doc ul { padding-left: 22px; } .doc li { margin: 3px 0; }
.doc p { margin: 10px 0; }

/* formulários */
.form { display: grid; gap: 14px; max-width: 520px; background: #fff; border: 1px solid var(--borda); border-radius: 12px; padding: 22px; }
.areas-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px,1fr)); gap: 6px; }
.areas-grid label { flex-direction: row; align-items: center; gap: 7px; font-weight: 500; }
.areas-grid input { width: auto; }
/* editores da Área do Hóspede (serviços e fidelidade) */
.hi-bloco { border: 1px solid var(--borda); border-radius: 12px; background: #fff; padding: 12px 16px; margin-bottom: 14px; }
.hi-bloco > summary { cursor: pointer; font-size: .98rem; padding: 4px 0; }
.hi-bloco[open] > summary { margin-bottom: 12px; border-bottom: 1px solid var(--borda); padding-bottom: 10px; }
.serv-edit { display: grid; grid-template-columns: 56px 1.2fr 1fr 1.6fr auto auto; gap: 8px; align-items: center; margin-bottom: 8px; }
.serv-edit input[type="text"], .serv-edit input:not([type]) { padding: 7px 9px; }
.serv-ativo { display: flex; align-items: center; gap: 5px; font-size: .82rem; white-space: nowrap; }
.serv-ativo input { width: auto; }
.btn.peq.perigo { padding: 4px 10px; line-height: 1; }
@media (max-width: 760px) { .serv-edit { grid-template-columns: 1fr 1fr; } }

/* grade de campos (rótulo em cima, input ocupando a coluna toda) — p/ a tela Área do Hóspede */
.form-larga { max-width: 720px; }
.hi-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 16px; }
.hi-grid input { width: 100%; }
.hi-grid-3 { grid-template-columns: 1fr 1fr 1fr; }
@media (max-width: 600px) { .hi-grid, .hi-grid-3 { grid-template-columns: 1fr; } }
/* Cartão do arquivo de manutenção (histórico pesquisável) */
.card-arq { background: #fff; border: 1px solid var(--borda); border-radius: 12px; padding: 12px 14px; margin-bottom: 10px; }
.card-arq-top { display: flex; justify-content: space-between; align-items: baseline; gap: 10px; }
.card-arq-top b { font-size: .98rem; }
.card-arq-top a { text-decoration: none; }
/* Grade de especialidades (cadastro de técnico) */
.tec-espec { display: grid; grid-template-columns: 1fr 1fr; gap: 4px 14px; margin-top: 6px; }
.tec-espec .tec-chk { flex-direction: row; align-items: center; gap: 6px; font-weight: 500; font-size: .9rem; }
.tec-espec .tec-chk input { width: auto; }
@media (max-width: 600px) { .tec-espec { grid-template-columns: 1fr; } }
.aviso { background: #fff7e6; border: 1px solid #f0dca6; border-radius: 10px; padding: 12px 14px; font-size: .88rem; margin-bottom: 18px; }

/* ---------- CRM / Funil ---------- */
.kanban { display: flex; gap: 12px; overflow-x: auto; padding-bottom: 14px; align-items: flex-start; }
.kanban .col { background: var(--areia); border: 1px solid var(--borda); border-radius: 12px; width: 216px; flex-shrink: 0; display: flex; flex-direction: column; }
.col-head { display: flex; justify-content: space-between; align-items: center; padding: 10px 12px; font-weight: 700; color: var(--petroleo); font-size: .9rem; }
.col-n { background: var(--lago); color: #fff; border-radius: 12px; padding: 0 8px; font-size: .74rem; }
.col-valor { padding: 0 12px 6px; font-size: .78rem; color: var(--concreto-claro); }
.col-cards { padding: 6px; display: flex; flex-direction: column; gap: 8px; min-height: 44px; flex: 1; }
.col-cards.sobre { background: #e2eef2; border-radius: 8px; outline: 2px dashed var(--lago); }
.col-vazio { text-align: center; color: var(--concreto-claro); font-size: .8rem; padding: 8px; }
/* Manutenção: as 3 colunas (aberto/agendado/em execução) dividem por igual a largura,
   ocupando a mesma faixa do box "➕ Novo chamado" (só neste quadro; os demais kanbans seguem fixos). */
#ch-board .col { width: auto; flex: 1 1 0; min-width: 180px; }
.kard { background: #fff; border: 1px solid var(--borda); border-left: 3px solid var(--lago); border-radius: 8px; padding: 9px 11px; cursor: grab; }
.kard:hover { box-shadow: 0 2px 8px rgba(0,0,0,.1); }
.kard.arrastando { opacity: .45; }
.kard-nome { font-weight: 700; font-size: .9rem; }
.kard-wa { float: right; text-decoration: none; font-size: .95rem; }
.kard-wa:hover { text-decoration: none; transform: scale(1.15); display: inline-block; }
.card-nav { cursor: pointer; }
.kard-meta { display: flex; gap: 5px; flex-wrap: wrap; margin: 5px 0; }
.kard-meta .chip { font-size: .72rem; padding: 1px 8px; }
.kard-acao { font-size: .76rem; border-radius: 6px; padding: 2px 7px; display: inline-block; margin-top: 3px; background: var(--areia); }
.kard-acao.atrasado { background: #fde7e6; color: var(--alerta); font-weight: 600; }
.kard-acao.hoje { background: #fff4e0; color: #9a6b00; font-weight: 600; }
.kard-acao.futuro { background: #eef6ee; color: var(--ok); }
.kard-origem { font-size: .67rem; color: var(--concreto-claro); margin-top: 4px; text-transform: uppercase; letter-spacing: .3px; }

.followups { background: #fff; border: 1px solid var(--borda); border-left: 4px solid var(--cerrado); border-radius: 10px; padding: 10px 14px; margin-bottom: 16px; display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.fu-chip { background: var(--areia); border: 1px solid var(--borda); border-radius: 16px; padding: 3px 11px; font-size: .78rem; cursor: pointer; color: var(--concreto); }
.fu-chip.atrasado { background: #fde7e6; border-color: #f3c9c6; color: var(--alerta); }
.fu-chip.hoje { background: #fff4e0; border-color: #f0dca6; }

.ficha { display: flex; gap: 18px; flex-wrap: wrap; align-items: flex-start; }
.ficha-col { flex: 1; min-width: 280px; display: flex; flex-direction: column; gap: 16px; }
.ficha-bloco { background: #fff; border: 1px solid var(--borda); border-radius: 12px; padding: 16px 18px; }
.ficha-bloco h3 { margin: 0 0 12px; color: var(--petroleo); font-size: 1rem; }
.ficha-bloco label { display: flex; flex-direction: column; gap: 5px; font-size: .82rem; font-weight: 600; margin-bottom: 10px; }
.ficha-bloco hr { border: none; border-top: 1px solid var(--borda); margin: 14px 0; }
.kv { display: flex; justify-content: space-between; gap: 10px; padding: 5px 0; border-bottom: 1px dashed var(--borda); font-size: .86rem; }
.kv:last-child { border-bottom: none; }
.kv span { color: var(--concreto-claro); }
.timeline { display: flex; flex-direction: column; gap: 10px; }
.tl-item { border-left: 2px solid var(--lago); padding: 2px 0 2px 12px; font-size: .86rem; }
.tl-tipo { display: inline-block; background: var(--areia); border: 1px solid var(--borda); border-radius: 10px; padding: 0 7px; font-size: .7rem; color: var(--concreto-claro); margin-right: 5px; }
.tl-data { font-size: .72rem; color: var(--concreto-claro); margin-top: 2px; }
.stays-totais { display: flex; gap: 16px; flex-wrap: wrap; padding-bottom: 10px; margin-bottom: 8px; border-bottom: 1px solid var(--borda); font-size: .9rem; }
.stays-res { padding: 8px 0; border-bottom: 1px dashed var(--borda); }
.stays-res:last-child { border-bottom: none; }
.stays-res-top { display: flex; justify-content: space-between; align-items: center; gap: 8px; font-size: .9rem; }
.stays-res-top .chip { font-size: .7rem; padding: 1px 8px; }
.stays-res-meta { font-size: .8rem; color: var(--concreto-claro); margin-top: 2px; }

@media (max-width: 760px) {
  .corpo { flex-direction: column; }
  .btn-menu { display: inline-flex; align-items: center; }
  .rot-inicio { display: none; } /* no celular mostra só o 🏠 para poupar espaço no cabeçalho */
  .topo-dir { gap: 9px; }
  /* No celular o menu vira gaveta: escondido por padrão, aberto pelo botão ☰.
     A home mostra o lançador de ícones (estilo app); o menu serve para navegar fora dela. */
  .menu { width: 100%; position: static; max-height: none; display: none; flex-wrap: wrap; gap: 4px; padding: 10px; }
  .menu.aberto { display: flex; }
  .menu button, .menu a.link-externo { width: auto; margin: 0; border-radius: 18px; padding: 7px 13px; }
  .menu button.ativo { box-shadow: none; background: rgba(217,164,65,.3); }
  .menu .grupo { flex-basis: 100%; display: block; color: var(--cerrado); padding: 8px 6px 2px; }
  .ficha { flex-direction: column; }
  .lc-itens { grid-template-columns: repeat(auto-fill, minmax(74px, 1fr)); }
}

/* ---- listas (compras / manutenção / pendências) e agenda ---- */
.lista-itens { margin-top: 14px; display: flex; flex-direction: column; gap: 8px; }
.lista-cab { display: flex; justify-content: space-between; align-items: center; font-size: .85rem; color: var(--concreto-claro); margin: 4px 0; }
/* coluna única: cada item é um bloco vertical (qtd, nome, quem empilhados);
   o botão de baixa fica à direita, alinhado ao topo do bloco. */
.linha-item { display: grid; grid-template-columns: 1fr auto; align-items: start; column-gap: 10px; row-gap: 4px;
  background: var(--branco); border: 1px solid var(--borda); border-radius: 10px; padding: 9px 12px; }
.linha-item .qtd { grid-column: 1; justify-self: start; font-weight: 800; color: var(--lago-escuro); text-align: center; background: var(--areia); border-radius: 6px; padding: 3px 8px; font-size: .9rem; }
.linha-item .nome { grid-column: 1; font-weight: 600; color: var(--concreto); }
.linha-item .nome .obs { font-weight: 400; color: var(--concreto-claro); font-size: .9rem; }
.linha-item .quem { grid-column: 1; font-size: .78rem; color: var(--concreto-claro); white-space: normal; }
.linha-item .btn.peq { grid-column: 2; grid-row: 1 / span 3; align-self: center; padding: 4px 9px; white-space: nowrap; }
/* --- Pendências: mural de post-its coloridos + linhas com categoria --- */
.postit-mural { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 14px; margin: 4px 0 22px; }
.postit { background: var(--pcor, #ffe08a); border-radius: 5px; padding: 12px 14px 14px; box-shadow: 0 4px 11px rgba(0,0,0,.14); }
.postit-cab { display: flex; justify-content: space-between; align-items: center; gap: 6px; margin-bottom: 7px; }
.postit-tit { font-weight: 800; color: #3a3320; font-size: .95rem; line-height: 1.2; }
.postit-n { background: rgba(0,0,0,.16); color: #2b2d2f; border-radius: 10px; padding: 0 8px; font-size: .72rem; font-weight: 700; flex-shrink: 0; }
.postit-lista { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 5px; }
.postit-lista li { display: flex; align-items: flex-start; gap: 7px; font-size: .86rem; color: #322d20; line-height: 1.35; }
.postit-check { flex-shrink: 0; width: 19px; height: 19px; border: none; border-radius: 50%; background: rgba(255,255,255,.65); cursor: pointer; font-size: .74rem; line-height: 1; color: var(--lago-escuro); font-weight: 700; }
.postit-check:hover { background: #fff; }
.pend-linha { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; background: #fff; border: 1px solid var(--borda); border-radius: 10px; padding: 9px 12px; }
.pend-linha .nome { flex: 1; min-width: 150px; font-weight: 600; color: var(--concreto); }
.pend-linha .nome .obs { font-weight: 400; color: var(--concreto-claro); font-size: .9rem; }
.pend-linha .quem { font-size: .76rem; color: var(--concreto-claro); }
.cat-badge { font-size: .68rem; font-weight: 800; color: #2b2d2f; padding: 3px 9px; border-radius: 11px; white-space: nowrap; }
.pend-cat-sel { font-size: .78rem; padding: 4px 6px; border: 1px solid var(--borda); border-radius: 8px; background: #fff; max-width: 140px; }
.badge { display: inline-block; font-size: .68rem; font-weight: 700; padding: 1px 7px; border-radius: 10px; text-transform: uppercase; letter-spacing: .3px; margin-right: 4px; }
.st-pendente { background: #fdf3e3; color: #8a5a00; }
.st-feito { background: #e6f4ea; color: var(--ok); }
.st-erro { background: #fdecea; color: var(--alerta); }

/* ============================ Calendário (réplica Stays) ============================ */
.cal-controls { display: flex; gap: 14px 18px; align-items: center; flex-wrap: wrap; margin-bottom: 12px; }
.cal-grp { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.cal-lab { display: flex; flex-direction: row; align-items: center; gap: 5px; font-size: .8rem; font-weight: 600; color: var(--concreto-claro); }
.cal-lab input { padding: 6px 9px; }
.cal-controls select, .cal-controls input { padding: 7px 10px; font-size: .85rem; }
.cal-props { position: relative; }
.cal-props > summary { list-style: none; cursor: pointer; border: 1px solid var(--borda); border-radius: 9px; padding: 7px 12px; font-size: .85rem; background: #fff; user-select: none; }
.cal-props > summary::-webkit-details-marker { display: none; }
.cal-props[open] > summary { border-color: var(--lago); }
.cal-props-lista { position: absolute; z-index: 20; top: calc(100% + 4px); left: 0; width: 320px; max-height: 340px; overflow: auto;
  background: #fff; border: 1px solid var(--borda); border-radius: 10px; box-shadow: 0 12px 30px rgba(0,0,0,.16); padding: 8px; }
.cal-props-acoes { display: flex; gap: 6px; margin-bottom: 6px; }
.cal-prop-it { display: flex; align-items: center; gap: 7px; padding: 4px 6px; font-size: .82rem; border-radius: 6px; }
.cal-prop-it:hover { background: var(--areia); }
.cal-prop-it input { width: auto; }

.cal-legenda { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 10px; font-size: .78rem; color: var(--concreto-claro); }
.cal-leg-it { display: inline-flex; align-items: center; gap: 5px; }
.cal-dot { width: 12px; height: 12px; border-radius: 3px; display: inline-block; }
.cal-dot-bloq, .cal-bar-bloq { background-image: repeating-linear-gradient(45deg, #9aa0a6, #9aa0a6 4px, #c4c8cc 4px, #c4c8cc 8px); }

/* cores por plataforma (barras e bolinhas da legenda) */
.plat-airbnb { background: #ff5a5f; } .plat-booking { background: #1e57c4; } .plat-decolar { background: #ef6d00; }
.plat-expedia { background: #14366b; } .plat-vrbo { background: #0d9488; } .plat-google { background: #34a853; }
.plat-site { background: var(--lago); } .plat-direto { background: var(--cerrado); } .plat-outro { background: #6b7075; }

.cal-scroll { overflow-x: auto; border: 1px solid var(--borda); border-radius: 12px; background: #fff; }
/* --cw é a largura MÍNIMA por dia; com minmax(--cw,1fr) as colunas esticam para preencher a
   largura (um mês inteiro cabe sem rolagem). display:block + width:100% dá largura definida ao 1fr. */
.cal-grade { --cw: 22px; --cw-label: 172px; display: block; width: 100%; }
.cal-faixa-mes, .cal-row { display: grid; align-items: stretch; }
.cal-mes { font-size: .76rem; font-weight: 800; color: var(--petroleo); text-transform: capitalize; padding: 5px 8px; border-left: 1px solid var(--borda); background: var(--areia); position: sticky; }
.cal-faixa-mes { border-bottom: 1px solid var(--borda); }
.cal-cab-row { border-bottom: 1px solid var(--borda); background: var(--areia); }
.cal-cab-dia { grid-row: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 4px 0; border-left: 1px solid var(--borda); font-size: .7rem; color: var(--concreto-claro); }
.cal-cab-dia .cal-num { font-weight: 700; color: var(--concreto); font-size: .82rem; }
.cal-cab-dia.fds { background: #f0ece1; } .cal-cab-dia.hoje { background: #fff4e0; box-shadow: inset 0 -2px 0 var(--cerrado); }
.cal-row { min-height: 38px; border-bottom: 1px solid #f0ece1; }
.cal-row:last-child { border-bottom: none; }
.cal-rot { grid-column: 1; grid-row: 1; position: sticky; left: 0; z-index: 4; background: #fff; border-right: 1px solid var(--borda);
  padding: 4px 10px; display: flex; flex-direction: column; justify-content: center; overflow: hidden; }
.cal-rot b { font-size: .8rem; color: var(--petroleo); }
.cal-rot span { font-size: .72rem; color: var(--concreto-claro); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cal-rot-cab { background: var(--areia); z-index: 5; }
.cal-cell { grid-row: 1; border-left: 1px solid #f0ece1; }
.cal-cell.fds { background: #faf7ef; } .cal-cell.hoje { background: #fff8ea; box-shadow: inset 1px 0 0 var(--cerrado), inset -1px 0 0 var(--cerrado); }
.cal-bar { z-index: 2; align-self: center; height: 24px; margin: 0 1px; border-radius: 6px; color: #fff; font-size: .74rem; font-weight: 600;
  line-height: 24px; padding: 0 8px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; cursor: pointer; box-shadow: 0 1px 2px rgba(0,0,0,.18); }
.cal-bar:hover { filter: brightness(1.07); box-shadow: 0 2px 6px rgba(0,0,0,.28); }
.cal-bar.plat-direto { color: var(--concreto); } .cal-bar.cal-bar-bloq { color: #3c4043; }
.cal-bar.aberta-esq { border-top-left-radius: 0; border-bottom-left-radius: 0; margin-left: 0; }
.cal-bar.aberta-dir { border-top-right-radius: 0; border-bottom-right-radius: 0; margin-right: 0; }
.cal-rodape { font-size: .76rem; color: var(--concreto-claro); margin: 10px 2px 0; }

/* vista mês */
.cal-mes-tit { font-size: 1.1rem; font-weight: 800; color: var(--petroleo); text-transform: capitalize; margin: 4px 0 10px; }
.cal-mes-grade { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.cal-mes-dow { text-align: center; font-size: .74rem; font-weight: 700; color: var(--concreto-claro); text-transform: uppercase; padding: 4px 0; }
.cal-mes-cel { background: #fff; border: 1px solid var(--borda); border-radius: 8px; min-height: 92px; padding: 5px 6px; display: flex; flex-direction: column; gap: 3px; }
.cal-mes-cel.fora { background: var(--areia); opacity: .65; }
.cal-mes-cel.hoje { border-color: var(--cerrado); box-shadow: 0 0 0 2px rgba(217,164,65,.4); }
.cal-mes-num { font-size: .82rem; font-weight: 700; color: var(--concreto); display: flex; justify-content: space-between; align-items: center; }
.cal-mes-ocup { background: var(--lago); color: #fff; border-radius: 10px; font-size: .68rem; padding: 0 7px; font-weight: 700; }
.cal-mes-chip { font-size: .72rem; color: #fff; border-radius: 5px; padding: 1px 6px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; cursor: pointer; }
.cal-mes-chip.plat-direto { color: var(--concreto); } .cal-mes-chip.cal-bar-bloq { color: #3c4043; }

/* modal de detalhe */
.cal-modal { position: fixed; inset: 0; background: rgba(12,54,68,.5); display: grid; place-items: center; z-index: 100; padding: 20px; }
.cal-modal-cx { background: #fff; border-radius: 14px; padding: 22px 24px; width: 100%; max-width: 380px; position: relative; box-shadow: 0 20px 50px rgba(0,0,0,.3); }
.cal-modal-cx h3 { margin: 0 0 12px; color: var(--petroleo); padding-right: 24px; }
.cal-modal-x { position: absolute; top: 12px; right: 14px; background: none; border: none; font-size: 1.1rem; cursor: pointer; color: var(--concreto-claro); }
.cal-det-l { display: flex; justify-content: space-between; gap: 12px; padding: 6px 0; border-bottom: 1px dashed var(--borda); font-size: .88rem; }
.cal-det-l span { color: var(--concreto-claro); } .cal-det-l b { text-align: right; }
.cal-det-acoes { margin-top: 14px; }

@media (max-width: 760px) { .cal-grade { --cw: 30px; --cw-label: 120px; } .cal-props-lista { width: 84vw; } }

/* ---- Reservas (Stays): criar reserva/bloqueio ---- */
.cr-box { background: #fff; border: 1px solid var(--borda); border-radius: 12px; padding: 14px 16px; margin-bottom: 8px; }
.cr-sum { cursor: pointer; font-weight: 700; color: var(--petroleo); list-style: none; }
.cr-sum::-webkit-details-marker { display: none; }
.cr-box .form { border: none; padding: 0; background: none; }
.cr-resumo { border: 1px solid var(--borda); border-left: 4px solid var(--lago); border-radius: 10px; padding: 12px 14px; margin-top: 10px; display: grid; gap: 5px; font-size: .9rem; }
.cr-resumo.ok { border-left-color: var(--ok); background: #f3faf4; }
.cr-resumo.bloq { border-left-color: var(--alerta); background: #fdf4f3; }
.sh-item:hover { box-shadow: 0 2px 8px rgba(0,0,0,.08); border-color: var(--lago); }

/* ---------- FAQ pesquisável ---------- */
.fq-item { background: #fff; border: 1px solid var(--borda); border-radius: 10px; padding: 4px 14px; margin-bottom: 8px; }
.fq-item > summary { cursor: pointer; font-weight: 600; padding: 10px 0; color: var(--petroleo); }
.fq-item[open] > summary { border-bottom: 1px solid var(--borda); }
.fq-resp { padding: 8px 0; font-size: .95rem; }
.fq-resp p { margin: 6px 0; }
.fq-item .btn.peq { margin: 4px 0 10px; }

/* ---------- Galeria de materiais de marca ---------- */
.ma-grade { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 14px; }
.ma-card { background: #fff; border: 1px solid var(--borda); border-radius: 12px; overflow: hidden; display: flex; flex-direction: column; box-shadow: 0 1px 3px rgba(12,54,68,.06); }
.ma-thumb { display: block; aspect-ratio: 4/3; background: var(--areia); overflow: hidden; }
.ma-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ma-ico { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 2.4rem; }
.ma-info { padding: 10px 12px; display: flex; flex-direction: column; gap: 5px; }
.ma-info b { font-size: .92rem; line-height: 1.25; }
.ma-tags { font-size: .74rem; color: var(--concreto-claro); }

/* ---------- Fotos (chamados / obras / limpeza) ---------- */
.ft-grade { display: grid; grid-template-columns: repeat(auto-fill, minmax(96px, 1fr)); gap: 10px; }
.ft-item { position: relative; aspect-ratio: 1; border-radius: 10px; overflow: hidden; border: 1px solid var(--borda); background: var(--areia); }
.ft-item img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ft-del { position: absolute; top: 4px; right: 4px; background: rgba(179,38,30,.9); color: #fff; border: none;
  border-radius: 8px; width: 22px; height: 22px; cursor: pointer; font-size: .8rem; line-height: 1; }
.ft-del:hover { background: var(--alerta); }

/* ---------- Mural da equipe (comunicação interna) ---------- */
.mural-form { background: #fff; border: 1px solid var(--borda); border-radius: 14px; padding: 14px 16px; margin-bottom: 18px; display: grid; gap: 10px; }
.mural-form textarea { resize: vertical; }
.mural-form-linha { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.mural-form-linha label { display: flex; flex-direction: row; align-items: center; gap: 7px; font-size: .85rem; font-weight: 600; }
.mural-fixar input { width: auto; }
.mural-msg { background: #fff; border: 1px solid var(--borda); border-radius: 12px; padding: 12px 16px; margin-bottom: 10px; }
.mural-msg.fixada { border-left: 4px solid var(--cerrado); background: #fffdf5; }
.mural-cab { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; font-size: .9rem; }
.mural-data { margin-left: auto; font-size: .76rem; color: var(--concreto-claro); }
.mural-texto { margin: 6px 0 2px; font-size: .95rem; }
.mural-chip-fix { background: #fff4e0; border-color: #f0dca6; }
.mural-chip-agente { background: #e8f0fe; border-color: #c6dafc; }
.mural-resps { margin-top: 8px; border-left: 2px solid var(--borda); padding-left: 12px; display: flex; flex-direction: column; gap: 8px; }
.mural-resp-meta { font-size: .78rem; color: var(--concreto-claro); }
.mural-resp .mural-texto { font-size: .9rem; margin: 2px 0 0; }
.mural-x { background: none; border: none; color: var(--alerta); cursor: pointer; font-size: .8rem; }
.mural-acoes { display: flex; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
.mural-form-resp { display: flex; gap: 8px; margin-top: 8px; }
.mural-form-resp input { flex: 1; }
