:root{
  --bg:#eef2f1; --card:#ffffff; --line:#e2e8f0; --line2:#cbd5e1;
  --ink:#1f2937; --ink2:#475569; --dim:#94a3b8;
  --emer:#059669; --emer-d:#047857; --emer-l:#d1fae5;
  --red:#dc2626; --amber:#d97706; --cyan:#0891b2;
  --paper:#f7f5ef;
  --tom-critico:#dc2626; --tom-correcao:#d97706; --tom-protetivo:#059669; --tom-info:#0891b2; --tom-cartorio:#6366f1;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;font-family:'Inter','Segoe UI',system-ui,Roboto,sans-serif;background:var(--bg);color:var(--ink);overflow:hidden}
.app{display:flex;flex-direction:column;height:100vh}
a{color:inherit}

/* TOPBAR */
.topbar{height:54px;background:var(--card);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 18px;flex-shrink:0;z-index:20}
.brand{display:flex;align-items:center;gap:11px}
.logo{width:33px;height:33px;border-radius:7px;background:linear-gradient(135deg,var(--emer),#0ea5e9);display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;font-size:13px}
.brand h1{font-size:13.5px;margin:0;font-weight:700}
.brand p{font-size:11px;margin:0;color:var(--dim)}
.topbar .back{font-size:12px;color:var(--emer-d);text-decoration:none;font-weight:600;border:1px solid var(--line2);padding:5px 11px;border-radius:7px}
.topbar .back:hover{background:var(--emer-l)}

/* TIMELINE */
.timeline{background:var(--card);border-bottom:1px solid var(--line);padding:10px 18px;display:flex;align-items:center;gap:0;overflow-x:auto;flex-shrink:0}
.step{display:flex;align-items:center;gap:9px;cursor:pointer;flex-shrink:0}
.step .dot{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;border:2px solid var(--line2);background:#fff;color:var(--dim)}
.step.ok .dot{background:var(--emer);border-color:var(--emer);color:#fff}
.step.atual .dot{background:#fff;border-color:var(--emer);color:var(--emer-d);box-shadow:0 0 0 4px var(--emer-l)}
.step .lab{font-size:12px;font-weight:600;line-height:1.1}.step .lab small{display:block;font-size:10px;color:var(--dim);font-weight:500}
.step.pendente .lab{color:var(--dim)}
.step .bar{width:34px;height:2px;background:var(--line2);margin:0 10px}
.step.ok .bar,.step.atual .bar{background:var(--emer)}

/* LAYOUT */
.layout{flex:1;display:flex;min-height:0}
.pane-left{width:57%;min-width:420px;background:#dfe3e1;overflow-y:auto;border-right:1px solid var(--line2)}
.doc-toolbar{position:sticky;top:0;background:#cfd6d3;border-bottom:1px solid var(--line2);padding:7px 14px;font-size:11.5px;color:#3f4a44;display:flex;justify-content:space-between;align-items:center;z-index:6;flex-wrap:wrap;gap:6px}
.doc-toolbar .leg{display:flex;gap:11px}.doc-toolbar .leg b{display:inline-flex;align-items:center;gap:4px;font-weight:600}
.doc-toolbar .leg i{width:10px;height:10px;border-radius:3px;display:inline-block}
#pdfHost{padding:18px;display:flex;flex-direction:column;align-items:center;gap:18px}
.pdf-page{position:relative;box-shadow:0 6px 28px rgba(0,0,0,.28);background:#fff;line-height:0}
.pdf-page canvas{display:block}
.textLayer{position:absolute;inset:0;overflow:hidden;line-height:1;opacity:1}
.textLayer span{color:transparent;position:absolute;white-space:pre;transform-origin:0 0;cursor:default}
.textLayer span.ov{cursor:pointer;border-radius:2px;transition:background .12s,box-shadow .12s}
.textLayer span.ov.tc{background:rgba(220,38,38,.22)} .textLayer span.ov.tc:hover{background:rgba(220,38,38,.38)}
.textLayer span.ov.to{background:rgba(217,119,6,.26)} .textLayer span.ov.to:hover{background:rgba(217,119,6,.42)}
.textLayer span.ov.tp{background:rgba(5,150,105,.22)} .textLayer span.ov.tp:hover{background:rgba(5,150,105,.38)}
.textLayer span.ov.ti{background:rgba(8,145,178,.20)} .textLayer span.ov.ti:hover{background:rgba(8,145,178,.36)}
.textLayer span.ov.tcart{background:rgba(99,102,241,.20)} .textLayer span.ov.tcart:hover{background:rgba(99,102,241,.36)}
.textLayer span.ov.ttl{background:rgba(100,116,139,.20)} .textLayer span.ov.ttl:hover{background:rgba(100,116,139,.34)}
/* PALETA: 6 cores distintas (vizinhos nunca repetem) */
.textLayer span.ov.p0{background:rgba(8,145,178,.24)}  .textLayer span.ov.p0:hover{background:rgba(8,145,178,.42)}
.textLayer span.ov.p1{background:rgba(5,150,105,.24)}  .textLayer span.ov.p1:hover{background:rgba(5,150,105,.42)}
.textLayer span.ov.p2{background:rgba(217,119,6,.26)}  .textLayer span.ov.p2:hover{background:rgba(217,119,6,.44)}
.textLayer span.ov.p3{background:rgba(124,58,237,.24)} .textLayer span.ov.p3:hover{background:rgba(124,58,237,.42)}
.textLayer span.ov.p4{background:rgba(225,29,72,.22)}  .textLayer span.ov.p4:hover{background:rgba(225,29,72,.40)}
.textLayer span.ov.p5{background:rgba(13,148,136,.24)} .textLayer span.ov.p5:hover{background:rgba(13,148,136,.42)}
.textLayer span.gh.p0{background:rgba(8,145,178,.46)!important}
.textLayer span.gh.p1{background:rgba(5,150,105,.46)!important}
.textLayer span.gh.p2{background:rgba(217,119,6,.48)!important}
.textLayer span.gh.p3{background:rgba(124,58,237,.46)!important}
.textLayer span.gh.p4{background:rgba(225,29,72,.44)!important}
.textLayer span.gh.p5{background:rgba(13,148,136,.46)!important}
.textLayer span.ov.sel{box-shadow:0 0 0 2px #0f172a, 0 0 0 5px rgba(15,23,42,.25)}
/* group hover: destaca o TRECHO INTEIRO */
.textLayer span.gh.tc{background:rgba(220,38,38,.42)!important}
.textLayer span.gh.to{background:rgba(217,119,6,.44)!important}
.textLayer span.gh.tp{background:rgba(5,150,105,.40)!important}
.textLayer span.gh.ti{background:rgba(8,145,178,.40)!important}
.textLayer span.gh.tcart{background:rgba(99,102,241,.40)!important}
.textLayer span.gh.ttl{background:rgba(100,116,139,.36)!important}

/* RIGHT PANE */
.pane-right{flex:1;min-width:360px;background:var(--card);overflow-y:auto;display:flex;flex-direction:column}
.rp{padding:16px 18px 50px}

/* overview: pendências */
.ov-title{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--ink2);margin:4px 0 10px;display:flex;align-items:center;gap:7px}
.pend-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}
.pend-col{background:#f8fafc;border:1px solid var(--line);border-radius:10px;padding:10px}
.pend-col h4{margin:0 0 8px;font-size:12px;display:flex;align-items:center;justify-content:space-between}
.pend-col h4 .n{background:#0f172a;color:#fff;border-radius:20px;font-size:10px;padding:1px 7px}
.pend-item{font-size:11.5px;line-height:1.45;padding:7px 9px;border-radius:7px;background:#fff;border:1px solid var(--line);margin-bottom:6px;cursor:pointer;border-left-width:3px}
.pend-item:hover{background:var(--emer-l)}
.pend-item .g{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;margin-right:5px}
.g-alta{color:var(--red)} .g-media{color:var(--amber)} .g-baixa{color:var(--cyan)}
.lb-alta{border-left-color:var(--red)} .lb-media{border-left-color:var(--amber)} .lb-baixa{border-left-color:var(--cyan)}

.indice{margin-top:6px}
.idx-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:7px;cursor:pointer;font-size:12px}
.idx-item:hover{background:#f1f5f9}
.idx-item .pin{width:9px;height:9px;border-radius:3px;flex-shrink:0}
.idx-item .id{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--dim);width:42px;flex-shrink:0}
.idx-item .ix-t{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.idx-item .ix-del{flex-shrink:0;background:none;border:none;cursor:pointer;opacity:0;font-size:13px;line-height:1;padding:2px 4px;border-radius:6px;transition:opacity .12s}
.idx-item:hover .ix-del{opacity:.55}
.idx-item .ix-del:hover{opacity:1;background:#fee2e2}
.idx-item .ix-flag{flex-shrink:0;font-size:12px}
.flag-corr{background:#fef2f2;border:1px solid #fecaca;border-left:4px solid #dc2626;color:#991b1b;padding:10px 12px;border-radius:8px;font-size:12.5px;line-height:1.55;margin-bottom:12px}
.flag-corr strong{color:#dc2626}
.formbox{display:flex;flex-wrap:wrap;gap:12px;margin:4px 0 10px}
.formbox .fg{flex:1;min-width:210px;background:#f8fafc;border:1px solid var(--line2);border-radius:9px;padding:11px 12px}
.formbox .fg-t{font-size:11.5px;font-weight:700;color:#334155;margin-bottom:8px}
.formbox .fld{display:flex;flex-direction:column;gap:3px;margin-bottom:8px;font-size:10.5px;color:#64748b;text-transform:uppercase;letter-spacing:.03em}
.formbox .fld input{border:1px solid #cbd5e1;border-radius:6px;padding:7px 9px;font-size:13px;color:#0f172a;text-transform:none;letter-spacing:0}
.formbox .fld input:focus{outline:none;border-color:var(--emer-d);box-shadow:0 0 0 3px rgba(16,185,129,.15)}
.form-row{display:flex;align-items:center;gap:10px}
.form-save{background:var(--emer-d);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-weight:700;cursor:pointer;font-size:12px}
.form-save:hover{filter:brightness(1.06)}
.form-msg{color:#047857;font-size:12px;font-weight:600}
.callout-amber{background:#fffbeb;border:1px solid #fde68a;border-left:4px solid #f59e0b;color:#92400e;padding:11px 13px;border-radius:8px;margin-top:12px;font-size:12.5px;line-height:1.55}
.callout-amber strong{color:#b45309}
.tl-title{font-weight:700;color:#334155;font-size:12.5px;margin:16px 0 9px}
.tl-clausula{margin:0 0 6px;padding-left:2px}
.tlc-step{position:relative;display:flex;gap:11px;padding-bottom:13px}
.tlc-step:not(:last-child)::before{content:'';position:absolute;left:12px;top:25px;bottom:-1px;width:2px;background:#e2e8f0}
.tlc-dot{flex-shrink:0;width:25px;height:25px;border-radius:50%;background:#e2e8f0;color:#475569;font-size:11.5px;font-weight:700;display:flex;align-items:center;justify-content:center;z-index:1}
.tlc-step.key .tlc-dot{background:var(--emer-d);color:#fff}
.tlc-body{font-size:12px;line-height:1.45;padding-top:3px}
.tlc-body b{display:block;color:#0f172a;font-size:12.5px;margin-bottom:1px}
.tlc-body span{color:#64748b}
.tlc-step.key .tlc-body b{color:var(--emer-d)}

/* DETAIL */
.det-back{font-size:12px;color:var(--emer-d);background:none;border:none;cursor:pointer;font-weight:700;padding:0;margin-bottom:10px}
.det-head h3{margin:2px 0 8px;font-size:17px}
.badges{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:14px}
.badge{font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;border:1px solid}
.bt-critico{color:#b91c1c;background:#fef2f2;border-color:#fecaca}
.bt-correcao{color:#b45309;background:#fffbeb;border-color:#fde68a}
.bt-protetivo{color:#047857;background:#ecfdf5;border-color:#a7f3d0}
.bt-info{color:#0e7490;background:#ecfeff;border-color:#a5f3fc}
.bt-cartorio{color:#4338ca;background:#eef2ff;border-color:#c7d2fe}
.bt-status{color:#334155;background:#f1f5f9;border-color:var(--line2)}

/* CHAT */
.chat{border:1px solid var(--line);border-radius:12px;overflow:hidden;margin-bottom:16px;background:#f8fafc}
.chat-h{padding:8px 12px;background:#0f172a;color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;gap:7px}
.chat-h .pill{font-size:9px;background:#1e293b;color:#67e8f9;padding:1px 7px;border-radius:10px;font-weight:600}
.chat-log{max-height:160px;overflow-y:auto;padding:10px 12px;display:flex;flex-direction:column;gap:8px}
.chat.tall .chat-log{max-height:60vh}
.chat-h .chat-exp{margin-left:auto;background:none;border:none;color:#fff;font-size:15px;line-height:1;cursor:pointer;opacity:.85}
.chat-h .chat-exp:hover{opacity:1}

/* ---- mobile (≤860px): mantém o desktop; empilha + abas Minuta/Pontos ---- */
.mob-tabs{display:none}
@media(max-width:860px){
  .mob-tabs{display:flex;background:var(--card);border-bottom:1px solid var(--line);flex-shrink:0;position:sticky;top:0;z-index:8}
  .mob-tabs button{flex:1;border:none;background:none;padding:11px 8px;font-size:13px;font-weight:700;color:var(--dim);cursor:pointer;border-bottom:3px solid transparent;font-family:inherit}
  .mob-tabs button.on{color:var(--emer-d);border-bottom-color:var(--emer-d);background:#f0fdf4}
  .layout{flex-direction:column}
  .pane-left,.pane-right{width:100%;min-width:0;border-right:none;flex:1 1 auto;min-height:0}
  .layout .pane-left{display:none}            /* padrão: mostra os Pontos */
  .layout.mob-doc .pane-left{display:block}
  .layout.mob-doc .pane-right{display:none}
  .topbar{height:auto;flex-wrap:wrap;padding:7px 12px;gap:7px 10px}
  .brand p{display:none}
  .brand h1{font-size:13px}
  .top-actions{gap:6px;flex-wrap:wrap}
  .topnav a,.btn-pacote,.btn-agente{padding:6px 10px;font-size:11.5px}
  .doc-toolbar{font-size:10.5px}
  .stage img,.cf img,.docview img{max-width:100%;height:auto}
}
.msg{font-size:12px;line-height:1.5;padding:7px 10px;border-radius:9px;max-width:88%}
.msg.u{align-self:flex-end;background:var(--emer);color:#fff}
.msg.a{align-self:flex-start;background:#fff;border:1px solid var(--line);color:var(--ink);white-space:pre-wrap}
.chat-in{display:flex;gap:6px;padding:9px;border-top:1px solid var(--line);background:#fff}
.chat-in input{flex:1;border:1px solid var(--line2);border-radius:8px;padding:7px 10px;font-size:12.5px;outline:none}
.chat-in input:focus{border-color:var(--emer)}
.chat-in button{background:var(--emer);color:#fff;border:none;border-radius:8px;padding:0 14px;font-weight:700;cursor:pointer;font-size:12.5px}
.chat-in button:hover{background:var(--emer-d)}

/* DOC VIEWER + COVERFLOW */
.docview{margin-bottom:16px}
.docview .stage{background:#0f172a;border-radius:12px;height:300px;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:zoom-in;position:relative}
.docview .stage img{max-width:100%;max-height:100%;object-fit:contain}
.docview .stage .nodoc{color:#64748b;font-size:40px}
.docview .stage .cap{position:absolute;left:0;bottom:0;width:100%;background:linear-gradient(0deg,rgba(2,6,23,.85),transparent);color:#e2e8f0;font-size:11px;padding:16px 12px 8px}
.docview .acts{display:flex;gap:8px;margin-top:8px}
.docview .acts a{font-size:11.5px;font-weight:700;text-decoration:none;padding:6px 12px;border-radius:8px;background:var(--emer);color:#fff}
.docview .acts a.ghost{background:#fff;color:var(--emer-d);border:1px solid var(--emer)}
.docview .seal{font-size:10px;color:#047857;background:#ecfdf5;border:1px solid #a7f3d0;padding:2px 8px;border-radius:10px;align-self:center}
.coverflow{display:flex;gap:8px;overflow-x:auto;padding:14px 4px 6px;perspective:900px;scroll-behavior:smooth}
.cf{flex-shrink:0;width:74px;height:96px;border-radius:7px;overflow:hidden;border:2px solid transparent;background:#e2e8f0;cursor:pointer;transition:transform .25s,border-color .2s,opacity .2s;opacity:.7;transform:rotateY(28deg) scale(.9);transform-style:preserve-3d}
.cf:nth-child(odd){transform:rotateY(-28deg) scale(.9)}
.cf img{width:100%;height:100%;object-fit:cover;object-position:top}
.cf .nodoc{display:flex;height:100%;align-items:center;justify-content:center;color:#94a3b8;font-size:22px}
.cf:hover{opacity:1;transform:rotateY(0) scale(1)}
.cf.active{opacity:1;transform:rotateY(0) scale(1.04);border-color:var(--emer);box-shadow:0 6px 18px rgba(5,150,105,.3)}

/* SECTIONS */
.sec{margin-bottom:16px}
.sec-t{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--emer-d);margin-bottom:7px}
.trecho{background:#f8fafc;border-left:3px solid var(--line2);padding:10px 13px;border-radius:0 7px 7px 0;font-style:italic;color:#475569;font-size:12.5px;line-height:1.6}
.expl{font-size:13px;line-height:1.65;color:var(--ink)} .expl strong{color:#0f172a} .expl em{color:#0e7490;font-style:normal}
.lei{background:#f8fafc;border:1px solid var(--line);border-radius:8px;padding:11px 13px;font-size:12px;line-height:1.6;color:#334155}
.lei .art{color:var(--emer-d);font-weight:700}
table.tbl{width:100%;border-collapse:collapse;font-size:11.5px}
table.tbl th{background:#f1f5f9;text-align:left;padding:6px 8px;border:1px solid var(--line);font-weight:700}
table.tbl td{padding:6px 8px;border:1px solid var(--line);vertical-align:top}

/* APROVAR */
.aprovar{border-top:1px solid var(--line);margin-top:16px;padding-top:14px}
.aprovar .row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.aprovar select,.aprovar input{border:1px solid var(--line2);border-radius:8px;padding:7px 9px;font-size:12px;outline:none}
.aprovar input{flex:1;min-width:120px}
.aprovar .ok{background:var(--emer);color:#fff;border:none;border-radius:8px;padding:9px 16px;font-weight:800;cursor:pointer}
.aprovar .ok:hover{background:var(--emer-d)}
.aprovar .corr{background:#fff;color:#b45309;border:1px solid #f59e0b;border-radius:8px;padding:9px 16px;font-weight:800;cursor:pointer}
.aprovar .corr:hover{background:#fffbeb}
.aprovar .estado{font-size:11.5px;color:var(--ink2);margin-top:8px}
.aprovar .estado b{color:var(--emer-d)}

/* lightbox */
.lb{position:fixed;inset:0;background:rgba(2,6,23,.9);display:none;align-items:center;justify-content:center;z-index:60;padding:28px}
.lb.open{display:flex}
.lb img{max-width:94%;max-height:90%;border-radius:6px;box-shadow:0 12px 60px rgba(0,0,0,.6)}
.lb .x{position:absolute;top:16px;right:22px;color:#fff;font-size:32px;cursor:pointer;background:none;border:none}
.lb .dl{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);background:var(--emer);color:#fff;padding:9px 18px;border-radius:8px;text-decoration:none;font-weight:700;font-size:13px}
::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}
.loading{color:var(--dim);font-size:13px;padding:24px;text-align:center}

/* ====== FERRAMENTA DE MARCAÇÃO MANUAL ====== */
.textLayer, .textLayer span{ user-select:text; -webkit-user-select:text; }
.ov-layer{position:absolute;inset:0;pointer-events:none;z-index:3}
.ovh{position:absolute;border-radius:2px;cursor:pointer;pointer-events:auto;transition:filter .12s,box-shadow .12s}
.ovh:hover,.ovh.ghm{filter:brightness(.86)}
.ovh.sel{outline:2px solid #0f172a;outline-offset:1px}
#seltool{position:fixed;display:none;z-index:60;background:#0f172a;border:1px solid #28354d;border-radius:11px;padding:10px;box-shadow:0 12px 44px rgba(0,0,0,.5);width:344px}
#seltool.open{display:block}
#seltool .st-row{display:flex;align-items:center;gap:8px;margin-bottom:9px}
#seltool .st-row.st-actions{margin-bottom:0;justify-content:space-between}
#sel-titulo{flex:1;background:#0b1424;border:1px solid #28354d;border-radius:7px;padding:8px 10px;color:#e2e8f0;font-size:12.5px;outline:none}
#sel-titulo:focus{border-color:#059669}
#sel-swatches{display:flex;gap:6px;flex:1;flex-wrap:wrap}
#sel-swatches .sw{width:23px;height:23px;border-radius:6px;cursor:pointer;border:2px solid transparent}
#sel-swatches .sw.on{border-color:#fff;box-shadow:0 0 0 2px #0ea5e9}
#sel-custom{width:34px;height:28px;border:1px solid #28354d;border-radius:6px;background:none;cursor:pointer;padding:1px}
.st-cancel{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:12px}
.st-cancel:hover{color:#e2e8f0}
.st-create{background:#059669;border:none;color:#fff;font-weight:800;border-radius:8px;padding:8px 15px;cursor:pointer;font-size:13px}
.st-create:hover{background:#047857}
.vazio{font-size:12.5px;color:#64748b;line-height:1.6;background:#f8fafc;border:1px dashed var(--line2);border-radius:10px;padding:16px}
.bt-del{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;cursor:pointer;font-weight:700;border-radius:20px;padding:3px 9px;font-size:10px}
.bt-del:hover{background:#fee2e2}

/* ---- resumo para a empresa ---- */
.top-actions{display:flex;align-items:center;gap:10px}
.btn-resumo{font-size:12px;font-weight:700;background:var(--emer,#10b981);color:#fff;border:none;padding:7px 13px;border-radius:8px;cursor:pointer;box-shadow:0 2px 9px rgba(16,185,129,.35);white-space:nowrap;text-decoration:none;display:inline-block}
.btn-resumo:hover{filter:brightness(1.07)}
.topnav{display:flex;gap:5px}
.topnav a{font-size:12.5px;font-weight:700;text-decoration:none;color:#475569;padding:7px 14px;border-radius:8px;border:1px solid var(--line2)}
.topnav a.active{background:var(--emer-d,#047857);color:#fff;border-color:var(--emer-d,#047857)}
.topnav a:hover:not(.active){background:#f1f5f9}
.btn-agente{font-size:12.5px;font-weight:700;background:#7c3aed;color:#fff;border:none;padding:7px 13px;border-radius:8px;cursor:pointer;white-space:nowrap;box-shadow:0 2px 9px rgba(124,58,237,.35)}
.btn-agente:hover{filter:brightness(1.07)}
.btn-pacote{font-size:12.5px;font-weight:700;background:#047857;color:#fff;border:none;padding:7px 13px;border-radius:8px;cursor:pointer;white-space:nowrap;text-decoration:none;display:inline-block}
.btn-pacote:hover{filter:brightness(1.08)}
.fld input.filled{color:#dc2626;font-weight:600}
.wpp-box{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:11px;padding:13px 14px}
.wpp-box p{font-size:12.5px;color:#3f6212;margin:0 0 9px;line-height:1.45}
.wpp-row{display:flex;gap:7px}
.wpp-row input{flex:1;border:1px solid #86efac;border-radius:8px;padding:9px 11px;font-size:13px;outline:none;font-family:inherit}
.wpp-row input:focus{border-color:#047857}
.wpp-row button{background:#25D366;color:#fff;border:none;border-radius:8px;padding:0 16px;font-weight:700;font-size:13px;cursor:pointer;white-space:nowrap}
.wpp-row button:hover{filter:brightness(1.05)}
.wpp-msg{font-size:12px;margin-top:8px;min-height:14px;line-height:1.4}
.ov-instr{font-size:12px;color:#64748b;line-height:1.5;margin:-2px 0 12px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:9px;padding:9px 12px}
.rmodal{position:fixed;inset:0;background:rgba(15,23,42,.55);display:none;align-items:flex-start;justify-content:center;z-index:80;padding:32px 16px;overflow-y:auto}
.rmodal.on{display:flex}
.rm-card{background:#fff;max-width:760px;width:100%;border-radius:16px;padding:24px 28px 20px;position:relative;box-shadow:0 24px 80px rgba(0,0,0,.42);font-family:'Palatino Linotype','Book Antiqua',Palatino,serif}
.rm-x{position:absolute;top:13px;right:16px;border:none;background:none;font-size:27px;line-height:1;color:#94a3b8;cursor:pointer}
.rm-x:hover{color:#475569}
.rm-head h2{font-size:20px;color:#0f172a;margin:0 0 3px}
.rm-head p{font-size:12px;color:#64748b;margin:0}
.rm-intro{font-size:13px;color:#334155;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:11px 14px;margin:15px 0 18px;line-height:1.5}
.rm-sec{margin-bottom:16px}
.rm-sec-h{font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px;margin-bottom:9px;padding-bottom:6px;border-bottom:2px solid #f1f5f9}
.rm-sec-h.imp{color:#b91c1c}
.rm-sec-h.peq{color:#0369a1}
.rm-sec-h span{margin-left:auto;font-size:12px;font-weight:700;background:#f1f5f9;color:#475569;border-radius:20px;padding:1px 10px}
.rm-item{border:1px solid #e2e8f0;border-left-width:4px;border-radius:10px;padding:9px 13px;margin-bottom:8px;cursor:pointer;transition:background .12s,transform .08s}
.rm-item:hover{background:#f8fafc;transform:translateX(2px)}
.rm-item.imp{border-left-color:#ef4444}
.rm-item.peq{border-left-color:#0ea5e9}
.rm-it-top{display:flex;align-items:center;gap:9px;margin-bottom:3px}
.rm-tag{font-size:11px;font-weight:700;background:#0f172a;color:#fff;border-radius:6px;padding:1px 7px;flex-shrink:0}
.rm-it-t{font-size:13.5px;font-weight:700;color:#1e293b}
.rm-it-d{font-size:12.5px;color:#475569;line-height:1.45}
.rm-foot{font-size:12px;color:#64748b;text-align:center;border-top:1px solid #f1f5f9;padding-top:13px;margin-top:6px;line-height:1.5}
@media(max-width:560px){.rm-card{padding:20px 16px}.btn-resumo{padding:6px 9px}}

/* ======================================================================
   MAPA DO PATRIMÔNIO — 3 painéis: navegador (mapa+cards) | PDF | observações
   ====================================================================== */
.pane-nav{width:322px;min-width:288px;flex-shrink:0;background:#0f172a;color:#e2e8f0;display:flex;flex-direction:column;border-right:1px solid #1e293b;overflow:hidden}
#map{height:300px;flex-shrink:0;background:#0a0f1a;z-index:1}
.pane-nav .nav-body{flex:1;overflow-y:auto;padding:12px 12px 30px}
.pane-nav .nav-body::-webkit-scrollbar{width:7px}.pane-nav .nav-body::-webkit-scrollbar-thumb{background:#334155;border-radius:4px}
.nav-title{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:#64748b;margin:4px 2px 9px}
.nav-foot{font-size:10px;color:#64748b;line-height:1.55;margin-top:12px;border-top:1px solid #1e293b;padding-top:10px}
.mcard{background:#1e293b80;border:1px solid #334155;border-left:4px solid var(--cor);border-radius:9px;padding:9px 11px;margin-bottom:8px;cursor:pointer;transition:background .15s,transform .1s}
.mcard:hover{background:#1e293b;transform:translateX(2px)}
.mcard.ativo{background:#1e293b;border-color:var(--cor);box-shadow:0 0 0 1px var(--cor),0 6px 16px rgba(0,0,0,.4)}
.mc-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.mc-num{font-size:12.5px;font-weight:700;color:#f1f5f9}
.mc-area{font-size:11px;color:#94a3b8;font-family:'JetBrains Mono',monospace;flex-shrink:0}
.mc-tit{font-size:11px;color:#cbd5e1;margin:3px 0 5px;line-height:1.35}
.mc-badge{font-size:10px;font-weight:600;display:inline-block;padding:2px 8px;border-radius:5px}
.mcard.st-limpo .mc-badge{background:rgba(16,185,129,.16);color:#6ee7b7}
.mcard.st-reg   .mc-badge{background:rgba(217,119,6,.18);color:#fcd34d}
.mcard.st-ativo .mc-badge{background:rgba(239,68,68,.16);color:#fca5a5}

/* CENTRO: PDF da matrícula (herda do antigo .pane-left) */
.pane-doc{flex:1;min-width:360px;background:#dfe3e1;overflow-y:auto;border-right:1px solid var(--line2);display:flex;flex-direction:column}
.pane-doc .doc-toolbar{position:sticky;top:0}
.pane-doc #pdfHost{flex:1}
.pdf-page{max-width:900px;width:100%}
.pg-img{display:block;width:100%;height:auto;aspect-ratio:595/842;background:#fff}
.pg-ph{display:flex;align-items:center;justify-content:center;background:#fff;color:#94a3b8;font-size:12px;aspect-ratio:595/842;width:100%}
.pdf-page.pg-erro{box-shadow:none}

/* DIREITA: observações — largura fixa */
.pane-right{flex:0 0 404px;min-width:340px}

/* mat-head (cabeçalho da matrícula no painel direito) */
.mat-head{background:#f8fafc;border:1px solid var(--line);border-radius:11px;padding:12px 14px;margin-bottom:14px}
.mh-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.mh-top h2{font-size:15px;margin:0;color:#0f172a;line-height:1.25}
.mh-pill{font-size:10px;font-weight:800;padding:3px 9px;border-radius:20px;white-space:nowrap;flex-shrink:0;border:1px solid}
.mh-pill.st-limpo{background:#ecfdf5;color:#047857;border-color:#a7f3d0}
.mh-pill.st-reg{background:#fffbeb;color:#b45309;border-color:#fde68a}
.mh-pill.st-ativo{background:#fef2f2;color:#b91c1c;border-color:#fecaca}
.mh-meta{font-size:11.5px;color:#64748b;margin-top:6px}
.mh-resumo{font-size:12.5px;color:#334155;line-height:1.6;margin:9px 0 0}

/* ferramenta de marcação por retângulo (modo edição) */
.draw-surface{position:absolute;inset:0;z-index:5;cursor:crosshair;background:transparent}
.draw-box{position:absolute;border:2px dashed #0f172a;background:rgba(15,23,42,.12);pointer-events:none;z-index:6}
.badge.bt-crop{background:#eef2ff;border:1px solid #c7d2fe;color:#4338ca;cursor:pointer;font-weight:700}
.badge.bt-crop:hover{background:#e0e7ff}

/* tooltip dos rótulos no mapa Leaflet */
.leaflet-tooltip.rotulo-mapa{background:#0f172acc;border:1px solid #334155;color:#e2e8f0;font:700 10px/1.1 'JetBrains Mono','Segoe UI',monospace;padding:2px 6px;border-radius:4px;box-shadow:none;white-space:nowrap}
.leaflet-tooltip.rotulo-mapa::before{display:none}

/* ---- mobile (≤980px): 3 abas Mapa / Matrícula / Observações ---- */
@media(max-width:980px){
  .mob-tabs{display:flex}
  .layout{flex-direction:column}
  .pane-nav,.pane-doc,.pane-right{width:100%;min-width:0;flex:1 1 auto;min-height:0;border-right:none}
  .pane-nav{display:none}.pane-doc{display:none}.pane-right{display:none}
  .layout.mob-mapa .pane-nav{display:flex}
  .layout.mob-doc  .pane-doc{display:flex}
  .layout.mob-obs  .pane-right{display:flex}
  .pane-nav #map{height:46vh}
}
@media(min-width:981px){ .mob-tabs{display:none} }

/* ====== modos: mapa-herói (overview) ↔ matrícula (detalhe) ====== */
.btn-baixar{font-size:12.5px;font-weight:700;text-decoration:none;color:#fff;background:#047857;padding:7px 13px;border-radius:8px;border:1px solid #047857;white-space:nowrap}
.btn-baixar:hover{filter:brightness(1.08)}
.btn-mapa{font-size:12px;font-weight:700;color:#fff;background:#0f172a;border:none;border-radius:7px;padding:5px 11px;cursor:pointer;margin-right:10px;flex-shrink:0}
.btn-mapa:hover{background:#1e293b}
@media(min-width:981px){
  .layout.modo-mapa .pane-nav{flex:1 1 auto;width:auto;min-width:520px}
  .layout.modo-mapa #map{height:58vh}
  .layout.modo-mapa #cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:10px}
  .layout.modo-mapa .pane-doc{display:none}
  .layout.modo-matricula .pane-nav{flex:0 0 322px;width:322px}
  .layout.modo-matricula #map{height:300px}
  .layout.modo-matricula .pane-doc{display:flex}
}
.layout.modo-mapa .btn-mapa{display:none}

/* painel do patrimônio (direita, no modo-mapa) */
.pat-hero{background:linear-gradient(135deg,#0f3b34,#065f46);color:#fff;border-radius:13px;padding:15px 17px;margin-bottom:16px}
.pat-hero h2{font-size:17px;margin:0 0 5px}
.pat-hero p{font-size:12.5px;line-height:1.55;opacity:.92;margin:0}
.pat-hero strong{color:#a7f3d0}
.passos{display:flex;flex-direction:column;gap:7px}
.passo{display:flex;align-items:center;gap:11px;background:#f8fafc;border:1px solid var(--line);border-left:4px solid var(--emer);border-radius:10px;padding:9px 12px;cursor:pointer;transition:background .12s,transform .08s}
.passo:hover{background:#ecfdf5;transform:translateX(2px)}
.passo.atual{border-left-color:#0ea5e9}
.passo.pendente{border-left-color:#cbd5e1}
.passo .pn{width:24px;height:24px;border-radius:50%;background:#0f172a;color:#fff;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.passo.ok .pn{background:var(--emer)}.passo.atual .pn{background:#0ea5e9}.passo.pendente .pn{background:#cbd5e1;color:#475569}
.passo .pb{flex:1;min-width:0}
.passo .pl{font-size:13px;font-weight:700;color:var(--ink)}
.passo .ps{font-size:11px;color:var(--dim)}
.passo .pchev{color:#94a3b8;font-size:13px}
.step{cursor:pointer}
.step:hover .lab{color:var(--emer-d)}

/* roadmap modal — etapas */
.rm-step{border:1px solid #e2e8f0;border-left:4px solid var(--emer);border-radius:11px;padding:13px 16px;margin-bottom:11px;background:#fff}
.rm-step.foco{box-shadow:0 0 0 2px var(--emer-l);border-left-color:var(--emer-d)}
.rm-step.atual{border-left-color:#0ea5e9}.rm-step.pendente{border-left-color:#cbd5e1}
.rm-step .rs-h{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.rm-step .rs-n{width:25px;height:25px;border-radius:50%;background:#0f172a;color:#fff;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rm-step.ok .rs-n{background:var(--emer)}.rm-step.atual .rs-n{background:#0ea5e9}.rm-step.pendente .rs-n{background:#cbd5e1;color:#475569}
.rm-step .rs-t{font-size:15px;font-weight:700;color:#0f172a}
.rm-step .rs-sub{font-size:11.5px;color:var(--dim);margin-left:auto;text-align:right}
.rm-step .rs-d{font-size:13px;color:#334155;line-height:1.6}
.rm-step .rs-d ul{margin:6px 0 0 18px}.rm-step .rs-d li{margin-bottom:4px}
.rm-step .rs-d p{margin:0 0 6px}

/* ====== repositório (modal) + visualizador de documento ====== */
.rm-zip{display:inline-block;background:#047857;color:#fff;font-weight:800;text-decoration:none;padding:9px 16px;border-radius:9px;font-size:13px}
.rm-zip:hover{filter:brightness(1.08)}
.rcat{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:9px;overflow:hidden}
.rcat-h{display:flex;align-items:center;gap:11px;padding:12px 15px;cursor:pointer;user-select:none}
.rcat-ic{width:32px;height:32px;border-radius:8px;background:#ecfdf5;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.rcat-t{font-size:13.5px;font-weight:700;color:var(--ink);flex:1}
.rcat-c{font-size:11px;font-weight:700;color:var(--ink2);background:#f1f5f9;border-radius:20px;padding:2px 9px}
.rcat-body{max-height:0;overflow:hidden;transition:max-height .3s ease}
.rcat.open .rcat-body{max-height:1600px}
.rfile{display:flex;align-items:center;gap:10px;padding:9px 15px;border-top:1px solid #f1f5f9;cursor:pointer}
.rfile:hover{background:#f0fdf4}
.rfile .rf-ic{font-size:15px;flex-shrink:0}
.rfile .rf-n{flex:1;font-size:12.5px;color:var(--ink2);font-weight:600}
.rfile .rf-go{font-size:11px;font-weight:700;color:var(--emer-d);border:1px solid #a7f3d0;background:#ecfdf5;border-radius:7px;padding:4px 10px;white-space:nowrap}
.docviewer{position:fixed;inset:0;background:#0f172a;z-index:95;display:none;flex-direction:column}
.docviewer.on{display:flex}
.dv-bar{height:50px;background:#1e293b;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 16px;color:#e2e8f0;flex-shrink:0}
.dv-name{font-size:13px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dv-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}
.dv-actions a,.dv-actions button{font-size:12px;font-weight:700;color:#e2e8f0;background:#334155;border:none;border-radius:7px;padding:7px 12px;text-decoration:none;cursor:pointer;font-family:inherit;white-space:nowrap}
.dv-actions a:hover,.dv-actions button:hover{background:#475569}
.dv-stage{flex:1;display:flex;align-items:center;justify-content:center;overflow:auto;background:#0b1220}
.dv-stage iframe{width:100%;height:100%;border:none;background:#fff}
.dv-stage img{max-width:100%;max-height:100%;object-fit:contain}

/* timeline (topo) — claramente clicável / "acesa" */
.timeline-hint{font-size:11px;font-weight:800;color:var(--emer-d);background:#ecfdf5;border:1px solid #a7f3d0;border-radius:20px;padding:4px 12px;white-space:nowrap;flex-shrink:0;align-self:center;margin-right:6px;text-transform:uppercase;letter-spacing:.4px}
.timeline .step.clic{cursor:pointer;border-radius:9px;padding:3px 8px;transition:background .12s,transform .08s}
.timeline .step.clic:hover{background:#ecfdf5;transform:translateY(-1px)}
.timeline .step.clic:hover .dot{box-shadow:0 0 0 4px var(--emer-l)}
.timeline .step.pendente .dot{border-color:#f59e0b;color:#b45309;background:#fffbeb}
.timeline .step.pendente .lab{color:#334155}

