/* ===================== AgilusMed · Repositório de Documentos ===================== */
@font-face { font-family:"Montserrat"; src:url("/fonts/Montserrat-Regular.ttf") format("truetype"); font-weight:400; font-display:swap; }
@font-face { font-family:"Montserrat"; src:url("/fonts/Montserrat-Medium.ttf") format("truetype"); font-weight:500; font-display:swap; }
@font-face { font-family:"Montserrat"; src:url("/fonts/Montserrat-SemiBold.ttf") format("truetype"); font-weight:600; font-display:swap; }
@font-face { font-family:"Montserrat"; src:url("/fonts/Montserrat-Bold.ttf") format("truetype"); font-weight:700; font-display:swap; }
@font-face { font-family:"Montserrat"; src:url("/fonts/Montserrat-ExtraBold.ttf") format("truetype"); font-weight:800; font-display:swap; }

:root{
  --oliva:#585850; --oliva-esc:#43433c; --oliva-claro:#6f6f64;
  --dourado:#D8C860; --dourado-esc:#B9A63F;
  --bg:#f4f4f1; --card:#ffffff; --linha:#e7e7e1; --texto:#33332e; --suave:#8a8a80;
  --vermelho:#c0392b; --laranja:#c97a17; --amarelo:#b9930a; --verde:#4f7a3a;
  --radius:14px; --sombra:0 1px 3px rgba(60,60,50,.08),0 6px 22px rgba(60,60,50,.06);
}
*{box-sizing:border-box}
[hidden]{display:none !important}
html,body{margin:0;padding:0}
body{font-family:"Montserrat",system-ui,sans-serif;background:var(--bg);color:var(--texto);-webkit-font-smoothing:antialiased;font-size:15px}
h1,h2,h3{margin:0;font-weight:700;letter-spacing:-.01em}
a{color:var(--oliva)}
button{font-family:inherit}
input,select,textarea{font-family:inherit;font-size:15px}

/* -------- Botões -------- */
.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--linha);background:#fff;color:var(--texto);
  padding:9px 15px;border-radius:10px;cursor:pointer;font-weight:600;font-size:14px;transition:.15s;white-space:nowrap}
