:root{
  --azul:#0f3d6e; --azul-2:#1656a0; --azul-claro:#e8eef6;
  --cinza:#5b6675; --linha:#d7dee8; --bg:#f4f6f9; --branco:#fff;
  --ok:#1a7f4b; --erro:#b3261e; --perigo:#b3261e;
  --sombra:0 1px 3px rgba(16,40,80,.08),0 1px 2px rgba(16,40,80,.06);
}
*{box-sizing:border-box}
body{margin:0;font-family:'Segoe UI',Roboto,system-ui,Arial,sans-serif;color:#1c2530;background:var(--bg);line-height:1.45}
a{color:var(--azul-2);text-decoration:none}
a:hover{text-decoration:underline}
h1{font-size:1.5rem;margin:0}
h2.sub{font-size:1.1rem;color:var(--azul);margin:1.4rem 0 .6rem}
small{color:var(--cinza)}

/* ---- topbar ---- */
.topbar{background:var(--azul);color:#fff;box-shadow:var(--sombra)}
.topbar-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem}
.brand{display:flex;align-items:center;gap:.6rem;color:#fff;font-weight:700;font-size:1.25rem}
.brand:hover{text-decoration:none}
.brand-logo{height:34px;width:auto;background:#fff;border-radius:6px;padding:2px}
.brand small{display:block;font-weight:400;font-size:.62rem;color:#cfe0f2;letter-spacing:.02em}
.nav{display:flex;align-items:center;gap:1rem}
.nav a{color:#dbe7f5}
.nav a.ativo{color:#fff;font-weight:600;border-bottom:2px solid #fff;padding-bottom:2px}
.nav-user{color:#aec3de;font-size:.85rem}
.btn-sair{background:rgba(255,255,255,.14);padding:.3rem .7rem;border-radius:6px;color:#fff}

/* ---- layout ---- */
.container{max-width:1100px;margin:1.4rem auto;padding:0 1rem;min-height:60vh}
.rodape{text-align:center;color:var(--cinza);font-size:.78rem;padding:1.4rem;border-top:1px solid var(--linha);margin-top:2rem}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.breadcrumb{color:var(--cinza);font-size:.85rem;margin:.2rem 0 1rem}
.cartao{background:var(--branco);border:1px solid var(--linha);border-radius:12px;padding:1.2rem 1.4rem;box-shadow:var(--sombra);margin-bottom:1.2rem}
.cartao.centro{text-align:center;max-width:480px;margin:3rem auto}

/* ---- botões ---- */
.btn{display:inline-block;border:1px solid var(--linha);background:#fff;color:#26405e;padding:.5rem .9rem;border-radius:8px;font-size:.9rem;cursor:pointer;font-weight:600}
.btn:hover{background:#f0f4fa;text-decoration:none}
.btn-primary{background:var(--azul);border-color:var(--azul);color:#fff}
.btn-primary:hover{background:var(--azul-2)}
.btn-perigo{color:#fff;background:var(--perigo);border-color:var(--perigo)}
.btn-sm{padding:.3rem .6rem;font-size:.8rem}
.btn-bloco{width:100%;margin-top:.4rem}
.barra-acoes{display:flex;gap:.6rem;align-items:center;margin-top:1.2rem;flex-wrap:wrap}
.inline{display:inline}

/* ---- login ---- */
.tela-login{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0f3d6e,#1656a0)}
.login-card{background:#fff;border-radius:16px;padding:2.2rem 2rem;width:360px;max-width:92vw;box-shadow:0 12px 40px rgba(0,0,0,.25);text-align:center}
.login-logo img{height:64px;margin-bottom:.4rem}
.login-card h1{color:var(--azul);letter-spacing:.08em}
.login-sub{color:var(--cinza);margin:.2rem 0 1.2rem;font-size:.9rem}
.login-card label{display:block;text-align:left;font-size:.85rem;font-weight:600;color:#33455c;margin-bottom:.8rem}
.login-card input{width:100%;margin-top:.25rem}

/* ---- formulários ---- */
input[type=text],input[type=password],input[type=search],textarea,select{
  width:100%;padding:.5rem .6rem;border:1px solid var(--linha);border-radius:8px;font:inherit;background:#ffff;color:#1c2530}
input:focus,textarea:focus{outline:none;border-color:var(--azul-2);box-shadow:0 0 0 3px rgba(22,86,160,.12)}
textarea{resize:vertical}
.busca{display:flex;gap:.5rem;margin-bottom:1rem;max-width:480px}
.form-linha{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}
.form-linha input{width:auto;flex:1;min-width:140px}
.check{display:flex;align-items:center;gap:.3rem;font-size:.9rem;white-space:nowrap}
input.mini{width:120px!important}

.editor fieldset.secao{border:1px solid var(--linha);border-radius:12px;padding:1rem 1.2rem 1.2rem;margin-bottom:1.2rem;background:#fff;box-shadow:var(--sombra)}
.editor legend{font-weight:700;color:var(--azul);padding:0 .5rem;font-size:1rem}
.secao-desc{color:var(--cinza);font-size:.85rem;margin:.2rem 0 .6rem}
.campos{display:grid;grid-template-columns:1fr 1fr;gap:.9rem 1.2rem}
.campo{display:flex;flex-direction:column}
.campo-largo{grid-column:1 / -1}
.campo label{font-size:.78rem;font-weight:600;color:#33455c;margin-bottom:.25rem}
.campo .ajuda{margin-top:.2rem}
.radios{display:flex;gap:1.2rem;flex-wrap:wrap;padding:.35rem 0}
.radio{display:flex;align-items:center;gap:.35rem;font-size:.9rem;font-weight:500;color:#1c2530}
.radio input{width:auto}
.aviso-autofill{background:var(--azul-claro);border:1px solid #c5d6ec;color:#1f4e85;padding:.6rem .9rem;border-radius:8px;font-size:.85rem;margin-bottom:1rem}

@media(max-width:680px){.campos{grid-template-columns:1fr}.campo-meio{grid-column:1 / -1}}

/* ---- tabelas ---- */
.tabela{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--linha);border-radius:12px;overflow:hidden;box-shadow:var(--sombra)}
.tabela th{background:var(--azul-claro);color:var(--azul);text-align:left;font-size:.78rem;text-transform:uppercase;letter-spacing:.03em;padding:.6rem .8rem}
.tabela td{padding:.6rem .8rem;border-top:1px solid var(--linha);font-size:.92rem;vertical-align:middle}
.tabela tr:hover td{background:#f8fafd}
.td-acao{white-space:nowrap;text-align:right;display:flex;gap:.4rem;justify-content:flex-end;align-items:center}
.link-forte{font-weight:600}
.badge{background:var(--azul);color:#fff;border-radius:6px;padding:.1rem .5rem;font-size:.72rem;font-weight:700}

/* ---- cards de formulário ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}
.card-form{display:block;background:#fff;border:1px solid var(--linha);border-radius:12px;padding:1.1rem 1.2rem;box-shadow:var(--sombra);transition:.12s}
.card-form:hover{border-color:var(--azul-2);transform:translateY(-2px);text-decoration:none;box-shadow:0 4px 14px rgba(16,40,80,.12)}
.card-form h3{margin:0 0 .3rem;color:var(--azul)}
.card-form p{margin:0 0 .8rem;color:var(--cinza);font-size:.86rem}
.card-cta{color:var(--azul-2);font-weight:600;font-size:.88rem}

/* ---- dados do paciente ---- */
.grid-dados{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:.8rem 1.2rem;margin-top:.6rem}
.grid-dados div{font-size:.95rem}
.grid-dados span{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.03em;color:var(--cinza);font-weight:600}

/* ---- diversos ---- */
.fonte-tag{font-size:.74rem;background:#eef1f6;color:var(--cinza);padding:.25rem .6rem;border-radius:999px;font-weight:600}
.fonte-tag.ok{background:#e6f4ec;color:var(--ok)}
.fonte-tag.alerta-tag{background:#fdeceb;color:var(--erro)}
.alerta{padding:.7rem .9rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}
.alerta.ok{background:#e6f4ec;color:var(--ok);border:1px solid #b9e0c8}
.alerta.erro{background:#fdeceb;color:var(--erro);border:1px solid #f3c4c0}
.vazio{background:#fff;border:1px dashed var(--linha);border-radius:12px;padding:2rem;text-align:center;color:var(--cinza)}
.erro-cod{font-size:3rem;color:var(--azul);margin:0}
.pdf-frame{border:1px solid var(--linha);border-radius:12px;overflow:hidden;box-shadow:var(--sombra);background:#fff}
.pdf-frame iframe{width:100%;height:78vh;border:0;display:block}
.resumo-clinico summary{font-weight:700;color:var(--azul);cursor:pointer}
.resumo-clinico h3{font-size:.85rem;color:var(--azul-2);margin:.9rem 0 .2rem;text-transform:uppercase;letter-spacing:.03em}
.bloco-clinico{white-space:pre-wrap;font-family:inherit;background:#f8fafd;border:1px solid var(--linha);border-radius:8px;padding:.7rem .9rem;margin:0;font-size:.88rem;line-height:1.5;color:#26323f;max-height:280px;overflow:auto}
/* ---- varredura ENCAMINHAMENTO ---- */
.scan-bar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;background:#fff;border:1px solid var(--linha);border-radius:10px;padding:.6rem .8rem;margin-bottom:.8rem;box-shadow:var(--sombra)}
.scan-prog{font-size:.85rem;color:var(--cinza);margin-left:.3rem}
.enc-badge{font-size:.72rem;font-weight:700;border-radius:6px;padding:.1rem .45rem}
.enc-badge.sim{background:#e6f4ec;color:var(--ok)}
.enc-badge.nao{color:#aeb6c2}
.enc-badge.err{background:#fdeceb;color:var(--erro)}
.enc-spin{color:var(--azul-2)}
tr.tem-enc td{background:#fffbe6}
.grifo{background:#fff3a0;padding:0 .15rem;border-radius:3px;font-weight:700}
.head-acoes{display:flex;gap:.5rem;flex-wrap:wrap}
.tag-origem{font-size:.7rem;background:#eef1f6;color:var(--cinza);padding:.1rem .45rem;border-radius:6px;font-weight:600;margin-left:.2rem}
/* ---- toolbar (adicionar BE + buscar) ---- */
.toolbar{display:flex;flex-wrap:wrap;gap:.8rem 1.2rem;align-items:center;justify-content:space-between;
  background:#fff;border:1px solid var(--linha);border-radius:10px;padding:.7rem .9rem;margin-bottom:1rem;box-shadow:var(--sombra)}
.tb-grupo{display:flex;gap:.5rem;align-items:center;margin:0}
.tb-busca{flex:1;min-width:240px;justify-content:flex-end}
.tb-input{height:40px;padding:.45rem .7rem;border:1px solid var(--linha);border-radius:8px;font:inherit;width:auto}
.tb-grupo .btn{height:40px;display:inline-flex;align-items:center;white-space:nowrap}
.tb-busca .tb-input{flex:1;max-width:440px}
/* ---- estado carregando ---- */
.btn.is-loading,a.is-loading{opacity:.75;pointer-events:none}
.spin{display:inline-block;animation:girar .8s linear infinite}
@keyframes girar{to{transform:rotate(360deg)}}
@media(max-width:680px){.toolbar{flex-direction:column;align-items:stretch}.tb-grupo{width:100%}.tb-busca{justify-content:stretch}.tb-input{flex:1}}
/* ---- etiquetas ---- */
.etq-filtros{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.9rem}
.etq-chip{display:inline-flex;align-items:center;gap:.25rem;font-size:.78rem;font-weight:600;border-radius:999px;padding:.22rem .6rem;border:1px solid var(--linha);background:#fff;color:#33455c;text-decoration:none}
.etq-chip:hover{text-decoration:none;filter:brightness(.97)}
.etq-chip.sel{outline:2px solid var(--azul-2);outline-offset:1px}
.etq-chip.mini{padding:.12rem .42rem;font-size:.9rem}
.chip-n{background:rgba(0,0,0,.10);border-radius:999px;padding:0 .42rem;font-size:.7rem;font-weight:700;margin-left:.1rem}
.aviso-inline{background:#eaf3ff;border:1px solid #bcd8f7;color:#1c3a5e;border-radius:8px;padding:.5rem .7rem;margin:.4rem 0;font-size:.9rem}
/* observações / pendências do NIR */
.obs-add{display:flex;gap:.5rem;margin:.2rem 0 .6rem;max-width:680px}
.obs-add .tb-input{flex:1}
.obs-lista{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.3rem}
.obs-item{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;border:1px solid var(--linha);border-radius:8px;background:#fff}
.obs-item.resolvida{opacity:.65;background:#f3f6f4}
.obs-item.resolvida .obs-txt{text-decoration:line-through}
.obs-check{background:none;border:none;cursor:pointer;font-size:1.15rem;line-height:1;color:var(--azul-2);padding:0}
.obs-txt{flex:1;font-size:.92rem}
.obs-meta{font-size:.72rem;color:#8a93a3;white-space:nowrap}
/* pendências em cartões lado a lado + comentários */
.obs-grid{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.35rem}
.obs-card{flex:1 1 280px;max-width:440px;border:1px solid var(--linha);border-radius:8px;padding:.45rem .55rem;background:#fff}
.obs-card.resolvida{opacity:.65;background:#f3f6f4}
.obs-card.resolvida .obs-txt{text-decoration:line-through}
.obs-card-top{display:flex;align-items:flex-start;gap:.4rem}
.obs-card-top .obs-txt{flex:1;font-size:.9rem}
.obs-coment{list-style:none;margin:.35rem 0 .25rem;padding:0;display:flex;flex-direction:column;gap:.15rem}
.obs-coment li{font-size:.8rem;background:#f5f8fb;border-radius:5px;padding:.15rem .4rem}
.obs-coment-add{display:flex;gap:.3rem;margin-top:.2rem}
.obs-coment-add input[type=text]{flex:1;font-size:.82rem;padding:.12rem .4rem;border:1px solid var(--linha);border-radius:6px}
.esp-valor{background:none;border:none;border-bottom:1px dashed var(--azul-2);cursor:pointer;font:inherit;font-size:.9rem;color:#33455c;padding:.05rem 0;text-align:left}
.row-pend{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.2rem}
.pend-chip{font-size:.72rem;background:#fff3d6;border:1px solid #f0c36d;color:#7a5a00;border-radius:5px;padding:.02rem .35rem}
.cad-externo{border:1px solid var(--linha);border-radius:8px;padding:.55rem .7rem;margin-bottom:.6rem}
.cad-tit{font-weight:700;font-size:.92rem;margin-bottom:.45rem}
/* etiquetas inline (triagem) no cartão de demografia */
.etq-inline{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center;margin-top:.7rem;padding-top:.6rem;border-top:1px solid var(--linha)}
.etq-add-lbl{font-size:.8rem;margin-left:.3rem}
.etq-chip.dash{cursor:pointer;border-style:dashed;font:inherit;font-weight:600}
.etq-chip .btn-del2.xs,.obs-item .btn-del2.xs{border:none;background:none;cursor:pointer;color:inherit;font-size:1rem;padding:0 0 0 .15rem;line-height:1}
.btn-del2.xs.armed{color:#c0392b;font-weight:700}
.bloco-retrai>summary{cursor:pointer;font-weight:600;font-size:.98rem;padding:.2rem 0}
/* topo compacto do paciente */
.cartao-topo{padding:.7rem .9rem}
.topo-titulo{display:flex;flex-wrap:wrap;align-items:baseline;gap:.4rem .6rem;margin-bottom:.5rem}
.topo-titulo h1{font-size:1.25rem;margin:0;line-height:1.1}
.t-meta{font-size:.82rem;color:#5b6573;font-weight:600}
.t-cache{margin-left:auto;font-size:.68rem}
.grid-topo{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:.3rem .9rem}
.grid-topo>div{font-size:.9rem;line-height:1.25;padding:.1rem 0}
.grid-topo>div>span{display:block;font-size:.66rem;text-transform:uppercase;letter-spacing:.02em;color:#8a93a3;font-weight:700}
.grid-topo .col-wide{grid-column:1 / -1}
.esp-req span{display:block;font-size:.66rem;text-transform:uppercase;letter-spacing:.02em;color:#8a93a3;font-weight:700}
.esp-form{display:flex;gap:.25rem;align-items:center;margin-top:.05rem}
.esp-input{flex:1;min-width:90px;padding:.1rem .1rem;border:none;border-bottom:1px solid var(--azul-2);border-radius:0;background:transparent;font:inherit;font-size:.9rem}
.esp-valor.vazio{color:#9aa3b0;font-style:italic;font-weight:600}
/* accordion clínico */
.clin-cab{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.3rem;font-size:.95rem}
.acc{display:flex;flex-direction:column}
.acc-item{border-top:1px solid var(--linha)}
.acc-item:first-child{border-top:none}
.acc-item>summary{cursor:pointer;font-weight:600;font-size:.9rem;padding:.4rem 0;display:flex;align-items:center;gap:.4rem;list-style:none}
.acc-item>summary::-webkit-details-marker{display:none}
.acc-item>summary::before{content:'▸';color:var(--azul-2);font-size:.78rem}
.acc-item[open]>summary::before{content:'▾'}
.acc-acoes{margin-left:auto;display:flex;gap:.3rem}
.acc-item .bloco-clinico{margin:.1rem 0 .5rem;font-size:.82rem}
.enc-det>summary{cursor:pointer;list-style:none}
.enc-det>summary::-webkit-details-marker{display:none}
.enc-more{color:var(--azul-2);font-weight:700}
.btn-xs{padding:.1rem .45rem;font-size:.78rem;line-height:1.4}
.barra-compacta{display:flex;gap:.4rem;align-items:center;margin:.55rem 0 .15rem}
.outros-dados{margin-top:.5rem;border-top:1px solid var(--linha);padding-top:.4rem}
.outros-dados>summary{cursor:pointer;font-size:.82rem;font-weight:600;color:var(--azul-2);padding:.1rem 0}
.outros-dados .grid-topo{margin-top:.4rem}
.tag-situacao.mudou{background:#fff3d6;color:#8a5a00;border:1px solid #f0c36d}
.cartao-topo.estado-alta{border:2px solid #e08a00;box-shadow:0 0 0 1px #e08a0033}
.cartao-topo.estado-obito{border:2px solid #c0392b;box-shadow:0 0 0 1px #c0392b33}
/* tarja clínica (evoluções + pareceres) */
.tarja-clinica{padding:.7rem .9rem}
.tarja-cab{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}
.tarja-cab .barra-acoes{margin-left:auto}
.evo-data{font-size:.78rem;color:#5b6573;font-weight:600}
.tarja-evos{display:flex;gap:.8rem;align-items:flex-start}
.tarja-evos .evo-col{flex:1 1 0;min-width:0}
.evo-titulo{font-size:.78rem;font-weight:700;color:var(--azul-2);text-transform:uppercase;letter-spacing:.02em;margin-bottom:.2rem}
.sub-evo{margin-top:.5rem}
.sub-evo>summary{cursor:pointer;font-weight:600;font-size:.85rem;color:var(--azul-2);padding:.15rem 0}
.sub-evo h4{margin:.4rem 0 .15rem;font-size:.82rem}
.pareceres-bloco{margin-top:.6rem;border-top:1px solid var(--linha);padding-top:.5rem}
.par-cab{font-weight:700;font-size:.85rem;margin-bottom:.35rem}
.pareceres-lista{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}
.pareceres-lista li{border-left:3px solid var(--azul-2);background:#f7fafd;border-radius:0 6px 6px 0;padding:.3rem .5rem}
.par-top{display:flex;gap:.5rem;align-items:baseline;flex-wrap:wrap}
.par-esp{font-weight:700;font-size:.86rem}
.par-data{font-size:.74rem;color:#5b6573}
.par-situ{font-size:.7rem;background:#e7eef7;border-radius:4px;padding:0 .35rem;color:#33455c}
.par-txt{font-size:.85rem;margin-top:.12rem;line-height:1.3}
@media (max-width:720px){.tarja-evos{flex-direction:column}}
/* anexos do paciente */
.anexos-acoes{margin-left:.6rem;display:inline-flex;gap:.4rem;vertical-align:middle;font-weight:400}
label.btn{cursor:pointer;position:relative}
label.btn input[type=file]{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden}
.anexos-lista{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.3rem}
.anexo-item{display:flex;gap:.5rem;border:1px solid var(--linha);border-radius:8px;padding:.4rem;background:#fff;width:310px;max-width:100%}
.anexo-item.na-guia{border-color:var(--azul-2);box-shadow:inset 0 0 0 1px var(--azul-2)}
.anexo-thumb{width:54px;height:54px;object-fit:cover;border-radius:6px;border:1px solid var(--linha);display:block}
.anexo-ico{display:inline-flex;width:54px;height:54px;align-items:center;justify-content:center;font-size:1.6rem;background:#f3f6fa;border-radius:6px}
.anexo-info{flex:1;min-width:0}
.anexo-nome{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.anexo-meta{font-size:.72rem;color:#8a93a3}
.anexo-acoes{display:flex;align-items:center;gap:.3rem;margin-top:.3rem}
.chk-guia{background:none;border:1px solid var(--linha);border-radius:6px;cursor:pointer;font-size:.74rem;padding:.12rem .4rem;color:#5b6573}
.chk-guia.on{border-color:var(--azul-2);color:var(--azul-2);font-weight:700;background:#eef5fc}
/* editor de guia lado a lado + painel de referência clínica */
.editor-layout{display:flex;gap:1rem;align-items:flex-start}
.editor-form{flex:1;min-width:0}
.clin-viewer{flex:0 0 370px;position:sticky;top:.6rem;max-height:calc(100vh - 1.2rem);overflow:auto;border:1px solid var(--linha);border-radius:10px;background:#fff;padding:.6rem .75rem;box-shadow:var(--sombra)}
.cv-head{font-weight:700;font-size:.92rem;margin-bottom:.5rem;border-bottom:1px solid var(--linha);padding-bottom:.4rem;display:flex;flex-direction:column}
.cv-sec{margin-bottom:.6rem;border-bottom:1px dashed var(--linha);padding-bottom:.45rem}
.cv-tit{font-size:.76rem;font-weight:700;color:var(--azul-2);text-transform:uppercase;letter-spacing:.02em;display:flex;align-items:center;gap:.35rem;margin-bottom:.25rem}
.cv-load{background:var(--azul-2);color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:.82rem;padding:0 .4rem;line-height:1.5}
.clin-viewer pre.bloco-clinico{font-size:.78rem;max-height:230px;overflow:auto;margin:.15rem 0}
.clin-viewer details>summary{cursor:pointer;font-size:.8rem;display:flex;align-items:center;gap:.3rem;justify-content:space-between;padding:.1rem 0}
.cv-par{font-size:.8rem;border-left:3px solid var(--azul-2);background:#f7fafd;padding:.2rem .4rem;border-radius:0 5px 5px 0;margin-bottom:.25rem}
.cv-pdf-row{display:flex;gap:.3rem;align-items:center;margin:.25rem 0}
@media (max-width:900px){.editor-layout{flex-direction:column}.clin-viewer{flex:1 1 auto;width:100%;position:static;max-height:none}}
/* editor compacto */
.editor-form .secao{padding:.55rem .75rem;margin-bottom:.6rem}
.editor-form .secao legend{font-size:.82rem;font-weight:700}
.editor-form .secao-desc{font-size:.74rem;margin:.1rem 0 .3rem}
.editor-form .campos{gap:.35rem .8rem}
.editor-form label{font-size:.76rem;margin-bottom:.05rem}
.editor-form input[type=text]{font-size:.84rem;padding:.22rem .45rem}
.editor-form textarea{font-size:.82rem;padding:.25rem .45rem;line-height:1.3;overflow:hidden}
.editor-form .ajuda{font-size:.68rem}
.editor-form .swap-evo{font-size:.72rem}
.secao-anexo .anx-vitai{display:flex;flex-wrap:wrap;gap:.5rem .9rem}
.secao-anexo .anx-arquivos{display:flex;flex-direction:column;gap:.15rem;margin:.35rem 0}
.secao-anexo .anx-add{display:flex;gap:.4rem;align-items:center;margin-top:.3rem}
.secao-anexo .check{font-size:.82rem}
.cv-tabs{display:flex;gap:.3rem;margin-bottom:.5rem;border-bottom:1px solid var(--linha)}
.cv-tab{background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:.82rem;font-weight:600;padding:.3rem .4rem;color:#5b6573}
.cv-tab.on{color:var(--azul-2);border-bottom-color:var(--azul-2)}
.cv-iframe{width:100%;height:72vh;border:1px solid var(--linha);border-radius:6px;background:#fff}
.ext-linha{display:flex;gap:.4rem;align-items:center;max-width:540px}
.ext-linha .tb-input{flex:1}
.ext-mais{margin-top:.6rem}
.fmt-bar{display:inline-flex;gap:.2rem;margin-left:.4rem}
.fmt-bar button{font-size:.72rem;padding:0 .4rem;line-height:1.5;border:1px solid var(--linha);background:#fff;border-radius:4px;cursor:pointer}
.ed-modos{display:flex;gap:.3rem;margin-bottom:.6rem}
.ed-modo{background:#eef2f7;border:1px solid var(--linha);border-radius:6px;padding:.3rem .7rem;cursor:pointer;font-size:.82rem;font-weight:600;color:#5b6573}
.ed-modo.on{background:var(--azul-2);color:#fff;border-color:var(--azul-2)}
.ed-doc-aviso{font-size:.74rem;margin:0 0 .4rem}
[data-ed-pane="doc"] .cv-iframe{height:78vh}
.cor-azul{background:#e8eef6;border-color:#bcd0ea;color:#13508a}
.cor-laranja{background:#fdf0dd;border-color:#f0cf9b;color:#955d09}
.cor-verde{background:#e6f4ec;border-color:#bfe3cd;color:#16713f}
.cor-roxo{background:#efe8f8;border-color:#d2bff0;color:#5b2f95}
.etq-lista{margin:.4rem 0 1rem}
.etq-card{border:1px solid var(--linha);border-left-width:4px;border-radius:8px;padding:.6rem .8rem;margin-bottom:.6rem;background:#fff;box-shadow:var(--sombra)}
.etq-card.cor-azul{border-left-color:#1656a0}.etq-card.cor-laranja{border-left-color:#b9770a}
.etq-card.cor-verde{border-left-color:#1a7f4b}.etq-card.cor-roxo{border-left-color:#6b3fa0}
.etq-card-head{display:flex;justify-content:space-between;align-items:center;gap:.5rem}
.etq-resumo{font-size:.9rem;color:#33455c;margin-top:.35rem}
.etq-editar summary,.etq-form-tipo summary{cursor:pointer;color:var(--azul-2);font-size:.85rem;margin-top:.45rem;font-weight:600}
.etq-externo>summary{cursor:pointer;font-weight:700;color:var(--azul)}
.etq-add .etq-form-tipo{margin:.5rem 0;border-top:1px solid var(--linha);padding-top:.55rem}
.btn-exp{border:1px solid var(--linha);background:#fff;border-radius:6px;width:26px;height:26px;cursor:pointer;color:var(--azul-2);line-height:1;font-size:.8rem}
.detalhe-row td{background:#f8fafd;font-size:.86rem;padding:.5rem .8rem}
.det-item{padding:.12rem 0}.det-item.muted{color:var(--cinza)}
.td-etq{display:flex;flex-wrap:wrap;gap:.25rem;align-items:center}
.tabela-pac th:first-child,.tabela-pac td:first-child{width:34px;padding-left:.5rem;padding-right:0;text-align:center}
.ic{vertical-align:-2px}
.cor-ciano{background:#e2f4f6;border-color:#aedce2;color:#0f6f7c}
.etq-card.cor-ciano{border-left-color:#119aab}
/* ---- painel ---- */
.painel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}
.painel-col{background:#fff;border:1px solid var(--linha);border-top-width:3px;border-radius:10px;padding:.8rem .9rem;box-shadow:var(--sombra)}
.painel-col.cor-azul{border-top-color:#1656a0}.painel-col.cor-laranja{border-top-color:#b9770a}
.painel-col.cor-verde{border-top-color:#1a7f4b}.painel-col.cor-roxo{border-top-color:#6b3fa0}.painel-col.cor-ciano{border-top-color:#119aab}
.painel-col h3{font-size:.92rem;margin:0 0 .6rem;display:flex;align-items:center;gap:.35rem;color:#26323f}
.painel-col .cont{margin-left:auto;background:var(--azul);color:#fff;border-radius:999px;font-size:.72rem;padding:.05rem .5rem;font-weight:700}
.painel-lista{list-style:none;margin:0;padding:0}
.painel-lista li{padding:.45rem 0;border-top:1px solid var(--linha)}
.painel-lista li:first-child{border-top:0}
.painel-resumo{font-size:.82rem;color:var(--cinza);margin-top:.15rem}
.painel-vazio{font-size:.85rem}
.muted{color:var(--cinza)}
.tag-neutro{font-size:.66rem;background:#fff3a0;color:#7a5c00;padding:.1rem .4rem;border-radius:6px;font-weight:700;margin-left:.25rem;text-transform:uppercase;letter-spacing:.03em}
.linha-neutro td{background:#fffdf3}
.det-enc{max-height:220px;overflow:auto;margin-top:.3rem;white-space:pre-wrap}
.retirados-box>summary{cursor:pointer;font-weight:700;color:var(--cinza)}
/* ---- janela flutuante do documento ---- */
.modal-backdrop{position:fixed;inset:0;background:rgba(15,40,80,.45);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:50}
.modal-doc{background:#fff;border-radius:12px;box-shadow:0 16px 50px rgba(0,0,0,.35);width:min(840px,96vw);max-height:94vh;display:flex;flex-direction:column;overflow:hidden}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem 1rem;border-bottom:1px solid var(--linha)}
.modal-head strong{margin-right:.5rem}
.modal-x{font-size:1.1rem;color:var(--cinza);text-decoration:none;padding:.1rem .5rem;border-radius:6px}
.modal-x:hover{background:#eef1f6;text-decoration:none}
.modal-corpo{flex:1;min-height:0;background:#eceef2}
.modal-pdf{width:100%;height:64vh;border:0;display:block}
.modal-acoes{display:flex;gap:.5rem;flex-wrap:wrap;padding:.6rem 1rem;border-top:1px solid var(--linha)}
/* ---- editor de formulário mais compacto ---- */
.editor fieldset.secao{padding:.6rem .9rem .7rem;margin-bottom:.7rem}
.editor legend{font-size:.92rem}
.campos{gap:.45rem .9rem}
.campo label{margin-bottom:.12rem;font-size:.74rem}
.editor input[type=text],.editor textarea{padding:.38rem .55rem}
.editor .radios{padding:.15rem 0}
/* ---- etiqueta rápida + retirar 2 cliques ---- */
.etq-quick{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;margin:.3rem 0 1rem}
.etq-quick form{margin:0}
.etq-quick .etq-chip{cursor:pointer;border-style:dashed;font:inherit}
.etq-card-acoes{display:flex;align-items:center;gap:.6rem}
.lnk-obs{background:none;border:0;color:var(--azul-2);cursor:pointer;font-size:.8rem;font-weight:600}
.btn-del2{background:#fff;border:1px solid var(--linha);border-radius:6px;min-width:26px;height:24px;cursor:pointer;color:var(--erro);font-weight:700;line-height:1;font-size:.95rem}
.btn-del2.armed{padding:0 .55rem;background:var(--erro);color:#fff;border-color:var(--erro);font-size:.78rem}
/* ---- título com Atualizar ---- */
.h1-flex{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.h1-flex form{margin:0}
/* ---- toast flutuante ---- */
.toast{position:fixed;top:70px;left:50%;transform:translateX(-50%);z-index:60;padding:.7rem 1.1rem;border-radius:10px;
  box-shadow:0 8px 30px rgba(0,0,0,.25);font-size:.92rem;font-weight:600;cursor:pointer;transition:opacity .5s,transform .5s;max-width:90vw}
.toast.ok{background:#e6f4ec;color:var(--ok);border:1px solid #b9e0c8}
.toast.erro{background:#fdeceb;color:var(--erro);border:1px solid #f3c4c0}
.toast.saindo{opacity:0;transform:translateX(-50%) translateY(-12px)}
/* ---- menu adicionar (escolher destino) ---- */
.add-menu{display:inline-flex;align-items:center}
.add-opts{display:inline-flex;flex-direction:row;gap:.3rem;align-items:center}
.add-opts[hidden]{display:none}
.add-opts form{margin:0}
.btn-cancelar{color:var(--cinza)}
.enc-meta{font-size:.72rem;color:var(--cinza);line-height:1.25;margin-top:.1rem}
.row-sub{font-size:.76rem;color:var(--cinza);margin-top:.15rem;max-width:46ch;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.swap-evo{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center;margin-top:.35rem}
.swap-evo .muted{font-size:.78rem}
.swap-evo .btn{padding:.2rem .5rem;font-size:.78rem}
/* ---- mudança de setor / alta-óbito ---- */
.tag-mudou{color:#b9770a;font-weight:700}
.leito-ant{font-size:.7rem;color:var(--cinza)}
.leito-ultimo{font-size:.7rem;font-weight:600;color:var(--cinza);text-transform:uppercase;letter-spacing:.02em}
.situacao-quando{font-size:.66rem;color:var(--cinza);margin-left:.25rem;white-space:nowrap}
.traj-card summary{cursor:pointer}
.traj-lista{list-style:none;margin:.4rem 0 0;padding:0;border-left:2px solid #e3e7ec;margin-left:.4rem}
.traj-lista li{position:relative;padding:.25rem 0 .25rem .9rem;font-size:.82rem}
.traj-lista li::before{content:"";position:absolute;left:-5px;top:.55rem;width:8px;height:8px;border-radius:50%;background:#c3cad3}
.traj-lista li.atual::before{background:var(--ok)}
.traj-lista li.atual .traj-local{font-weight:700}
.traj-local{margin-right:.5rem}
.traj-quando{color:var(--cinza)}
.traj-motivo{margin-left:.4rem;font-size:.66rem;text-transform:uppercase;color:#8a5a00;background:#fff3d6;border-radius:5px;padding:.05rem .35rem}
.tag-situacao{font-size:.66rem;font-weight:700;border-radius:6px;padding:.1rem .4rem;margin-left:.25rem;text-transform:uppercase}
.tag-situacao.alta{background:#e6f4ec;color:var(--ok)}
.tag-situacao.obito{background:#3a3f47;color:#fff}
.tag-situacao.sumiu{background:#fdeceb;color:var(--erro)}
.linha-situacao td{background:#fbf4ec}
.linha-alta td{background:#fff1df;box-shadow:inset 3px 0 0 #e08a00}
.linha-obito td{background:#fdecea;box-shadow:inset 3px 0 0 #c0392b}
.linha-nao_encontrado td{background:#f3f0fa;box-shadow:inset 3px 0 0 #7a5cc0}
.linha-novo td{background:#eaf7ee;box-shadow:inset 3px 0 0 #2e9e5b}
.tag-novo6h{font-size:.66rem;background:#2e9e5b;color:#fff;border-radius:4px;padding:.02rem .35rem;font-weight:700;margin-left:.2rem}
.busca-viva{max-width:380px;margin:.1rem 0 .6rem;display:block}
/* lista de pacientes em cards (sem colunas fixas) */
.pac-cards{display:flex;flex-direction:column;gap:.4rem}
.pac-card{border:1px solid var(--linha);border-radius:8px;padding:.4rem .6rem;background:#fff;font-size:.82rem}
.pac-card.is-neutro{background:#fffdf3}
.pac-card.is-novo{background:#eaf7ee;box-shadow:inset 3px 0 0 #2e9e5b}
.pac-card.is-alta{box-shadow:inset 3px 0 0 #e08a00}
.pac-card.is-obito{box-shadow:inset 3px 0 0 #c0392b}
.pac-card.is-nao_encontrado{box-shadow:inset 3px 0 0 #7a5cc0}
.pc-top{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}
.pc-nome{font-size:.95rem}
.pc-acoes{margin-left:auto;display:flex;flex-wrap:wrap;gap:.25rem;align-items:center}
.pc-meta{font-size:.76rem;color:#5b6573;margin-top:.15rem}
.pc-linha{font-size:.78rem;margin-top:.15rem;line-height:1.3;color:#33455c}
.pc-linha b{color:#1c3a5e}
.pc-full{margin-top:.4rem;border-top:1px dashed var(--linha);padding-top:.3rem}
.pc-full .bloco-clinico{font-size:.76rem;line-height:1.3}
.pc-full .det-item{font-size:.78rem;margin-top:.35rem}


/* ===================== Internos · mapa de leitos ===================== */
:root{
  --li-ocup:#e23b3b; --li-ocup2:#b91c1c;
  --li-livre:#e9f5ee; --li-livre-b:#86c9a4; --li-livre-t:#157a47;
  --li-alta:#f3a712; --li-alta2:#d98a00;
  --li-bloq:#3a4654; --li-bloq2:#202a36;
}
.mapa-wrap{margin-bottom:2rem}
.container-larga{max-width:none}
.mapa-acoes{display:flex;gap:.5rem;align-items:center}

/* ---- dashboard de ocupação ---- */
.mapa-dash{display:flex;align-items:center;gap:1.1rem;background:linear-gradient(180deg,#fff,#fbfcfe);
  border:1px solid var(--linha);border-radius:14px;padding:.8rem 1.1rem;box-shadow:var(--sombra);margin:.2rem 0 1.2rem;flex-wrap:wrap}
.dash-gauge{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:78px;
  padding:.2rem .7rem;border-right:1px solid var(--linha)}
.dash-taxa{font-weight:800;color:var(--azul);line-height:1;display:flex;align-items:baseline}
.dash-taxa b{font-size:2rem}
.dash-taxa span{font-size:1rem;margin-left:1px;color:var(--azul-2)}
.dash-taxa-lbl{font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:var(--cinza);margin-top:.15rem}
.dash-bar-wrap{flex:1;min-width:240px}
.dash-bar{display:flex;height:14px;border-radius:8px;overflow:hidden;background:#eef2f7;box-shadow:inset 0 1px 2px rgba(16,40,80,.12)}
.dash-bar .seg{height:100%;transition:width .5s ease}
.dash-bar .seg.ocupado{background:linear-gradient(180deg,var(--li-ocup),var(--li-ocup2))}
.dash-bar .seg.alta_pendencia{background:linear-gradient(180deg,var(--li-alta),var(--li-alta2))}
.dash-bar .seg.bloqueado{background:linear-gradient(180deg,var(--li-bloq),var(--li-bloq2))}
.dash-bar .seg.livre{background:#d6e8dd}
.dash-stats{display:flex;flex-wrap:wrap;gap:.2rem 1.1rem;margin-top:.5rem}
.dash-stats .st{display:inline-flex;align-items:center;gap:.35rem;font-size:.82rem;color:#42566e}
.dash-stats .st b{color:#1c2530;font-size:.92rem}
.dash-stats .st i{width:10px;height:10px;border-radius:3px;display:inline-block}
.dash-stats .st.ocupado i{background:var(--li-ocup)}
.dash-stats .st.alta_pendencia i{background:var(--li-alta)}
.dash-stats .st.bloqueado i{background:var(--li-bloq)}
.dash-stats .st.livre i{background:var(--li-livre-b)}
.dash-stats .st.total{margin-left:auto;color:var(--cinza)}
.mapa-prog{font-size:.82rem;color:var(--azul-2);min-height:1em;width:100%}

/* ---- andar (camada do prédio) ---- */
.andar{display:flex;align-items:stretch;margin-bottom:1rem;border:1px solid var(--linha);
  border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 2px 10px rgba(16,40,80,.07);
  animation:liSurge .35s ease both}
.andar-badge{flex:0 0 78px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.2rem;background:linear-gradient(155deg,#1a5694,#0c2f57);
  color:#fff;padding:.7rem .3rem;text-align:center;position:relative}
.andar-badge::after{content:"";position:absolute;right:0;top:8%;height:84%;width:3px;background:rgba(255,255,255,.18);border-radius:3px}
.andar-n{font-size:1.7rem;font-weight:800;line-height:1;text-shadow:0 1px 3px rgba(0,0,0,.25)}
.andar-nome{font-size:.6rem;letter-spacing:.04em;color:#cfe0f2;text-transform:uppercase}
.andar-ocup{margin-top:.25rem;font-size:.68rem;font-weight:700;color:#fff;background:rgba(255,255,255,.16);
  padding:.08rem .4rem;border-radius:20px}
.andar-corpo{flex:1;padding:.8rem 1rem;display:flex;align-items:flex-start;gap:.7rem;min-width:0;overflow-x:auto;
  background:linear-gradient(180deg,#fafbfd,#f4f7fb)}

/* ---- colunas posicionais do andar ---- */
.col-andar{display:flex;flex-direction:column;gap:.6rem;min-width:0;align-self:flex-start}
.col-andar.col-1{--acc:#d23b4e;background:rgba(210,59,78,.05);border:1px dashed rgba(210,59,78,.3);
  border-radius:11px;padding:.5rem .5rem .55rem}
.col-andar.col-1::before{content:"UTI";display:block;font-size:.58rem;font-weight:800;letter-spacing:.1em;
  text-transform:uppercase;color:#d23b4e;text-align:center;margin-bottom:.1rem}
.col-andar{min-width:132px}
.col-andar .setor{width:100%}
.grupo,.grupo-setores{display:contents}  /* compat (layout antigo) */
.g-uti{--acc:#d23b4e}.g-utiped{--acc:#c0398f}.g-semi{--acc:#e07b2a}.g-enf{--acc:#2f74c0}
.g-ped{--acc:#159b9b}.g-bloco{--acc:#7a52cc}.g-estab{--acc:#c0392b}.g-amarela{--acc:#d9a400}
.g-verde{--acc:#2e9e5b}.g-utq{--acc:#cc527a}.g-def{--acc:#7c8aa0}

/* ---- setor (card) ---- */
.setor{border:1px solid var(--linha);border-top:3px solid var(--acc);border-radius:11px;
  padding:.5rem .6rem .6rem;background:#fff;min-width:124px;box-shadow:0 1px 3px rgba(16,40,80,.06);
  transition:box-shadow .12s,transform .12s}
.setor:hover{box-shadow:0 5px 16px rgba(16,40,80,.13);transform:translateY(-1px)}
.setor-tit{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.35rem}
.setor-nome{font-size:.82rem;font-weight:700;color:#26405e}
.setor-cont{font-size:.68rem;font-weight:700;color:#5b6675;background:#f1f5fa;border:1px solid var(--linha);
  border-radius:20px;padding:.05rem .42rem}
.setor-bar{height:4px;border-radius:3px;background:#edf1f6;overflow:hidden;margin-bottom:.5rem}
.setor-bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--acc),var(--acc));opacity:.55;border-radius:3px}
.setor-vazio{font-size:.72rem;color:var(--cinza);font-style:italic}
.leitos{display:flex;flex-wrap:wrap;gap:.3rem;max-width:248px}

/* ---- o leito (bolinha) ---- */
.leito{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid rgba(16,40,80,.16)}
button.leito{width:27px;height:27px;padding:0;cursor:pointer;color:#fff;position:relative;
  transition:transform .1s,box-shadow .1s;box-shadow:inset 0 1px 1px rgba(255,255,255,.35),0 1px 2px rgba(16,40,80,.18)}
button.leito::before{content:"";position:absolute;top:3px;left:5px;width:9px;height:6px;border-radius:50%;
  background:rgba(255,255,255,.4);filter:blur(1px);pointer-events:none}
button.leito:hover{transform:translateY(-2px) scale(1.16);box-shadow:0 5px 12px rgba(16,40,80,.32);z-index:3}
.leito-n{font-size:.6rem;font-weight:700;opacity:.9;pointer-events:none;text-shadow:0 1px 1px rgba(0,0,0,.25)}
i.leito,.lm-bt .leito{width:13px;height:13px;flex:0 0 13px;box-shadow:none}
i.leito::before,.lm-bt .leito::before{display:none}
.leito.ocupado{background:radial-gradient(circle at 35% 30%,#f25c5c,var(--li-ocup) 55%,var(--li-ocup2))}
.leito.livre{background:var(--li-livre);border-color:var(--li-livre-b)}
.leito.livre .leito-n{color:var(--li-livre-t);opacity:.85;text-shadow:none}
.leito.bloqueado{background:linear-gradient(145deg,var(--li-bloq),var(--li-bloq2))}
.leito.alta_pendencia{background:radial-gradient(circle at 35% 30%,#ffc34d,var(--li-alta) 55%,var(--li-alta2));
  animation:liPulse 1.8s ease-in-out infinite}
.leito.excedente{outline:2px dashed var(--li-ocup);outline-offset:1px}

@keyframes liPulse{0%,100%{box-shadow:inset 0 1px 1px rgba(255,255,255,.35),0 0 0 0 rgba(243,167,18,.55)}
  50%{box-shadow:inset 0 1px 1px rgba(255,255,255,.35),0 0 0 5px rgba(243,167,18,0)}}
@keyframes liSurge{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

.aviso-vazio{color:var(--cinza);padding:2rem;text-align:center}

/* ---- popover de ação do leito ---- */
.leito-menu{position:absolute;z-index:50;width:258px;background:#fff;border:1px solid var(--linha);
  border-radius:14px;box-shadow:0 16px 40px rgba(16,40,80,.26);padding:.8rem .9rem;animation:liSurge .14s ease both}
.lm-head{font-weight:800;font-size:.86rem;color:var(--azul);margin-bottom:.4rem}
.lm-body{font-size:.82rem;color:#33455c;margin-bottom:.55rem;min-height:1em;line-height:1.5}
.lm-body .lm-risco{display:inline-block;font-size:.64rem;font-weight:800;text-transform:uppercase;
  color:#fff;border-radius:20px;padding:.05rem .45rem;margin-left:.3rem;vertical-align:middle}
.lm-acoes{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;margin-bottom:.55rem}
.lm-bt{display:inline-flex;align-items:center;gap:.4rem;border:1px solid var(--linha);background:#fff;
  border-radius:9px;padding:.35rem .45rem;font-size:.77rem;cursor:pointer;color:#26405e;transition:.1s}
.lm-bt:hover{background:#f0f4fa}
.lm-bt.sel{border-color:var(--azul-2);box-shadow:0 0 0 2px rgba(22,86,160,.16);font-weight:700;background:#f4f8ff}
.lm-motivo{margin-bottom:.55rem;font-size:.82rem}
.lm-rodape{display:flex;align-items:center;justify-content:space-between;gap:.6rem}
.lm-paciente{font-size:.82rem;font-weight:600}

/* ---- admin do mapa ---- */
.form-setor .fs-grid{display:flex;flex-wrap:wrap;gap:.5rem;align-items:end}
.form-setor label{display:flex;flex-direction:column;font-size:.7rem;font-weight:600;color:#33455c;gap:.15rem}
.form-setor input[type=number]{width:70px}
.form-setor input[type=text]{width:130px}
.form-setor .fs-nome input{width:170px}
.form-setor .fs-vitai select{width:220px}
.form-setor .fs-ativo{align-items:center}
.linha-setor{border-top:1px solid var(--linha);padding:.7rem 0;display:flex;gap:1rem;align-items:end;flex-wrap:wrap}
.linha-setor.inativo{opacity:.55}
.linha-setor-acoes{display:flex;gap:.4rem}

@media (max-width:720px){
  .andar{flex-direction:column}
  .andar-badge{flex-direction:row;flex-basis:auto;gap:.5rem;justify-content:flex-start;padding:.4rem .8rem}
  .andar-badge::after{display:none}
  .andar-n{font-size:1.2rem}
  .dash-gauge{border-right:none;border-bottom:1px solid var(--linha)}
}

/* ===================== Internos · visão por GRUPOS ===================== */
.seg-toggle{display:inline-flex;border:1px solid var(--linha);border-radius:9px;overflow:hidden;background:#fff}
.seg-toggle a{padding:.4rem .8rem;font-size:.85rem;color:#42566e;font-weight:600}
.seg-toggle a:hover{background:#f0f4fa;text-decoration:none}
.seg-toggle a.ativo{background:var(--azul);color:#fff}

/* resumo (chips dos grupos) */
.grp-resumo{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;margin:.2rem 0 .55rem}
.grp-chip{--gacc:#7c8aa0;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;
  min-width:96px;padding:.4rem .7rem;border-radius:11px;background:#fff;border:1px solid var(--linha);
  border-top:3px solid var(--gacc);box-shadow:var(--sombra)}
.grp-chip b{font-size:1.5rem;font-weight:800;color:var(--gacc);line-height:1}
.grp-chip span{font-size:.66rem;text-transform:uppercase;letter-spacing:.03em;color:var(--cinza);margin-top:.15rem}
.grp-chip.total{--gacc:var(--azul)}
.grp-chip.g-1{--gacc:#d23b4e}.grp-chip.g-2{--gacc:#2f74c0}.grp-chip.g-3{--gacc:#e07b2a}
.grp-resumo .mapa-prog{margin-left:auto;font-size:.82rem;color:var(--azul-2)}


/* legenda compacta dos tiles */
/* busca fuzzy de paciente */
.busca-box{margin-left:auto;display:flex;align-items:center;gap:.5rem;min-width:240px}
.busca-pac{flex:1;width:300px;max-width:42vw;padding:.4rem .8rem;border:1px solid var(--linha);
  border-radius:20px;font-size:.85rem;background:#fff;box-shadow:var(--sombra)}
.busca-pac:focus{outline:none;border-color:#1a5694;box-shadow:0 0 0 3px rgba(26,86,148,.18)}
.busca-cont{font-size:.78rem;color:var(--cinza);font-weight:700;white-space:nowrap}
.tile.nomatch{opacity:.14;filter:grayscale(.6)}
.tile.match{outline:3px solid #1a5694;outline-offset:1px;z-index:4;opacity:1;filter:none}

/* macro-grupo = retângulo externo */
.tg{--gacc:#7c8aa0;border:2px solid var(--gacc);border-radius:12px;margin-bottom:.45rem;background:rgba(124,138,160,.05)}
.tg.gm-1{--gacc:#d23b4e}.tg.gm-2{--gacc:#2f74c0}.tg.gm-3{--gacc:#e07b2a}
.tg-head{display:flex;align-items:center;gap:.7rem;padding:.32rem .7rem;background:var(--gacc);
  border-radius:11px 11px 0 0;color:#fff}
.tg-head h2{font-size:1rem;margin:0;letter-spacing:.02em}
.tg-cont{font-size:.78rem;font-weight:700;background:rgba(255,255,255,.2);padding:.05rem .5rem;border-radius:20px}
/* GRADE FIXA por setor: célula de rótulo + leitos (5 colunas). JS empacota os blocos */
.tg-setores{position:relative;padding:6px}
.gblock{display:grid;grid-template-columns:repeat(5,76px);grid-auto-rows:56px;gap:3px;
  background:#fff;border:1px solid var(--linha);border-radius:8px;padding:4px;box-shadow:var(--sombra)}
.glabel{background:#37496a;color:#fff;border-radius:5px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;gap:2px;padding:2px;overflow:hidden}
.glabel span{font-size:.62rem;font-weight:800;line-height:1.06}
.glabel b{font-size:.55rem;font-weight:700;opacity:.85;font-variant-numeric:tabular-nums}
/* Emergência: blocos de LARGURA CHEIA (leitos esq->dir, próximo setor abaixo) */
.gblock.gwide{grid-template-columns:repeat(auto-fill,76px);width:100%;box-sizing:border-box;justify-content:start}
.gblock.gwide.aguard{padding-top:4px}
/* marcador "PA · Não internados" (faixa cheia entre internados e não-internados) */
.gmarker{width:100%;box-sizing:border-box;background:#2a3645;color:#fff;font-size:.72rem;font-weight:800;
  letter-spacing:.05em;text-transform:uppercase;padding:6px 12px;border-radius:6px;box-shadow:var(--sombra)}
.bloco-bg{position:absolute;z-index:0;border-radius:4px;pointer-events:none}
.bloco-svg{position:absolute;left:0;top:0;z-index:2;pointer-events:none;overflow:visible}
.bloco-label{position:absolute;z-index:3;font-size:.54rem;font-weight:800;letter-spacing:.02em;color:#fff;
  padding:0 4px;border-radius:0 5px 5px 0;pointer-events:none;white-space:nowrap;line-height:1.35;
  text-shadow:0 1px 1px rgba(0,0,0,.45)}
.enf-mark{position:absolute;z-index:2;font-size:.46rem;font-weight:800;color:#fff;background:rgba(0,0,0,.5);
  padding:0 3px;border-radius:0 0 4px 0;pointer-events:none;line-height:1.5}

/* setor = [espinha vertical com o nome | grade de leitos] */
.ts{display:flex;align-items:stretch;background:#fff;border:1px solid var(--linha);border-radius:8px;
  overflow:hidden;width:316px;box-shadow:var(--sombra)}
.ts-spine{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  flex:0 0 18px;background:#37496a;color:#fff;padding:4px 0;overflow:hidden}
.ts-nome{writing-mode:vertical-rl;text-orientation:mixed;font-size:.58rem;font-weight:800;letter-spacing:.02em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-height:100%}
.ts-cont{writing-mode:vertical-rl;font-size:.54rem;font-weight:700;opacity:.85;font-variant-numeric:tabular-nums}
.ts-tiles{flex:1 1 auto;display:flex;flex-wrap:wrap;gap:3px;padding:3px;align-content:flex-start}
/* rótulo da sub-enfermaria (quebra a linha, leitos de cada enfermaria juntos) */
.ts-sublabel{flex:1 0 100%;font-size:.56rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;
  color:#42566e;background:#e7edf5;border-radius:3px;padding:.06rem .4rem;margin:2px 0 0}
/* linha grossa separando internados dos não-internados (corta estilo tetris) */
.ts-corte{flex:1 0 100%;height:0;border-top:4px solid #2a3645;margin:4px 1px 2px;border-radius:2px}

/* paciente = retângulo interno (tile) */
.tile{position:relative;width:76px;height:56px;border-radius:5px;border:1px solid rgba(16,40,80,.12);
  display:flex;flex-direction:column;justify-content:flex-start;padding:3px 4px;overflow:hidden;color:#fff;
  text-decoration:none;line-height:1.05}
.tile[data-be]{cursor:pointer}
.tile[data-be]:hover{filter:brightness(1.08);box-shadow:0 3px 9px rgba(16,40,80,.32);z-index:2}
.tile-leito{display:flex;align-items:center;justify-content:space-between;gap:2px;margin:-3px -4px 1px;
  height:13px;line-height:13px;background:rgba(0,0,0,.26);font-size:.53rem;color:#fff;padding:0 4px;
  white-space:nowrap;overflow:hidden;letter-spacing:.02em}
.tile-leito b{font-weight:800}
.tile-dias{font-weight:800;background:rgba(255,255,255,.28);border-radius:5px;padding:0 3px;font-style:normal;font-size:.5rem}
.tile-nome{font-size:.6rem;font-weight:700;line-height:1.04;overflow:hidden;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;text-shadow:0 1px 1px rgba(0,0,0,.28)}
.tile-be{font-size:.54rem;opacity:.85;font-variant-numeric:tabular-nums;margin-top:auto}

/* estados — paciente em VERDE por tempo de internação */
.tile.livre{background:#dfe5ee;border-color:#cdd6e2}
.tile.livre,.tile.bloqueado{justify-content:center;align-items:center;padding:2px}
.tile-vago{display:flex;flex-direction:column;align-items:center;line-height:1;font-size:.8rem;font-weight:800;color:#7a8699;text-shadow:none}
.tile-vago small{font-size:.46rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#9aa6b5;margin-bottom:1px}
.tile.bloqueado .tile-vago{color:#5b6675}
.tile.verde1{--g:#4fb37e;background:var(--g)}   /* < 48h (claro) */
.tile.verde2{--g:#2f9d5c;background:var(--g)}   /* 48h a 7 dias */
.tile.verde3{--g:#185e38;background:var(--g)}   /* > 7 dias (escuro) */
/* encaminhamento ext.: METADE amarelo (por tempo de regulação) METADE verde (por internação) */
.tile.enc{background:linear-gradient(90deg,var(--am,#efc230) 0 50%,var(--g,#2f9d5c) 50% 100%)}
.tile.enc.am1{--am:#f6db73}   /* pedido regulação < 24h (claro) */
.tile.enc.am2{--am:#efc230}   /* 24-48h (normal) */
.tile.enc.am3{--am:#c89400}   /* > 48h (escuro) */
/* sem movimentação de prontuário (Fluxista): cinza + ⚠ + horas */
.tile.sem-mov{background:#9aa6b5 !important;border-color:#7c8a99}
.tile.sem-mov .tile-nome{color:#1c2530;background:rgba(255,255,255,.6)}
.tile.sem-mov .tile-be{color:#26323f}
.tile-semmov{font-weight:800;background:#c0392b;color:#fff;border-radius:5px;padding:0 3px;font-style:normal;font-size:.5rem}
.tile.obito{background:#1c2530}                            /* óbito */
.tile.alta{background:linear-gradient(90deg,#aab4c2 0 50%,#d23b4e 50% 100%)}  /* alta médica sem sair */
.tile.bloqueado{background:#dfe5ee;
  background-image:linear-gradient(45deg,transparent 46%,#94a0ad 46% 54%,transparent 54%),
                   linear-gradient(-45deg,transparent 46%,#94a0ad 46% 54%,transparent 54%)}

/* recém-internado: efeito de "entrando" + brilho de novo */
.tile.recem{animation:tileEntra .5s cubic-bezier(.2,1.45,.5,1) both, tileNovo 1.7s ease-in-out .55s infinite}
@keyframes tileEntra{0%{transform:scale(.5);opacity:0}55%{transform:scale(1.12);opacity:1}100%{transform:scale(1)}}
@keyframes tileNovo{0%,100%{box-shadow:0 0 0 0 rgba(40,180,110,.6)}50%{box-shadow:0 0 0 5px rgba(40,180,110,0)}}

/* ONDA de movimentação (3h): AZUL = foi pra leito (vaga casada); ROXO = mudou de leito */
.tile.onda-azul{--onda:rgba(120,190,255,.6);box-shadow:inset 0 0 0 2px rgba(86,166,255,.95)}
.tile.onda-roxo{--onda:rgba(196,156,255,.55);box-shadow:inset 0 0 0 2px rgba(158,108,236,.95)}
.tile.onda-azul::after,.tile.onda-roxo::after{content:'';position:absolute;inset:0;border-radius:inherit;
  pointer-events:none;z-index:0;mix-blend-mode:screen;background-size:250% 100%;
  background:linear-gradient(120deg,transparent 35%,var(--onda) 50%,transparent 65%);
  animation:ondaMove 2.6s linear infinite}
.tile.onda-azul>*,.tile.onda-roxo>*{position:relative;z-index:1}
@keyframes ondaMove{from{background-position:130% 0}to{background-position:-130% 0}}
/* timer discreto do leito vazio (vazio há Nh) */
.tile-vazioh{position:absolute;top:2px;right:3px;font-size:.46rem;font-weight:800;color:#6c7a8c;
  background:rgba(255,255,255,.72);border-radius:5px;padding:0 3px;font-style:normal;line-height:1.5}

/* não-internados (acolhimento) — fluem AO LADO dos internados; preenchem com o tempo */
/* não-internado: a parte COLORIDA (com textura) cresce em ALTURA com as horas (6h=cheio) */
.tile.aguardando{--a:#2e9e5b;--ad:#1c6e44;--acl:#eef8f1;color:#1c2530;border:1px solid var(--a);
  justify-content:space-between;box-shadow:none;background-color:var(--acl);
  background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.32) 0 3px,transparent 3px 7px),
                   linear-gradient(var(--a),var(--a));
  background-repeat:no-repeat;background-position:bottom;background-size:100% var(--fill,0%)}
.tile.aguardando::before{display:none}
.tile.aguardando.area-verde{--a:#2e9e5b;--ad:#155033;--acl:#eef8f1}
.tile.aguardando.area-amarela{--a:#d9a400;--ad:#8f6c00;--acl:#fdf7e4}
.tile.aguardando.area-vermelha{--a:#d23b4e;--ad:#8f2030;--acl:#fdecef}
/* cheio (>=6h): tom escuro + textura — apressar conduta */
.tile.aguardando.cheio{border-color:var(--ad);animation:aguardCheio 1.5s ease-in-out infinite}
@keyframes aguardCheio{0%,100%{box-shadow:0 0 0 0 rgba(0,0,0,.0)}50%{box-shadow:0 0 0 3px rgba(160,30,45,.18)}}
.tile.aguardando .tile-nome{background:rgba(255,255,255,.86);color:#1c2530;border-radius:3px;padding:0 3px;text-shadow:none}
.tile.aguardando .tile-rod{display:flex;justify-content:space-between;align-items:center;gap:3px;margin-top:auto}
.tile.aguardando .tile-be{margin-top:0;opacity:.95;color:#1c2530;font-weight:700;background:rgba(255,255,255,.72);border-radius:3px;padding:0 2px}
.tile.aguardando.cheio .tile-nome{background:rgba(255,255,255,.9)}
.tile-cod{position:absolute;top:1px;right:2px;font-size:.74rem;line-height:1;z-index:1}
.tile-timer{align-self:flex-end;font-family:ui-monospace,Menlo,Consolas,monospace;font-weight:800;
  font-size:.64rem;color:#fff;background:rgba(0,0,0,.42);border-radius:4px;padding:0 4px}

/* popup do paciente (salta pra frente ao clicar) */
.pac-pop-bg{position:fixed;inset:0;background:rgba(14,26,46,.45);z-index:90;display:flex;
  align-items:center;justify-content:center;animation:popBg .14s ease both}
.pac-pop{background:#fff;border-radius:16px;box-shadow:0 26px 70px rgba(16,40,80,.45);
  width:360px;max-width:93vw;overflow:hidden;animation:popIn .22s cubic-bezier(.2,1.3,.4,1) both}
@keyframes popBg{from{opacity:0}to{opacity:1}}
@keyframes popIn{from{transform:scale(.55) translateY(14px);opacity:0}to{transform:scale(1);opacity:1}}
.pac-pop-head{padding:.8rem 1.1rem;background:linear-gradient(150deg,#1a5694,#0c2f57);color:#fff}
.pac-pop-head.aguard{background:linear-gradient(150deg,#d9a400,#b07d00)}
.pac-pop-nome{font-size:1.05rem;font-weight:800;line-height:1.15}
.pac-pop-sub{font-size:.78rem;color:#cfe0f2;margin-top:.15rem}
.pac-pop-head.aguard .pac-pop-sub{color:#fff5dd}
.pac-pop-body{padding:.7rem 1.1rem 1rem}
.pac-pop-row{display:flex;justify-content:space-between;gap:1rem;padding:.32rem 0;border-bottom:1px solid #eef2f7;font-size:.86rem}
.pac-pop-row:last-child{border-bottom:none}
.pac-pop-row .k{color:var(--cinza);font-weight:600}
.pac-pop-row .v{color:#1c2530;font-weight:600;text-align:right}
.pac-pop-cod{display:inline-block;font-size:.7rem;font-weight:800;color:#fff;border-radius:20px;padding:.05rem .5rem;margin-top:.4rem}
.pac-pop-x{position:absolute;top:8px;right:12px;color:#fff;font-size:1.3rem;cursor:pointer;opacity:.8;line-height:1}
.pac-pop-x:hover{opacity:1}
