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

/* ============================================================
   VARIÁVEIS
   ============================================================ */
:root {
  --verde-gaia:       #bad971;
  --verde-gaia-dark:  #9abf4a;
  --azul:        #14465f;
  --azul-dark:   #0d3347;
  --azul-light:  #1a5a7a;
  --fundo:       #f5f5f5;
  --branco:      #ffffff;
  --cinza-borda: #e0e0e0;
  --cinza-texto: #555555;
  --vermelho:    #c0392b;
  --amarelo:     #e67e22;
  --sidebar-w:   260px;
  --header-h:    64px;
  --radius:      8px;
  --sombra:      0 2px 8px rgba(0,0,0,.10);
  --sombra-md:   0 4px 16px rgba(0,0,0,.13);
  --trans:       all .2s ease;
}

/* ============================================================
   RESET E BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 15px; }

body {
  font-family: 'Inter', sans-serif;
  background: var(--fundo);
  color: #2c2c2c;
  min-height: 100vh;
}

a { color: var(--azul); text-decoration: none; transition: var(--trans); }
a:hover { color: var(--azul-light); }

h1, h2, h3, h4 { font-family: 'Sora', sans-serif; font-weight: 600; }

input, select, textarea, button {
  font-family: 'Inter', sans-serif;
  font-size: .95rem;
}

/* ============================================================
   LAYOUT PRINCIPAL
   ============================================================ */
.layout-wrapper {
  display: flex;
  min-height: 100vh;
}

/* --------- SIDEBAR --------- */
.sidebar {
  width: var(--sidebar-w);
  background: var(--azul);
  color: #fff;
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0; left: 0;
  height: 100vh;
  z-index: 200;
  transition: var(--trans);
  overflow-y: auto;
  overflow-x: hidden;
}

.sidebar-logo {
  padding: 1.6rem 1.4rem 1.2rem;
  border-bottom: 1px solid rgba(255,255,255,.12);
  display: flex;
  align-items: center;
  gap: .75rem;
}

.sidebar-brand {
  font-family: 'Sora', sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: rgba(255,255,255,.9);
  letter-spacing: .04em;
}

.sidebar-logo .logo-icon {
  width: 38px; height: 38px;
  background: var(--verde-gaia);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}

.sidebar-logo .logo-icon svg { width: 22px; height: 22px; fill: var(--azul); }

.sidebar-logo .logo-texto {
  font-family: 'Sora', sans-serif;
  font-size: 1.45rem;
  font-weight: 700;
  letter-spacing: .5px;
  color: #fff;
}

.sidebar-logo .logo-sub {
  font-size: .65rem;
  color: rgba(255,255,255,.55);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-top: 1px;
}

.sidebar-nav { flex: 1; padding: .8rem 0; }

.nav-section {
  font-size: .65rem;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: rgba(255,255,255,.4);
  padding: .9rem 1.4rem .3rem;
  font-weight: 600;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .65rem 1.4rem;
  color: rgba(255,255,255,.78);
  border-left: 3px solid transparent;
  transition: var(--trans);
  cursor: pointer;
  font-size: .9rem;
  font-weight: 500;
}

.nav-item:hover {
  background: rgba(255,255,255,.08);
  color: #fff;
  border-left-color: var(--verde-gaia);
}

.nav-item.active {
  background: rgba(186,217,113,.3);
  color: #fff;
  border-left-color: var(--verde-gaia);
}

.nav-item svg { width: 18px; height: 18px; flex-shrink: 0; opacity: .8; }
.nav-item.active svg, .nav-item:hover svg { opacity: 1; }

.nav-badge {
  margin-left: auto;
  background: var(--vermelho);
  color: #fff;
  font-size: .7rem;
  font-weight: 700;
  padding: 1px 7px;
  border-radius: 10px;
  min-width: 18px;
  text-align: center;
  line-height: 1.4;
}

.sidebar-user {
  padding: 1rem 1.4rem;
  border-top: 1px solid rgba(255,255,255,.12);
  display: flex;
  align-items: center;
  gap: .7rem;
}

.sidebar-user .user-avatar {
  width: 36px; height: 36px;
  background: var(--verde-gaia);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700;
  font-size: .9rem;
  color: var(--azul);
  flex-shrink: 0;
}

.sidebar-user .user-info { flex: 1; min-width: 0; }
.sidebar-user .user-name {
  font-size: .85rem;
  font-weight: 600;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sidebar-user .user-perfil {
  font-size: .7rem;
  color: rgba(255,255,255,.5);
  text-transform: capitalize;
}

.sidebar-user .btn-logout {
  color: rgba(255,255,255,.5);
  background: none;
  border: none;
  cursor: pointer;
  padding: .3rem;
  border-radius: 4px;
  transition: var(--trans);
  display: flex;
}
.sidebar-user .btn-logout:hover { color: #fff; background: rgba(255,255,255,.1); }
.sidebar-user .btn-logout svg { width: 18px; height: 18px; }

/* --------- CONTEÚDO PRINCIPAL --------- */
.main-wrapper {
  margin-left: var(--sidebar-w);
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
}

/* --------- HEADER --------- */
.header {
  height: var(--header-h);
  background: var(--branco);
  border-bottom: 1px solid var(--cinza-borda);
  display: flex;
  align-items: center;
  padding: 0 1.8rem;
  gap: 1rem;
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
}

.header-title {
  flex: 1;
  font-family: 'Sora', sans-serif;
  font-size: 1.2rem;
  color: var(--azul);
  font-weight: 600;
}

.header-relogio {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  line-height: 1.3;
  margin-right: .5rem;
}
#relogio-hora {
  font-family: 'Sora', sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--azul);
  letter-spacing: .04em;
}
#relogio-data {
  font-size: .72rem;
  color: var(--cinza-texto);
}
.header-actions { display: flex; align-items: center; gap: .5rem; }

/* Olho global */
.btn-olho {
  background: none;
  border: none;
  cursor: pointer;
  padding: .45rem;
  border-radius: 50%;
  color: var(--cinza-texto);
  transition: var(--trans);
  display: flex;
  align-items: center;
  position: relative;
}
.btn-olho:hover { background: var(--fundo); color: var(--azul); }
.btn-olho svg { width: 20px; height: 20px; }
.btn-olho .olho-tooltip {
  position: absolute;
  bottom: -30px; left: 50%;
  transform: translateX(-50%);
  background: #333;
  color: #fff;
  font-size: .7rem;
  padding: 3px 8px;
  border-radius: 4px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s;
}
.btn-olho:hover .olho-tooltip { opacity: 1; }

/* Sino de notificações */
.btn-notif {
  background: none;
  border: none;
  cursor: pointer;
  padding: .45rem;
  border-radius: 50%;
  color: var(--cinza-texto);
  transition: var(--trans);
  display: flex;
  align-items: center;
  position: relative;
}
.btn-notif:hover { background: var(--fundo); color: var(--azul); }
.btn-notif svg { width: 20px; height: 20px; }

.notif-badge {
  position: absolute;
  top: 2px; right: 2px;
  background: var(--vermelho);
  color: #fff;
  font-size: .6rem;
  font-weight: 700;
  min-width: 16px; height: 16px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  padding: 0 3px;
  border: 2px solid #fff;
}
.notif-badge.hidden { display: none; }

