/* =========================================================
   Finlly — style.css (baseado no modelo aprovado)
   Objetivo: UI moderna, limpa e consistente.
   IMPORTANTE: mantém compatibilidade com classes já usadas no projeto.
   ========================================================= */

/* =================================================================================
   TOKENS
================================================================================= */
:root{
  /* Finlly brand */
  --finlly-blue:#33528A;
  --finlly-blue-hover:#2A4475;
  --finlly-lime:#C4E81D;

  /* Modelo */
  --primary-color: var(--finlly-blue);
  --primary-color-hover: var(--finlly-blue-hover);
  --secondary-color: #0B1220;

  --light-color: #ffffff;

  --text-color-dark: #212529;
  --text-color-light: #ffffff;
  --text-color-medium: #6c757d;
  --text-color-light-gray: #adb5bd;

  --success-color: #198754;
  --danger-color: #dc3545;
  --warning-color: #ffc107;
  --info-color: #0dcaf0;

  --bg-color: #f3f6fb;
  --card-bg: #ffffff;
  --input-bg: #ffffff;
  --border-color: #dee2e6;

  --table-header-bg: #f8f9fa;
  --table-striped-bg: #f8f9fa;
  --table-hover-bg: #e9ecef;

  /* MENU */
  --menu-bg: var(--primary-color);
  --menu-hover-bg: var(--primary-color-hover);
  --menu-text: #ffffff;

  --shadow-soft: 0 10px 30px rgba(0,0,0,.07);
  --shadow-menu: 0 10px 35px rgba(51,82,138,.22);
  --radius-xl: 1.25rem;
  --radius-lg: 1rem;
}

/* =================================================================================
   BASE (isolado no app)
================================================================================= */
html{ box-sizing:border-box; height:100%; }
*,*::before,*::after{ box-sizing:inherit; }

body.app-body{
  background-color: var(--bg-color);
  color: var(--text-color-dark);
  font-family: system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",
               "Noto Sans","Liberation Sans",Arial,sans-serif,
               "Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";
  transition: background-color .3s ease, color .3s ease;
  min-height: 100vh;

  /* Layout padrão: sidebar + main */
  padding: 1rem;
  display: flex;
  gap: 1rem;
}

h1,h2,h3,h4,h5,h6{ color: var(--text-color-dark); font-weight: 700; }
a{ color: var(--primary-color); text-decoration: none; }
a:hover{ color: var(--primary-color-hover); }

::selection{ background: rgba(196,232,29,.35); }

.visually-hidden-focusable:focus{
  position: static !important;
  width: auto !important;
  height: auto !important;
  margin: 0.5rem !important;
}

/* =================================================================================
   BOTÕES (Bootstrap + compat)
================================================================================= */
.btn{
  border-radius: 50rem !important;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
  font-weight: 500;
  transition: all .2s ease-in-out;
}
.btn-lg{ padding-left: 2rem; padding-right: 2rem; }
.btn-sm{ padding-left: 1rem; padding-right: 1rem; border-radius: 50rem !important; }

.btn-primary{
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: var(--text-color-light);
}
.btn-primary:hover{
  background-color: var(--primary-color-hover);
  border-color: var(--primary-color-hover);
  color: var(--text-color-light);
  transform: translateY(-2px);
  box-shadow: 0 4px 10px rgba(51,82,138,0.20);
}
.btn-outline-primary{
  color: var(--primary-color);
  border-color: var(--primary-color);
}
.btn-outline-primary:hover{
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: var(--text-color-light);
  transform: translateY(-2px);
}
.btn-outline-secondary{
  color: var(--text-color-medium);
  border-color: var(--border-color);
}
.btn-outline-secondary:hover{
  background-color: var(--text-color-medium);
  border-color: var(--text-color-medium);
  color: var(--light-color);
  transform: translateY(-2px);
}

/* Compat: botões antigos do Finlly */
.btn-organiza{
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: #fff !important;
  border-radius: 50rem !important;
}
.btn-organiza:hover{
  background-color: var(--primary-color-hover);
  border-color: var(--primary-color-hover);
  transform: translateY(-2px);
  box-shadow: 0 4px 10px rgba(51,82,138,0.20);
}
.btn-outline-organiza{
  color: var(--primary-color) !important;
  border-color: var(--primary-color);
  background: transparent;
  border-radius: 50rem !important;
}
.btn-outline-organiza:hover{
  background: var(--primary-color);
  border-color: var(--primary-color);
  color: #fff !important;
}

