/* Tabs */
.tabbtn{
  width:56px;
  height:56px;
  border:1px solid rgba(6,164,81,.18);
  background:transparent;
  color:var(--verde-escuro);
  padding:0;
  border-radius:18px;
  cursor:pointer;
  font-weight:800;
  font-size:13px;
  display:flex; align-items:center; justify-content:center;
  white-space:nowrap;
  transition: transform .12s ease, background .18s ease, box-shadow .18s ease, border-color .18s ease;
  position:relative;
}
.tabbtn:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,.88);
  border-color:rgba(6,164,81,.28);
  box-shadow:0 12px 24px rgba(14,30,20,.10);
}
.tabbtn:active{transform:translateY(0)}
.tabbtn.active{
  background:linear-gradient(135deg,#fff,#eef8f2);
  color:var(--verde-escuro);
  border-color:rgba(6,164,81,.30);
  box-shadow:0 14px 28px rgba(6,164,81,.12);
}
.tabbtn .tabicon{
  font-size:22px;
  line-height:1;
  display:block;
}
.tabbtn .tablabel{display:none;}
.tabbtn::after{
  content: attr(title);
  position:absolute;
  top:50%;
  opacity:0;
  pointer-events:none;
  transform:translateY(-50%) translateX(8px);
  transition:opacity .16s ease, transform .16s ease;
  background:rgba(10,76,43,.96);
  color:#fff;
  padding:6px 10px;
  border-radius:10px;
  font-size:12px;
  font-weight:800;
  white-space:nowrap;
  box-shadow:0 12px 28px rgba(0,0,0,.18);
  z-index:30;
}
.sidebar-left .tabbtn::after{left:68px;}
.sidebar-right .tabbtn::after{right:68px; transform:translateY(-50%) translateX(-8px);}
.sidebar-right .tabbtn:hover::after{transform:translateY(-50%) translateX(0);}
.tabbtn:hover::after{opacity:1; transform:translateY(-50%) translateX(0);}

@media (max-width: 980px){
  .tabbtn{
    width:100%;
    height:auto;
    min-height:52px;
    justify-content:flex-start;
    gap:10px;
    padding:10px 14px;
    border-radius:16px;
    background:#fff;
    border-color:rgba(6,164,81,.16);
  }
  .tabbtn .tablabel{display:inline;}
  .tabbtn::after{display:none;}
}

/* Cards */
.card{
  background:var(--card);
  border:1px solid var(--borda);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  padding:16px;
}
.card h2{
  margin:0 0 12px 0;
  font-size:16px;
  display:flex; align-items:center; justify-content:space-between;
}
.card h2::after{
  content:"";
  display:block;
  height:1px;
  background:rgba(0,0,0,.06);
  flex:1;
  margin-left:12px;
}

/* Buttons */
.btns{display:flex; gap:8px; flex-wrap:wrap; margin-top:10px}
.btn{
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  color:var(--verde-escuro);
  padding:10px 12px;
  border-radius:var(--radius-sm);
  cursor:pointer;
  font-weight:800;
  transition: transform .05s ease, box-shadow .15s ease, background .15s ease;
}
.btn:hover{box-shadow:var(--shadow-sm)}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--verde); border-color:var(--verde); color:#fff}
.btn.primary:hover{box-shadow:0 12px 24px rgba(6,164,81,.22)}
.btn.danger{background:var(--vermelho); border-color:var(--vermelho); color:#fff}
.btn.danger:hover{box-shadow:0 12px 24px rgba(223,62,72,.20)}
.btn.ghost{background:rgba(0,0,0,.04); border-color:transparent}
.btn.small{padding:8px 10px; border-radius:10px; font-size:12px}

/* Table */
table{width:100%; border-collapse:separate; border-spacing:0}
th,td{padding:10px 10px; border-bottom:1px solid rgba(0,0,0,.06); vertical-align:top}
th{
  font-size:12px;
  letter-spacing:.2px;
  text-transform:none;
  color:rgba(15,27,22,.75);
  background:rgba(0,0,0,.02);
}
tbody tr:hover td{background:rgba(6,164,81,.04)}
tbody tr:last-child td{border-bottom:0}

/* Layout helpers used by screens */
.row{display:grid; gap:12px; margin-bottom:12px}
.row.cols2{grid-template-columns: 1fr 1fr}
.row.cols3{grid-template-columns: 1fr 1fr 1fr}
@media (max-width: 980px){
  .row.cols2, .row.cols3{grid-template-columns:1fr}
}

/* Badges / hints */
.hint{padding:10px 12px; border:1px dashed rgba(0,0,0,.14); border-radius:12px; background:rgba(0,0,0,.02)}
.small{font-size:12px}
.muted{color:rgba(15,27,22,.70)}
.pill{display:inline-flex; gap:6px; align-items:center; padding:6px 10px; border-radius:999px; font-size:12px; font-weight:800; border:1px solid rgba(0,0,0,.10); background:rgba(0,0,0,.02)}
.pill.ok{border-color:rgba(6,164,81,.25); background:rgba(6,164,81,.10); color:var(--verde-escuro)}
.pill.no{border-color:rgba(223,62,72,.25); background:rgba(223,62,72,.10); color:var(--vermelho-escuro)}

/* Toast */
.toast{
  position:fixed; right:18px; bottom:18px;
  background:#111; color:#fff;
  padding:12px 14px; border-radius:14px;
  box-shadow:0 18px 40px rgba(0,0,0,.25);
  max-width:min(420px, calc(100vw - 36px));
  display:none;
}
.toast.show{display:block}
.toast.error{background:var(--vermelho-escuro)}
.toast.success{background:var(--verde-escuro)}

/* Autocomplete */
.ac-results{
  position:absolute;
  left:0; right:0; top:100%;
  z-index:50;
  background:#fff;
  border:1px solid rgba(0,0,0,.12);
  border-radius:14px;
  box-shadow: 0 18px 42px rgba(0,0,0,.14);
  margin-top:6px;
  overflow:hidden;
  display:none;
}
.ac-results.open{display:block}
.ac-item{
  width:100%;
  display:block;
  text-align:left;
  padding:10px 12px;
  border:0;
  background:#fff;
  cursor:pointer;
}
.ac-item:hover{background:rgba(6,164,81,.06)}
.ac-title{font-weight:900; font-size:13px; color:var(--texto)}
.ac-sub{font-size:12px; color:rgba(15,27,22,.65); margin-top:2px}


/* ==========================
   Menu de ações (⋮) nas listas
   ========================== */
.dropdown{ position:relative; display:inline-block; }
.iconbtn{
  width:36px; height:36px;
  display:inline-flex; align-items:center; justify-content:center;
  border:1px solid var(--bd);
  background:var(--card);
  border-radius:12px;
  cursor:pointer;
  line-height:1;
  font-size:18px;
  transition: transform .06s ease, box-shadow .12s ease, border-color .12s ease;
}
.iconbtn:hover{ box-shadow:0 6px 16px rgba(0,0,0,.08); border-color: rgba(0,0,0,.18); }
/* Em alguns ambientes, o shift no :active pode causar jitter no menu (⋮)
   posicionado por JS. Mantemos feedback via hover/sombra e removemos o shift. */
.iconbtn:active{ transform: none; }

.ddmenu{
  position:absolute;
  right:0;
  top:calc(100% + 8px);
  min-width:220px;
  background:var(--card);
  border:1px solid var(--bd);
  border-radius:14px;
  box-shadow:0 16px 40px rgba(0,0,0,.14);
  padding:8px;
  display:none;
  z-index:50;
}
.dropdown.open .ddmenu{ display:block; }

/* Portal: menu fora de tabelas/containers com overflow */
#dd-portal{ position:fixed; inset:0; z-index:9999; pointer-events:none; }
#dd-portal .ddmenu{ pointer-events:auto; position:fixed; display:block; z-index:9999; }


.dditem{
  width:100%;
  text-align:left;
  padding:10px 10px;
  border:0;
  background:transparent;
  border-radius:12px;
  cursor:pointer;
  font-weight:600;
}
.dditem:hover{ background:rgba(0,0,0,.06); }
.dditem.danger{ color:#b00020; }
.ddsep{ height:1px; background:rgba(0,0,0,.12); margin:6px 4px; }


/* Login */
.login-logo{display:none;max-width:180px;width:100%;height:auto;margin:0 auto 14px;object-fit:contain;}

/* Contas a pagar/receber */
.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800;}
.badge.warn{background:rgba(255,193,7,.15);color:#8a6d00;}
.badge.danger{background:rgba(220,53,69,.15);color:#8a1c27;}
.badge.ok{background:rgba(40,167,69,.15);color:#1c6b2d;}


/* Fotos de associados (3x4) */
.avatar{
  width: 60px;
  height: 80px; /* 3x4 */
  aspect-ratio: 3 / 4;
  object-fit: cover;
  object-position: center;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--panel);
  flex: 0 0 auto;
}
.avatar.avatar-lg{
  width: 90px;
  height: 120px;
}


/* Mini barras para dashboard */
.barwrap{
  background: rgba(255,255,255,.06);
  border: 1px solid var(--borda);
  border-radius: 999px;
  height: 10px;
  overflow: hidden;
}
.bar{height:100%;}
.bar.in{background: var(--verde);}
.bar.out{background: var(--vermelho);}

/* Paginação */
.pager{
  margin: 10px 0;
  padding: 10px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  background: var(--surface-2);
}
.pager-actions{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:flex-end; }
.pager select{ background: #fff; color: var(--fg); border: 1px solid rgba(0,0,0,.12); border-radius: 10px; padding: 6px 8px; }



/* ===== V11 PROFESSIONAL UI UPGRADE ===== */

.card{
 border-radius:14px;
 box-shadow:0 4px 14px rgba(0,0,0,.08);
 transition:.2s;
}
.card:hover{
 transform:translateY(-2px);
 box-shadow:0 8px 22px rgba(0,0,0,.12);
}

button{
 border-radius:10px;
 font-weight:600;
 letter-spacing:.3px;
 transition:.15s;
}
button:hover{
 transform:translateY(-1px);
}

table{
 border-radius:12px;
 overflow:hidden;
}
thead{
 position:sticky;
 top:0;
 background:#fff;
 z-index:2;
}
tbody tr:nth-child(even){
 background:#fafafa;
}
tbody tr:hover{
 background:#f1f7ff;
}

input,select,textarea{
 border-radius:10px;
 transition:.15s;
}
input:focus,select:focus,textarea:focus{
 outline:none;
 box-shadow:0 0 0 3px rgba(0,120,255,.15);
 border-color:#0078ff;
}

.section-header{
 display:flex;
 justify-content:space-between;
 align-items:center;
 margin-bottom:14px;
}

.fade-in{
 animation:fade .25s ease;
}
@keyframes fade{
 from{opacity:0; transform:translateY(4px)}
 to{opacity:1; transform:translateY(0)}
}

/* ===== END V11 UPGRADE ===== */



/* ===== v3 profissional: dashboard / status ===== */
.dashboard-shell{display:grid; gap:14px}
.dashboard-hero{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  background:linear-gradient(135deg, rgba(11,16,32,.98), rgba(22,163,74,.92));
  color:#fff;
  border:none;
}
.dashboard-hero .muted{color:rgba(255,255,255,.82)}
.dashboard-hero h2{margin:4px 0 6px 0; font-size:24px}
.dashboard-hero h2::after{display:none}
.eyebrow{font-size:12px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; opacity:.78}
.hero-meta{display:flex; gap:8px; flex-wrap:wrap; justify-content:flex-end}
.hero-meta .pill{background:rgba(255,255,255,.12); color:#fff; border-color:rgba(255,255,255,.2)}
.stats-grid{display:grid; gap:12px; grid-template-columns:repeat(4,minmax(0,1fr))}
.metric-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:18px;
  padding:16px;
  box-shadow:0 10px 24px rgba(15,27,22,.06);
  position:relative;
  overflow:hidden;
}
.metric-card::before{content:""; position:absolute; inset:0 auto 0 0; width:5px; background:var(--verde)}
.metric-card.accent-blue::before{background:#2563eb}
.metric-card.accent-orange::before{background:#ea580c}
.metric-card.accent-purple::before{background:#7c3aed}
.metric-label{font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.04em; color:rgba(15,27,22,.62)}
.metric-value{font-size:28px; font-weight:900; margin-top:8px; color:var(--texto)}
.metric-foot{font-size:12px; color:rgba(15,27,22,.65); margin-top:8px}
.quick-summary-grid{display:grid; gap:10px; grid-template-columns:repeat(2,minmax(0,1fr))}
.ops-grid{display:grid; gap:10px}
.ops-item{display:flex; align-items:center; justify-content:space-between; gap:10px; padding:10px 12px; border:1px solid rgba(0,0,0,.08); border-radius:12px; background:rgba(255,255,255,.72)}
.ops-item span{color:rgba(15,27,22,.66); font-size:12px}
.ops-item b{font-size:13px}
.timeline-list{display:grid; gap:10px}
.timeline-item{display:grid; grid-template-columns:12px 1fr; gap:10px; align-items:flex-start}
.timeline-dot{width:10px; height:10px; border-radius:999px; background:var(--verde); margin-top:5px; box-shadow:0 0 0 4px rgba(6,164,81,.12)}
.timeline-title{font-weight:800; color:var(--texto); line-height:1.3}
@media (max-width: 980px){
  .stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .dashboard-hero{flex-direction:column}
  .hero-meta{justify-content:flex-start}
}
@media (max-width: 640px){
  .stats-grid, .quick-summary-grid{grid-template-columns:1fr}
  .metric-value{font-size:24px}
}


/* ===== v4 acabamento comercial ===== */
.login-shell{display:grid; gap:14px; grid-template-columns:minmax(0,1.15fr) minmax(360px,.85fr)}
.login-showcase{
  min-height:100%;
  background:linear-gradient(135deg, rgba(8,15,29,.98), rgba(16,185,129,.92));
  color:#fff;
  border:none;
}
.login-showcase h1{margin:8px 0 10px; font-size:32px; line-height:1.08}
.login-showcase .muted{color:rgba(255,255,255,.82)}
.login-panel{background:linear-gradient(180deg, rgba(255,255,255,1), rgba(247,250,248,1));}
.login-panel-head{display:flex; justify-content:space-between; align-items:flex-start; gap:10px; margin-bottom:6px}
.login-panel h2{margin:2px 0 0}
.login-panel h2::after{display:none}
.login-note-grid,.feature-grid,.action-grid,.mini-kpis{display:grid; gap:10px}
.login-note-grid,.feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.feature-tile,.action-tile,.mini-kpi{
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.08);
  color:inherit;
  border-radius:16px;
  padding:14px;
}
.feature-tile b,.action-tile b,.mini-kpi b{display:block; font-size:14px; margin-bottom:4px}
.feature-tile span,.action-tile span,.mini-kpi span{display:block; font-size:12px; color:rgba(255,255,255,.82)}
.login-panel .feature-tile,.login-panel .action-tile,.action-tile{
  background:#fff;
  color:var(--texto);
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 8px 20px rgba(15,27,22,.05);
}
.login-panel .feature-tile span,.login-panel .action-tile span,.action-tile span,.mini-kpi span{color:rgba(15,27,22,.68)}
.action-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.action-tile{appearance:none; text-align:left; cursor:pointer; transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease}
.action-tile:hover{transform:translateY(-1px); box-shadow:0 14px 26px rgba(15,27,22,.08); border-color:rgba(16,185,129,.32)}
.action-tile.danger{border-color:rgba(220,38,38,.18)}
.action-tile.danger:hover{border-color:rgba(220,38,38,.32)}
.login-footer-card{grid-column:1 / -1}
.dashboard-main-grid{display:grid; gap:14px; grid-template-columns:minmax(0,1.25fr) minmax(320px,.75fr)}
.dashboard-side-stack{display:grid; gap:14px}
.dashboard-panels-grid{display:grid; gap:14px; grid-template-columns:1.2fr .8fr}
.progress-head{display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:6px}
.mini-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}
.mini-kpi{background:linear-gradient(180deg, rgba(255,255,255,1), rgba(247,250,248,1)); border:1px solid rgba(0,0,0,.08)}
.mini-kpi b{font-size:24px; color:var(--texto); margin-bottom:2px}
.admin-shell{display:grid; gap:14px}
.admin-hero h2{font-size:26px}
.admin-stats-grid .metric-value{font-size:24px}
@media (max-width: 980px){
  .login-shell,.dashboard-main-grid,.dashboard-panels-grid{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .feature-grid,.login-note-grid,.action-grid,.mini-kpis{grid-template-columns:1fr}
  .login-showcase h1{font-size:26px}
}

/* ===== v6 premium operacional: associados + mensalidades ===== */
.page-shell{display:grid; gap:14px}
.members-hero,.mensalidades-hero{border:none}
.members-layout-grid{display:grid; gap:14px; grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr)}
.members-side-stack{display:grid; gap:14px}
.members-form-grid,.members-filter-grid{display:grid; gap:12px; grid-template-columns:repeat(2,minmax(0,1fr))}
.members-filter-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.member-form-card .btns,.mensalidades-config-card .btns{margin-top:12px}
.section-head{display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin-bottom:12px}
.section-head h2{margin:2px 0 0}
.section-head h2::after{display:none}
.section-chip{display:inline-flex; align-items:center; gap:6px; padding:8px 12px; border-radius:999px; border:1px solid rgba(16,185,129,.18); background:rgba(16,185,129,.08); color:var(--texto); font-size:12px; font-weight:800}
.member-photo-preview{gap:10px; min-height:76px; border:1px dashed rgba(0,0,0,.12); border-radius:16px; padding:10px; background:rgba(247,250,248,1)}
.member-action-panel{box-shadow:0 16px 32px rgba(15,27,22,.10)}
.table-premium{border-radius:16px; overflow:hidden}
.table-premium thead th{background:rgba(15,27,22,.04); font-size:12px; text-transform:uppercase; letter-spacing:.04em}
.table-premium tbody tr:hover{background:rgba(16,185,129,.05)}
.monthly-toggle-box{padding:12px 14px; border-radius:14px; border:1px solid rgba(0,0,0,.08); background:rgba(247,250,248,1)}
.mensalidades-config-card{min-height:100%}
@media (max-width: 1100px){
  .members-layout-grid{grid-template-columns:1fr}
}
@media (max-width: 780px){
  .members-form-grid,.members-filter-grid,.members-filter-grid-2{grid-template-columns:1fr}
  .section-head{flex-direction:column}
}


/* ===== v7.1 acabamento fino: login + admin ===== */
.login-panel{align-self:start;padding:22px}
.login-panel .btns{gap:10px}
.login-panel-head .pill{white-space:nowrap}
.user-admin-card{background:linear-gradient(180deg, rgba(255,255,255,1), rgba(247,250,248,1));}
.user-admin-layout{display:grid;gap:14px;grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);align-items:start}
.user-form-panel{padding:14px;border:1px solid rgba(0,0,0,.08);border-radius:18px;background:#fff;box-shadow:0 12px 24px rgba(15,27,22,.05)}
.user-form-grid{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}
.user-actions-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.permission-legend{display:grid;gap:10px}
.permission-item{padding:12px 14px;border-radius:16px;border:1px solid rgba(16,185,129,.16);background:rgba(16,185,129,.06)}
.permission-item b{display:block;font-size:12px;letter-spacing:.04em}
.permission-item span{display:block;margin-top:4px;font-size:12px;color:rgba(15,27,22,.72);line-height:1.45}
.user-kpi-row{grid-template-columns:repeat(4,minmax(0,1fr))}
.user-table td{vertical-align:middle}
.user-row-name{font-weight:800;color:var(--texto)}
@media (max-width: 980px){
  .user-admin-layout{grid-template-columns:1fr}
}
@media (max-width: 700px){
  .user-form-grid,.user-kpi-row{grid-template-columns:1fr}
}


/* ===== v9 financeiro premium + gráficos ===== */
.finance-stats-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.finance-chart-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.chart-bars{display:grid;gap:12px;margin-top:12px}
.chart-row{display:grid;gap:8px}
.chart-label{font-size:12px;font-weight:800;color:rgba(15,27,22,.72)}
.chart-bars-stack{display:grid;gap:6px}
.chart-bar{height:18px;border-radius:999px;position:relative;min-width:24px;display:flex;align-items:center;padding:0 10px;color:#fff;font-size:11px;font-weight:800;box-shadow:0 8px 18px rgba(15,27,22,.08)}
.chart-bar span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chart-previsto{background:linear-gradient(90deg,#2563eb,#60a5fa)}
.chart-recebido{background:linear-gradient(90deg,#16a34a,#4ade80)}
.chart-aberto{background:linear-gradient(90deg,#ea580c,#fb923c)}
.chart-caixaIn{background:linear-gradient(90deg,#0f766e,#2dd4bf)}
.chart-caixaOut{background:linear-gradient(90deg,#b91c1c,#f87171)}
.bank-grid{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr));margin-top:12px}
.bank-card{border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:14px;background:linear-gradient(180deg, rgba(255,255,255,1), rgba(247,250,248,1));box-shadow:0 10px 24px rgba(15,27,22,.05);display:grid;gap:4px}
.bank-card b{font-size:14px;color:var(--texto)}
.bank-card span{font-size:12px;color:rgba(15,27,22,.7)}
.bank-card strong{font-size:13px;color:var(--texto)}
@media (max-width: 1100px){
  .finance-stats-grid,.finance-chart-grid,.bank-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 700px){
  .finance-stats-grid,.finance-chart-grid,.bank-grid{grid-template-columns:1fr}
  .chart-bar{font-size:10px}
}


/* ===== v10 dashboard executivo + caixa com gráficos ===== */
.chart-entradas{background:linear-gradient(90deg,#15803d,#4ade80)}
.chart-saidas{background:linear-gradient(90deg,#b91c1c,#fb7185)}
.chart-saldo{background:linear-gradient(90deg,#1d4ed8,#60a5fa)}
.cash-shell{gap:14px}
.cash-hero{background:linear-gradient(135deg,#0b3b2e 0%,#0f6b44 52%,#18a85c 100%);border:none;color:#fff;box-shadow:0 18px 34px rgba(4,23,16,.22);} 
@media (max-width: 700px){
  .cash-shell .stats-grid{grid-template-columns:1fr}
}


/* ===== v11 identidade visual unificada + relatórios premium ===== */
.reports-shell,.company-shell{display:grid;gap:14px}
.reports-hero,.company-hero{background:linear-gradient(135deg,#0b3b2e 0%,#0f6b44 52%,#18a85c 100%);border:none;color:#fff;box-shadow:0 18px 34px rgba(4,23,16,.22)}
.reports-stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.reports-layout-grid,.company-layout-grid{display:grid;gap:14px;grid-template-columns:minmax(0,1.15fr) minmax(340px,.85fr)}
.reports-main-stack,.reports-side-stack,.company-side-stack{display:grid;gap:14px}
.reports-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.report-actions-grid{display:grid;gap:12px;grid-template-columns:repeat(3,minmax(0,1fr));margin-top:14px}
.action-tile-label{position:relative;display:block}
.action-tile-label input{position:absolute;inset:0;opacity:0;cursor:pointer}
.reports-chart-bars{display:grid;gap:12px}
.report-month-card{padding:14px;border-radius:18px;border:1px solid rgba(0,0,0,.08);background:linear-gradient(180deg, rgba(255,255,255,1), rgba(247,250,248,1));box-shadow:0 10px 24px rgba(15,27,22,.05)}
.report-month-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.report-month-head b{font-size:13px;color:var(--texto)}
.report-month-head span{font-size:12px;font-weight:800;color:rgba(15,27,22,.72)}
.premium-table-wrap{overflow:auto}
.company-preview-card .section-head h2,.reports-filter-card .section-head h2{margin-bottom:0}
.brand-preview-box{display:grid;gap:14px;padding:16px;border-radius:20px;border:1px solid rgba(0,0,0,.08);background:linear-gradient(135deg, rgba(255,255,255,1), rgba(247,250,248,1));box-shadow:0 14px 30px rgba(15,27,22,.06)}
.brand-preview-head{display:flex;align-items:center;gap:14px}
.brand-preview-head b{display:block;font-size:18px;color:var(--texto)}
.brand-preview-logo{width:70px;height:70px;border-radius:18px;background:linear-gradient(135deg, rgba(16,185,129,.18), rgba(37,99,235,.14));display:flex;align-items:center;justify-content:center;overflow:hidden;border:1px solid rgba(0,0,0,.08)}
.brand-preview-logo img{width:100%;height:100%;object-fit:contain;background:#fff}
.brand-preview-logo span{font-size:24px;font-weight:900;color:var(--texto)}
.brand-color-row{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}
.brand-color-row div{padding:12px 14px;border-radius:16px;border:1px solid rgba(0,0,0,.08);background:#fff;display:grid;gap:4px}
.brand-color-row span{width:100%;height:18px;border-radius:999px;display:block;border:1px solid rgba(0,0,0,.08)}
.brand-color-row b{font-size:12px;color:var(--texto)}
.brand-color-row small{font-size:11px;color:rgba(15,27,22,.64)}
.company-usage-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
#card_config_empresa{background:linear-gradient(180deg, rgba(255,255,255,1), rgba(247,250,248,1));border:none}
#card_config_empresa input,#card_config_empresa select,#card_config_empresa textarea{background:#fff}
@media (max-width: 1100px){
  .reports-stats-grid,.reports-layout-grid,.company-layout-grid,.report-actions-grid,.company-usage-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 820px){
  .reports-stats-grid,.reports-layout-grid,.company-layout-grid,.report-actions-grid,.company-usage-grid{grid-template-columns:1fr}
  .reports-filter-grid,.brand-color-row{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .dashboard-hero h2,.section-head h2{font-size:22px}
  .metric-card{padding:14px}
  .card{padding:14px}
  .btns{gap:8px}
  .table th,.table td{padding:10px 8px;font-size:12px}
  .brand-preview-head{flex-direction:column;align-items:flex-start}
}


/* ===== v12 acabamento final: agenda + contas + microinterações ===== */
.agenda-shell,.bills-shell{display:grid;gap:14px}
.agenda-hero,.bills-hero{background:linear-gradient(135deg,#0b3b2e 0%,#0f6b44 52%,#18a85c 100%);border:none;color:#fff;box-shadow:0 18px 34px rgba(4,23,16,.22)}
.agenda-stats-grid,.bills-stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.agenda-layout-grid,.bills-layout-grid{display:grid;gap:14px;grid-template-columns:minmax(0,1.1fr) minmax(300px,.9fr)}
.agenda-form-grid,.bills-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.agenda-form-card textarea{min-height:96px}
.table-premium tbody tr{transition:transform .18s ease, box-shadow .18s ease, background-color .18s ease}
.table-premium tbody tr:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(15,27,22,.05);background:rgba(247,250,248,1)}
.card,.metric-card,.bank-card,.report-month-card,.btn,.iconbtn,input,select,textarea{transition:all .18s ease}
.card:hover,.metric-card:hover,.bank-card:hover,.report-month-card:hover{transform:translateY(-1px)}
.btn:hover,.iconbtn:hover{transform:translateY(-1px)}
input:focus,select:focus,textarea:focus{box-shadow:0 0 0 4px rgba(16,185,129,.10)}
@media (max-width: 1100px){
  .agenda-stats-grid,.bills-stats-grid,.agenda-layout-grid,.bills-layout-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 820px){
  .agenda-stats-grid,.bills-stats-grid,.agenda-layout-grid,.bills-layout-grid,.agenda-form-grid,.bills-filter-grid,.bills-filter-grid-2{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .agenda-shell .hero-meta,.bills-shell .hero-meta{width:100%}
  .agenda-shell .hero-meta .pill,.bills-shell .hero-meta .pill{width:100%;justify-content:center;text-align:center}
}


/* ===== V12.1 revisão final ===== */
.tabs{scroll-snap-type:x proximity; -webkit-overflow-scrolling:touch;}
.tabbtn{scroll-snap-align:start; backdrop-filter: blur(8px); box-shadow: inset 0 1px 0 rgba(255,255,255,.08);}
.tabbtn.active{box-shadow:0 12px 24px rgba(0,0,0,.14);}
.page-shell,.dashboard-shell,.cash-shell,.admin-shell{animation:fadeRise .22s ease both;}
.section-head h3{margin:2px 0 0;}
.quick-summary-grid .hint,.permission-item,.action-tile,.metric-card,.card{transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease;}
.quick-summary-grid .hint:hover,.permission-item:hover,.action-tile:hover,.metric-card:hover{transform:translateY(-1px);}
.validar-shell #val_out .card{margin-top:10px;}
.login-panel .btns .btn{min-width:120px;}
@keyframes fadeRise{from{opacity:0; transform:translateY(8px)}to{opacity:1; transform:translateY(0)}}
@media (max-width:980px){
  .tabs{width:100%; order:3; padding-bottom:2px;}
  .tabbtn{font-size:12px; padding:8px 11px;}
}
@media (max-width:640px){
  .topbar{gap:10px;}
  .brand{width:100%;}
  .brand .title small{display:block; max-width:100%;}
  .lock{font-size:11px;}
  .login-panel .btns .btn{flex:1 1 calc(50% - 8px); min-width:0;}
  .section-head{gap:8px; align-items:flex-start;}
  .hero-meta{width:100%;}
}
@media (max-width:480px){
  .login-panel .btns .btn{flex:1 1 100%;}
  .tabbtn{border-radius:14px;}
}


/* ===== V13 revisão funcional fina ===== */
.quick-preset-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.chipbtn{appearance:none;border:1px solid rgba(0,0,0,.08);background:#fff;color:var(--texto);padding:8px 12px;border-radius:999px;font-size:12px;font-weight:800;cursor:pointer;box-shadow:0 6px 16px rgba(15,27,22,.04)}
.chipbtn:hover{transform:translateY(-1px);border-color:rgba(16,185,129,.28);box-shadow:0 10px 18px rgba(15,27,22,.08)}
.chipbtn.danger{border-color:rgba(220,38,38,.16)}
.empty-state-card{display:grid;place-items:center;gap:10px;padding:18px;border:1px dashed rgba(0,0,0,.12);border-radius:18px;background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(247,250,248,1));text-align:center}
.empty-state-icon{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg, rgba(16,185,129,.14), rgba(37,99,235,.12));display:grid;place-items:center;font-size:18px;font-weight:900;color:var(--texto)}
.empty-state-body{display:grid;gap:4px}
.empty-state-body b{font-size:14px;color:var(--texto)}
.empty-state-body span{font-size:12px;color:rgba(15,27,22,.72);line-height:1.45}
.empty-state-actions{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}
.mobile-dock{display:none}
@media (max-width: 820px){
  .mobile-dock{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;position:sticky;bottom:10px;z-index:20;background:rgba(255,255,255,.8);backdrop-filter:blur(10px);padding:10px;border:1px solid rgba(0,0,0,.08);border-radius:18px;box-shadow:0 18px 40px rgba(15,27,22,.12)}
  .mobile-dock-btn{appearance:none;border:1px solid rgba(0,0,0,.08);background:#fff;color:var(--texto);padding:12px;border-radius:14px;font-size:12px;font-weight:800;cursor:pointer}
  .mobile-dock-btn.primary{background:linear-gradient(90deg,var(--verde),#22c55e);border-color:transparent;color:#fff}
  .mobile-dock-btn:active{transform:translateY(1px)}
}
@media (max-width: 480px){
  .quick-preset-row{gap:6px}
  .chipbtn{flex:1 1 calc(50% - 6px);justify-content:center;text-align:center}
}

/* ===== V14 revisão tela por tela: histórico + anamnese ===== */
.history-shell,.anam-shell{display:grid;gap:14px}
.history-hero,.anam-hero{background:linear-gradient(135deg,#0b3b2e 0%,#0f6b44 52%,#18a85c 100%);border:none;color:#fff;box-shadow:0 18px 34px rgba(4,23,16,.22)}
.history-search-card,.anam-form-card,.anam-records-card,.history-side-card,.anam-side-card{background:linear-gradient(180deg, rgba(255,255,255,1), rgba(247,250,248,1))}
.history-selected-box{min-height:46px;display:flex;align-items:center}
.history-stats-grid,.anam-stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.history-grid,.anam-layout-grid{display:grid;gap:14px;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr)}
.history-main-stack,.history-side-stack,.anam-main-stack,.anam-side-stack{display:grid;gap:14px}
.history-list{display:grid;gap:10px}
.history-list-item{padding:12px 14px;border-radius:16px;border:1px solid rgba(0,0,0,.08);background:#fff;box-shadow:0 10px 24px rgba(15,27,22,.04);display:grid;gap:4px}
.history-list-item b{font-size:13px;color:var(--texto)}
.history-list-item span{font-size:12px;color:rgba(15,27,22,.72)}
.history-list-item small{font-size:12px;color:rgba(15,27,22,.64);line-height:1.45}
.history-metric-name,.anam-model-name{font-size:22px;line-height:1.1;word-break:break-word}
.note-list{max-height:420px;overflow:auto;padding-right:4px}
@media (max-width: 1100px){
  .history-stats-grid,.anam-stats-grid,.history-grid,.anam-layout-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 820px){
  .history-stats-grid,.anam-stats-grid,.history-grid,.anam-layout-grid{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .history-metric-name,.anam-model-name{font-size:20px}
}


/* ===== V16 unificação final dos cabeçalhos ===== */
.cash-hero .eyebrow,.cash-hero .muted,.cash-hero h2,
.reports-hero .eyebrow,.reports-hero .muted,.reports-hero h2,
.company-hero .eyebrow,.company-hero .muted,.company-hero h2,
.agenda-hero .eyebrow,.agenda-hero .muted,.agenda-hero h2,
.bills-hero .eyebrow,.bills-hero .muted,.bills-hero h2,
.history-hero .eyebrow,.history-hero .muted,.history-hero h2,
.anam-hero .eyebrow,.anam-hero .muted,.anam-hero h2{color:#fff !important;}
.cash-hero .hero-meta .pill,
.reports-hero .hero-meta .pill,
.company-hero .hero-meta .pill,
.agenda-hero .hero-meta .pill,
.bills-hero .hero-meta .pill,
.history-hero .hero-meta .pill,
.anam-hero .hero-meta .pill{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.22);backdrop-filter:none;}
.cash-hero .hero-meta .pill:hover,
.reports-hero .hero-meta .pill:hover,
.company-hero .hero-meta .pill:hover,
.agenda-hero .hero-meta .pill:hover,
.bills-hero .hero-meta .pill:hover,
.history-hero .hero-meta .pill:hover,
.anam-hero .hero-meta .pill:hover{background:rgba(255,255,255,.20);}
@media (max-width:640px){
  .cash-hero,.reports-hero,.company-hero,.agenda-hero,.bills-hero,.history-hero,.anam-hero{padding:18px 16px;}
  .cash-hero .hero-meta .pill,.reports-hero .hero-meta .pill,.company-hero .hero-meta .pill,.agenda-hero .hero-meta .pill,.bills-hero .hero-meta .pill,.history-hero .hero-meta .pill,.anam-hero .hero-meta .pill{width:100%;justify-content:center;text-align:center;}
}


/* Sidebar navigation safe */
.tabs.sidebar-tabs{scroll-snap-type:none; -webkit-overflow-scrolling:auto;}
.sidebar .tabbtn{
  position:relative;
  width:100%;
  justify-content:flex-start;
  border-radius:16px;
  border:1px solid rgba(6,164,81,.15);
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(239,247,242,.92));
  color:var(--verde-escuro);
  box-shadow:0 6px 14px rgba(15,27,22,.03), inset 0 1px 0 rgba(255,255,255,.9);
  padding:13px 14px;
  gap:10px;
  transition:transform .08s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.sidebar .tabbtn:hover{
  background:linear-gradient(180deg, rgba(247,252,249,1), rgba(231,245,236,.98));
  border-color:rgba(6,164,81,.26);
  box-shadow:0 10px 22px rgba(15,27,22,.08);
  transform:translateY(-1px);
}
.sidebar .tabbtn.active{
  background:linear-gradient(180deg, var(--verde), #11804b);
  color:#fff;
  box-shadow:0 16px 32px rgba(6,164,81,.22);
  border-color:transparent;
}
.sidebar .tabbtn.active::before{
  content:"";
  position:absolute;
  left:0;
  top:10px;
  bottom:10px;
  width:4px;
  border-radius:0 999px 999px 0;
  background:rgba(255,255,255,.92);
}
.sidebar .tabbtn .tabicon{
  width:22px;
  min-width:22px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
}
.sidebar .tabbtn .tablabel{
  flex:1;
  overflow:hidden;
  text-overflow:ellipsis;
}
body.nav-collapsed .sidebar .tabbtn{
  justify-content:center;
  padding:13px 10px;
}
body.nav-collapsed .sidebar .tabbtn .tablabel{display:none}
body.nav-collapsed .sidebar .tabbtn .tabicon{margin:0}
@media (max-width: 980px){
  body.nav-collapsed .sidebar .tabbtn .tablabel{display:block}
  body.nav-collapsed .sidebar .tabbtn{justify-content:flex-start; padding:13px 14px}
}


/* V40.9.6 SPLIT NAV SAFE */
.sidebar .tabbtn{
  width:100%;
  justify-content:flex-start;
  gap:10px;
  padding:13px 14px;
  border-radius:18px;
  background:linear-gradient(180deg,#f7fbf8,#edf7f1);
  color:var(--verde-escuro);
  border:1px solid rgba(6,164,81,.18);
  box-shadow:none;
}
.sidebar .tabbtn:hover{
  background:#ffffff;
  box-shadow:0 10px 22px rgba(15,27,22,.08);
  transform:translateY(-1px);
}
.sidebar .tabbtn.active{
  background:linear-gradient(135deg,var(--verde),var(--verde-escuro));
  border-color:transparent;
  color:#fff;
  box-shadow:0 12px 24px rgba(6,164,81,.22);
}
.sidebar .tabbtn .tabicon{
  font-size:18px;
  width:24px;
  display:inline-flex;
  justify-content:center;
}
.sidebar .tabbtn .tablabel{
  font-size:14px;
  font-weight:800;
}
body.nav-collapsed .sidebar .tabbtn{
  justify-content:center;
  padding:13px 10px;
}
body.nav-collapsed .sidebar .tabbtn .tablabel{display:none;}
@media (max-width: 980px){
  .sidebar .tabbtn{justify-content:flex-start; padding:12px 13px;}
  .sidebar .tabbtn .tablabel{display:block;}
}


/* V40.9.6 icon bubble refinement */
.sidebar{display:flex;justify-content:center;}
.tabs.sidebar-tabs{align-items:center;gap:14px;}
.sidebar .tabbtn{
  width:64px;
  height:64px;
  min-height:64px;
  padding:0;
  justify-content:center;
  gap:0;
  border-radius:20px;
  background:linear-gradient(180deg,#ffffff,#f6fbf8);
  border:1px solid rgba(6,164,81,.18);
  box-shadow:none;
}
.sidebar .tabbtn .tablabel{display:none !important;}
.sidebar .tabbtn .tabicon{
  width:auto;
  font-size:24px;
  line-height:1;
  margin:0;
}
.sidebar .tabbtn.active{
  background:linear-gradient(135deg,var(--verde),var(--verde-escuro));
  color:#fff;
  box-shadow:0 12px 24px rgba(6,164,81,.18);
}
.sidebar .tabbtn.active::before{display:none;}
.sidebar .tabbtn:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 22px rgba(15,27,22,.08);
  background:#fff;
}
body.nav-collapsed .sidebar .tabbtn{padding:0;justify-content:center;}
@media (max-width: 980px){
  .sidebar{display:block;}
  .tabs.sidebar-tabs{align-items:stretch;gap:10px;}
  .sidebar .tabbtn{
    width:100%;
    height:auto;
    min-height:0;
    padding:12px 13px;
    justify-content:flex-start;
    gap:10px;
  }
  .sidebar .tabbtn .tablabel{display:block !important;}
  .sidebar .tabbtn .tabicon{font-size:18px;width:24px;}
}

/* ===== V40.9.7 TOOLTIP FIX SAFE =====
   Corrige nomes dos ícones ficando por trás/cortados.
   Mantém o visual limpo com ícones soltos + tooltip no hover.
===================================== */

/* Garante contexto acima do conteúdo central */
.sidebar-left,
.sidebar-right{
  position: relative;
  z-index: 120;
  overflow: visible !important;
}

/* Não corta tooltip nos docks laterais */
.sidebar-left .tabs,
.sidebar-right .tabs,
.sidebar-left .sidebar-tabs,
.sidebar-right .sidebar-tabs{
  overflow: visible !important;
}

/* Botão em si precisa permitir pseudo-elemento sair */
.sidebar .tabbtn{
  position: relative;
  overflow: visible !important;
  z-index: 121;
}

/* Tooltip acima de qualquer card/conteúdo */
.sidebar .tabbtn::after{
  z-index: 9999 !important;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

/* Seta do tooltip */
.sidebar .tabbtn::before{
  content: "";
  position: absolute;
  top: 50%;
  width: 8px;
  height: 8px;
  background: rgba(10,76,43,.96);
  transform: translateY(-50%) rotate(45deg);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 9998 !important;
}

/* Tooltip para menu esquerdo apontando para dentro */
.sidebar-left .tabbtn::after{
  left: 72px;
  right: auto;
  transform: translateY(-50%) translateX(8px);
}
.sidebar-left .tabbtn::before{
  left: 66px;
}

/* Tooltip para menu direito apontando para dentro */
.sidebar-right .tabbtn::after{
  right: 72px;
  left: auto;
  transform: translateY(-50%) translateX(-8px);
}
.sidebar-right .tabbtn::before{
  right: 66px;
}

/* Hover / foco */
.sidebar-left .tabbtn:hover::after,
.sidebar-left .tabbtn:hover::before,
.sidebar-left .tabbtn:focus-visible::after,
.sidebar-left .tabbtn:focus-visible::before,
.sidebar-right .tabbtn:hover::after,
.sidebar-right .tabbtn:hover::before,
.sidebar-right .tabbtn:focus-visible::after,
.sidebar-right .tabbtn:focus-visible::before{
  opacity: 1;
  visibility: visible;
}

.sidebar-left .tabbtn:hover::after,
.sidebar-left .tabbtn:focus-visible::after{
  transform: translateY(-50%) translateX(0);
}
.sidebar-right .tabbtn:hover::after,
.sidebar-right .tabbtn:focus-visible::after{
  transform: translateY(-50%) translateX(0);
}

/* Em desktop com ícones soltos, mantém sem texto visível */
@media (min-width: 981px){
  .sidebar .tabbtn .tablabel{
    display: none !important;
  }
}

/* No mobile, some com tooltip e volta texto normal */
@media (max-width: 980px){
  .sidebar .tabbtn::before,
  .sidebar .tabbtn::after{
    display: none !important;
  }
  .sidebar,
  .sidebar-left,
  .sidebar-right,
  .tabs,
  .sidebar-tabs{
    overflow: visible;
  }
}

.pill-compact{padding:4px 8px;font-size:11px;min-width:auto;white-space:nowrap;}
.finance-stats-grid .metric-value{overflow-wrap:anywhere;word-break:break-word;}
.table td .pill-compact{justify-content:center;}

/* ===== etapa 3: banco de dados + mensalidades ===== */
.rlg-db-prof-box{
  display:grid;
  gap:14px;
  width:100%;
  margin-top:14px;
  padding:18px;
  border-radius:20px;
  background:linear-gradient(180deg,#ffffff,#f7fbf9);
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 12px 28px rgba(15,23,42,.06);
}
.rlg-db-prof-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.rlg-db-prof-eyebrow{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#64748b;margin-bottom:4px}
.rlg-db-prof-title{font-weight:800;font-size:24px;color:#0f172a;line-height:1.1}
.rlg-db-prof-pill{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;border:1px solid rgba(148,163,184,.24);background:rgba(148,163,184,.14);font-size:12px;font-weight:800;color:#475569}
.rlg-db-prof-pill.is-sqlite{background:rgba(22,163,74,.10);border-color:rgba(22,163,74,.18);color:#166534}
.rlg-db-prof-grid{display:grid;gap:12px;grid-template-columns:repeat(3,minmax(0,1fr))}
.rlg-db-prof-item{padding:14px;border:1px solid rgba(15,23,42,.08);border-radius:16px;background:#fff;min-width:0}
.rlg-db-prof-item.is-path{grid-column:1 / -1}
.rlg-db-prof-label{font-size:11px;color:#64748b;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.rlg-db-prof-value{font-size:16px;color:#0f172a;line-height:1.35;display:block}
.rlg-db-prof-path{font-size:13px;color:#334155;word-break:break-word;line-height:1.5}
.rlg-db-prof-actions{display:flex;gap:10px;flex-wrap:wrap}

.table-premium tbody td .pill.in,
.table-premium tbody td .pill.out{padding:6px 10px;font-size:11px;letter-spacing:.03em;min-width:auto}

@media (max-width: 980px){
  .rlg-db-prof-grid{grid-template-columns:1fr}
}
/* ================================
   FINANCEIRO - ETAPA 5 FIX PRO
================================ */

/* Cabeçalho relatório */
.report-header {
  background: linear-gradient(135deg, #1e9e4a, #16833c);
  border-radius: 16px;
  padding: 18px 22px;
  display: flex;
  align-items: center;
  gap: 16px;
}

.report-header h1 {
  font-size: 22px;
  margin: 0;
}

.report-header small {
  opacity: 0.9;
  font-size: 13px;
}

/* Reduz altura exagerada */
.report-header.compact {
  padding: 14px 18px;
}

/* Cards resumo */
.report-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px,1fr));
  gap: 12px;
  margin-top: 12px;
}

.report-summary .card {
  padding: 14px;
  border-radius: 12px;
}

/* Evita quebra feia de valor */
.report-summary .value {
  font-size: 18px;
  font-weight: 600;
  white-space: nowrap;
}

/* BADGE ENTRADA/SAÍDA (compacta) */
.badge-tipo {
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.5px;
}

.badge-entrada {
  background: #e6f7ee;
  color: #1e9e4a;
}

.badge-saida {
  background: #fdecea;
  color: #d93025;
}

/* TABELA FINANCEIRA */
.finance-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 10px;
}

.finance-table th {
  text-align: left;
  font-size: 12px;
  opacity: 0.7;
  padding: 10px;
}

.finance-table td {
  padding: 12px 10px;
  border-top: 1px solid #eee;
}

/* descrição quebra correto */
.finance-table .desc {
  max-width: 240px;
  word-break: break-word;
}

/* valor alinhado à direita */
.finance-table .valor {
  text-align: right;
  font-weight: 600;
}

/* linha hover */
.finance-table tr:hover {
  background: rgba(0,0,0,0.03);
}

/* FILTROS */
.finance-filters {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px,1fr));
  gap: 10px;
  margin-bottom: 10px;
}

.finance-filters input,
.finance-filters select {
  height: 36px;
  border-radius: 8px;
  padding: 6px 10px;
}

/* Botões período */
.period-buttons {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.period-buttons button {
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 12px;
}

/* botão limpar destacado */
.btn-limpar {
  border: 1px solid #e53935;
  color: #e53935;
  background: transparent;
}

/* RODAPÉ PDF LIMPO */
.report-footer {
  margin-top: 20px;
  font-size: 12px;
  opacity: 0.7;
  display: flex;
  justify-content: space-between;
}

.report-footer .left {
  text-align: left;
}

.report-footer .right {
  text-align: right;
}

/* Anamnese search compact */
.anam-search-results{ position:relative; }
.anam-search-list{ display:grid; gap:8px; }
.anam-search-item{
  width:100%; display:flex; align-items:center; justify-content:space-between; gap:10px;
  text-align:left; padding:10px 12px; border:1px solid var(--line,#d9dee7); border-radius:14px;
  background:#fff; cursor:pointer;
}
.anam-search-item:hover{ border-color:var(--brand,#16a34a); box-shadow:0 6px 18px rgba(0,0,0,.05); }
.anam-search-main{ display:grid; gap:2px; min-width:0; }
.anam-search-main b{ color:var(--text,#0f172a); }
.anam-search-main .muted{ white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.anam-search-badge{
  flex:0 0 auto; font-size:11px; font-weight:700; padding:5px 8px; border-radius:999px;
  color:#166534; background:#dcfce7; border:1px solid #bbf7d0;
}
.anam-preview-host{ border-style:solid; }
.anam-preview-card{ display:grid; gap:8px; }
.anam-preview-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.anam-preview-existing{ padding-top:4px; border-top:1px dashed var(--line,#d9dee7); }
@media (max-width: 720px){
  .anam-search-item{ align-items:flex-start; flex-direction:column; }
  .anam-search-main .muted{ white-space:normal; }
  .anam-preview-head{ flex-direction:column; }
}
