@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&display=swap');

:root{
  --navy:#0D1F4C; --navy-light:#162a5e; --teal:#00B4B4; --teal-dark:#009999;
  --gray-50:#F8FAFC; --gray-100:#F1F5F9; --gray-200:#E2E8F0; --gray-300:#CBD5E1;
  --gray-400:#94A3B8; --gray-500:#64748B; --gray-600:#475569; --gray-700:#334155; --gray-800:#1E293B;
  --pos:#0E9F6E; --pos-bg:#DCFCE7; --neg:#EF4444; --neg-bg:#FEE2E2; --warn:#F59E0B; --warn-bg:#FEF3C7;
  --r-card:12px; --r-ctrl:8px; --layout-max:1320px;
  --sh-card:0 1px 2px rgba(13,31,76,.05), 0 1px 3px rgba(13,31,76,.06);
  --sh-pop:0 8px 24px rgba(13,31,76,.12);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Space Grotesk',system-ui,sans-serif;background:var(--gray-100);color:var(--gray-800);min-height:100vh;line-height:1.5;font-size:14px}
.hidden{display:none !important}
.screen{min-height:100vh;display:flex;flex-direction:column}
.center{display:flex;align-items:center;justify-content:center}
.grow{flex:1}
.muted{color:var(--gray-500)}
.small{font-size:12px}
a{color:var(--teal-dark);text-decoration:none}
a:hover{text-decoration:underline}

.btn-primary{background:var(--teal);color:#fff;border:none;border-radius:var(--r-ctrl);padding:9px 16px;font:600 13px 'Space Grotesk';cursor:pointer}
.btn-primary:hover{background:var(--teal-dark)}
.btn-primary.full{width:100%;padding:11px}
.btn-ghost{background:transparent;border:1px solid var(--gray-300);color:var(--navy);border-radius:var(--r-ctrl);padding:7px 13px;font:500 13px 'Space Grotesk';cursor:pointer}
.btn-ghost:hover{background:var(--gray-50)}

/* login */
.login-wrap{width:100%;max-width:420px;padding:24px}
.brand{text-align:center;margin-bottom:20px}
.brand-mark{font-weight:700;font-size:28px;color:var(--navy);letter-spacing:-.02em}
.brand-sub{color:var(--teal);font-size:12px}
.card{background:#fff;border-radius:var(--r-card);box-shadow:var(--sh-card);padding:24px}
.login-card h1{font-size:15px;color:var(--navy);margin-bottom:16px}
.login-card label{display:block;font-size:11px;text-transform:uppercase;color:var(--gray-500);margin:12px 0 4px}
.login-card input{width:100%;border:1px solid var(--gray-300);border-radius:var(--r-ctrl);padding:9px 11px;font:400 13px 'Space Grotesk'}
.login-card input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 2px rgba(0,180,180,.25)}
.login-card .btn-primary{margin-top:18px}
.login-foot{text-align:center;font-size:10px;text-transform:uppercase;color:var(--gray-400);margin-top:16px;letter-spacing:.04em}
.banner-error{background:var(--neg-bg);color:var(--neg);border-radius:var(--r-ctrl);padding:10px 12px;font-size:12px;margin-bottom:8px}

/* topbar */
.topbar{background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:14px 24px;gap:16px;flex-wrap:wrap}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:14px}
.logo-mark{font-weight:700;font-size:18px;letter-spacing:-.02em;cursor:pointer}
.topbar-sub{color:var(--teal);font-size:11px}
.area-pick{display:flex;align-items:center;gap:6px;background:var(--navy-light);padding:5px 10px;border-radius:var(--r-ctrl)}
.area-pick label{font-size:10px;color:var(--gray-300);text-transform:uppercase}
.area-pick select{background:transparent;color:#fff;border:none;font:600 13px 'Space Grotesk';cursor:pointer}
.area-pick select option{color:var(--navy)}
.acct{font-size:12px;color:var(--gray-300)}

.content{max-width:var(--layout-max);width:100%;margin:0 auto;padding:24px}
.pane-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.crumb{font-size:12px;color:var(--gray-500)}
.back-link{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--gray-500);text-decoration:none;margin:2px 0 12px;padding:3px 10px;border:1px solid var(--gray-200);border-radius:999px;background:#fff}
.back-link:hover{border-color:var(--teal);color:var(--teal-dark)}
.proj-sub{font-size:12.5px;color:var(--gray-500);font-weight:500;letter-spacing:.01em;margin:0 0 2px}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:1024px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.grid{grid-template-columns:1fr}}
.empty{text-align:center;color:var(--gray-600);padding:48px}
.empty .btn-primary{margin-top:12px}
.loading{padding:32px;text-align:center;color:var(--gray-500)}

/* card de projeto */
.pcard{background:#fff;border-radius:var(--r-card);box-shadow:var(--sh-card);padding:16px;cursor:pointer;border:1px solid transparent;transition:.12s}
.pcard:hover{border-color:var(--teal);transform:translateY(-1px);box-shadow:var(--sh-pop)}
.pcard-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.pcard-name{font-size:15px;font-weight:600;color:var(--navy)}
.pcard-meta{font-size:12px;color:var(--gray-500);margin-top:6px}

/* chips */
.chip{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;padding:3px 8px;border-radius:999px}
.chip-kind{background:#EEF2F7;color:var(--navy-light)}
.vis-private{background:var(--gray-100);color:var(--gray-500)} .vis-private::before{content:"\1F512"}
.vis-public{background:#E6F7F7;color:var(--teal-dark)} .vis-public::before{content:"\1F441"}
.vis-shared{background:#DBEAFE;color:#2563EB} .vis-shared::before{content:"\1F465"}
.chip-pending{background:var(--warn-bg);color:var(--warn)}
.chip-master{background:var(--teal);color:#fff}

/* pending */
.pending-card{max-width:520px;text-align:center;margin:auto}
.pending-icon{font-size:36px;margin-bottom:8px}
.pending-card h2{font-size:20px;color:var(--navy);margin-bottom:10px}
.pending-card p{font-size:13px;color:var(--gray-600);margin-bottom:8px}

/* projeto: cabecalho + abas */
.proj-head{display:flex;align-items:center;gap:10px;margin:4px 0 2px}
.proj-head h2{font-size:20px;color:var(--navy)}
.tabbar{display:flex;align-items:center;gap:6px;border-bottom:1px solid var(--gray-200);margin-top:10px}
.tabs{display:flex;gap:2px;flex-wrap:wrap}
.tab{background:none;border:none;border-bottom:2px solid transparent;padding:9px 14px;font:500 13px 'Space Grotesk';color:var(--gray-500);cursor:pointer}
.tab:hover{color:var(--navy)}
.tab.on{color:var(--navy);border-bottom-color:var(--teal)}
.tab-add{background:none;border:1px dashed var(--gray-300);color:var(--gray-500);border-radius:6px;width:26px;height:26px;cursor:pointer;font-size:16px;line-height:1;margin-left:4px}
.tab-add:hover{border-color:var(--teal);color:var(--teal-dark)}
.proj-content{padding-top:18px}

/* transferin: tabela mestre */
.tf-toolbar{display:flex;align-items:baseline;gap:10px;margin-bottom:10px}
.tf-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--r-card);overflow:hidden;box-shadow:var(--sh-card);font-size:12px}
.tf-table th{background:var(--gray-50);text-align:left;padding:10px 12px;font-size:10px;text-transform:uppercase;letter-spacing:.03em;color:var(--gray-500);border-bottom:1px solid var(--gray-200)}
.tf-table td{padding:10px 12px;border-bottom:1px solid var(--gray-100);vertical-align:top}
.tf-table td.num{text-align:right;font-variant-numeric:tabular-nums}
.tf-row{cursor:pointer}
.tf-row:hover{background:var(--gray-50)}
.tf-nome{font-size:13px;font-weight:600;color:var(--navy);max-width:320px}
.tf-cnpj{font-size:11px;color:var(--gray-500);margin-top:2px}
.tf-open{color:var(--teal-dark);white-space:nowrap;font-weight:600}
.badge-classe{display:inline-block;background:#E6F7F7;color:var(--teal-dark);font-size:9px;font-weight:700;text-transform:uppercase;padding:1px 6px;border-radius:999px;margin-left:4px;letter-spacing:.03em}
.compl{display:flex;align-items:center;gap:8px;min-width:120px}
.compl-bar{flex:1;height:6px;background:var(--gray-200);border-radius:999px;overflow:hidden}
.compl-bar span{display:block;height:100%}
.compl-bar span.hi{background:var(--pos)} .compl-bar span.md{background:var(--warn)} .compl-bar span.lo{background:var(--neg)}
.compl-pct{font-size:11px;color:var(--gray-600);font-variant-numeric:tabular-nums;width:34px;text-align:right}

/* transferin: detalhe */
.tf-detail-head{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.tf-detail-title h3{font-size:16px;color:var(--navy)}
.tf-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:820px){.tf-cols{grid-template-columns:1fr}}
.tf-col{background:#fff;border-radius:var(--r-card);box-shadow:var(--sh-card);padding:16px}
.tf-col-head{font-size:11px;text-transform:uppercase;letter-spacing:.03em;color:var(--gray-500);font-weight:600;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--gray-200)}
.kv{padding:6px 0;border-bottom:1px solid var(--gray-100)}
.kv-label{font-size:11px;color:var(--gray-500);text-transform:uppercase;letter-spacing:.02em}
.kv-val{font-size:13px;color:var(--navy);margin-top:2px}
.kv-fonte{font-size:11px;color:var(--gray-400);margin-left:4px}
.kv.pend .kv-label{display:flex;align-items:center;gap:8px;color:var(--gray-700);text-transform:none;font-size:13px}
.kv.pend .dot{width:12px;height:12px;border:1.5px solid var(--gray-300);border-radius:3px;display:inline-block}

/* modais */
.overlay{position:fixed;inset:0;background:rgba(13,31,76,.4);display:flex;align-items:center;justify-content:center;padding:24px;z-index:50}
.modal{background:#fff;border-radius:var(--r-card);max-width:560px;width:100%;box-shadow:var(--sh-pop)}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--gray-200)}
.modal-head strong{font-size:15px;color:var(--navy)}
.modal-head .x{background:none;border:none;font-size:22px;color:var(--gray-400);cursor:pointer;line-height:1}
.modal-body{padding:20px}
.modal-body label{display:block;font-size:11px;text-transform:uppercase;color:var(--gray-500);margin:16px 0 8px}
.modal-body label:first-child{margin-top:0}
.modal-body input{width:100%;border:1px solid var(--gray-300);border-radius:var(--r-ctrl);padding:9px 11px;font:400 13px 'Space Grotesk'}
.modal-body input:focus{outline:none;border-color:var(--teal)}
.tpl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.tpl-opt{border:1px solid var(--gray-300);background:#fff;border-radius:var(--r-ctrl);padding:10px 8px;font:500 12px 'Space Grotesk';color:var(--navy);cursor:pointer;text-align:center}
.tpl-opt:hover{border-color:var(--teal);background:#E6F7F7}
.tpl-opt.on{border-color:var(--teal);background:#E6F7F7}
.vis-grid{display:flex;gap:10px;flex-wrap:wrap}
.vis-opt{border:1px solid var(--gray-300);background:#fff;border-radius:var(--r-ctrl);padding:8px 10px;cursor:pointer}
.vis-opt.on{border-color:var(--teal);background:var(--gray-50)}
.modal-foot{display:flex;justify-content:flex-end;align-items:center;gap:10px;padding:16px 20px;border-top:1px solid var(--gray-200)}
.modal-foot .err{margin-right:auto}

/* transferin: barra de acoes + resumo + filtro + lista */
.tf-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.seg{display:inline-flex;align-items:stretch}
.seg .btn-primary{border-top-right-radius:0;border-bottom-right-radius:0}
.seg-sel{border:1px solid var(--gray-300);border-left:none;border-radius:0 var(--r-ctrl) var(--r-ctrl) 0;background:#fff;font:500 12px 'Space Grotesk';padding:0 8px;cursor:pointer;color:var(--navy)}
.tf-search{margin-left:auto;border:1px solid var(--gray-300);border-radius:var(--r-ctrl);padding:7px 11px;font:400 13px 'Space Grotesk';min-width:200px}
.tf-search:focus{outline:none;border-color:var(--teal)}
.tf-summary{font-size:13px;color:var(--gray-600);margin-bottom:10px}
.tf-summary strong{color:var(--navy)}
.dotsep{margin-left:6px;padding-left:10px;border-left:1px solid var(--gray-300)}
.dotsep.err{color:var(--neg)}
.tf-filters{display:flex;gap:6px;margin-bottom:14px}
.fchip{background:#fff;border:1px solid var(--gray-300);border-radius:999px;padding:4px 12px;font:500 12px 'Space Grotesk';color:var(--gray-600);cursor:pointer}
.fchip:hover{border-color:var(--teal)}
.fchip.on{background:var(--navy);color:#fff;border-color:var(--navy)}

.tf-list{display:flex;flex-direction:column;gap:8px}
.tf-card{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--r-card);padding:12px 16px;cursor:pointer;transition:.12s}
.tf-card:hover{border-color:var(--teal);box-shadow:var(--sh-card)}
.tf-card-left{flex:1;min-width:0}
.tf-card-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.tf-card-name{font-size:14px;font-weight:600;color:var(--navy)}
.tf-card-sub{font-size:12px;color:var(--gray-500);margin-top:3px}
.tf-card-right{display:flex;align-items:center;gap:16px;flex-shrink:0}
.tf-open{color:var(--teal-dark);font-weight:600;white-space:nowrap;font-size:12px}

.status-chip{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:2px 8px;border-radius:999px}
.status-chip.s-ok{background:var(--pos-bg);color:var(--pos)}
.status-chip.s-pend{background:var(--gray-100);color:var(--gray-500)}
.status-chip.s-run{background:#DBEAFE;color:#2563EB}
.status-chip.s-md{background:var(--warn-bg);color:var(--warn)}
.status-chip.s-err{background:var(--neg-bg);color:var(--neg)}

.doc-row{padding:8px 0;border-bottom:1px solid var(--gray-100);font-size:13px;color:var(--navy)}

/* header estilo MyIB */
.logo-block{display:flex;align-items:center;gap:12px;cursor:pointer}
.logo-img{height:42px;display:block}
.logo-titles{display:flex;flex-direction:column;line-height:1.05}
.logo-h1{font-weight:700;font-size:20px;color:#fff;letter-spacing:-.02em}
.logo-sub{font-size:11px;color:var(--teal)}
.hist{display:flex;gap:6px}
.icon-btn{width:32px;height:32px;border-radius:50%;border:none;background:var(--navy-light);color:#fff;cursor:pointer;font-size:15px;line-height:1}
.icon-btn:disabled{opacity:.4;cursor:not-allowed}
.icon-btn:not(:disabled):hover{background:#1d3a78}
.upd{text-align:right;font-size:11px;color:var(--gray-300);line-height:1.35}
.upd-1 strong{color:#fff}
.avatar-wrap{position:relative}
.avatar{display:inline-flex;align-items:center;gap:7px;background:var(--teal);color:#fff;border:none;border-radius:999px;height:36px;padding:0 13px;cursor:pointer;font:700 13px 'Space Grotesk'}
.avatar:hover{background:var(--teal-dark)}
.avatar .caret{font-size:9px;font-weight:400}
.avatar-menu{position:absolute;right:0;top:44px;background:#fff;border-radius:10px;box-shadow:var(--sh-pop);min-width:210px;padding:12px;z-index:60}
.am-email{font-size:13px;color:var(--navy);font-weight:600;word-break:break-all}
.am-role{font-size:10px;color:var(--gray-500);margin:3px 0 8px;text-transform:uppercase;letter-spacing:.04em}
.am-item{width:100%;text-align:left;background:none;border:none;border-top:1px solid var(--gray-200);padding:9px 2px 2px;font:600 13px 'Space Grotesk';color:var(--neg);cursor:pointer}
.am-item:hover{color:#b91c1c}

/* botao de download por fundo no card */
.tf-dl{background:#EEF2F7;border:1px solid var(--gray-200);color:var(--navy);border-radius:var(--r-ctrl);padding:5px 10px;font:600 11px 'Space Grotesk';cursor:pointer;white-space:nowrap}
.tf-dl:hover{border-color:var(--teal);background:#E6F7F7;color:var(--teal-dark)}
.spin{display:inline-block;width:13px;height:13px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:vxspin .6s linear infinite;vertical-align:middle}
@keyframes vxspin{to{transform:rotate(360deg)}}

/* transferin v2: overview + tiles + anel */
.tf-overview{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;background:#fff;border:1px solid var(--gray-200);border-radius:var(--r-card);padding:12px 16px;margin-bottom:18px}
.ov-status{display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:13px;color:var(--gray-700)}
.ov-pill{display:inline-flex;align-items:center;gap:6px}
.ov-media{font-weight:600;color:var(--navy)}
.ov-tipos{display:flex;gap:7px;font-size:12px;flex-wrap:wrap;align-items:center}
.ov-flabel{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);margin-right:2px}
.ov-tipo{font:inherit;font-size:12px;background:#fff;border:1px solid var(--gray-200);border-radius:999px;padding:3px 10px;cursor:pointer;color:var(--gray-600);display:inline-flex;align-items:center;gap:5px;transition:.12s}
.ov-tipo:hover{border-color:var(--gray-400)}
.ov-tipo b{font-weight:700;color:var(--tc,var(--navy))}
.ov-tipo.on{border-color:var(--tc,var(--navy));background:var(--tc,var(--navy));color:#fff}
.ov-tipo.on b{color:#fff}
.status-dot{width:9px;height:9px;border-radius:50%;display:inline-block;flex-shrink:0}
.status-dot.s-ok{background:var(--pos)} .status-dot.s-md{background:var(--warn)} .status-dot.s-err{background:var(--neg)} .status-dot.s-pend{background:var(--gray-400)} .status-dot.s-run{background:#3B82F6}
.tranche-sec{margin-bottom:4px}
.tranche-band{display:flex;align-items:center;gap:10px;margin:6px 0 12px;cursor:pointer;user-select:none}
.tranche-band .chev{font-size:11px;color:var(--gray-400);transition:transform .12s}
.tranche-band .tb-name{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--navy);white-space:nowrap}
.tranche-band::after{content:"";flex:1;height:1px;background:var(--gray-200);order:2}
.tranche-band .tb-count{font-size:11px;color:var(--gray-400);order:3;white-space:nowrap}
.tranche-sec.collapsed .tranche-band .chev{transform:rotate(-90deg)}
.tranche-sec.collapsed .tranche-band{margin-bottom:6px}
.tranche-sec.collapsed .tile-grid{display:none}
.tile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-bottom:24px}
.tf-tile{position:relative;background:#fff;border:1px solid var(--gray-200);border-radius:var(--r-card);padding:14px 12px 10px;cursor:pointer;transition:.12s;text-align:center}
.tf-tile:hover{border-color:var(--teal);box-shadow:var(--sh-pop);transform:translateY(-2px)}
.tile-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.tipo-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;border-radius:999px;border:1px solid}
.tile-ring{display:flex;justify-content:center;margin:4px 0}
.tile-name{font-size:13px;font-weight:600;color:var(--navy);line-height:1.2;min-height:31px;display:flex;align-items:center;justify-content:center}
.tile-actions{display:flex;align-items:center;justify-content:space-between;margin-top:8px;opacity:0;transition:.12s;font-size:11px}
.tf-tile:hover .tile-actions{opacity:1}
.tile-dl{background:#EEF2F7;border:1px solid var(--gray-200);color:var(--navy);border-radius:6px;padding:3px 7px;font:600 10px 'Space Grotesk';cursor:pointer}
.tile-dl:hover{border-color:var(--teal);color:var(--teal-dark)}
.tile-open{color:var(--teal-dark);font-weight:600}
.ring{display:block}
.ring-bg{fill:none;stroke:var(--gray-200);stroke-width:6}
.ring-fg{fill:none;stroke-width:6;stroke-linecap:round}
.ring-fg.hi{stroke:var(--pos)} .ring-fg.md{stroke:var(--warn)} .ring-fg.lo{stroke:var(--neg)}
.ring-txt{fill:var(--navy);font:700 15px 'Space Grotesk';text-anchor:middle}

/* detalhe v2: ficha + abas */
.det-head{display:flex;align-items:center;gap:16px;margin-bottom:16px}
.det-title{flex:1}
.det-title h3{font-size:18px;color:var(--navy)}
.det-sub{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--gray-600);margin-top:3px}
.det-ring{flex-shrink:0}
.ficha{background:#fff;border:1px solid var(--gray-200);border-radius:var(--r-card);padding:14px 18px;display:grid;grid-template-columns:1fr 1fr;gap:2px 28px;margin-bottom:18px}
@media(max-width:680px){.ficha{grid-template-columns:1fr}}
.fc{display:flex;justify-content:space-between;gap:12px;padding:6px 0;border-bottom:1px solid var(--gray-100)}
.fc-k{font-size:12px;color:var(--gray-500)}
.fc-v{font-size:13px;color:var(--navy);font-weight:500;text-align:right}
.det-tabs{display:flex;gap:4px;border-bottom:1px solid var(--gray-200);margin-bottom:16px;flex-wrap:wrap}
.det-tab{background:none;border:none;border-bottom:2px solid transparent;padding:8px 14px;font:600 13px 'Space Grotesk';color:var(--gray-500);cursor:pointer}
.det-tab.on{color:var(--navy);border-bottom-color:var(--teal)}
.tema-group{margin-bottom:16px}
.tema-h{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid var(--gray-100);cursor:pointer;user-select:none}
.tema-h .chev{font-size:10px;color:var(--gray-400);transition:transform .12s}
.tema-h .tema-n{margin-left:auto;font-weight:600;color:var(--gray-400)}
.tema-group.collapsed .tema-h{margin-bottom:0}
.tema-group.collapsed .tema-h .chev{transform:rotate(-90deg)}
.tema-group.collapsed .tema-body{display:none}
.pub-bar{display:flex;align-items:center;justify-content:flex-end;gap:12px;margin-bottom:12px}
.pub-row{display:grid;grid-template-columns:minmax(150px,230px) 1fr minmax(90px,170px);gap:14px;align-items:baseline;padding:5px 4px;font-size:13px;border-radius:6px}
.pub-row:hover{background:#F8FAFC}
.pub-k{color:var(--gray-600)}
.pub-v{color:var(--navy);font-weight:500;word-break:break-word}
.pub-src{text-align:right;font-size:11px}
.src-link{color:var(--teal-dark);text-decoration:none;border-bottom:1px dotted var(--teal)}
.src-link:hover{color:var(--teal);border-bottom-style:solid}
.src-txt{color:var(--gray-400)}
@media(max-width:620px){.pub-row{grid-template-columns:1fr;gap:2px}.pub-src{text-align:left}}
.kv2{display:flex;justify-content:space-between;gap:16px;padding:5px 0;font-size:13px}
.kv2-l{color:var(--gray-600)}
.kv2-v{color:var(--navy);text-align:right;font-weight:500}
.kv-fonte{font-size:11px;color:var(--gray-400);font-weight:400}
.doc-list{display:flex;flex-direction:column;gap:8px}
.doc-item{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1px solid var(--gray-200);border-radius:var(--r-ctrl);padding:10px 14px;font-size:13px}
.pend-item{display:flex;align-items:center;gap:9px;padding:6px 0;font-size:13px;color:var(--gray-700)}
.pend-box{width:13px;height:13px;border:1.5px solid var(--gray-300);border-radius:3px;flex-shrink:0}

/* areas > subareas > projetos */
.area-block{margin-bottom:30px}
.area-block-head{display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid var(--gray-200);padding-bottom:8px;margin-bottom:16px}
.ab-name{font-size:18px;font-weight:700;color:var(--navy)}
.sections-row{display:flex;gap:16px;align-items:flex-start;overflow-x:auto;padding-bottom:8px}
.section{flex:0 0 320px;max-width:340px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--r-card);padding:14px}
.section .grid{grid-template-columns:1fr;gap:10px}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.section-name{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-500)}
.btn-link{background:none;border:none;color:var(--teal-dark);font:600 12px 'Space Grotesk';cursor:pointer;padding:0}
.btn-link:hover{text-decoration:underline}

/* popup baixar documentos */
.dc-choice{display:flex;gap:10px}
.check-all{display:block;font-weight:600;color:var(--navy);padding:6px 2px;border-bottom:1px solid var(--gray-200);margin-bottom:10px;cursor:pointer}
.fund-checks{max-height:300px;overflow:auto;display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.fund-check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--navy);cursor:pointer}