/* Dropdown notificações */
.notif-dropdown {
  position: absolute;
  top: calc(var(--header-h) - 4px);
  right: 1.8rem;
  width: 340px;
  background: var(--branco);
  border: 1px solid var(--cinza-borda);
  border-radius: var(--radius);
  box-shadow: var(--sombra-md);
  z-index: 300;
  display: none;
}
.notif-dropdown.open { display: block; }
.notif-dropdown-header {
  padding: .9rem 1.1rem;
  border-bottom: 1px solid var(--cinza-borda);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.notif-dropdown-header span { font-weight: 600; font-size: .9rem; color: var(--azul); }
.notif-dropdown-header a { font-size: .78rem; color: var(--cinza-texto); }
.notif-dropdown-header a:hover { color: var(--azul); }

.notif-list { max-height: 320px; overflow-y: auto; }
.notif-item {
  padding: .75rem 1.1rem;
  border-bottom: 1px solid #f0f0f0;
  cursor: pointer;
  transition: var(--trans);
}
.notif-item:hover { background: #fafafa; }
.notif-item.nao-lida { background: #f0f6ea; }
.notif-item.nao-lida:hover { background: #e8f0e0; }
.notif-item .notif-titulo { font-size: .85rem; font-weight: 600; color: #333; }
.notif-item .notif-msg { font-size: .78rem; color: var(--cinza-texto); margin-top: 2px; }
.notif-item .notif-data { font-size: .7rem; color: #aaa; margin-top: 4px; }
.notif-empty {
  padding: 1.5rem;
  text-align: center;
  color: #aaa;
  font-size: .85rem;
}

/* --------- ÁREA DE CONTEÚDO --------- */
.content-area {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 2rem 1.8rem;
}
.content-area > *:not(.modal-overlay):not(.btn-flutuante) {
  width: 100%;
  max-width: 1350px;
}

/* ============================================================
   COMPONENTES GERAIS
   ============================================================ */

/* Cards */
.card {
  background: var(--branco);
  border-radius: var(--radius);
  box-shadow: var(--sombra);
  padding: 1.5rem;
  margin-bottom: 1.5rem;
}
.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.2rem;
  padding-bottom: .8rem;
  border-bottom: 1px solid var(--cinza-borda);
}
.card-title {
  font-family: 'Sora', sans-serif;
  font-size: 1.05rem;
  color: var(--azul);
  font-weight: 600;
}

/* Botões */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .52rem 1.1rem;
  border-radius: var(--radius);
  border: none;
  font-family: 'Inter', sans-serif;
  font-size: .88rem;
  font-weight: 600;
  cursor: pointer;
  transition: var(--trans);
  text-decoration: none;
  line-height: 1.4;
}
.btn svg { width: 16px; height: 16px; }

.btn-primary { background: var(--azul); color: #fff; }
.btn-primary:hover { background: var(--azul-dark); color: #fff; }

.btn-success { background: var(--verde-gaia); color: var(--azul); }
.btn-success:hover { background: var(--verde-gaia-dark); color: var(--azul); }

.btn-danger { background: var(--vermelho); color: #fff; }
.btn-danger:hover { background: #a93226; color: #fff; }

.btn-outline {
  background: transparent;
  border: 1.5px solid var(--azul);
  color: var(--azul);
}
.btn-outline:hover { background: var(--azul); color: #fff; }

.btn-sm { padding: .35rem .75rem; font-size: .8rem; }
.btn-lg { padding: .75rem 1.6rem; font-size: 1rem; }

/* Formulários */
.form-group { margin-bottom: 1.1rem; }
.form-label {
  display: block;
  font-size: .83rem;
  font-weight: 600;
  color: var(--azul);
  margin-bottom: .35rem;
  text-transform: uppercase;
  letter-spacing: .4px;
}
.form-control {
  width: 100%;
  padding: .6rem .9rem;
  border: 1.5px solid var(--cinza-borda);
  border-radius: var(--radius);
  background: #fff;
  color: #2c2c2c;
  transition: var(--trans);
  font-size: .92rem;
}
.form-control:focus {
  outline: none;
  border-color: var(--verde-gaia);
  box-shadow: 0 0 0 3px rgba(186,217,113,.7);
}
.form-control.is-invalid { border-color: var(--vermelho); }
.form-control.is-invalid:focus { box-shadow: 0 0 0 3px rgba(192,57,43,.2); }

.form-error { font-size: .78rem; color: var(--vermelho); margin-top: .3rem; }
.form-hint  { font-size: .78rem; color: #888; margin-top: .3rem; }

/* Alertas */
.alert {
  padding: .85rem 1.1rem;
  border-radius: var(--radius);
  font-size: .88rem;
  margin-bottom: 1rem;
  display: flex;
  align-items: flex-start;
  gap: .6rem;
}
.alert svg { width: 18px; height: 18px; flex-shrink: 0; margin-top: 1px; }
.alert-success { background: #edf7e6; color: #2d6a1e; border: 1px solid #b8e0a0; }
.alert-danger   { background: #fdecea; color: #8b1a1a; border: 1px solid #f5b8b2; }
.alert-warning  { background: #fef8e7; color: #7a5a00; border: 1px solid #f5e0a0; }
.alert-info     { background: #e8f4fd; color: #145480; border: 1px solid #a8d4f5; }

/* Badges */
.badge {
  display: inline-flex;
  align-items: center;
  padding: .2rem .6rem;
  border-radius: 20px;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .3px;
}
.badge-success  { background: #edf7e6; color: #2d6a1e; }
.badge-danger   { background: #fdecea; color: var(--vermelho); }
.badge-warning  { background: #fef8e7; color: #b06800; }
.badge-info     { background: #e8f4fd; color: #145480; }
.badge-secondary{ background: #f0f0f0; color: #555; }

/* Tabelas */
.table-wrapper { overflow-x: auto; }
table.gaia-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .88rem;
}
.gaia-table thead tr {
  background: var(--azul);
  color: #fff;
}
.gaia-table thead th {
  padding: .7rem 1rem;
  text-align: left;
  font-weight: 600;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .5px;
  white-space: nowrap;
}
.gaia-table tbody tr { transition: var(--trans); }
.gaia-table tbody tr:nth-child(even) { background: var(--verde-gaia); }
.gaia-table tbody tr:hover { background: var(--verde-gaia-dark); }

/* Tabela clientes ativos — zebra verde, sem efeito de hover, underline no nome */
.gaia-table-ativos tbody tr:nth-child(even) { background: var(--verde-gaia); }
.gaia-table-ativos tbody tr:nth-child(odd):hover  { background: transparent; }
.gaia-table-ativos tbody tr:nth-child(even):hover { background: var(--verde-gaia); }
.gaia-table-ativos tbody tr:hover .dash-nome-link { text-decoration: underline; }

/* Tabela clientes arquivados — zebra cinza, sem efeito de hover, underline no nome */
.gaia-table-arquivados tbody tr:nth-child(even) { background: #e8e8e8; }
.gaia-table-arquivados tbody tr:nth-child(odd):hover  { background: transparent; }
.gaia-table-arquivados tbody tr:nth-child(even):hover { background: #e8e8e8; }
.gaia-table-arquivados tbody tr:hover .dash-nome-link { text-decoration: underline; }

/* Link de nome nas tabelas do dashboard */
.dash-nome-link { color: inherit; text-decoration: none; }
.gaia-table tbody td { padding: .65rem 1rem; border-bottom: 1px solid #f0f0f0; vertical-align: middle; }

/* Ícones SVG sprite */
.icon {
  display: inline-block;
  vertical-align: middle;
  flex-shrink: 0;
  pointer-events: none;
}

/* Valor protegido */
.valor-protegido {
  filter: blur(5px);
  user-select: none;
  transition: filter .2s;
  cursor: pointer;
  display: inline-block;
}
.valor-protegido:hover { filter: blur(0); }
body.valores-visiveis .valor-protegido { filter: blur(0); cursor: default; }

/* Modal */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(4px);
  z-index: 1000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.modal-overlay.open { display: flex; }
.modal {
  background: var(--branco);
  border-radius: var(--radius);
  box-shadow: var(--sombra-md);
  width: 100%;
  max-width: 480px;
  animation: modalIn .2s ease;
}
@keyframes modalIn {
  from { transform: scale(.95); opacity: 0; }
  to   { transform: scale(1);   opacity: 1; }
}
.modal-header {
  padding: 1.1rem 1.4rem;
  border-bottom: 1px solid var(--cinza-borda);
  display: flex; align-items: center; justify-content: space-between;
}
.modal-title { font-family: 'Sora', sans-serif; font-size: 1.05rem; color: var(--azul); }
.modal-close {
  background: none; border: none; cursor: pointer;
  color: #aaa; font-size: 1.3rem; line-height: 1; padding: .2rem;
  transition: var(--trans);
}
.modal-close:hover { color: var(--vermelho); }
.modal-body { padding: 1.3rem 1.4rem; }
.modal-footer {
  padding: .9rem 1.4rem;
  border-top: 1px solid var(--cinza-borda);
  display: flex; justify-content: flex-end; gap: .6rem;
}

/* Toast / feedback */
.toast-container {
  position: fixed;
  bottom: 1.5rem; right: 1.5rem;
  z-index: 2000;
  display: flex;
  flex-direction: column;
  gap: .5rem;
  pointer-events: none;
}
.toast {
  background: #333;
  color: #fff;
  padding: .75rem 1.1rem;
  border-radius: var(--radius);
  font-size: .88rem;
  box-shadow: var(--sombra-md);
  display: flex;
  align-items: center;
  gap: .6rem;
  max-width: 320px;
  animation: toastIn .25s ease;
  pointer-events: all;
}
.toast svg { width: 18px; height: 18px; flex-shrink: 0; }
.toast.success { background: #2d6a1e; }
.toast.error   { background: var(--vermelho); }
.toast.warning { background: #b06800; }
@keyframes toastIn {
  from { transform: translateX(60px); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}

/* Spinner */
.spinner {
  width: 20px; height: 20px;
  border: 2.5px solid rgba(255,255,255,.4);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin .7s linear infinite;
  display: inline-block;
}
.spinner.dark {
  border-color: rgba(20,70,95,.25);
  border-top-color: var(--azul);
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Paginação */
.pagination { display: flex; gap: .35rem; margin-top: 1.2rem; flex-wrap: wrap; }
.page-btn {
  padding: .4rem .75rem;
  border: 1.5px solid var(--cinza-borda);
  border-radius: var(--radius);
  background: var(--branco);
  color: var(--azul);
  font-size: .83rem;
  font-weight: 600;
  cursor: pointer;
  transition: var(--trans);
}
.page-btn:hover, .page-btn.active {
  background: var(--azul);
  border-color: var(--azul);
  color: #fff;
}
.page-btn:disabled { opacity: .4; cursor: not-allowed; }

/* Seção colapsável */
.colapsavel .colapsavel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  user-select: none;
  padding: .9rem 1.2rem;
  background: var(--branco);
  border-radius: var(--radius);
  box-shadow: var(--sombra);
  margin-bottom: .5rem;
}
.colapsavel .colapsavel-header h3 {
  font-size: .98rem;
  font-weight: 600;
  color: #2a2a2a;
  display: flex; align-items: center; gap: .5rem;
}
.colapsavel .colapsavel-chevron {
  transition: transform .25s;
  color: var(--cinza-texto);
}
.colapsavel.aberto .colapsavel-chevron { transform: rotate(180deg); }
.colapsavel-body {
  display: none;
  padding: .2rem 0 .8rem;
}
.colapsavel.aberto .colapsavel-body { display: block; }
.colapsavel-body .table-wrapper { max-height: 400px; overflow-y: auto; }
.secao-carregando { padding: 2rem; text-align: center; color: #888; font-size: .9rem; }

/* ---- Grid dashboard ---- */
.dashboard-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
  align-items: start;
}
@media (max-width: 900px) {
  .dashboard-grid { grid-template-columns: 1fr; }
}
.dashboard-col-pag [data-secao] {
  display: flex;
  flex-direction: column;
  gap: 1.4rem;
}

/* ---- Widget pagamentos ---- */
.pag-secao-header {
  display: flex; align-items: center; gap: .4rem;
  padding: .6rem 1rem;
  background: #d9e8f5;
  font-size: .85rem; font-weight: 600; color: var(--azul);
  border-bottom: 1px solid var(--cinza-borda);
}
.pag-secao-atraso {
  background: #fdecea; color: var(--vermelho);
  cursor: pointer; user-select: none;
}
.pag-chevron { transition: transform .2s; }
.pag-lista-atraso { max-height: 280px; overflow-y: auto; }
.pag-lista-fechada .pag-row-atraso,
.pag-lista-fechada .pag-vazio { display: none; }
.pag-lista-fechada .pag-row-atraso:first-child { display: none; }
.pag-row {
  display: flex; align-items: center; gap: .8rem;
  padding: .5rem 1rem;
  border-bottom: 1px solid var(--cinza-borda);
  font-size: .83rem;
}
.pag-row:last-child { border-bottom: none; }
.pag-data { font-weight: 600; min-width: 95px; white-space: nowrap; color: var(--azul); display: flex; align-items: center; gap: .25rem; }
.pag-info { flex: 1; color: var(--texto); }
.pag-info small { color: #999; }
.pag-valor { white-space: nowrap; font-size: .8rem; }
.pag-row-atraso { background: #fff5f5; }
.pag-row-atraso .pag-data { color: var(--vermelho); }
.pag-vazio { padding: .8rem 1rem; color: #888; font-size: .83rem; }

/* ============================================================
   LOGIN
   ============================================================ */
.login-page {
  min-height: 100vh;
  background: linear-gradient(135deg, var(--azul) 0%, var(--azul-light) 60%, #1e7a6e 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
}

.login-card {
  background: var(--branco);
  border-radius: 12px;
  box-shadow: 0 8px 40px rgba(0,0,0,.25);
  width: 100%;
  max-width: 420px;
  padding: 2.5rem 2.2rem;
}

.login-logo {
  text-align: center;
  margin-bottom: 2rem;
}
.login-logo .logo-circulo {
  width: 64px; height: 64px;
  background: var(--verde-gaia);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: .8rem;
  box-shadow: 0 4px 12px rgba(186,217,113,.5);
}
.login-logo .logo-circulo svg { width: 34px; height: 34px; fill: var(--azul); }
.login-logo h1 {
  font-size: 1.8rem;
  color: var(--azul);
  font-weight: 700;
  letter-spacing: .5px;
}
.login-logo p {
  font-size: .78rem;
  color: #888;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  margin-top: .2rem;
}

.login-footer {
  text-align: center;
  margin-top: 1.5rem;
  font-size: .8rem;
  color: #aaa;
}

/* Input com ícone de senha */
.input-senha-wrap { position: relative; }
.input-senha-wrap .form-control { padding-right: 2.8rem; }
.btn-toggle-senha {
  position: absolute;
  right: .7rem; top: 50%;
  transform: translateY(-50%);
  background: none; border: none;
  cursor: pointer; color: #aaa;
  display: flex; align-items: center;
  transition: var(--trans);
}
.btn-toggle-senha:hover { color: var(--azul); }
.btn-toggle-senha svg { width: 18px; height: 18px; }

/* Botão flutuante */
.btn-flutuante {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--azul);
  color: #fff;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(20,70,95,.4);
  transition: var(--trans);
  z-index: 500;
}
.btn-flutuante:hover {
  background: var(--azul-dark);
  transform: scale(1.08);
  box-shadow: 0 6px 20px rgba(20,70,95,.5);
}

/* Utilitários */
.hidden { display: none !important; }
.text-danger      { color: var(--vermelho) !important; }
.text-success     { color: #2d6a1e !important; }
.text-success-dark{ color: #27ae60 !important; }
.text-muted       { color: #888 !important; }
.text-muted-light { color: #ccc !important; }
.text-light       { color: #ddd !important; }
.text-primary     { color: var(--azul) !important; }
.text-sm          { font-size: .85rem; }
.text-xs          { font-size: .82rem; }
.text-nowrap      { white-space: nowrap; }
.text-center      { text-align: center; }
.text-right       { text-align: right; }
.fw-bold          { font-weight: 700; }
.fw-500           { font-weight: 500; }
.overflow-x       { overflow-x: auto; }
.pos-rel          { position: relative; }
.resize-v         { resize: vertical; }
.cursor-default   { cursor: default; }
.m-0   { margin: 0; }
.mt-0  { margin-top: 0; }
.mt-1  { margin-top: .5rem; }
.mt-2  { margin-top: 1rem; }
.mt-3  { margin-top: 1.2rem; }
.mt-4  { margin-top: 1.5rem; }
.mb-0  { margin-bottom: 0 !important; }
.mb-1  { margin-bottom: .5rem; }
.mb-2  { margin-bottom: 1rem; }
.mb-3  { margin-bottom: 1.2rem; }
.mb-4  { margin-bottom: 1.5rem; }
.ml-xs { margin-left: .25rem; }
.ml-1  { margin-left: .4rem; }
.p-0-oh        { padding: 0; overflow: hidden; }
.p-card        { padding: 1.4rem 1.6rem; }
.p-card-inner  { padding: .9rem 1.2rem; }
.pl-icon       { padding-left: 2.5rem; }
.col-full      { grid-column: 1 / -1; }
.grid-2        { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.flex-between  { display: flex; align-items: center; justify-content: space-between; }
.flex-between-wrap { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.flex-end-gap  { display: flex; gap: .8rem; justify-content: flex-end; }
.w-100px { width: 100px; }
.w-110   { width: 110px; }
.w-130   { width: 130px; }
.w-160   { width: 160px; }
/* Links */
.link-muted        { color: #888; font-size: .85rem; text-decoration: none; }
.link-muted:hover  { color: var(--azul); }
.link-primary      { color: var(--azul); text-decoration: none; }
.link-primary:hover{ text-decoration: underline; }
.link-primary-bold { color: var(--azul); font-weight: 500; text-decoration: none; }
.link-primary-bold:hover { text-decoration: underline; }
/* Elementos estruturais comuns */
.section-title   { font-size: 1.3rem; color: var(--azul); margin: 0; }
.card-hdr        { padding: .9rem 1.2rem; border-bottom: 1px solid var(--cinza-borda); font-weight: 600; font-size: .9rem; color: #333; }
.card-hdr-mb     { margin-bottom: 1rem; padding: .9rem 1.2rem; border-bottom: 1px solid var(--cinza-borda); font-weight: 600; font-size: .9rem; color: #333; }
.form-section-title { margin: 0 0 1rem; font-family: 'Sora', sans-serif; font-size: 1rem; color: #14465f; }
.field-hint      { font-size: .9rem; color: #555; margin-top: .35rem; }
.field-hint-sm   { font-size: .82rem; color: #888; margin: .2rem 0 0; }
.ml-form-info    { margin: .4rem 0 0 1.2rem; }
.empty-state     { text-align: center; color: #aaa; padding: 2rem; font-size: .88rem; }
.input-icon-abs  { position: absolute; left: .8rem; top: 50%; transform: translateY(-50%); color: #aaa; line-height: 0; }
.btn-xs          { font-size: .85rem; padding: .35rem .8rem; }
.btn-xxs         { font-size: .8rem;  padding: .3rem .8rem; }
.mt-sm { margin-top: .8rem; }
.mw-120 { max-width: 120px; }
.mw-520 { max-width: 520px; }
.mw-540 { max-width: 540px; }
.w-70  { width: 70px; }
.w-52  { width: 52px; }
.w-36  { width: 36px; }
.w-full { width: 100%; }
.bg-light   { background: #f5f5f5; }
.text-sm-dark { font-size: .9rem; color: #555; }
.text-xxs   { font-size: .76rem; color: #aaa; }
.hint-xxs   { font-size: .8rem; color: #aaa; margin-top: .25rem; }
.text-warning { color: var(--amarelo, #e6a817) !important; }
.disabled-look { pointer-events: none; opacity: .7; }
.flex-no-shrink { flex-shrink: 0; }
.logo-preview   { max-height: 72px; max-width: 200px; object-fit: contain; margin-bottom: .6rem; }
.text-light-sm  { color: #aaa; font-size: .82rem; }
.text-muted-xs  { color: #888; font-size: .78rem; }
.link-inherit   { color: inherit; text-decoration: none; }
.flex-gap-5     { display: flex; gap: .5rem; flex-wrap: wrap; }
.flex-gap-6     { display: flex; gap: .6rem; }
.flex-gap-7     { display: flex; gap: .7rem; flex-wrap: wrap; }
.flex-gap-15    { display: flex; gap: 1.5rem; flex-wrap: wrap; align-items: flex-start; }
.flex-between-sm { display: flex; align-items: center; justify-content: space-between; margin-bottom: .8rem; }
.flex-between-mb4 { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.5rem; }
.flex-between-wrap-mb3 { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: .7rem; margin-bottom: 1.4rem; }
.flex-center-gap { display: flex; align-items: center; gap: .5rem; }
.grid-2-mt2     { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 1rem; }
.grid-2-mb3     { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; margin-bottom: 1.2rem; }
.empty-muted    { color: #999; text-align: center; padding: 2rem; }
.badge-cinza    { background: var(--cinza-medio); color: #fff; border-radius: 10px; padding: 2px 8px; font-size: .78rem; }
.badge-warning  { background: #fef3c7; color: #92400e; }

/* Ícones inline do dashboard (lista ativos/arquivados + busca) */
.dash-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #888;
  text-decoration: none;
  border-radius: 4px;
  padding: 2px 3px;
  transition: color .15s, background .15s;
  vertical-align: middle;
}
.dash-ico:hover { color: var(--azul); background: rgba(20,100,140,.07); }
.dash-ico-copy { cursor: pointer; }

/* Controle de caixa */
.caixa-card {
  overflow: hidden;
}
.caixa-titulo {
  background: #c8c8c8;
  text-align: center;
  font-size: .82rem;
  font-weight: 600;
  color: #555;
  padding: .45rem .8rem;
  border-bottom: 1px solid var(--cinza-borda);
}
.caixa-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.caixa-cel {
  padding: .55rem .8rem;
  text-align: center;
}
.caixa-cel + .caixa-cel { border-left: 1px solid var(--cinza-borda); }
.caixa-entrada { background: var(--verde-gaia); }
.caixa-receber { background: #fff; }
.caixa-label {
  font-size: .75rem;
  font-weight: 600;
  color: #555;
  margin-bottom: .25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .25rem;
}
.caixa-valor { font-size: .92rem; font-weight: 700; color: var(--azul); }

/* Resultado de busca — altura fixa com scroll */
.busca-resultado-scroll {
  max-height: 320px;
  overflow-y: auto;
  border-radius: var(--radius);
  border: 1px solid var(--cinza-borda);
}
.busca-resultado-scroll .gaia-table { min-width: 0; }
@media (max-width: 640px) {
  .busca-resultado-scroll { max-height: 260px; }
  .busca-resultado-scroll .col-cpf { display: none; }
}

/* ============================================================
   RESPONSIVO
   ============================================================ */
.btn-hamburger {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--azul);
  padding: .3rem;
  line-height: 0;
  flex-shrink: 0;
}
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.4);
  z-index: 149;
}
.sidebar-overlay.active { display: block; }

@media (max-width: 768px) {
  :root { --sidebar-w: 0px; }

  .btn-hamburger { display: flex; align-items: center; }

  .sidebar {
    transform: translateX(-260px);
    width: 260px;
    transition: transform .25s ease;
  }
  .sidebar.mobile-open {
    transform: translateX(0);
  }
  .main-wrapper { margin-left: 0; }
  .content-area { padding: 1.2rem 1rem; }
  .notif-dropdown { right: .5rem; width: calc(100vw - 1rem); }
}

/* ============================================================
   TABS
   ============================================================ */
.tab-nav { display:flex; gap:0; border-bottom:2px solid var(--cinza-borda); margin-bottom:1.25rem; }
.tab-nav a { padding:.52rem 1.1rem; font-size:.875rem; color:var(--cinza-texto); text-decoration:none; position:relative; transition:color .15s; white-space:nowrap; }
.tab-nav a:hover { color:var(--azul); }
.tab-nav a.active { color:var(--azul); font-weight:600; }
.tab-nav a.active::after { content:''; position:absolute; bottom:-2px; left:0; right:0; height:2px; background:var(--azul); }
.tab-count { display:inline-block; background:#e8e8e8; border-radius:10px; padding:1px 6px; font-size:.72rem; margin-left:.3rem; font-weight:500; color:#555; }
.tab-count.verde { background:rgba(45,106,30,.15); color:#2d6a1e; }
.tab-count.vermelho { background:rgba(192,57,43,.12); color:var(--vermelho); }

/* ============================================================
   FORM GRID
   ============================================================ */
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-grid .form-group { margin-bottom:0; }
.form-grid .g-span-2 { grid-column:span 2; }
@media (max-width:600px) { .form-grid { grid-template-columns:1fr; } .form-grid .g-span-2 { grid-column:span 1; } }

/* ============================================================
   DETALHE DE REGISTRO
   ============================================================ */
.detalhe-secao-titulo { font-size:.78rem; text-transform:uppercase; letter-spacing:.8px; color:var(--azul); font-weight:700; padding-bottom:.5rem; border-bottom:1px solid var(--cinza-borda); margin-bottom:.9rem; display:flex; align-items:center; gap:.4rem; }
.detalhe-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:.7rem 1.5rem; }
.detalhe-campo label { font-size:.72rem; text-transform:uppercase; letter-spacing:.4px; color:#999; display:block; margin-bottom:.2rem; }
.detalhe-campo span { font-size:.9rem; color:#2c2c2c; font-weight:500; }
.detalhe-campo span.vazio { color:#bbb; font-weight:400; }

/* ============================================================
   PARCELAS — tabela + cards mobile
   ============================================================ */
/* Form gerar parcelas */
.parc-form-gerar {
  display: grid;
  grid-template-columns: 1fr 130px 150px auto;
  gap: .7rem;
  align-items: end;
}
@media (max-width: 640px) {
  .parc-form-gerar {
    grid-template-columns: 1fr 1fr;
  }
  .parc-form-gerar button[type=submit] { grid-column: span 2; }
}

/* Resumo de parcelas */
.parc-resumo {
  display: grid;
  grid-template-columns: repeat(4, 1fr) 1.3fr 1.3fr 1.3fr;
  gap: .6rem;
  margin-bottom: 1.2rem;
}
.parc-resumo-item {
  background: #fff;
  border: 1px solid var(--cinza-borda);
  border-radius: 10px;
  padding: .75rem 1rem;
  text-align: center;
}
.parc-res-valor {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
  color: var(--azul);
}
.parc-res-label {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .4px;
  color: #999;
  margin-top: .25rem;
}
.parc-res-sub { font-size: .7rem; color: #bbb; display: block; }
.parc-res-pago    .parc-res-valor { color: #2a7d2e; }
.parc-res-atraso  .parc-res-valor { color: #c53030; }
.parc-res-pendente .parc-res-valor { color: #b06800; }
/* Itens financeiros */
.parc-res-fin { text-align: left; }
.parc-res-fin .parc-res-label { margin-top: 0; margin-bottom: .3rem; }
.parc-res-fin-val { font-size: .95rem; font-weight: 700; color: #333; }
.parc-res-fin.parc-res-pago   .parc-res-fin-val { color: #2a7d2e; }
.parc-res-fin.parc-res-atraso .parc-res-fin-val { color: #c53030; }
@media (max-width: 860px) {
  .parc-resumo { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .parc-resumo { grid-template-columns: 1fr 1fr; }
  .parc-res-fin { text-align: center; }
}

/* Linha colorida por status */
.parc-row-pago    td { background: #f0faf2 !important; }
.parc-row-parcial td { background: #fffbee !important; }
.parc-row-atraso  td { background: #fff4f4 !important; }
.parc-row-atraso  td:nth-child(2) { color: #c53030; font-weight: 600; }

/* Número da parcela */
.parc-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--azul);
  color: #fff;
  font-size: .78rem;
  font-weight: 700;
  flex-shrink: 0;
}
.parc-row-pago    .parc-num { background: #2a7d2e; }
.parc-row-parcial .parc-num { background: #b06800; }
.parc-row-atraso  .parc-num { background: #c53030; }

/* Vazio */
.parc-vazio { color: #ccc; }

/* Botões de ação inline */
.parc-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px; height: 30px;
  border: 1px solid var(--cinza-borda);
  border-radius: 6px;
  background: #fff;
  color: #555;
  cursor: pointer;
  transition: var(--trans);
  padding: 0;
}
.parc-btn:hover { border-color: var(--azul); color: var(--azul); background: #f0f6fa; }
.parc-btn-danger:hover { border-color: #c53030; color: #c53030; background: #fff4f4; }

/* Desktop: esconde cards, mostra tabela */
.parc-table-wrap { display: block; }
.parc-cards      { display: none; }

/* Mobile: esconde tabela, mostra cards */
@media (max-width: 700px) {
  .parc-table-wrap { display: none; }
  .parc-cards { display: flex; flex-direction: column; gap: .75rem; margin-bottom: 1.2rem; }

  .parc-card {
    background: #fff;
    border: 1px solid var(--cinza-borda);
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 1px 4px rgba(0,0,0,.06);
  }
  .parc-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .65rem .9rem;
    border-bottom: 1px solid var(--cinza-borda);
    background: #f8f9fa;
  }
  .parc-card-body {
    padding: .7rem .9rem;
    display: flex;
    flex-direction: column;
    gap: .4rem;
  }
  .parc-card-row {
    display: flex;
    justify-content: space-between;
    font-size: .88rem;
  }
  .parc-card-row span { color: #888; }
  .parc-card-actions {
    display: flex;
    gap: .5rem;
    padding: .6rem .9rem;
    border-top: 1px solid var(--cinza-borda);
    background: #f8f9fa;
  }
  .parc-card-row strong .valor-protegido { display: inline; }

  /* cores nos cards */
  .parc-row-pago    .parc-card-top { background: #f0faf2; }
  .parc-row-parcial .parc-card-top { background: #fffbee; }
  .parc-row-atraso  .parc-card-top { background: #fff4f4; }
  .parc-row-atraso  .parc-card-row:first-child strong { color: #c53030; }
}
.detalhe-campo.g-span-2 { grid-column:span 2; }

/* ============================================================
   TOGGLE OCULTAR ATRASO (ficha do cliente)
   ============================================================ */
.toggle-atraso-btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .3rem .75rem .3rem .5rem;
  border: 1px solid var(--cinza-borda);
  border-radius: 20px;
  background: #fff;
  cursor: pointer;
  font-size: .8rem;
  font-weight: 500;
  color: #888;
  transition: border-color .2s, color .2s, background .2s;
  white-space: nowrap;
  font-family: inherit;
}
.toggle-atraso-btn:hover {
  border-color: #f59e0b;
  color: #b45309;
  background: #fffbeb;
}
.toggle-atraso-btn.ativo {
  border-color: #f59e0b;
  color: #b45309;
  background: #fffbeb;
}

/* Track do switch */
.toggle-atraso-track {
  position: relative;
  display: inline-block;
  width: 28px;
  height: 16px;
  border-radius: 8px;
  background: #d1d5db;
  transition: background .2s;
  flex-shrink: 0;
}
.toggle-atraso-thumb {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.2);
  transition: transform .2s;
}
.toggle-atraso-btn.ativo .toggle-atraso-track { background: #f59e0b; }
.toggle-atraso-btn.ativo .toggle-atraso-thumb { transform: translateX(12px); }

/* Ícone do modal de feedback */
.modal-ocultar-icon {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto .5rem;
}
.modal-ocultar-icon.oculto  { background: #fffbeb; color: #f59e0b; }
.modal-ocultar-icon.visivel { background: #f0faf2; color: #2a7d2e; }

/* ============================================================
   AJUDA / FAQ
   ============================================================ */
.ajuda-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
  gap: .7rem;
}

/* Busca */
.ajuda-busca-wrap {
  margin-bottom: 1.75rem;
}
.ajuda-busca-inner {
  position: relative;
  max-width: 640px;
}
.ajuda-busca-icone {
  position: absolute;
  left: .9rem;
  top: 50%;
  transform: translateY(-50%);
  color: #aaa;
  pointer-events: none;
}
.ajuda-busca-input {
  width: 100%;
  padding: .75rem 2.8rem .75rem 2.6rem;
  border: 2px solid var(--cinza-borda);
  border-radius: 10px;
  font-size: 1rem;
  font-family: inherit;
  color: #333;
  background: #fff;
  transition: border-color .2s;
  box-sizing: border-box;
}
.ajuda-busca-input:focus {
  outline: none;
  border-color: var(--azul);
}
.ajuda-busca-limpar {
  position: absolute;
  right: .7rem;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  color: #aaa;
  padding: .2rem;
  line-height: 1;
  border-radius: 4px;
}
.ajuda-busca-limpar:hover { color: #555; }

/* Categorias */
.ajuda-cat {
  margin-bottom: 1rem;
  border: 1px solid var(--cinza-borda);
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
}
.ajuda-cat-header {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .85rem 1.1rem;
  font-weight: 700;
  font-size: .9rem;
  color: var(--azul);
  background: #f5f8fa;
  border-bottom: 1px solid var(--cinza-borda);
  cursor: pointer;
  user-select: none;
  transition: background .15s;
  letter-spacing: .2px;
}
.ajuda-cat-header:hover { background: #eaf1f5; }
.ajuda-lista {
  display: none;
}
.ajuda-cat.aberta .ajuda-lista { display: block; }

/* Perguntas e Respostas */
.ajuda-item {
  border-bottom: 1px solid #f0f0f0;
}
.ajuda-item:last-child { border-bottom: none; }

.ajuda-q {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .85rem 1.1rem;
  background: none;
  border: none;
  text-align: left;
  font-size: .9rem;
  font-weight: 500;
  color: #2c2c2c;
  cursor: pointer;
  transition: background .15s;
  font-family: inherit;
}
.ajuda-q:hover { background: #f8fbfd; }
.ajuda-q[aria-expanded="true"] { color: var(--azul); background: #f0f7fb; }

.ajuda-chevron {
  flex-shrink: 0;
  color: #aaa;
  transition: transform .2s;
}
.ajuda-q[aria-expanded="true"] .ajuda-chevron {
  transform: rotate(180deg);
  color: var(--azul);
}

.ajuda-a {
  padding: 0 1.1rem .9rem 1.1rem;
  animation: fadeIn .15s ease;
}
.ajuda-a p {
  margin: 0;
  font-size: .88rem;
  color: #444;
  line-height: 1.65;
}
.ajuda-a code {
  background: #f0f0f0;
  border-radius: 4px;
  padding: .1em .35em;
  font-size: .82rem;
  color: #c53030;
}
.ajuda-a mark {
  background: #fff176;
  color: inherit;
  border-radius: 2px;
  padding: 0 .1em;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (max-width: 640px) {
  .ajuda-busca-input { font-size: .9rem; }
  .ajuda-cat-header  { font-size: .85rem; }
  .ajuda-q           { font-size: .85rem; }
}

/* ===== ARQUIVOS / UPLOADS ===== */
.arq-upload-area {
  border: 2px dashed var(--border);
  border-radius: var(--radius);
  padding: 2rem 1.5rem;
  text-align: center;
  cursor: pointer;
  transition: border-color .2s, background .2s;
  background: var(--bg);
}
.arq-upload-area:hover,
.arq-drag-over {
  border-color: var(--primary);
  background: rgba(var(--primary-rgb, 59,130,246), .04);
}
.arq-upload-icon { color: var(--text-muted); margin-bottom: .5rem; }
.arq-upload-text { font-size: .95rem; color: var(--text); margin-bottom: .25rem; }
.arq-upload-link {
  color: var(--primary);
  cursor: pointer;
  text-decoration: underline;
  font-weight: 500;
}
.arq-upload-info { font-size: .8rem; color: var(--text-muted); }

.arq-preview {
  display: flex;
  align-items: center;
  gap: .75rem;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: .75rem 1rem;
}
.arq-preview-nome { flex: 1; font-weight: 500; font-size: .9rem; word-break: break-all; }
.arq-preview-size { font-size: .8rem; color: var(--text-muted); white-space: nowrap; }
.arq-preview-clear {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-muted);
  padding: .2rem;
  display: flex;
  align-items: center;
  border-radius: 4px;
  transition: color .15s, background .15s;
}
.arq-preview-clear:hover { color: var(--danger); background: rgba(239,68,68,.08); }

.arq-nome-link {
  color: var(--text);
  text-decoration: none;
  font-size: .88rem;
  word-break: break-all;
}
.arq-nome-link:hover { color: var(--primary); text-decoration: underline; }

/* ============================================================
   KANBAN
   ============================================================ */
.kan-board {
  display: flex;
  gap: 1rem;
  overflow-x: auto;
  padding-bottom: 1.25rem;
  align-items: flex-start;
  min-height: calc(100vh - 200px);
}

.kan-col {
  flex: 0 0 285px;
  width: 285px;
  background: #fff;
  border: 1px solid var(--cinza-borda);
  border-radius: var(--radius);
  display: flex;
  flex-direction: column;
  max-height: calc(100vh - 175px);
}

.kan-col-sem-fase {
  border-style: dashed;
  border-color: #ccc;
}
.kan-col-sem-fase .kan-col-header { background: #fafafa; }

.kan-col-header {
  padding: .65rem 1rem;
  border-bottom: 1px solid var(--cinza-borda);
  border-radius: var(--radius) var(--radius) 0 0;
  background: #f7f9fb;
  display: flex;
  align-items: center;
  gap: .5rem;
}

.kan-col-nome {
  flex: 1;
  font-weight: 700;
  font-size: .85rem;
  color: var(--azul);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.kan-col-nome-edit {
  flex: 1;
  background: none;
  border: none;
  border-bottom: 2px solid var(--azul);
  font-weight: 700;
  font-size: .85rem;
  color: var(--azul);
  padding: 0 2px;
  outline: none;
  font-family: inherit;
  min-width: 0;
}

.kan-col-count {
  background: var(--azul);
  color: #fff;
  border-radius: 999px;
  font-size: .68rem;
  font-weight: 700;
  padding: 2px 7px;
  flex-shrink: 0;
}

.kan-col-actions {
  display: flex;
  gap: .2rem;
  flex-shrink: 0;
  opacity: 0;
  transition: opacity .15s;
}
.kan-col-header:hover .kan-col-actions { opacity: 1; }

.kan-col-act-btn {
  background: none;
  border: none;
  cursor: pointer;
  color: #999;
  padding: 3px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  line-height: 1;
  transition: color .15s, background .15s;
}
.kan-col-act-btn:hover       { color: var(--azul);    background: rgba(20,70,95,.1); }
.kan-col-act-btn.danger:hover { color: var(--vermelho); background: #fdecea; }

.kan-col-body {
  flex: 1;
  overflow-y: auto;
  padding: .65rem;
  display: flex;
  flex-direction: column;
  gap: .55rem;
  min-height: 100px;
  transition: background .15s;
}
.kan-col-body.drag-over {
  background: rgba(20,70,95,.055);
  outline: 2px dashed var(--azul);
  outline-offset: -3px;
}

.kan-col-footer {
  padding: .45rem .9rem;
  border-top: 1px solid var(--cinza-borda);
  font-size: .72rem;
  color: #999;
  text-align: right;
}

/* Cards */
.kan-card {
  background: #fff;
  border: 1px solid #e4e8ed;
  border-radius: 6px;
  padding: .7rem .75rem;
  cursor: grab;
  transition: box-shadow .15s, border-color .15s;
  user-select: none;
}
.kan-card:hover       { box-shadow: 0 2px 8px rgba(0,0,0,.1); border-color: var(--azul); }
.kan-card.dragging    { opacity: .35; cursor: grabbing; }

.kan-card-tipo {
  font-size: .67rem;
  font-weight: 700;
  color: var(--azul);
  background: #eaf2f7;
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: .35rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  border-radius: 4px;
  padding: 2px 6px;
  display: inline-block;
  max-width: 100%;
}

.kan-card-cliente {
  font-size: .875rem;
  font-weight: 600;
  color: var(--azul);
  margin-bottom: .15rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: 1.35;
}
.kan-card-cliente a            { color: inherit; text-decoration: none; }
.kan-card-cliente a:hover      { text-decoration: underline; }

.kan-card-num {
  font-size: .7rem;
  color: #bbb;
  margin-bottom: .35rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.kan-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .3rem;
  flex-wrap: wrap;
  margin-top: .3rem;
}

.kan-card-adv {
  font-size: .7rem;
  color: #bbb;
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.kan-badge-atraso {
  background: #fdecea;
  color: var(--vermelho);
  border-radius: 999px;
  font-size: .65rem;
  font-weight: 700;
  padding: 2px 7px;
  flex-shrink: 0;
}

.kan-badge-proc {
  background: #eaf2f7;
  color: var(--azul);
  border-radius: 999px;
  font-size: .65rem;
  font-weight: 600;
  padding: 3px 8px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 3px;
  flex-shrink: 0;
  transition: background .15s, color .15s;
}
.kan-badge-proc:hover { background: var(--azul); color: #fff; }

/* Empty state dentro da coluna */
.kan-empty {
  padding: 1.5rem .75rem;
  text-align: center;
  color: #ccc;
  font-size: .78rem;
  font-style: italic;
  pointer-events: none;
}

/* Botão de nova coluna */
.kan-add-col {
  flex: 0 0 200px;
  padding-top: .25rem;
}
.kan-add-col-btn {
  width: 100%;
  background: none;
  border: 2px dashed var(--cinza-borda);
  border-radius: var(--radius);
  color: #aaa;
  font-size: .85rem;
  padding: .75rem 1rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  font-family: inherit;
  transition: border-color .15s, color .15s;
}
.kan-add-col-btn:hover { border-color: var(--azul); color: var(--azul); }

/* ============================================================
   PORTAL DO CLIENTE
   ============================================================ */

/* Layout */
.portal-wrapper {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.portal-header {
  background: var(--azul);
  color: #fff;
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: 0 2px 8px rgba(0,0,0,.15);
}

.portal-header-inner {
  max-width: 900px;
  margin: 0 auto;
  padding: .75rem 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.portal-header-left {
  display: flex;
  align-items: center;
  gap: .7rem;
}

.portal-logo {
  max-height: 38px;
  max-width: 120px;
  object-fit: contain;
}

.portal-brand {
  font-family: 'Sora', sans-serif;
  font-size: .9rem;
  font-weight: 600;
  color: rgba(255,255,255,.85);
  letter-spacing: .02em;
}

.portal-header-right {
  display: flex;
  align-items: center;
  gap: .7rem;
}

.portal-usuario-nome {
  font-size: .82rem;
  color: rgba(255,255,255,.75);
  display: flex;
  align-items: center;
  gap: .3rem;
}

.portal-header-link {
  color: rgba(255,255,255,.7);
  display: flex;
  align-items: center;
  gap: .3rem;
  font-size: .82rem;
  padding: .3rem .5rem;
  border-radius: 4px;
  transition: var(--trans);
}

.portal-header-link:hover {
  color: #fff;
  background: rgba(255,255,255,.12);
}

.portal-header-logout {
  border: 1px solid rgba(255,255,255,.25);
}

.portal-main {
  flex: 1;
  max-width: 900px;
  width: 100%;
  margin: 0 auto;
  padding: 1.5rem 1.25rem;
}

.portal-footer {
  text-align: center;
  padding: 1rem;
  font-size: .78rem;
  color: #bbb;
  border-top: 1px solid var(--cinza-borda);
  margin-top: 2rem;
}

/* Cards de processo */
.portal-proc-card {
  display: block;
  background: #fff;
  border: 1px solid var(--cinza-borda);
  border-radius: var(--radius);
  padding: .9rem 1.1rem;
  text-decoration: none;
  color: inherit;
  transition: var(--trans);
}

.portal-proc-card:hover {
  border-color: var(--azul);
  box-shadow: 0 2px 8px rgba(20,70,95,.1);
  color: inherit;
}

.portal-proc-top {
  display: flex;
  align-items: center;
  gap: .6rem;
  flex-wrap: wrap;
  margin-bottom: .35rem;
}

.portal-proc-tipo {
  font-family: 'Sora', sans-serif;
  font-weight: 600;
  font-size: .92rem;
  color: var(--azul);
}

.portal-proc-meta {
  font-size: .8rem;
  color: #888;
  margin-bottom: .4rem;
}

.portal-proc-badges {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin-top: .2rem;
}

.portal-badge-alerta {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  font-size: .75rem;
  padding: .2rem .55rem;
  border-radius: 12px;
  background: #fff5f5;
  color: var(--vermelho);
  border: 1px solid #ffd5d5;
}

.portal-badge-info {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  font-size: .75rem;
  padding: .2rem .55rem;
  border-radius: 12px;
  background: #f0f6fb;
  color: #555;
  border: 1px solid #d0e5f5;
}

/* Responsivo */
@media (max-width: 600px) {
  .portal-brand { display: none; }
  .portal-usuario-nome { display: none; }
  .portal-main { padding: 1rem .8rem; }
}

/* =====================================================
   NOTIFICAÇÕES — Página completa
   ===================================================== */

.notif-page-lista {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}

.notif-page-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  background: #fff;
  border: 1px solid var(--cinza-borda);
  border-radius: var(--radius);
  padding: .9rem 1.1rem;
  transition: var(--trans);
}

.notif-page-item.nao-lida {
  border-left: 3px solid var(--azul);
  background: #f4f8fb;
}

.notif-page-item.lida {
  opacity: .75;
}

.notif-page-body {
  flex: 1;
}

.notif-page-titulo {
  font-weight: 600;
  font-size: .92rem;
  color: var(--texto);
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: .3rem;
}

.notif-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--azul);
  flex-shrink: 0;
}

.notif-page-msg {
  font-size: .84rem;
  color: #666;
  line-height: 1.45;
  margin-bottom: .4rem;
}

.notif-page-data {
  font-size: .76rem;
  color: #bbb;
}

.notif-page-acoes {
  display: flex;
  gap: .4rem;
  flex-shrink: 0;
  padding-top: .1rem;
}

/* =====================================================
   INFORME DE RENDIMENTOS
   ===================================================== */

.informe-wrapper {
  max-width: 800px;
  background: #fff;
  border: 1px solid var(--cinza-borda);
  border-radius: var(--radius);
  padding: 2rem 2.5rem;
  margin-bottom: 1.5rem;
}

.informe-cabecalho {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  border-bottom: 2px solid var(--azul);
  padding-bottom: 1.2rem;
  margin-bottom: 1.5rem;
}

.informe-titulo-doc {
  font-family: 'Sora', sans-serif;
  font-weight: 700;
  font-size: 1.15rem;
  color: var(--azul);
  letter-spacing: .5px;
}

.informe-subtitulo {
  font-size: .85rem;
  color: #888;
  margin-top: .3rem;
}

.informe-ano-badge {
  font-family: 'Sora', sans-serif;
  font-weight: 700;
  font-size: 1.8rem;
  color: var(--azul);
  opacity: .18;
  line-height: 1;
}

.informe-partes {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-bottom: 1.8rem;
}

.informe-parte-label {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .8px;
  color: #aaa;
  text-transform: uppercase;
  margin-bottom: .35rem;
}

.informe-parte-nome {
  font-size: 1rem;
  font-weight: 600;
  color: var(--texto);
}

.informe-parte-doc {
  font-size: .83rem;
  color: #777;
  margin-top: .2rem;
}

.informe-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .88rem;
  margin-bottom: 1.5rem;
}

.informe-table th {
  background: var(--azul);
  color: #fff;
  padding: .6rem .8rem;
  font-weight: 600;
  font-size: .8rem;
  letter-spacing: .3px;
}

.informe-table td {
  padding: .55rem .8rem;
  border-bottom: 1px solid #f0f0f0;
  color: var(--texto);
}

.informe-table tbody tr:hover td {
  background: #f8fafb;
}

.informe-total-row td {
  background: #f0f6fb;
  border-top: 2px solid var(--azul);
  padding: .7rem .8rem;
}

.informe-nota {
  font-size: .78rem;
  color: #999;
  border-top: 1px solid var(--cinza-borda);
  padding-top: 1rem;
  line-height: 1.5;
}

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

/* =====================================================
   CALCULADORA — grid responsivo
   ===================================================== */

@media (max-width: 600px) {
  .calc-grid-prazo {
    grid-template-columns: 1fr 1fr !important;
  }
  .calc-grid-entre {
    grid-template-columns: 1fr 1fr !important;
  }
}

/* =====================================================
   PRINT — ocultar navegação ao imprimir
   ===================================================== */

@media print {
  .sidebar, .header, .no-print,
  .notif-dropdown, .toast-container,
  .modal-overlay, .sidebar-overlay { display: none !important; }
  .main-wrapper { margin-left: 0 !important; }
  .content-area { padding: .5rem !important; }
  .informe-wrapper {
    max-width: 100% !important;
    border: none !important;
    padding: 0 !important;
    box-shadow: none !important;
  }
  body { background: #fff !important; }
}

/* =====================================================
   INFORME DE RENDIMENTOS — Global (todos os clientes)
   ===================================================== */

.informe-global-wrap {
  max-width: 900px;
}

.informe-global-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  border-bottom: 2px solid var(--azul);
  padding-bottom: 1rem;
  margin-bottom: 1.5rem;
  font-family: 'Sora', sans-serif;
  color: var(--azul);
}

.informe-mes-secao {
  margin-bottom: 1.8rem;
}

.informe-mes-titulo {
  font-family: 'Sora', sans-serif;
  font-weight: 700;
  font-size: .95rem;
  color: var(--azul);
  background: #f0f6fb;
  padding: .45rem .9rem;
  border-left: 3px solid var(--azul);
  margin-bottom: .5rem;
  text-transform: uppercase;
  letter-spacing: .5px;
}

.informe-global-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .84rem;
}

.informe-global-table th {
  background: var(--azul);
  color: #fff;
  padding: .5rem .7rem;
  font-weight: 600;
  font-size: .78rem;
  letter-spacing: .3px;
}

.informe-global-table td {
  padding: .45rem .7rem;
  border-bottom: 1px solid #f0f0f0;
  color: var(--texto);
  vertical-align: top;
}

.informe-global-table tbody tr:hover td {
  background: #fafcfe;
}

.informe-mes-total td {
  background: #e8f3f9;
  border-top: 1px solid #c5dcea;
  padding: .5rem .7rem;
}

.informe-col-data { white-space: nowrap; color: #777; font-size: .8rem; }
.informe-col-cpf  { white-space: nowrap; color: #999; font-size: .79rem; }

.informe-total-geral {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--azul);
  color: #fff;
  font-family: 'Sora', sans-serif;
  font-weight: 700;
  font-size: 1rem;
  padding: .8rem 1rem;
  border-radius: 6px;
  margin-top: .5rem;
  margin-bottom: 1.5rem;
}

.informe-rodape {
  font-size: .75rem;
  color: #bbb;
  text-align: right;
  border-top: 1px solid var(--cinza-borda);
  padding-top: .8rem;
}

/* =====================================================
   PRINT — Informe de rendimentos sem cores
   ===================================================== */

@media print {
  /* Esconde tudo do sistema */
  .sidebar, .header, .no-print,
  .notif-dropdown, .toast-container,
  .modal-overlay, .sidebar-overlay { display: none !important; }

  /* Layout */
  body { background: #fff !important; color: #000 !important; font-size: 11pt; }
  .main-wrapper { margin-left: 0 !important; }
  .content-area { padding: .5cm !important; }

  /* Informe global */
  .informe-global-wrap { max-width: 100% !important; }
  .informe-global-header { border-bottom: 1.5pt solid #000 !important; color: #000 !important; }
  .informe-mes-titulo {
    background: none !important;
    border-left: 2pt solid #000 !important;
    color: #000 !important;
    font-size: 10pt !important;
  }
  .informe-global-table th {
    background: #000 !important;
    color: #fff !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .informe-global-table td { border-bottom: .5pt solid #ddd !important; }
  .informe-mes-total td { background: #eee !important; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  .informe-total-geral {
    background: #000 !important;
    color: #fff !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .informe-mes-secao { page-break-inside: avoid; }
  .informe-col-data, .informe-col-cpf { color: #000 !important; }

  /* Informe por cliente (portal) */
  .informe-wrapper { max-width: 100% !important; border: none !important; padding: 0 !important; }
  .informe-cabecalho { border-bottom: 1.5pt solid #000 !important; color: #000 !important; }
  .informe-titulo-doc { color: #000 !important; }
  .informe-table th { background: #000 !important; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  .informe-total-row td { background: #eee !important; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
}

/* Botão informe de rendimentos (dashboard) */
.btn-informe-link {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .82rem;
  color: var(--azul);
  border: 1px solid var(--azul);
  border-radius: var(--radius);
  padding: .3rem .8rem;
  text-decoration: none;
  transition: var(--trans);
}
.btn-informe-link:hover {
  background: var(--azul);
  color: #fff;
}
.btn-informe-link svg { color: inherit; }

/* Paginação */
.paginacao {
  display: flex;
  gap: .35rem;
  justify-content: center;
  align-items: center;
  padding: 1rem .5rem .5rem;
  flex-wrap: wrap;
}
.paginacao a,
.paginacao span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  height: 34px;
  padding: 0 .55rem;
  border-radius: var(--radius);
  font-size: .85rem;
  text-decoration: none;
  color: var(--azul);
  border: 1px solid #ddd;
  transition: var(--trans);
}
.paginacao a:hover { background: var(--verde-gaia); border-color: var(--verde-gaia-dark); }
.paginacao span.pag-atual { background: var(--azul); color: #fff; border-color: var(--azul); font-weight: 700; }
.paginacao span.pag-off { color: #ccc; border-color: #eee; cursor: default; }

/* Botões Easy Calc / Agenda */
.btn-dash-tool {
  background: var(--verde-gaia);
  color: var(--azul);
  border: 2px solid #000;
  border-radius: var(--radius);
  padding: .45rem 1.1rem;
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-family: 'Inter', sans-serif;
  transition: var(--trans);
}
.btn-dash-tool:disabled {
  opacity: .6;
  cursor: not-allowed;
}

/* Variantes de btn-outline */
.btn-outline-muted {
  border-color: #d0d0d0 !important;
  color: #777 !important;
}
.btn-outline-muted:hover {
  background: var(--azul) !important;
  border-color: var(--azul) !important;
  color: #fff !important;
}
.btn-outline-verde {
  border-color: #27ae60 !important;
  color: #27ae60 !important;
}
.btn-outline-verde:hover {
  background: #27ae60 !important;
  border-color: #27ae60 !important;
  color: #fff !important;
}

/* ============================================================
   RELATÓRIOS
   ============================================================ */

/* Cards de resumo */
.rel-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1rem;
  margin-bottom: 1.4rem;
}
.rel-card {
  background: var(--branco);
  border-radius: var(--radius);
  border: 1px solid var(--cinza-borda);
  border-top-width: 3px;
  padding: .9rem 1.1rem;
  box-shadow: var(--sombra);
}
.rel-card-green  { border-top-color: #27ae60; }
.rel-card-yellow { border-top-color: var(--amarelo); }
.rel-card-red    { border-top-color: var(--vermelho); }
.rel-card-blue   { border-top-color: var(--azul); }
.rel-card-gray   { border-top-color: #aaa; }
.rel-card-label {
  font-size: .76rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-weight: 600;
  color: #777;
  margin-bottom: .35rem;
  display: flex;
  align-items: center;
  gap: .3rem;
}
.rel-card-val {
  font-size: 1.22rem;
  font-weight: 700;
  font-family: 'Sora', sans-serif;
  color: #1a1a1a;
}

/* Barras CSS horizontais */
.rel-bar-wrap {
  display: flex;
  align-items: center;
  gap: .4rem;
  height: 14px;
}
.rel-bar {
  height: 10px;
  border-radius: 5px;
  min-width: 4px;
  transition: width .3s ease;
}
.rel-bar-green { background: #27ae60; }
.rel-bar-blue  { background: var(--azul); }
.rel-bar-verde { background: var(--verde-gaia-dark); }
.rel-bar-red   { background: var(--vermelho); }
.rel-bar-pct {
  font-size: .72rem;
  color: #aaa;
  white-space: nowrap;
}

/* Título visível apenas na impressão */
.rel-print-title {
  display: none;
  font-size: 1.1rem;
  font-weight: 700;
  margin-bottom: 1.2rem;
  color: #1a1a1a;
}

/* ================================================================
   HISTÓRICO + LOG DE ACESSO
================================================================ */
.hist-filtros {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem 1rem;
  align-items: flex-start;
}
.hist-filtros .form-group { flex: 1 1 160px; min-width: 140px; margin: 0; }

.hist-details summary {
  cursor: pointer;
  font-size: .8rem;
  color: var(--azul);
  list-style: none;
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  user-select: none;
}
.hist-details summary::-webkit-details-marker { display: none; }
.hist-details[open] summary { color: #555; }

.hist-diff {
  display: flex;
  gap: .75rem;
  margin-top: .5rem;
  flex-wrap: wrap;
}
.hist-diff-bloco { flex: 1 1 220px; }
.hist-diff-label {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: #888;
  margin-bottom: .2rem;
}
.hist-json {
  background: #f7f7f7;
  border: 1px solid #e0e0e0;
  border-radius: 4px;
  padding: .5rem .65rem;
  font-size: .75rem;
  line-height: 1.5;
  white-space: pre-wrap;
  word-break: break-word;
  max-height: 200px;
  overflow-y: auto;
  margin: 0;
  color: #333;
}

.hist-ip-link {
  color: var(--azul);
  text-decoration: none;
  font-size: .83rem;
}
.hist-ip-link:hover { text-decoration: underline; }

.hist-ua {
  font-size: .78rem;
  color: #777;
  max-width: 280px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media print {
  .rel-print-title { display: block; }
  .no-print        { display: none !important; }
  .tab-nav         { display: none !important; }
  .rel-cards       { grid-template-columns: repeat(4, 1fr); }
  .rel-bar-wrap    { display: none; }
  .card { box-shadow: none; border: 1px solid #ccc; page-break-inside: avoid; }
  .sidebar, .header, .sidebar-overlay { display: none !important; }
  .content-area { margin: 0 !important; padding: 1rem !important; }
  .main-wrapper { margin: 0 !important; }
  .layout-wrapper { display: block !important; }
}

/* ============================================================
   MENSAGENS INTERNAS
   ============================================================ */

/* Botão de mensagens no header */
.btn-msgs {
  position: relative;
  background: none;
  border: none;
  cursor: pointer;
  padding: .3rem .4rem;
  color: var(--texto);
  display: flex;
  align-items: center;
  border-radius: 6px;
  text-decoration: none;
}
.btn-msgs:hover { background: rgba(0,0,0,.06); }
.msgs-badge {
  position: absolute;
  top: 2px; right: 2px;
  background: var(--vermelho);
  color: #fff;
  font-size: .6rem;
  font-weight: 700;
  min-width: 16px;
  height: 16px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 3px;
  pointer-events: none;
}
.msgs-badge.hidden { display: none; }

/* Layout do chat */
.chat-layout {
  display: flex;
  height: calc(100vh - 64px);
  overflow: hidden;
  gap: 0;
  margin: -1.5rem;
}

/* Painel esquerdo */
.chat-sidebar {
  width: 280px;
  min-width: 280px;
  border-right: 1px solid #e8e8e8;
  display: flex;
  flex-direction: column;
  background: #fff;
}
.chat-sidebar-header {
  padding: .9rem 1rem;
  font-family: 'Sora', sans-serif;
  font-weight: 700;
  font-size: .95rem;
  color: var(--azul);
  border-bottom: 1px solid #e8e8e8;
  display: flex;
  align-items: center;
  gap: .4rem;
}
.chat-lista { flex: 1; overflow-y: auto; }
.chat-lista-vazia {
  padding: 1.5rem 1rem;
  color: #aaa;
  font-size: .85rem;
  text-align: center;
}
.chat-contato {
  display: flex;
  align-items: center;
  gap: .7rem;
  padding: .75rem 1rem;
  cursor: pointer;
  border-bottom: 1px solid #f2f2f2;
  transition: background .15s;
  position: relative;
}
.chat-contato:hover  { background: #f7f9fc; }
.chat-contato.ativo  { background: #eef4fb; }
.chat-contato-avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--azul);
  color: #fff;
  font-weight: 700;
  font-size: .9rem;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.chat-contato-info { flex: 1; min-width: 0; }
.chat-contato-nome {
  font-size: .85rem;
  font-weight: 600;
  color: #222;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.chat-contato-preview {
  font-size: .75rem;
  color: #888;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.chat-badge {
  background: var(--vermelho);
  color: #fff;
  font-size: .65rem;
  font-weight: 700;
  min-width: 18px;
  height: 18px;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  flex-shrink: 0;
}

/* Painel direito */
.chat-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  background: #f5f7fa;
  min-width: 0;
}
.chat-vazio {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #bbb;
  gap: .7rem;
  font-size: .9rem;
}
.chat-conv-header {
  display: flex;
  align-items: center;
  gap: .7rem;
  padding: .75rem 1rem;
  background: #fff;
  border-bottom: 1px solid #e8e8e8;
}
.chat-conv-nome {
  font-family: 'Sora', sans-serif;
  font-weight: 700;
  font-size: .95rem;
  color: #222;
}
.chat-voltar {
  background: none;
  border: none;
  cursor: pointer;
  color: #666;
  padding: .2rem;
  display: none;
}

/* Área de mensagens */
.chat-mensagens {
  flex: 1;
  overflow-y: auto;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.chat-carregando, .chat-sem-msg {
  text-align: center;
  color: #bbb;
  font-size: .85rem;
  margin: auto;
}
.chat-msg {
  max-width: 68%;
  display: flex;
  flex-direction: column;
  gap: .15rem;
}
.chat-msg-meu   { align-self: flex-end; align-items: flex-end; }
.chat-msg-deles { align-self: flex-start; align-items: flex-start; }
.chat-msg-texto {
  padding: .5rem .8rem;
  border-radius: 12px;
  font-size: .88rem;
  line-height: 1.45;
  word-break: break-word;
  white-space: pre-wrap;
}
.chat-msg-meu   .chat-msg-texto { background: var(--azul); color: #fff; border-bottom-right-radius: 3px; }
.chat-msg-deles .chat-msg-texto { background: #fff; color: #222; border: 1px solid #e8e8e8; border-bottom-left-radius: 3px; }
.chat-msg-hora {
  font-size: .68rem;
  color: #aaa;
  padding: 0 .3rem;
}

/* Input */
.chat-input-wrap {
  display: flex;
  align-items: flex-end;
  gap: .5rem;
  padding: .75rem 1rem;
  background: #fff;
  border-top: 1px solid #e8e8e8;
}
.chat-input {
  flex: 1;
  border: 1px solid #ddd;
  border-radius: 20px;
  padding: .5rem .9rem;
  font-size: .88rem;
  font-family: inherit;
  resize: none;
  outline: none;
  line-height: 1.4;
  max-height: 120px;
  overflow-y: auto;
  background: #f7f9fc;
}
.chat-input:focus { border-color: var(--azul); background: #fff; }
.chat-enviar-btn {
  background: var(--azul);
  color: #fff;
  border: none;
  border-radius: 50%;
  width: 38px; height: 38px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  transition: background .15s;
}
.chat-enviar-btn:hover { background: var(--azul-dark, #0e3a55); }

/* Mobile */
@media (max-width: 640px) {
  .chat-layout { margin: -1rem; }
  .chat-sidebar {
    position: absolute;
    left: 0; top: 64px;
    height: calc(100vh - 64px);
    z-index: 100;
    transform: translateX(-100%);
    transition: transform .25s;
    width: 100%;
    max-width: 320px;
    box-shadow: 2px 0 12px rgba(0,0,0,.12);
  }
  .chat-sidebar.chat-sidebar-aberta { transform: translateX(0); }
  .chat-voltar { display: flex; }
}

/* ============================================================
   AGENDA — Sessão 15
   ============================================================ */

/* Layout principal */
.agenda-wrap {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}
.agenda-grid-wrap {
  flex: 1;
  min-width: 0;
}

/* Barra de navegação */
.agenda-nav {
  display: flex;
  align-items: center;
  gap: .4rem;
  flex-wrap: wrap;
}
.agenda-nav-btn { padding: .3rem .5rem; }
.agenda-sel-mes,
.agenda-sel-ano {
  padding: .3rem .5rem;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: .9rem;
  font-family: inherit;
  cursor: pointer;
  background: #fff;
}
.agenda-nav-titulo {
  font-family: 'Sora', sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  margin-left: .5rem;
  color: var(--azul);
}
.agenda-visoes { display: flex; gap: .3rem; }

/* Grade mensal */
.agenda-grade {
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
}
.agenda-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  background: var(--azul);
}
.agenda-wd {
  padding: .45rem;
  text-align: center;
  font-size: .78rem;
  font-weight: 600;
  color: #fff;
  letter-spacing: .03em;
}
.agenda-wd.agenda-fds { color: rgba(255,255,255,.65); }

.agenda-days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
}
.agenda-day {
  min-height: clamp(88px, 12vh, 160px);
  padding: .35rem;
  border-right: 1px solid #e8e8e8;
  border-bottom: 1px solid #e8e8e8;
  cursor: pointer;
  transition: background .15s;
  position: relative;
  overflow: hidden;
}
.agenda-day:hover { background: #f5f9ff; transform: translateY(-1px); box-shadow: 0 2px 6px rgba(0,0,0,.08); z-index: 1; }
.agenda-day.agenda-fds { background: #cacaca; }
.agenda-day.agenda-outro-mes { background: #efefef; color: #bbb; }
.agenda-day.agenda-outro-mes .agenda-day-num { color: #ccc; }
.agenda-day.agenda-hoje { background: var(--verde-gaia); }
.agenda-day.agenda-feriado-dia { background: #fde8e8; }

.agenda-day-num {
  display: inline-block;
  width: 24px;
  height: 24px;
  line-height: 24px;
  text-align: center;
  font-size: .82rem;
  font-weight: 600;
  border-radius: 50%;
  color: #333;
}
.agenda-hoje-num {
  background: var(--azul);
  color: #fff !important;
}

/* Pílulas de evento na grade */
.agenda-ev-pill {
  display: block;
  margin: 2px 0;
  padding: 1px 5px;
  border-radius: 3px;
  font-size: .72rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  cursor: pointer;
  color: #222;
  font-weight: 500;
  transition: opacity .1s;
}
.agenda-ev-pill:hover { opacity: .85; }
.agenda-ev-dia-inteiro {
  border: 2px dashed rgba(0,0,0,.4);
  border-radius: 3px;
  margin-left: -.35rem;
  margin-right: -.35rem;
  font-weight: 600;
}
.agenda-ev-concluido { opacity: .55; text-decoration: line-through; }
.agenda-ev-mais { font-size: .65rem; color: #fff; background: var(--azul); padding: 1px 5px; border-radius: 3px; font-weight: 600; }
.agenda-feriado-tag {
  font-size: .68rem;
  font-weight: 600;
  color: #c0392b;
  cursor: default;
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.2;
  padding: 1px 0;
}

/* Visão semanal */
.agenda-semana-cols {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
}
.agenda-semana-col {
  border-right: 1px solid #e8e8e8;
  cursor: pointer;
  transition: background .15s;
  min-height: 200px;
}
.agenda-semana-col:last-child { border-right: none; }
.agenda-semana-col:hover { background: #f5f9ff; }
.agenda-semana-col.agenda-fds { background: #fafafa; }
.agenda-semana-col.agenda-hoje { background: #fffde7; }
.agenda-semana-hdr {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: .5rem .3rem;
  border-bottom: 1px solid #e8e8e8;
  background: var(--azul);
  color: #fff;
}
.agenda-semana-col.agenda-fds .agenda-semana-hdr { background: #6b7280; }
.agenda-semana-dianum {
  font-size: 1.1rem;
  font-weight: 700;
  font-family: 'Sora', sans-serif;
  line-height: 1;
}
.agenda-hoje-num {
  background: var(--verde-gaia);
  color: #1a1a1a !important;
  border-radius: 50%;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.agenda-semana-dianome { font-size: .75rem; opacity: .8; }
.agenda-semana-eventos { padding: .4rem; }

/* Painel lateral */
.agenda-panel {
  width: 0;
  overflow: hidden;
  transition: width .25s;
  background: #fff;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  flex-shrink: 0;
}
.agenda-panel.agenda-panel-aberto {
  width: 300px;
}
.agenda-panel-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .75rem 1rem;
  border-bottom: 1px solid #e8e8e8;
  background: var(--azul);
  color: #fff;
  font-weight: 600;
  font-size: .9rem;
}
.agenda-panel-close {
  background: none;
  border: none;
  color: #fff;
  cursor: pointer;
  padding: 0;
  display: flex;
}
.agenda-panel-body {
  padding: 1rem;
  overflow-y: auto;
  max-height: calc(100vh - 280px);
}
.agenda-panel-ev {
  background: #f9f9f9;
  border-radius: 6px;
  padding: .65rem .8rem;
  margin-bottom: .65rem;
  border-left: 4px solid #ccc;
}
.agenda-panel-ev-hdr { display: flex; align-items: flex-start; gap: .5rem; }
.agenda-panel-ev-hora { font-size: .78rem; color: #888; white-space: nowrap; flex-shrink: 0; }
.agenda-panel-ev-desc { font-size: .82rem; color: #666; margin-top: .3rem; }
.agenda-panel-ev-acoes {
  display: flex;
  gap: .4rem;
  margin-top: .5rem;
  flex-wrap: wrap;
}

/* Visão lista */
.agenda-lista-wrap { }
.agenda-lista-grupo { margin-bottom: 1.5rem; }
.agenda-lista-data {
  font-family: 'Sora', sans-serif;
  font-weight: 700;
  font-size: .9rem;
  color: var(--azul);
  border-bottom: 2px solid var(--azul);
  padding-bottom: .3rem;
  margin-bottom: .6rem;
  text-transform: capitalize;
}
.agenda-lista-item {
  display: flex;
  align-items: center;
  gap: .75rem;
  background: #fff;
  border: 1px solid #e8e8e8;
  border-radius: 6px;
  padding: .65rem .9rem;
  margin-bottom: .4rem;
  cursor: pointer;
  transition: background .15s;
}
.agenda-lista-item:hover { background: #f5f9ff; }
.agenda-lista-cor { width: 10px; height: 36px; border-radius: 3px; flex-shrink: 0; }
.agenda-lista-hora { font-size: .8rem; color: #888; width: 70px; flex-shrink: 0; }
.agenda-lista-info { flex: 1; min-width: 0; }
.agenda-lista-desc { display: block; font-size: .8rem; color: #888; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Seletor de cor */
.agenda-cores {
  display: flex;
  gap: .4rem;
  flex-wrap: wrap;
  margin-top: .25rem;
}
.agenda-cor {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  cursor: pointer;
  border: 3px solid transparent;
  transition: transform .15s, border-color .15s;
}
.agenda-cor:hover { transform: scale(1.15); }
.agenda-cor.agenda-cor-sel { border-color: var(--azul); transform: scale(1.1); }

/* Modal caixa (reutilizável) */
.modal-caixa {
  background: #fff;
  border-radius: 10px;
  width: 90%;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.modal-caixa-hdr {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .9rem 1.2rem;
  border-bottom: 1px solid #e8e8e8;
  font-weight: 600;
  font-size: 1rem;
  color: var(--azul);
  background: #f8fafc;
}
.modal-caixa-close {
  margin-left: auto;
  background: none;
  border: none;
  cursor: pointer;
  color: #888;
  display: flex;
}
.modal-caixa-close:hover { color: var(--vermelho); }
.modal-caixa-body {
  padding: 1.2rem;
  overflow-y: auto;
  flex: 1;
}
.modal-caixa-footer {
  padding: 1rem 1.2rem;
  border-top: 1px solid #e8e8e8;
  background: #f8fafc;
}

/* Feriados lista */
.agenda-feriados-lista { display: flex; flex-direction: column; gap: .4rem; }
.agenda-feriado-item {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .5rem .75rem;
  background: #f9f9f9;
  border-radius: 5px;
  font-size: .9rem;
}

/* Loading */
.agenda-loading {
  text-align: center;
  color: #aaa;
  font-size: .85rem;
  padding: 1.5rem;
}

/* ---- Estatísticas da Agenda ---- */
#sec-agenda-stats .colapsavel-header { box-shadow: none; }

.ag-stat-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .75rem;
  margin-bottom: 1rem;
}
.ag-stat-card {
  display: flex;
  align-items: center;
  gap: .75rem;
  background: #f8fafc;
  border-radius: 10px;
  padding: .75rem 1rem;
  transition: transform .2s ease, box-shadow .2s ease;
}
.ag-stat-card:hover { transform: translateY(-3px); box-shadow: 0 6px 16px rgba(0,0,0,.1); }
.ag-stat-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  flex-shrink: 0;
}
.ag-stat-num {
  display: block;
  font-size: 1.5rem;
  font-family: 'Sora', sans-serif;
  font-weight: 700;
  line-height: 1.1;
  color: var(--azul);
}
.ag-stat-label {
  display: block;
  font-size: .75rem;
  color: #888;
  margin-top: .1rem;
}
.ag-resumo-titulo {
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: #e07b00;
  display: flex;
  align-items: center;
  gap: .3rem;
  margin: 0 0 .6rem;
}
.ag-resumo-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .75rem;
}
.ag-resumo-card {
  background: #f8fafc;
  border-radius: 8px;
  padding: .75rem;
  position: relative;
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease;
}
.ag-resumo-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--verde-gaia) 0%, var(--azul) 100%);
}
.ag-resumo-card:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,.08); }
.ag-resumo-card-hdr {
  display: flex;
  align-items: center;
  gap: .3rem;
  font-size: .78rem;
  font-weight: 600;
  color: #555;
  margin-bottom: .5rem;
}
.ag-prox-titulo {
  font-weight: 600;
  font-size: .9rem;
  color: var(--azul);
  margin-bottom: .25rem;
}
.ag-prox-meta { display: flex; gap: .5rem; align-items: center; font-size: .82rem; }
.ag-prox-hora { font-weight: 700; color: #333; }
.ag-prox-dia  { color: #888; }
.ag-hoje-count {
  font-size: 2rem;
  font-family: 'Sora', sans-serif;
  font-weight: 700;
  color: var(--azul);
  line-height: 1;
  text-align: center;
}
.ag-hoje-label { text-align: center; font-size: .75rem; color: #888; margin-bottom: .5rem; }
.ag-hoje-lista { display: flex; flex-direction: column; gap: .25rem; }
.ag-hoje-item {
  display: flex;
  align-items: center;
  gap: .35rem;
  font-size: .8rem;
  color: #333;
}
.ag-hoje-item.ag-hoje-concluido { color: #aaa; text-decoration: line-through; }
.ag-hoje-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.ag-hoje-hora { font-size: .75rem; color: #666; white-space: nowrap; flex-shrink: 0; }
.ag-semana-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
  margin-top: .5rem;
}
.ag-semana-col { display: flex; flex-direction: column; align-items: center; gap: 2px; }
.ag-semana-dow { font-size: .65rem; color: #aaa; }
.ag-semana-qtd {
  width: 26px;
  height: 26px;
  border-radius: 6px;
  background: #f0f0f0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .8rem;
  font-weight: 600;
  color: #aaa;
}
.ag-semana-qtd.ag-semana-com-ev { background: var(--verde-gaia); color: var(--azul); }
.ag-semana-col.ag-semana-hoje .ag-semana-dow { color: var(--azul); font-weight: 700; }
.ag-semana-col.ag-semana-hoje .ag-semana-qtd { outline: 2px solid var(--azul); }
.ag-resumo-nums {
  display: flex;
  justify-content: space-around;
  margin-bottom: .6rem;
}
.ag-resumo-num-bloco { text-align: center; }
.ag-resumo-num-bloco strong { display: block; font-size: 1.3rem; font-family: 'Sora', sans-serif; }
.ag-resumo-num-bloco span  { font-size: .72rem; color: #888; }
.ag-progresso-wrap {
  height: 10px;
  background: #e8e8e8;
  border-radius: 5px;
  overflow: hidden;
}
.ag-progresso-bar {
  height: 100%;
  background: var(--verde-gaia);
  border-radius: 5px;
  transition: width .4s;
}

@media (max-width: 900px) {
  .ag-stat-cards  { grid-template-columns: repeat(2, 1fr); }
  .ag-resumo-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 550px) {
  .ag-stat-cards  { grid-template-columns: repeat(2, 1fr); }
  .ag-resumo-grid { grid-template-columns: 1fr; }
}

/* Mobile toggle button — hidden on desktop */
.agenda-btn-mobile-toggle { display: none; }

/* Mobile lista container — hidden by default */
.agenda-mobile-lista { display: none; }
.agenda-mobile-fds { background: #cacaca; }

/* Responsive */
@media (max-width: 768px) {
  .agenda-wrap { flex-direction: column; }
  /* Painel padrão (grade): aparece abaixo */
  .agenda-panel.agenda-panel-aberto { width: 100%; margin-top: 1rem; }
  /* Painel no modo lista: overlay fixo por cima */
  .agenda-panel.agenda-panel-aberto.agenda-panel-overlay {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    width: 100%;
    margin: 0;
    border-radius: 0;
    z-index: 1000;
    overflow-y: auto;
  }
  .agenda-semana-cols { grid-template-columns: repeat(7, minmax(100px, 1fr)); overflow-x: auto; }
  .agenda-grade { width: 100%; }
  .agenda-days  { grid-template-columns: repeat(7, 1fr); }
  .agenda-day   { min-height: 52px; padding: 2px 2px 3px; }
  .agenda-day-num { font-size: .8rem; width: 20px; height: 20px; line-height: 20px; }
  .agenda-ev-pill { font-size: .62rem; padding: 1px 3px; margin-bottom: 1px; }
  .agenda-ev-dia-inteiro { margin-left: -2px; margin-right: -2px; }
  .agenda-ev-mais { font-size: .6rem; }
  .agenda-feriado-tag { font-size: .6rem; }

  /* Mobile toggle button */
  .agenda-btn-mobile-toggle {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: .3rem .75rem;
    border: 1px solid #ccc;
    border-radius: 4px;
    background: #fff;
    cursor: pointer;
    font-size: .9rem;
    font-family: inherit;
    margin-left: auto;
  }
  .agenda-btn-mobile-toggle:hover { background: #f0f0f0; }

  /* Mobile lista view */
  .agenda-mobile-lista { border: 1px solid #e0e0e0; border-radius: 6px; overflow: hidden; }
  .agenda-mobile-dia {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .45rem .75rem;
    border-bottom: 1px solid #eee;
    cursor: pointer;
    min-height: 44px;
  }
  .agenda-mobile-dia:last-child { border-bottom: none; }
  .agenda-mobile-dia:hover { background: #eef4ff; }
  .agenda-mobile-fds { background: #e8e8e8; }
  .agenda-mobile-hoje { background: #fffde7; }
  .agenda-mobile-fer-bg { background: #fce4ec; }
  .agenda-mobile-num {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 34px;
    flex-shrink: 0;
  }
  .agenda-mobile-d {
    font-weight: 700;
    font-size: 1rem;
    line-height: 1.1;
    color: #222;
  }
  .agenda-mobile-dow {
    font-size: .62rem;
    color: #999;
    text-transform: uppercase;
    letter-spacing: .03em;
  }
  .agenda-mobile-evs {
    flex: 1;
    display: flex;
    flex-wrap: wrap;
    gap: .25rem;
    min-width: 0;
  }
  .agenda-mobile-livre {
    font-size: .82rem;
    color: #bbb;
    font-style: italic;
  }
  .agenda-mobile-fer-tag {
    font-size: .72rem;
    font-weight: 600;
    background: #fce4ec;
    color: #c0392b;
    border: 1px solid #f5c6cb;
    border-radius: 3px;
    padding: 2px 6px;
    white-space: nowrap;
    flex-shrink: 0;
    align-self: center;
  }
}