/* =================================================================================
   SIDEBAR — menu azul, hover/ativo azul escuro, sem bordas e ícones brancos
================================================================================= */
.sidebar{
  z-index: 1030;
  position: fixed;
  top: 1rem; left: 1rem; bottom: 1rem;
  height: calc(100vh - 2rem);
  width: 92px;
  padding: 15px 0;
  background: var(--menu-bg) !important;
  box-shadow: var(--shadow-menu);
  overflow-x: hidden;
  overflow-y: auto;
  transition: width .3s ease-in-out, box-shadow .3s ease;
  border-radius: var(--radius-xl);
}
.sidebar:hover{
  width: 280px;
  box-shadow: 0 15px 45px rgba(51,82,138,.26);
}

.sidebar .logo{
  width: 100%;
  padding: 0 25px;
  margin-top: 10px;
  margin-bottom: 22px;
  max-height: 40px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.sidebar .sidebar-heading{
  padding: .5rem 1.5rem .5rem 30px;
  font-size: .72rem;
  color: rgba(255,255,255,.70) !important;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-top: 1rem;
  white-space: nowrap;
  opacity: 0;
  transition: opacity .2s ease-in-out;
}
.sidebar:hover .sidebar-heading{
  opacity: 1;
  transition-delay: .1s;
}

.sidebar hr{
  border-color: rgba(255,255,255,.25) !important;
  margin: 1rem 1.5rem;
}

.sidebar .nav-link{
  display: flex;
  align-items: center;
  color: var(--menu-text) !important;
  background: var(--menu-bg) !important;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  font-size: .95rem;
  padding: 12px 18px;
  white-space: nowrap;
  transition: background-color .15s ease, color .15s ease;
  border-radius: .75rem;
  margin: 6px 10px;
}
.sidebar .nav-link i{
  font-size: 1.25rem;
  min-width: 26px;
  text-align: center;
  color: inherit !important;
}
.sidebar .nav-link:hover,
.sidebar .nav-link.active{
  margin-left: 10px;
  margin-right: 10px;
}
.sidebar .nav-link:hover{
  background: var(--menu-hover-bg) !important;
  color: var(--menu-text) !important;
}
.sidebar .nav-link.active,
.sidebar .nav-link.active:hover{
  background: var(--menu-hover-bg) !important;
  color: var(--menu-text) !important;
  font-weight: 600;
}

.sidebar .nav-link .link-text{
  margin-left: 20px;
  opacity: 0;
  transition: opacity .2s ease-in-out;
  color: inherit !important;
}
.sidebar:hover .nav-link .link-text{
  opacity: 1;
  transition-delay: .1s;
}

/* =================================================================================
   MAIN (respeita sidebar expansível)
================================================================================= */
.main-content{
  padding: 20px 30px 0 30px;
  margin-left: calc(92px + 1rem + 1rem);
  margin-right: 1rem;
  transition: margin-left .3s ease-in-out;
  min-height: calc(100vh - 2rem);
  padding-top: 0;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  width: calc(100% - (92px + 1rem + 1rem));
}
.sidebar:hover ~ .main-content{
  margin-left: calc(280px + 1rem + 1rem);
  width: calc(100% - (280px + 1rem + 1rem));
}

/* Cabeçalho do app (top row) */
.app-header{
  margin-bottom: 1.5rem;
  padding-top: 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}
.app-header-left{
  display: flex;
  align-items: center;
  gap: .75rem;
  min-width: 0;
}
.app-header-title{
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.app-header-title h1{
  font-size: 1.35rem;
  margin: 0;
  line-height: 1.1;
}
.app-header-title p{
  margin: 0;
  color: var(--text-color-medium);
  font-size: .9rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.app-header-right{
  display: flex;
  align-items: center;
  gap: .6rem;
}

/* Avatar / profile */
.app-user-btn{
  border: 0;
  background: transparent;
  padding: 0;
}
.app-header .avatar{
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--primary-color);
  color: var(--light-color) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 700;
  font-size: 1.05rem;
  cursor: pointer;
  border: 2px solid var(--light-color);
  box-shadow: 0 0 15px rgba(0,0,0,.10);
  overflow: hidden;
  text-align: center;
}

/* Footer */
.main-footer{
  padding: 1rem;
  margin-top: auto;
  border-top: none;
  font-size: .9rem;
  background: var(--primary-color);
  color: var(--light-color);
  text-align: center;
  border-radius: 1rem;
  margin-top: 2rem;
  margin-bottom: 30px;
}
.main-footer a{ color: var(--light-color); font-weight: 600; text-decoration: underline; }
.main-footer a:hover{ color: rgba(255,255,255,.8); }

/* =================================================================================
   OFFCANVAS (mobile)
================================================================================= */
.offcanvas{
  border: none;
  border-radius: 0 1.25rem 1.25rem 0;
  box-shadow: -10px 0 35px rgba(0,0,0,.1);
  background: var(--bg-color);
}
.offcanvas-header{
  border-bottom: 1px solid var(--border-color);
  background: var(--bg-color);
}
.offcanvas-header .btn-close{ filter: none; opacity: .7; }
.offcanvas-body{ background: var(--bg-color); }

.offcanvas-body .avatar{
  background: var(--primary-color);
  color: var(--light-color) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50%;
  overflow: hidden;
  text-align: center;
}

/* listas no offcanvas */
.account-list .list-group-item{
  background: transparent;
  border: 1px solid var(--border-color);
  border-radius: .75rem !important;
  margin-bottom: .5rem;
  transition: all .2s ease;
  color: var(--text-color-dark);
}
.account-list .list-group-item:hover{
  border-color: var(--primary-color);
  background: var(--table-hover-bg);
}
.account-list .list-group-item.active{
  background: var(--primary-color);
  border-color: var(--primary-color);
  color: var(--light-color);
}
.account-list .list-group-item.active .text-muted{ color: rgba(255,255,255,.7) !important; }

.offcanvas-body .list-group-item.border-0{
  color: var(--text-color-dark);
  border-radius: .75rem;
  padding: .75rem 1rem;
}
.offcanvas-body .list-group-item.border-0:hover{ background: var(--table-hover-bg); }

/* =================================================================================
   CARDS / FORM / TABLES
================================================================================= */
.content-card, .kpi-card, .summary-card, .report-summary-card, .receipt-card{
  background: var(--card-bg);
  border: none;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-soft);
  backdrop-filter: none;
  transition: all .3s ease;
  overflow: hidden;
}
.kpi-card:hover{
  transform: translateY(-5px);
  box-shadow: 0 15px 35px rgba(51,82,138,.14);
}
.kpi-card .card-body{ padding: 1.5rem; }
.kpi-card .card-title{
  font-size: .85rem;
  font-weight: 500;
  color: var(--text-color-medium);
  text-transform: uppercase;
  letter-spacing: .5px;
}
.kpi-card .card-text{
  font-size: 2rem;
  font-weight: 700;
  color: var(--text-color-dark);
}

.form-label{ font-weight: 500; color: var(--text-color-medium); margin-bottom: .5rem; font-size: .9rem; }
.form-control, .form-select{
  background: var(--input-bg);
  border: 1px solid var(--border-color);
  color: var(--text-color-dark);
  padding: .75rem 1rem;
  height: auto;
  border-radius: .75rem;
  box-shadow: none;
}
.form-control::placeholder{ color: var(--text-color-light-gray); opacity: 1; }
.form-control:focus, .form-select:focus{
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(51,82,138,.12);
  background: var(--input-bg);
}
.input-group-text{
  background: var(--input-bg);
  border-color: var(--border-color);
  color: var(--text-color-light-gray);
  border-radius: .75rem;
}

.filter-bar{ padding: 1rem 1.5rem; border-radius: .75rem; }

.table-custom{
  vertical-align: middle;
  --bs-table-bg: transparent;
  --bs-table-border-color: var(--border-color);
  --bs-table-striped-bg: var(--table-striped-bg);
  --bs-table-hover-bg: var(--table-hover-bg);
  color: var(--text-color-dark);
  border-collapse: separate;
  border-spacing: 0;
}
.table-custom th{
  font-weight: 600;
  padding: .9rem 1.2rem;
  color: var(--text-color-medium);
  background: var(--table-header-bg);
  border-bottom: 1px solid var(--border-color);
  white-space: nowrap;
}
.table-custom td{
  padding: .9rem 1.2rem;
  color: var(--text-color-dark);
  border-top: 1px solid var(--border-color);
}
.table-striped > tbody > tr:nth-of-type(odd) > *{
  --bs-table-accent-bg: var(--table-striped-bg);
  color: var(--text-color-dark);
}
.table-hover > tbody > tr:hover > *{
  --bs-table-accent-bg: var(--table-hover-bg);
  color: var(--text-color-dark);
  transition: background-color .15s ease-in-out;
}

/* =================================================================================
   BADGES (status) — corrigido para “vencidas”
================================================================================= */
.badge{
  font-weight: 700;
  letter-spacing: .02em;
  border-radius: 50rem;
  padding: .35rem .65rem;
}

.badge-status-pendente{
  background: rgba(255,193,7,.18);
  border: 1px solid rgba(255,193,7,.28);
  color: #7a5b00;
}
.badge-status-pago{
  background: rgba(25,135,84,.14);
  border: 1px solid rgba(25,135,84,.22);
  color: #0b4a2c;
}
.badge-status-cancelado{
  background: rgba(108,117,125,.14);
  border: 1px solid rgba(108,117,125,.22);
  color: #495057;
}

/* “Atrasado” = status principal */
.badge-atrasado,
.badge-status-atrasado{
  background: rgba(220,53,69,.14);
  border: 1px solid rgba(220,53,69,.22);
  color: #b02a37;
}

/* “Vencida há Xd” = info secundária, ainda com fundo */
.badge-vencida,
.badge-status-vencida{
  background: rgba(220,53,69,.10);
  border: 1px dashed rgba(220,53,69,.35);
  color: #b02a37;
}

/* “Hoje” */
.badge-hoje{
  background: rgba(13,202,240,.14);
  border: 1px solid rgba(13,202,240,.22);
  color: #055160;
}

/* =================================================================================
   FAB (compat)
================================================================================= */
.fab-container{ position: fixed; right: 18px; bottom: 18px; z-index: 1040; }
.fab-main{
  width: 56px; height: 56px; border-radius: 999px; border: 0;
  background: var(--primary-color); color: #fff;
  box-shadow: 0 18px 34px rgba(51,82,138,.28);
  display: grid; place-items: center;
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.fab-main:hover{ filter: brightness(1.03); transform: translateY(-2px); }

.fab-menu{
  position: absolute; right: 0; bottom: 70px; width: 260px;
  background: rgba(255,255,255,.98);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  box-shadow: 0 18px 40px rgba(0,0,0,.14);
  padding: .55rem;
  transform-origin: 90% 100%;
  transform: scale(.92) translateY(8px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;
}
.fab-open .fab-menu{
  opacity: 1;
  transform: scale(1) translateY(0);
  pointer-events: auto;
}
.fab-item{
  display: flex; align-items: center; gap: .75rem;
  padding: .75rem .75rem;
  border-radius: 14px;
  cursor: pointer;
  transition: background .18s ease, transform .18s ease;
}
.fab-item:hover{ background: rgba(51,82,138,.08); transform: translateY(-1px); }

/* =================================================================================
   RESPONSIVIDADE
================================================================================= */
@media (max-width: 991.98px){
  body.app-body{
    padding: .75rem;
    display: block;
  }
  .sidebar{ width: 0; padding: 0; border: none; box-shadow: none; left: -1rem; }
  .main-content{
    margin-left: 0;
    margin-right: 0;
    width: 100%;
    padding: 0;
  }
  .app-header{ margin-bottom: 1rem; padding-top: 0; }
}

@media (max-width: 768px){
  body.app-body{ padding: .5rem; }
  .main-content{ padding: 0; }
  .kpi-card .card-text{ font-size: 1.5rem; }
  .content-card, .kpi-card{ border-radius: .75rem; }
  .filter-bar{ padding: .75rem; }
  .table-custom th, .table-custom td{ padding: .5rem .7rem; font-size: .85rem; }
}

/* =================================================================================
   ESTILOS DE LINK PARA UPLOAD (Pagamento em Lote) — mantido
================================================================================= */
.upload-dropzone-link{ position: relative; display:block; text-decoration:none; }
.upload-dropzone-link .stretched-link::after{
  position:absolute; inset:0; z-index:1; content:"";
}
.upload-dropzone-link .btn{ position:relative; z-index:2; }


/* =================================================================================
   LOGIN (Finlly) — layout 2 colunas (branding + formulário)
   Isolado para não herdar o flex/padding do app principal
================================================================================= */
body.login-body{
  height: 100vh;
  overflow: hidden;
  padding: 0 !important;
  margin: 0 !important;
  background: var(--light-color) !important;
  background-image: none !important;
  display: block !important;
}

.login-body .main-container{
  display: flex;
  width: 100%;
  height: 100%;
  min-height: 100vh;
}

.login-body .branding-side{
  width: 55%;
  background: var(--primary-color);
  color: var(--text-color-light);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 4rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.login-body .branding-side::before{
  content:"";
  position:absolute;
  inset:-20%;
  background:
    radial-gradient(50% 45% at 30% 30%, rgba(255,255,255,.18), transparent 60%),
    radial-gradient(50% 45% at 70% 70%, rgba(255,255,255,.12), transparent 60%);
  pointer-events:none;
}

.login-body .branding-side .logo{
  max-width: 260px;
  margin-bottom: 2rem;
  filter: brightness(0) invert(1);
  position: relative;
  z-index: 1;
}

.login-body .branding-side h1{
  font-size: clamp(2rem, 3.2vw, 3rem);
  font-weight: 800;
  line-height: 1.12;
  margin: 0 0 1rem;
  color: var(--text-color-light);
  position: relative;
  z-index: 1;
}

.login-body .branding-side p{
  margin: 0;
  font-size: 1.05rem;
  opacity: .92;
  position: relative;
  z-index: 1;
  max-width: 520px;
}

.login-body .form-side{
  width: 45%;
  background: var(--bg-color) !important;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 3rem;
  overflow-y: auto;
}

.login-body .form-wrapper{
  max-width: 520px;
  width: 100%;
}

.login-body .form-wrapper .logo-mobile{
  max-width: 160px;
  margin-bottom: 1.5rem;
  display: none;
}

.login-body .login-card{
  padding: 2.5rem !important;
  border-radius: 1.25rem;
}

.login-body .login-title{
  font-size: 2rem;
  font-weight: 800;
  margin-bottom: 1.4rem;
}

.login-body .login-footer{
  text-align: center;
  margin-top: 1.25rem;
  color: var(--text-color-medium);
  font-size: .92rem;
}

/* Responsivo */
@media (max-width: 991.98px){
  .login-body .branding-side{ display: none; }
  .login-body .form-side{ width: 100%; padding: 2rem 1.25rem; }
  .login-body .form-wrapper .logo-mobile{ display: inline-block; }
  .login-body .login-card{ padding: 2rem !important; }
}
@media (max-width: 576px){
  .login-body .form-side{ padding: 1.25rem .9rem; }
  .login-body .login-card{ padding: 1.5rem !important; }
  .login-body .login-title{ font-size: 1.6rem; }
}



/* =========================================================
   EXTRA (Contas a Pagar) — ajustes de espaçamento e ícones
   (Somente adições; não quebra classes existentes)
========================================================= */
.btn-icon-pill{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  border-radius: 999px;
  padding: .55rem 1rem;
}
.icon-16{ width:16px; height:16px; display:inline-block; vertical-align:middle; }
.icon-18{ width:18px; height:18px; display:inline-block; vertical-align:middle; }
.icon-22{ width:22px; height:22px; display:inline-block; vertical-align:middle; }

.kpi-icon-wrap{
  width:44px; height:44px;
  border-radius: 14px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(51,82,138,.10);
  color: var(--primary-color);
  flex: 0 0 auto;
}
.kpi-number{
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--text-color-dark);
}
.kpi-hint{
  font-size: .85rem;
  color: var(--text-color-medium);
}

.badge-soft{
  background: rgba(51,82,138,.10);
  color: var(--primary-color);
  border: 1px solid rgba(51,82,138,.15);
  padding: .35rem .6rem;
  border-radius: 999px;
  font-weight: 600;
}
.table-icon{
  color: var(--text-color-medium);
}

.action-btn{
  width: 36px;
  height: 36px;
  border-radius: 12px;
  border: 1px solid var(--border-color);
  background: var(--card-bg);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color: var(--text-color-dark);
  transition: all .15s ease;
}
.action-btn:hover{
  transform: translateY(-1px);
  box-shadow: var(--shadow-soft);
  border-color: rgba(51,82,138,.25);
}
.action-btn:active{ transform: translateY(0); }


/* =================================================================================
   FINLLY — PADRONIZAÇÃO VISUAL (módulos financeiros)
   Objetivo: componentes consistentes para cards, filtros e tabelas (sem gambiarras)
   - Não remove nada do CSS existente
   - Só adiciona/normaliza classes usadas nos módulos (ex.: contas_pagar.php)
================================================================================= */

/* ---------- Tipografia e espaçamento base (mais “produto”, menos “bootstrap cru”) ---------- */
:root{
  --gap-1: 8px;
  --gap-2: 12px;
  --gap-3: 16px;
  --gap-4: 20px;
  --gap-5: 24px;
  --line-soft: rgba(15, 23, 42, .10);
  --line-soft-2: rgba(15, 23, 42, .14);
}

h1,h2,h3{ letter-spacing: -0.4px; }
.small, small{ opacity: .88; }

/* ---------- Cards padrão (bootstrap .card + cards custom) ---------- */
.card,
.content-card,
.filtros-card,
.table-card,
.stat-card{
  background: #fff;
  border: 1px solid var(--line-soft);
  border-radius: 14px;
  box-shadow: var(--shadow-light);
}

.card-header{
  background: transparent;
  border-bottom: 1px solid var(--line-soft);
  padding: 14px 16px;
}
.card-body{ padding: 16px; }

/* ---------- KPI cards (stat-card) ---------- */
.stats-grid,
.kpi-grid{
  display: grid;
  /* Auto-ajuste: evita “coluna vazia” quando há 4/5 cards */
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--gap-2);
  align-items: stretch;
}
@media (max-width: 900px){
  .stats-grid,.kpi-grid{ grid-template-columns: repeat(2, minmax(220px, 1fr)); }
}
@media (max-width: 520px){
  .stats-grid,.kpi-grid{ grid-template-columns: 1fr; }
}

.stat-card{
  padding: 14px 14px;
  display: flex;
  gap: 10px;
  align-items: center;
  min-height: 84px;
}
.stat-card .stat-ico{
  width: 36px; height: 36px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: rgba(59,130,246,.10);
  color: var(--primary-color);
  flex: 0 0 auto;
}
.stat-card .stat-title{
  font-size: 12px;
  color: var(--text-color-medium);
  margin: 0;
}
.stat-card .stat-value{
  font-weight: 800;
  font-size: 18px;
  margin: 2px 0 0 0;
}

/* ---------- Alertas / dica (“organiza”) ---------- */
.btn-outline-organiza{
  border: 1px solid var(--line-soft-2) !important;
  color: var(--text-color-dark) !important;
  background: rgba(2,6,23,.02) !important;
  border-radius: 999px !important;
}
.btn-outline-organiza:hover{
  background: rgba(2,6,23,.04) !important;
}

/* ---------- Filtros ---------- */
.filtros-card{ overflow: hidden; }
.filtros-card .card-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: var(--gap-2);
}
.filtros-grid,
.filters-grid,
.filter-bar{
  display: grid;
  grid-template-columns: 1.4fr .9fr .9fr 1fr 1fr .9fr;
  gap: var(--gap-2);
  align-items: end;
}
@media (max-width: 1200px){
  .filtros-grid,.filters-grid,.filter-bar{
    grid-template-columns: repeat(2, minmax(240px, 1fr));
  }
}
@media (max-width: 520px){
  .filtros-grid,.filters-grid,.filter-bar{ grid-template-columns: 1fr; }
}
.filter-actions,
.filters-actions,
.form-actions{
  display:flex;
  gap: var(--gap-2);
  align-items:center;
  justify-content:flex-end;
}

.form-control,
.form-select,
input[type="text"], input[type="search"], input[type="date"], input[type="number"]{
  border-radius: 12px !important;
  border: 1px solid var(--line-soft-2) !important;
  padding: 10px 12px !important;
}
.form-control:focus,
.form-select:focus,
input:focus{
  outline: none !important;
  border-color: rgba(37, 99, 235, .45) !important;
  box-shadow: 0 0 0 4px rgba(37, 99, 235, .12) !important;
}

/* ---------- Tabela padrão do módulo (table-fin) ---------- */
.table-fin,
.table-custom{
  width: 100%;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--line-soft);
  background: #fff;
}
.table-fin thead th,
.table-custom thead th{
  background: rgba(2,6,23,.02);
  border-bottom: 1px solid var(--line-soft);
  font-size: 12px;
  color: var(--text-color-medium);
  font-weight: 700;
  padding: 12px 12px;
}
.table-fin tbody td,
.table-custom tbody td{
  border-bottom: 1px solid rgba(15, 23, 42, .08);
  padding: 12px 12px;
  vertical-align: middle;
}
.table-fin tbody tr:hover,
.table-custom tbody tr:hover{
  background: rgba(2,6,23,.018);
}
.table-fin td:last-child,
.table-custom td:last-child{
  white-space: nowrap;
  min-width: 240px;
}