.btn:hover{border-color:#cfcfc6;background:#fafaf8}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--oliva);border-color:var(--oliva);color:#fff}
.btn-primary:hover{background:var(--oliva-esc);border-color:var(--oliva-esc)}
.btn-gold{background:var(--dourado);border-color:var(--dourado);color:#43433c}
.btn-gold:hover{background:var(--dourado-esc);border-color:var(--dourado-esc)}
.btn-ghost{border-color:transparent;background:transparent}
.btn-ghost:hover{background:#eceae3}
.btn-danger{color:var(--vermelho);border-color:#e9cfca}
.btn-danger:hover{background:#fbeae7;border-color:#e0b6ae}
.btn-sm{padding:6px 11px;font-size:13px;border-radius:9px}
.btn-block{width:100%;justify-content:center;padding:12px}
.btn:disabled{opacity:.55;cursor:not-allowed}
.icon-btn{padding:7px;border-radius:9px;line-height:0}

/* -------- Login -------- */
.login-wrap{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:24px;
  background:radial-gradient(1200px 600px at 50% -10%, #fff, var(--bg))}
.login-card{background:var(--card);border:1px solid var(--linha);border-radius:18px;box-shadow:var(--sombra);
  padding:30px 28px;width:100%;max-width:380px;display:flex;flex-direction:column;gap:12px}
.login-logo{height:270px;max-width:100%;object-fit:contain;align-self:center;margin-bottom:10px}
.login-card h1{font-size:20px;text-align:center;color:var(--oliva)}
.login-sub{margin:0 0 8px;text-align:center;color:var(--suave);font-size:13px}
.login-card label,.modal label{display:flex;flex-direction:column;gap:5px;font-size:13px;font-weight:600;color:var(--oliva)}
.login-card input,.modal input,.modal select,.modal textarea{
  border:1px solid var(--linha);border-radius:10px;padding:11px 12px;background:#fcfcfa;color:var(--texto);font-weight:500}
.login-card input:focus,.modal input:focus,.modal select:focus,.modal textarea:focus{
  outline:none;border-color:var(--dourado-esc);background:#fff;box-shadow:0 0 0 3px rgba(216,200,96,.18)}
.login-foot{color:var(--suave);font-size:12px;text-align:center;max-width:540px;display:grid;gap:6px;line-height:1.5}
.login-foot a{color:var(--oliva);text-decoration:none}
.login-foot a:hover{text-decoration:underline}
.lf-brand{font-weight:600;color:var(--oliva-claro)}
.lf-links{display:flex;flex-wrap:wrap;gap:6px 10px;justify-content:center;align-items:center}
.lf-legal{font-size:11px;color:var(--suave)}
.erro{color:var(--vermelho);font-size:13px;font-weight:600;min-height:18px;text-align:center}

/* -------- Topo / layout -------- */
.topbar{position:sticky;top:0;z-index:20;background:var(--oliva);color:#fff;box-shadow:0 2px 12px rgba(60,60,50,.18)}
.topbar-main{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 18px;height:58px}
.topbar .brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:16px;color:#fff;text-decoration:none}
.topbar .brand img{height:30px}
.topbar .brand small{display:block;font-size:10.5px;font-weight:600;color:var(--dourado);letter-spacing:.04em;text-transform:uppercase}
.nav{display:flex;flex-wrap:wrap;gap:4px;padding:6px 14px 9px;border-top:1px solid rgba(255,255,255,.12)}
.nav a{display:inline-flex;align-items:center;gap:7px;color:#e9e9e2;text-decoration:none;padding:9px 13px;border-radius:9px;
  font-weight:600;font-size:14px;white-space:nowrap;cursor:pointer}
.nav a svg{width:17px;height:17px;opacity:.85}
.nav a:hover{background:rgba(255,255,255,.1)}
.nav a.ativo{background:rgba(216,200,96,.22);color:#fff}
.nav a.ativo svg{opacity:1;color:var(--dourado)}
.usermenu{position:relative}
.usermenu>button{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.08);border:none;color:#fff;
  padding:7px 11px;border-radius:10px;cursor:pointer;font-weight:600;font-size:13px}
.usermenu .av{width:28px;height:28px;border-radius:50%;background:var(--dourado);color:#43433c;display:grid;place-items:center;font-weight:800;font-size:13px}
.dropdown{position:absolute;right:0;top:46px;background:#fff;color:var(--texto);border:1px solid var(--linha);border-radius:12px;
  box-shadow:var(--sombra);min-width:210px;padding:6px;display:none}
.dropdown.open{display:block}
.dropdown .who{padding:9px 11px;border-bottom:1px solid var(--linha);margin-bottom:4px}
.dropdown .who b{display:block;font-size:14px}
.dropdown .who span{font-size:12px;color:var(--suave)}
.dropdown button{display:flex;align-items:center;gap:9px;width:100%;text-align:left;background:none;border:none;padding:9px 11px;
  border-radius:8px;cursor:pointer;font-size:14px;color:var(--texto);font-weight:500}
.dropdown button:hover{background:#f3f2ec}
.dropdown button svg{width:16px;height:16px;flex-shrink:0;color:var(--oliva)}

main{max-width:1180px;margin:0 auto;padding:22px 18px 60px}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.page-head h2{font-size:22px;color:var(--oliva-esc)}
.page-head .sub{color:var(--suave);font-size:13px;margin-top:2px}
.toolbar{display:flex;gap:9px;flex-wrap:wrap;align-items:center}

/* -------- Cards / grids -------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:22px}
.stat{background:var(--card);border:1px solid var(--linha);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--sombra)}
.stat .v{font-size:30px;font-weight:800;color:var(--oliva-esc);line-height:1}
.stat .l{color:var(--suave);font-size:13px;font-weight:600;margin-top:6px}
.stat.alerta .v{color:var(--vermelho)}
.stat.aviso .v{color:var(--laranja)}
.stat .l svg{width:15px;height:15px;vertical-align:-2px;margin-right:3px}

.panel{background:var(--card);border:1px solid var(--linha);border-radius:var(--radius);box-shadow:var(--sombra);margin-bottom:18px;overflow:hidden}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 18px;border-bottom:1px solid var(--linha)}
.panel-head h3{font-size:16px;color:var(--oliva-esc);display:flex;align-items:center;gap:8px}
.panel-head h3 svg{width:18px;height:18px;color:var(--oliva)}
.panel-body{padding:6px 18px 16px}
.panel-body label{display:flex;flex-direction:column;gap:5px;font-size:13px;font-weight:600;color:var(--oliva);margin-bottom:11px}
.panel-body label.check{flex-direction:row;align-items:center;gap:9px}
.panel-body label input:not([type=checkbox]),.panel-body label select,.panel-body label textarea{border:1px solid var(--linha);border-radius:9px;padding:9px 11px;background:#fcfcfa;font-weight:500;font-size:14px;color:var(--texto);font-family:inherit}
.panel-body label input:focus,.panel-body label select:focus,.panel-body label textarea:focus{outline:none;border-color:var(--dourado-esc);background:#fff;box-shadow:0 0 0 3px rgba(216,200,96,.18)}

/* -------- Tabelas -------- */
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.03em;color:var(--suave);font-weight:700;padding:10px 10px;border-bottom:1px solid var(--linha)}
.tbl td{padding:11px 10px;border-bottom:1px solid #f0efe9;vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr.click{cursor:pointer}
.tbl tr.click:hover td{background:#faf9f4}
.tbl .nome{font-weight:600;color:var(--oliva-esc)}
.tbl .mut{color:var(--suave);font-size:13px}
.right{text-align:right}.center{text-align:center}
.acoes{display:flex;gap:5px;justify-content:flex-end}

/* -------- Chips / badges -------- */
.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;
  background:#eef0e8;color:var(--oliva)}
.chip.cat{background:#eef0e8;color:var(--oliva-esc)}
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:7px;font-size:12px;font-weight:700}
.b-vencido{background:#fbeae7;color:var(--vermelho)}
.b-30{background:#fbeedd;color:var(--laranja)}
.b-60{background:#fdf6df;color:var(--amarelo)}
.b-90{background:#eaf2e4;color:var(--verde)}
.b-ok{background:#eef0e8;color:var(--oliva)}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.pill-tab{display:flex;flex-wrap:wrap;background:#eceae3;border-radius:10px;padding:3px;gap:3px}
.pill-tab button{border:none;background:none;padding:7px 14px;border-radius:8px;font-weight:600;font-size:13px;color:var(--suave);cursor:pointer}
.pill-tab button.ativo{background:#fff;color:var(--oliva-esc);box-shadow:0 1px 3px rgba(0,0,0,.08)}

/* -------- Busca / inputs inline -------- */
.search{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--linha);border-radius:10px;padding:0 12px;min-width:230px}
.search input{border:none;outline:none;background:none;padding:10px 0;flex:1;font-weight:500}
.search svg{width:17px;height:17px;color:var(--suave)}
select.sel{border:1px solid var(--linha);border-radius:10px;padding:9px 12px;background:#fff;font-weight:600;color:var(--texto);cursor:pointer}

/* -------- Modal -------- */
.modal-bg{position:fixed;inset:0;background:rgba(50,50,42,.42);backdrop-filter:blur(2px);z-index:60;display:flex;align-items:flex-start;justify-content:center;padding:30px 16px;overflow:auto}
.modal{background:#fff;border-radius:18px;box-shadow:0 20px 60px rgba(0,0,0,.25);width:100%;max-width:540px;animation:pop .14s ease}
.modal.lg{max-width:760px}
@keyframes pop{from{transform:translateY(8px);opacity:.6}to{transform:none;opacity:1}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--linha)}
.modal-head h3{font-size:18px;color:var(--oliva-esc)}
.modal-body{padding:20px 22px;display:flex;flex-direction:column;gap:14px}
.modal-foot{display:flex;justify-content:flex-end;gap:9px;padding:14px 22px;border-top:1px solid var(--linha)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.row{display:flex;gap:12px;align-items:center}
.check{flex-direction:row !important;align-items:center;gap:9px;cursor:pointer;font-weight:600;color:var(--texto)}
.check input{width:18px;height:18px;accent-color:var(--oliva)}
.hint{font-size:12px;color:var(--suave);font-weight:500}

/* -------- Dropzone -------- */
.dropzone{border:2px dashed #d3d2c8;border-radius:12px;padding:22px;text-align:center;color:var(--suave);cursor:pointer;background:#fcfcfa;transition:.15s}
.dropzone:hover,.dropzone.over{border-color:var(--dourado-esc);background:#fffdf2;color:var(--oliva)}
.dropzone svg{width:26px;height:26px;color:var(--oliva-claro);margin-bottom:6px}
.dropzone b{color:var(--oliva-esc)}
.file-chip{display:flex;align-items:center;gap:10px;background:#eef0e8;border-radius:10px;padding:10px 12px;font-weight:600;color:var(--oliva-esc)}
.file-chip .x{margin-left:auto;cursor:pointer;color:var(--suave)}

/* -------- Estados -------- */
.empty{text-align:center;color:var(--suave);padding:46px 20px}
.empty svg{width:42px;height:42px;opacity:.4;margin-bottom:10px}
.empty b{display:block;color:var(--oliva-esc);font-size:16px;margin-bottom:4px}
.loading{text-align:center;color:var(--suave);padding:40px}
.spin{width:30px;height:30px;border:3px solid var(--linha);border-top-color:var(--oliva);border-radius:50%;animation:r 1s linear infinite;margin:0 auto 12px}
@keyframes r{to{transform:rotate(360deg)}}

/* -------- Toast -------- */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--oliva-esc);color:#fff;padding:12px 20px;
  border-radius:12px;font-weight:600;font-size:14px;z-index:90;box-shadow:0 8px 30px rgba(0,0,0,.25);max-width:90vw}
.toast.err{background:var(--vermelho)}
.toast.ok{background:var(--verde)}

/* -------- Portal cliente -------- */
.portal-hero{background:linear-gradient(120deg,var(--oliva),var(--oliva-esc));color:#fff;border-radius:var(--radius);padding:24px;margin-bottom:20px}
.portal-hero h2{font-size:22px}
.portal-hero p{margin:6px 0 0;color:#e6e6dd}
.doc-card{display:flex;align-items:center;gap:14px;padding:13px 14px;border:1px solid var(--linha);border-radius:12px;background:#fff;margin-bottom:10px}
.doc-card .fi{width:42px;height:42px;border-radius:10px;background:#eef0e8;display:grid;place-items:center;color:var(--oliva);flex-shrink:0}
.doc-card .fi svg{width:21px;height:21px}
.doc-card .meta{flex:1;min-width:0}
.doc-card .meta b{display:block;color:var(--oliva-esc);font-size:15px}
.doc-card .meta span{font-size:12.5px;color:var(--suave)}
.cat-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--dourado-esc);margin:18px 0 10px}

/* -------- Solicitações / conversa -------- */
.nav-badge{display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--dourado);color:#43433c;font-size:11px;font-weight:800;margin-left:3px}
.stat.click:hover,.stat[data-nav]:hover{border-color:var(--dourado-esc)}
.thread{display:flex;flex-direction:column;gap:10px;max-height:46vh;overflow-y:auto;padding:4px 2px;margin:8px 0 14px}
.msg{display:flex}
.msg.eq{justify-content:flex-end}
.msg-bubble{max-width:82%;border:1px solid var(--linha);border-radius:12px;padding:9px 12px;background:#fafaf7}
.msg.eq .msg-bubble{background:#eef0e8;border-color:#dfe2d6}
.msg-aut{font-size:12px;font-weight:700;color:var(--oliva-esc);margin-bottom:3px;display:flex;align-items:center;gap:6px}
.msg-tag{font-weight:700;font-size:10px;color:#fff;background:var(--oliva-claro);padding:1px 6px;border-radius:6px;text-transform:uppercase;letter-spacing:.03em}
.msg.eq .msg-tag{background:var(--dourado-esc);color:#43433c}
.msg-txt{font-size:14px;color:var(--texto);line-height:1.45}
.msg-file{display:inline-flex;align-items:center;gap:5px;margin-top:6px;font-size:13px;font-weight:600;color:var(--oliva);text-decoration:none}
.msg-file svg{width:15px;height:15px}
.msg-dt{font-size:11px;color:var(--suave);margin-top:5px}
.reply textarea{width:100%;border:1px solid var(--linha);border-radius:10px;padding:10px 12px;background:#fcfcfa;font-family:inherit;font-size:14px;resize:vertical}
.reply textarea:focus{outline:none;border-color:var(--dourado-esc);background:#fff;box-shadow:0 0 0 3px rgba(216,200,96,.18)}

/* -------- Mural de avisos (portal do cliente) -------- */
.mural{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.aviso{display:flex;gap:12px;background:#fffdf2;border:1px solid #ecdf9e;border-left:4px solid var(--dourado-esc);border-radius:12px;padding:13px 15px}
.aviso-ic{color:var(--dourado-esc);flex-shrink:0;line-height:0;margin-top:2px}
.aviso-ic svg{width:20px;height:20px}
.aviso b{color:var(--oliva-esc);font-size:15px}
.aviso p{margin:4px 0 0;font-size:14px;color:var(--texto);line-height:1.45}
.aviso-dt{display:block;margin-top:5px;font-size:11.5px;color:var(--suave)}

/* -------- Contratos -------- */
.contrato-corpo{max-height:52vh;overflow-y:auto;border:1px solid var(--linha);border-radius:10px;padding:18px 20px;background:#fff;margin:8px 0}
.ct-doc{font-family:Georgia,"Times New Roman",serif;color:#2a2a26;line-height:1.6;font-size:13.5px;text-align:justify}
.ct-titulo{text-align:center;font-weight:700;font-size:15px;text-transform:uppercase;margin:0 0 2px}
.ct-sub{text-align:center;font-weight:700;color:var(--oliva);margin:0 0 14px;font-size:13px}
.ct-quadro{border:1px solid var(--linha);border-radius:8px;overflow:hidden;margin:0 0 16px}
.ct-quadro-h{background:var(--oliva);color:#fff;font-weight:700;font-size:11.5px;letter-spacing:.04em;padding:7px 12px;text-align:center}
.ct-row{display:flex;gap:10px;padding:6px 12px;border-top:1px solid #efeee8;font-size:12.5px}
.ct-k{flex:0 0 40%;font-weight:700;color:var(--oliva-esc)}
.ct-v{flex:1}
.ct-clausula{font-size:13px;font-weight:700;margin:16px 0 6px;color:var(--oliva-esc);text-align:left;border-left:3px solid var(--dourado);padding-left:8px}
.ct-p{margin:0 0 9px;text-align:justify}
.ct-data{margin:18px 0;text-align:center}
.ct-sign{margin:14px 0 0;text-align:center;font-weight:700}
.ct-logo{text-align:center;margin-bottom:16px;padding-bottom:14px;border-bottom:3px solid var(--dourado)}
.ct-logo img{height:240px;max-width:100%;object-fit:contain}
.assinatura{border:1px solid #cfe0c4;background:#eef4e8;border-radius:10px;padding:12px 14px;font-size:13px;color:var(--oliva-esc);margin:8px 0}
.assinatura b{color:var(--verde)}
.assinatura svg{width:16px;height:16px;vertical-align:-3px}

@media (max-width:680px){
  main{padding:16px 12px 60px}
  .grid2{grid-template-columns:1fr}
  .nav a span{display:none}
  .nav a{padding:9px}
  .hide-sm{display:none}
  .topbar .brand small{display:none}
}

/* ---- Atendimento (área do cliente) ---- */
.atend{display:grid;gap:16px}
.atend-h{display:flex;align-items:center;gap:9px;font-size:16px;color:var(--oliva);margin:0 0 10px}
.atend-h svg{width:20px;height:20px;color:var(--dourado-esc)}
.atend p{margin:0 0 12px;line-height:1.6;color:var(--texto)}
.atend-list{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.atend-list li{display:flex;align-items:flex-start;gap:10px;line-height:1.5}
.atend-list li svg{width:18px;height:18px;flex:0 0 18px;margin-top:2px;color:var(--oliva-claro)}
.atend-note{font-size:13px;color:var(--suave);font-style:italic;margin:6px 0 0!important}
.contato-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.contato-item{display:flex;align-items:center;gap:12px;padding:14px;border:1px solid var(--linha);border-radius:12px;background:#fcfcfa;text-decoration:none;color:var(--texto);transition:.15s}
.contato-item:hover{border-color:var(--dourado-esc);background:#fff;box-shadow:var(--sombra)}
.contato-item svg{width:22px;height:22px;color:var(--dourado-esc);flex:0 0 22px}
.contato-item span{display:block;font-size:12px;color:var(--suave)}
.contato-item b{font-size:14px}
@media(max-width:640px){.contato-grid{grid-template-columns:1fr}}

/* ---- Rodapé do portal ---- */
.portal-foot{margin:34px 0 10px;padding-top:18px;border-top:1px solid var(--linha);font-size:12.5px}
.pf-top{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-bottom:12px}
.pf-brand{display:flex;align-items:center;gap:10px}
.pf-brand img{width:30px;height:30px}
.pf-brand b{display:block;color:var(--oliva);font-size:14px}
.pf-brand span{font-size:11px;color:var(--suave)}
.pf-links{display:flex;flex-wrap:wrap;gap:16px}
.pf-links a{display:inline-flex;align-items:center;gap:6px;color:var(--oliva);text-decoration:none;font-weight:600}
.pf-links a:hover{color:var(--dourado-esc)}
.pf-links svg{width:15px;height:15px}
.pf-bottom{line-height:1.6;color:var(--suave)}
.pf-ip{display:block;margin-top:6px;font-size:10.5px;color:#aaa;line-height:1.5}

/* ---- Atendimento: acordeão, tabela, blocos de destaque/ação ---- */
.acc{display:grid;gap:8px}
.acc details{border:1px solid var(--linha);border-radius:10px;background:#fcfcfa;overflow:hidden}
.acc summary{cursor:pointer;padding:12px 14px;font-size:14px;color:var(--oliva);list-style:none;display:flex;align-items:center;justify-content:space-between;gap:10px}
.acc summary::-webkit-details-marker{display:none}
.acc summary::after{content:"+";font-size:19px;color:var(--dourado-esc);font-weight:700;line-height:1}
.acc details[open] summary{border-bottom:1px solid var(--linha);background:#fff}
.acc details[open] summary::after{content:"–"}
.acc-body{padding:12px 14px}
.acc-body p{margin:0;line-height:1.6}
.tbl-wrap{overflow-x:auto;margin:4px 0 14px}
.atend-tbl{width:100%}
.atend-tbl td{vertical-align:top;line-height:1.5}
.atend-ul{margin:0;padding-left:20px;display:grid;gap:8px;line-height:1.55}
.atend-ul.check{list-style:none;padding-left:0}
.atend-ul.check li{position:relative;padding-left:26px}
.atend-ul.check li::before{content:"✓";position:absolute;left:0;top:-1px;color:var(--verde);font-weight:800}
.callout{display:flex;gap:10px;align-items:flex-start;padding:13px 14px;border-radius:10px;line-height:1.55;margin-top:12px}
.callout svg{width:20px;height:20px;flex:0 0 20px;margin-top:1px}
.callout.warn{background:#fbf4e0;border:1px solid #ecdca0;color:#6b5611}
.callout.warn svg{color:var(--amarelo)}
.callout.ok{background:#eef4e8;border:1px solid #cdd9c2;color:#3c5a2c}
.callout.ok svg{color:var(--verde)}
.panel.destaque{border-color:#cdd9c2;background:linear-gradient(0deg,#f3f7ee,#fff)}
.panel.acao{border-color:#ecdca0;background:linear-gradient(0deg,#fdf9ec,#fff)}
.acao-item{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-top:1px dashed var(--linha)}
.acao-item:first-of-type{border-top:none;padding-top:4px}
.acao-num{flex:0 0 30px;width:30px;height:30px;border-radius:50%;background:var(--dourado);color:#43433c;display:grid;place-items:center;font-weight:800}
.acao-item b{color:var(--oliva)}
.acao-item p{margin:6px 0 0;line-height:1.6}
.acao-ol{margin:8px 0 0;padding-left:20px;display:grid;gap:6px;line-height:1.55}

/* ---- Campanhas ---- */
.camp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.camp-card{display:flex;gap:12px;background:#fff;border:1px solid var(--linha);border-radius:14px;padding:16px;box-shadow:var(--sombra)}
.camp-ic{flex:0 0 40px;width:40px;height:40px;border-radius:10px;background:#f3f7ee;color:var(--oliva);display:grid;place-items:center}
.camp-ic svg{width:22px;height:22px}
.camp-body{flex:1;min-width:0}
.camp-body b{color:var(--oliva);display:block}
.camp-body p{margin:6px 0 0;font-size:13.5px;line-height:1.5}
.camp-acts{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}

/* ---- Canal de escuta (NR-1) ---- */
.escuta-top{display:flex;gap:22px;flex-wrap:wrap;align-items:flex-start}
.escuta-qr{flex:0 0 auto;display:flex;flex-direction:column;gap:10px;align-items:center}
.qrbox{width:200px;height:200px;border:1px solid var(--linha);border-radius:12px;padding:10px;background:#fff;display:grid;place-items:center}
.qrbox svg{width:100%;height:100%;display:block}
.escuta-info{flex:1;min-width:240px}
.escuta-info p{line-height:1.6;margin:8px 0 0}
.manif-prev{max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(max-width:560px){.escuta-top{flex-direction:column;align-items:stretch}.escuta-qr{align-items:flex-start}}
