.body2 {
  font-family: Montserrat, Arial, sans-serif;
  background-color: #f4f4f9;
  color: #333;
  padding: 20px;
}

/* Layout principal */
.dashboard { display: flex; gap: 20px; }

.icone { color: #999; font-size: 25px; cursor: pointer; }

/* menus */
 
/* Coluna da esquerda (Associados + Agenda) */
.associados-agendas {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Aniversariantes - Coluna à direita */
.aniversariantes {
  flex-basis: 30%;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 15px;
}

/* Geral */
.section {
  background-color: #fff;
  border-radius: 8px;
  box-shadow: 0 2px 4px rgba(0,0,0,.1);
  padding: 20px;
}
.section h2 {
  font-size: 1.5em;
  margin-bottom: 15px;
  display: flex;
  align-items: center;
}
.section h2 i { margin-right: 10px; color: #007BFF; }

/* Associados */
.associados {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
  gap: 10px;
  text-align: center;
}
.associados .card {
  background-color: #fff;
  padding: 15px;
  border-radius: 8px;
  border: 1px solid #ddd;
  box-shadow: 0 2px 6px rgba(0,0,0,.1);
  font-size: 2em;
  text-align: center;
  transition: all .3s ease;
}
.associados .card:hover {
  border-color: #007BFF;
  box-shadow: 0 4px 10px rgba(0,123,255,.2);
  transform: translateY(-5px);
}
.associados .ativo { color: #28a745; }
.associados .inativo { color: #dc3545; }

/* Agendas */
.agendas {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px,1fr));
  gap: 15px;
}
.agendas .card {
  display: flex; flex-direction: column; justify-content: start; align-items: flex-start;
  background-color: #fff; padding: 20px; border-radius: 8px;
  border: 1px solid #ddd; box-shadow: 0 2px 6px rgba(0,0,0,.1);
  min-height: 100px; max-width: 300px; transition: all .3s ease;
}
.agendas .card:hover {
  border-color: #007BFF;
  box-shadow: 0 4px 10px rgba(0,123,255,.2);
  transform: translateY(-5px);
}
.agendas .card h3 { font-size: 1em; margin: 0 0 5px; }
.agendas .card p  { font-size: .8em; margin: 0 0 5px; }

/* Aniversariantes */
.aniversariantes h2 {
  font-size: 1.5em; margin-bottom: 15px; display: flex; align-items: center;
}
.aniversariantes .card {
  display: flex; align-items: center; background-color: #f9f9f9;
  padding: 15px; border-radius: 8px; box-shadow: 0 1px 3px rgba(0,0,0,.1);
  margin-bottom: 15px;
}
.aniversariantes img { width: 80px; height: 80px; border-radius: 50%; margin-right: 15px; }
.aniversariantes .info h3 { font-size: 1em; margin: 0 0 5px; }
.aniversariantes .info p { font-size: .9em; color: #555; margin: 0; }

/* Responsividade */
@media (max-width: 768px) {
  .dashboard { flex-direction: column; }
  .aniversariantes { flex-basis: 100%; }
}

/* ====== Trumbowyg ====== */
.trumbowyg-box {
  border: 1px solid #ddd; box-shadow: 0 4px 6px rgba(0,0,0,.1);
  border-radius: 8px; background-color: #fff;
}
.trumbowyg-editor {
  padding: 10px; font-family: 'Roboto', sans-serif; font-size: 14px; color: #333;
  min-height: 150px; line-height: 1.6;
}
.trumbowyg-button-pane button{
  color:#000; font-size:14px; padding:8px 12px; border-radius:6px; border:2px solid transparent;
}
.trumbowyg-button-pane button:hover{
  background-color:#45A049; border-color:#1E7A1E;
}
.trumbowyg-button-pane .trumbowyg-button{ font-size:16px; }
.trumbowyg-box:hover{ border-color:#007BFF; }
.trumbowyg-button i{ font-size:18px; color:#fff; }
.trumbowyg-button:hover i{ color:#FFD700; }
.trumbowyg-button-pane button:active{ box-shadow: inset 0 2px 4px rgba(0,0,0,.2); }
.trumbowyg-button-bold{ background-color:#FF5722; }
.trumbowyg-button-italic{ background-color:#03A9F4; }
.trumbowyg-button-underline{ background-color:#8BC34A; }
.trumbowyg-button-pane button{ padding:12px 16px; font-size:16px; margin:4px; }

/* ====== Inputs e layout de cadastro ====== */
.custom-textarea-box{
  margin-top:24px; min-height:50px; display:flex; align-items:center;
  border:0; border-radius:8px; background-color:#f9f9f9;
  box-shadow:0 2px 4px rgba(0,0,0,.1); padding:0; position:relative; flex:1; margin-right:0; box-sizing:border-box;
}
.espaco_cadastro{ display:flex; flex-direction:column; gap:10px; width:100%; }
.linha_cadastro{ display:flex; flex-direction:row; gap:0; box-sizing:border-box; }
@media (max-width:600px){
  .linha_cadastro{ gap:2px; }
}
.custom-select-box, .custom-input-box{
  margin-top:0; display:flex; flex-direction:column; gap:2px; align-items:flex-start; padding:2px;
  text-align:left; width:100%; box-sizing:border-box;
}
.custom-select-box select,
.custom-input-box select,
.custom-input-box input{ width:100%; box-sizing:border-box; }

.chosen-container{ width:100% !important; }

/* ultimo item não precisa margem extra (mantive onde você já tinha) */
.custom-select-box:last-child{ margin-right:10px; }
.custom-input-box:last-child{ margin-right:0; } /* <– aqui estava '10' sem 'px' */

.custom-select-box label, .custom-input-box label{
  margin-top:0; background:#fff; padding:0 5px; font-size:1.1rem; color:#34495e;
  white-space:nowrap; z-index:1; font-weight:600; text-align:left; margin-bottom:0;
}

.chosen-container{ border-radius:6px; border:1px solid #ccc; margin-top:0 !important; }
.custom-select-box:hover{ border-color:#007BFF; }

/* ====== Menu lateral / container ====== */
.menu-container{
  background-color:#fff; padding:10px; border-radius:8px;
  box-shadow:0 4px 6px rgba(0,0,0,.1); max-width:100%;
  overflow-y:auto; height:90vh;
}
.menu-header{ display:flex; justify-content:space-between; align-items:center; margin-bottom:2px; }
.menu-header i{ font-size:30px; color:#848484; cursor:pointer; }
.menu-section{ display:flex; flex-wrap:wrap; gap:2px; margin-bottom:5px; }
.menu-item{ flex:1 1 48%; min-width:120px; }
.menu-item.full{ flex:1 1 100%; }
@media (max-width:768px){
  .menu-item{ flex:1 1 100%; }
}

/* chosen / selects */
.custom-input-box input, .custom-select-box select, .chosen-select{
  height:40px !important; border:1px solid #ccc; border-radius:6px;
}
.chosen-select, .chosen-container-single{
  width:100% !important; height:100% !important; border:1px solid #ccc; border-radius:6px; padding:4px;
}
.chosen-container-single{
  width:100% !important; height:100% !important; border:1px solid #ccc; border-radius:6px; padding:4px;
}
.chosen-container-multi, .chosen-container-single{ height:40px; }
.chosen-select:focus{
  border-color:#007BFF; outline:none; box-shadow:0 0 5px rgba(0,123,255,.5);
}
.chosen-container-mult{ width:98% !important; }
.chosen-choices{ width:98% !important; background-image:none; }
/* garantir borda visível do chosen */
.chosen-container .chosen-single{ border:1px solid #ccc; }

/* Labels flutuantes */
.custom-textarea-box label{
  position:absolute; top:-12px; left:10px; background:#fff; padding:0 5px;
  font-size:15px; color:#6AB28E; white-space:nowrap; z-index:1; font-weight:400;
}
.custom-input-box input:hover{
  border-color:#007BFF; box-shadow:0 0 5px rgba(0,123,255,.5);
}

/* Grupos lado a lado */
.input-row{
  display:flex; flex-wrap:wrap; gap:15px; justify-content:space-between;
}

/* Tabelas responsivas dos grupos */
.table-container{
  display:flex; flex-wrap:wrap; gap:15px; margin-top:12px;
}
.table-container table{ flex:1; min-width:200px; }

.cinza11{ font-size:14px; color:#333; }
.cinzacampo{ font-size:12px; font-weight:600; color:#555; margin-bottom:8px; display:block; }

/* Placeholder de grupo */
optgroup{ font-weight:bold; color:#007BFF; }

/* Boxes de selects customizados */
.meu-boxb{
  margin-top:12px; height:45px; display:flex; align-items:center;
  border:1px solid #ccc; border-radius:8px; background-color:#f9f9f9;
  box-shadow:0 2px 4px rgba(0,0,0,.1); padding:0 10px; position:relative;
  flex:1; margin-right:10px; box-sizing:border-box;
}
.meu-boxb select{
  width:100%; height:100%; border:none; border-radius:8px; background:transparent;
  font-size:14px; color:#333; outline:none; appearance:none; padding:0; text-align:left; cursor:pointer;
}
.meu-boxb label{
  position:absolute; top:-5px; left:10px; background:#fff; padding:0 5px;
  font-size:12px; color:#6AB28E; white-space:nowrap; z-index:1;
}
.meu-boxb .chosen-container{
  width:100% !important; height:auto; border:1px solid #ccc; border-radius:8px;
  box-shadow:0 2px 4px rgba(0,0,0,.1); background-color:#f9f9f9; padding:0 10px; box-sizing:border-box;
}
.meu-boxb .chosen-single{
  height:45px; line-height:45px; border:none; background:transparent; color:#333; font-size:14px; outline:none; border-radius:8px; cursor:pointer;
}
.meu-boxb .chosen-drop{ border:1px solid #ccc; border-radius:8px; background-color:#fff; z-index:10; }

/* Utilidades / footer de menus */
.menu-footer{ text-align:right; margin-top:15px; }
.hidden{ display:none; }

.containermodal{
  display:flex; flex-direction:column; align-items:flex-start; justify-content:flex-start; gap:10px;
}
.containermodalfooter{
  float:left; gap:10px; margin-top:30px; border-top:1px solid #ccc; padding-top:10px;
}

/* Botão grande com ícone sobreposto */
.icon-overlay{ position:relative; display:inline-block; }
.btnSelecionar{
  background-color:#4CAF50; border:none; color:#fff; padding:5px 14px; text-align:center;
  text-decoration:none; display:inline-block; font-size:26px; margin:0; cursor:pointer;
  border-radius:12px; transition:.4s; box-shadow:0 4px 8px rgba(0,0,0,.2);
}
.btnSelecionar i{ font-size:26px; }
.btnSelecionar:hover{
  background-color:#fff; color:#000; border:2px solid #4CAF50;
}

/* Ícone genérico ao lado de textos */
.icone{ margin-right:8px; }

/* Botão de filtro circular */
.filter-btn{
  background-color:#2980b9; color:#fff; border:none; padding:12px 16px; font-size:18px;
  border-radius:50px; cursor:pointer; box-shadow:0 4px 8px rgba(0,0,0,.2); transition:.3s;
}
.filter-btn:hover{ background-color:#1e6b9a; }