/* ---------- Ações na tabela (botões apertados -> resolvido) ---------- */
.actions,
.action-buttons,
.table-actions,
.acoes,
td .acoes,
td .actions,
td .action-group,
td .btn-group{
  display: inline-flex !important;
  gap: 10px !important;
  align-items: center !important;
  justify-content: flex-end !important;
  flex-wrap: wrap;
}

.btn,
a.btn,
button.btn{
  border-radius: 999px !important;
  font-weight: 700;
}

.btn-sm{
  height: 36px !important;
  min-height: 36px !important;
  padding: 0 12px !important;
}
.btn-sm.btn-pagar{
  padding: 0 16px !important;
  min-width: 96px;
}

/* botões ícone (ex.: anexos/editar/excluir) */
.btn-icon,
.action-btn{
  height: 36px;
  width: 40px;
  padding: 0 !important;
  border-radius: 999px !important;
  display: inline-grid;
  place-items: center;
}

/* ---------- Badges “soft” (status e categorias) ---------- */
.badge-soft-primary{ background: rgba(59,130,246,.12) !important; border: 1px solid rgba(59,130,246,.20) !important; color: rgba(30,64,175,1) !important; }
.badge-soft-secondary{ background: rgba(100,116,139,.12) !important; border: 1px solid rgba(100,116,139,.20) !important; color: rgba(51,65,85,1) !important; }
.badge-soft-warning{ background: rgba(245,158,11,.14) !important; border: 1px solid rgba(245,158,11,.22) !important; color: rgba(146,64,14,1) !important; }
.badge-soft-danger{ background: rgba(220,53,69,.14) !important; border: 1px solid rgba(220,53,69,.22) !important; color: rgba(176,42,55,1) !important; }

/* ---------- Linhas especiais ---------- */
tr.row-atrasada,
tr.atrasado,
tr.vencido{
  background: rgba(220,53,69,.08) !important;
}

/* ---------- Modal (se bootstrap modal existir, fica padronizado) ---------- */
.modal-content{
  border-radius: 16px !important;
  border: 1px solid var(--line-soft) !important;
  box-shadow: 0 24px 60px rgba(2,6,23,.16) !important;
}
.modal-header{
  border-bottom: 1px solid var(--line-soft) !important;
  padding: 14px 16px !important;
}
.modal-body{ padding: 16px !important; }
.modal-footer{
  border-top: 1px solid var(--line-soft) !important;
  padding: 14px 16px !important;
}

/* ---------- Categorias (tela/modal) ---------- */
.cat-list{
  display: grid;
  gap: 10px;
}
.cat-item{
  display:flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--line-soft);
  border-radius: 12px;
  background: rgba(2,6,23,.01);
}
.cat-item .cat-meta{
  display:flex;
  flex-direction: column;
  gap: 2px;
}
.cat-item .cat-name{ font-weight: 800; }
.cat-item .cat-sub{ font-size: 12px; color: var(--text-color-medium); }
.cat-item .cat-actions{
  display:flex;
  gap: 10px;
  align-items:center;
}

/* ---------- Responsivo: evita “apertar tudo” ---------- */
.table-responsive{ border-radius: 14px; }

/* ===== FIX: centralizar conteúdo dos botões (texto + ícone) ===== */
.btn{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: .45rem;
  line-height: 1.1 !important;
}

.btn i, .btn .bi{
  line-height: 1 !important;
}

/* opcional: deixa o "pill" consistente */
.btn-sm{
  min-height: 36px;
}
