        /* Estilos para a sidebar colapsável */
        #sidebar, #sidebar-right {
            transition: all 0.3s ease;
            overflow-y: auto;
            position: fixed;
            top: 0;
            bottom: 0;
            z-index: 1000;
            background-color: #0A1A45;
            color: white;
        }

       

        /* Estilos para os ícones no menu */
        .nav-link i {
            font-size: 1.5rem;
            transition: color 0.3s ease;
            position: relative; /* Para permitir o posicionamento do tooltip */
        }

        .nav-link span {
            margin-left: 10px;
            display: none; /* O texto dos itens do menu ficará oculto inicialmente */
        }

        /* Efeito hover para ícones e texto */
        .nav-link:hover i {
            color: #DBFC7E; /* Cor dos ícones ao passar o mouse (amarelo claro da paleta) */
        }

        .nav-link:hover span {
            display: inline; /* Exibe o texto ao passar o mouse */
            color: #F5FFE6; /* Cor do texto (verde claro da paleta) */
        }

        /* Estilo do tooltip */
        .nav-link[data-tooltip]::before {
            content: attr(data-tooltip); /* O conteúdo do tooltip vem do atributo data-tooltip */
            position: absolute;
            left: 100%; /* Posiciona o tooltip à direita do ícone */
            top: 50%;
            transform: translateY(-50%);
            margin-left: 10px; /* Espaço entre o ícone e o tooltip */
            background-color: #0A1A45; /* Fundo do tooltip (azul escuro da paleta) */
            color: #DBFC7E; /* Cor do texto do tooltip (amarelo claro da paleta) */
            padding: 5px;
            border-radius: 5px;
            white-space: nowrap;
            opacity: 0;
            pointer-events: none; /* Garante que o tooltip não interfira nos eventos do mouse */
            transition: opacity 0.3s ease;
            z-index: 999; /* Garante que o tooltip apareça sobre os outros elementos */
        }

        /* Exibir o tooltip no hover */
        .nav-link:hover[data-tooltip]::before {
            opacity: 1; /* Mostra o tooltip ao passar o mouse */
        }
        
        .stars {
            display: inline-block; /* Garantir que o container permita itens em linha */
            vertical-align: middle; /* Alinhamento vertical para centralizar as imagens, se necessário */
            margin-bottom: 15px;
        }
        
        .stars span {
            display: inline-block; /* Garantir que cada imagem seja tratada como um bloco em linha */
            width: 22px; /* Largura da imagem */
            height: 30px; /* Altura da imagem */
            vertical-align: middle; /* Ajuste de alinhamento */
            margin-top: 5px; /* Adiciona 5px de margem superior */
            margin-bottom: 5px; /* Adiciona 5px de margem inferior */
        }
        
        .stars img {
            width: 100%; /* Ajuste a imagem para preencher o span */
            height: auto; /* Mantenha a proporção da imagem */
            display: block; /* Remove qualquer espaço extra abaixo da imagem */
        }
                
        .logo {
            margin: 15px 0px 0px -140px;
            height: 86px;
            width: 200px;
        }

        #sidebar.expanded .logo {
            margin: 15px 0px 0px 0px;
            height: 86px;
            width: 200px;

        }


        .nav-link i {
            font-size: 1.1rem; /* Aumente o tamanho do ícone */
            font-weight: bold; /* Aumenta a grossura do ícone (para ícones que suportam peso) */
            line-height: 1; /* Ajuste o line-height para centralizar o ícone */
        }
        
        .nav-link span {
            margin-left: 10px; /* Adicione espaço entre o ícone e o texto */
        }
        

        /* Sidebar esquerda */
        #sidebar {
            width: 80px; /* Largura inicial colapsada */
            left: 0;
        }
        #sidebar.expanded {
            width: 250px; /* Largura expandida */
        }

        
        #sidebar .nav-link {
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            padding: 10px 22px;
        }
        #sidebar.expanded .nav-link span {
            display: inline; /* Exibir o texto dos links quando expandido */
        }
        #sidebar .nav-link span {
            display: none; /* Ocultar o texto dos links quando colapsado */
        }

        .foto-lotacao {
            width: 190px; /* Define a largura do contêiner da imagem */
            height: 280px; /* Define a altura do contêiner da imagem */
            object-fit: cover; /* Faz com que a imagem cubra completamente o contêiner sem deformar */
            object-position: center; /* Centraliza a imagem dentro do contêiner */
        }
        
        /* Sidebar direita */
        #sidebar-right {
            right: 0;
            background-color: #f8f9fa;
            color: black;
        }

        .ocultar {
            display: none;
        }
        #sidebar-right.expanded {
            width: 250px; /* Largura expandida */
            padding: 10px;

        }
        #sidebar-right .sidebar-content {
            display: none; /* Ocultar conteúdo quando colapsado */
        }
        #sidebar-right.expanded .sidebar-content {
            display: block; /* Exibir conteúdo quando expandido */
        }

        /* Ajustes de conteúdo principal */
        #main-content {
            margin: 0 auto;
            padding: 15px;
            padding-top: 70px; /* Espaço para o header fixo */
            transition: margin-left 0.3s, margin-right 0.3s;
            margin-left: 80px; /* Margem inicial com sidebars colapsadas */
            margin-right: 80px;
        }
        #main-content.sidebar-expanded-left {
            margin-left: 250px; /* Ajuste de margem quando a sidebar esquerda está expandida */
        }
        #main-content.sidebar-expanded-right {
            margin-right: 350px; /* Ajuste de margem quando a sidebar direita está expandida */
        }

        /* Estilo para o header fixo */
        header {
            background-color: #DBFC7E;
            padding: 10px 15px;
            position: fixed;
            top: 0;
            left: 80px; /* Inicialmente alinhado com sidebar colapsada */
            right: 0px;
            z-index: 999;
            display: flex;
            align-items: center;
            justify-content: space-between;
            transition: left 0.3s, right 0.3s;
        }

        header.sidebar-expanded-left {
            left: 250px; /* Ajuste quando a sidebar esquerda está expandida */
        }
        header.sidebar-expanded-right {
            right: 250px; /* Ajuste quando a sidebar direita está expandida */
        }

        /* Ajuste de responsividade */
        @media (max-width: 991.98px) {
            /* Sidebar esquerda */
        #sidebar {
            width: 0px; /* Largura inicial colapsada */
            left: 0;
        }
        #sidebar.expanded {
            width: 250px; /* Largura expandida */
        }

        #sidebar.expanded .logo {
            margin: 15px 0px 0px -90px;
            height: 86px;
            width: 200px;

        }

        #sidebar .nav-link {
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            padding: 10px 22px;
        }
        #sidebar.expanded .nav-link span {
            display: inline; /* Exibir o texto dos links quando expandido */
        }
        #sidebar .nav-link span {
            display: none; /* Ocultar o texto dos links quando colapsado */
        }

        /* Sidebar direita */
        #sidebar-right {
            right: 0;
            background-color: #f8f9fa;
            color: black;
        }
        #sidebar-right.expanded {
            width: 250px; /* Largura expandida */
            padding: 10px;
            right: 135px;

        }
        #sidebar-right .sidebar-content {
            display: none; /* Ocultar conteúdo quando colapsado */
        }
        #sidebar-right.expanded .sidebar-content {
            display: block; /* Exibir conteúdo quando expandido */
        }

        #main-content {
            margin-left: 0;
            margin-right: 0;
            padding-top: 100px;
        }
        header {
            left: 0;
            right: 0;
        }
        }


.titulo-header { 
    color: #ff0062;
    font-size: 36px;
    font-family: 'Oswald', sans-serif;
    margin-bottom: -20px;
    font-weight: 700;
    font-stretch: expanded;

}

/* Seções de Conteúdo */
.section-content {
    width: 100vw;
    padding: 80px 0;
    margin-left: calc(50% - 50vw); /* Centraliza a seção com fundo colorido */
    
}

.section-content .container {
    max-width: 1140px; /* Limita a largura do conteúdo dentro da seção */
    margin: 0 auto;
}

.section-content h2, .section-content p {
    color: #0A1A45;
}

.section-content.bg-alt {
    background-color: #F5FFE6;
}

.section-content h2 {
    color: #0A1A45;
    margin-bottom: 20px;
}

.section-content p {
    color: #0A1A45;
}

.section-content img {
    border-radius: 10px;
}

/* Seção de Call to Action */
.section-cta {
    background-color: #DBFC7E; /* A cor de fundo ocupa 100% da largura */
    width: 100vw;
    margin-left: calc(50% - 50vw); /* Garante que o fundo ocupe toda a largura */
    color: #F5FFE6;
}

.section-cta .container {
    max-width: 1140px; /* Define a largura máxima do conteúdo */
    margin: 0 auto; /* Centraliza o conteúdo */
    text-align: center;
}

.section-cta h2 {
    color: #0A1A45;
    margin-bottom: 40px;
}

.section-cta .btn-primary {
    background-color: #DBFC7E;
    border-color: #DBFC7E;
    padding: 15px 30px;
    font-size: 1.2rem;
}

.section-cta .btn-primary:hover {
    background-color: #789484;
}

/* Animações */
.section-content {
    opacity: 0;
    transform: translateY(50px);
    transition: all 0.6s ease-in-out;
}

.section-content.visible {
    opacity: 1;
    transform: translateY(0);
}

/* Mobile Responsivo */
@media (max-width: 768px) {
    .hero-content h1 {
        font-size: 3rem;
    }
    
    .hero-content p {
        font-size: 1.2rem;
    }
}

.quadriculado {
    background-image:  linear-gradient(#0A1A45 1px, transparent 1px), linear-gradient(to right, #0A1A45 1px, transparent 1px);
    background-size: 150px 150px;
    margin-top: -15px;
    padding-top: 65px;
    padding-bottom: 65px;
}

.isometrico {
    background-color: #e5e5f7;
    opacity: 1;
    background: repeating-linear-gradient( 45deg, #DBFC7E, #DBFC7E 0.5px, #F5FFE6 2.5px, #F5FFE6 12.5px );
    padding: 18px 10px 40px 10px;
}

.hexagon-container {
    display: flex;
    justify-content: center;
    align-items: center;
    
}
.hexagon {
    width: 307px;
    height: 301px;
    background-color: #0A1A45; /* Azul da borda */
    position: relative;
    clip-path: polygon(50% 0%, 80% 10%, 100% 35%, 100% 70%, 100% 100%, 50% 100%, 20% 90%, 0% 70%, 0% 35%, 20% 10%);
    overflow: hidden;
    border: 5px solid #0A1A45; /* Ajuste da borda */
}

.hexagon {
    width: 307px;
    height: 301px;
    background-color: #0A1A45; /* Azul da borda */
    position: relative;
    clip-path: polygon(50% 0%, 80% 10%, 100% 35%, 100% 70%, 100% 100%, 50% 100%, 20% 90%, 0% 70%, 0% 35%, 20% 10%);
    overflow: hidden;
    border: 5px solid #0A1A45; /* Ajuste da borda */
}

.hexagon-detalhe {
    width: 200px;
    height: 290px;
    background-color: #0A1A45; /* Azul da borda */
    position: relative;
    clip-path: polygon(50% 0%, 101.25% -0.43%, 100% 35%, 100% 70%, 100% 100%, 50% 100%, 20% 90%, 0% 70%, 0% 35%, 20% 10%);
    overflow: hidden;
    border: 5px solid #0A1A45; /* Ajuste da borda */
}

.hexagon-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    clip-path: inherit; /* Garante que a imagem siga o formato hexagonal */
}

.hexagon-small-container {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 80px;  /* Tamanho da imagem */
    height: 80px; /* Tamanho da imagem */
}

.hexagon-small {
    width: 80px;
    height: 150px;
    background-color: #0A1A45; /* Azul da borda */
    position: relative;
    clip-path: polygon(50% 0%, 101.25% -0.43%, 100% 35%, 100% 70%, 100% 100%, 50% 100%, 20% 90%, 0% 70%, 0% 35%, 20% 10%);
    overflow: hidden;
    border: 3px solid #0A1A45; /* Ajuste da borda */
}

.hexagon-small-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    clip-path: inherit; /* Garante que a imagem siga o formato hexagonal */
}

/* Hexágono genérico com borda via pseudo-elemento */
.hex {
  --b: 5px;           /* espessura da borda */
  --c: #0A1A45;       /* cor da borda */
  position: relative;
  width: 200px;       /* ajuste o tamanho aqui (o “grande”) */
  aspect-ratio: 1 / 1.1547; /* altura ~115.47% da largura (hex regular) */
}

/* “Casco” da borda */
.hex::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--c);
  -webkit-clip-path: polygon(25% 6.7%, 75% 6.7%, 100% 50%, 75% 93.3%, 25% 93.3%, 0% 50%);
          clip-path: polygon(25% 6.7%, 75% 6.7%, 100% 50%, 75% 93.3%, 25% 93.3%, 0% 50%);
}

/* Conteúdo interno (imagem ou fallback) recortado e “afastado” pela espessura da borda */
.hex > img,
.hex > .hex-fallback {
  position: absolute;
  inset: var(--b);
  width: calc(100% - var(--b)*2);
  height: calc(100% - var(--b)*2);
  object-fit: cover;
  -webkit-clip-path: polygon(25% 6.7%, 75% 6.7%, 100% 50%, 75% 93.3%, 25% 93.3%, 0% 50%);
          clip-path: polygon(25% 6.7%, 75% 6.7%, 100% 50%, 75% 93.3%, 25% 93.3%, 0% 50%);
}

/* Hex pequeno reaproveitando a mesma base */
.hex--sm { width: 80px; }

/* Fallback (sem foto) centralizado */
.hex .hex-fallback {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #0A1A45;
}
.hex .hex-fallback i { color: #fff; font-size: 1.6rem; }

/* Avatar circular com “anel” configurável */
.avatar {
  --size: 200px;           /* tamanho padrão (altere por variação) */
  --ring: 5px;             /* espessura da borda */
  --ring-color: #0A1A45;   /* cor da borda (navy) */

  width: var(--size);
  height: var(--size);
  border-radius: 50%;
  border: var(--ring) solid var(--ring-color);
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #0A1A45;     /* fundo quando não há foto (fica navy) */
}

/* A imagem preenche sem deformar */
.avatar > img {
  width: 100%;
  height: 100%;
  object-fit: cover;       /* “corta” mantendo proporção */
  display: block;          /* remove gaps */
}

/* Tamanhos prontos */
.avatar--sm { --size: 80px;  --ring: 3px; }
.avatar--md { --size: 140px; --ring: 4px; }
.avatar--lg { --size: 200px; --ring: 5px; }

/* Ícone de fallback centralizado e legível sobre o fundo navy */
.avatar > i { color: #fff; font-size: calc(var(--size) * 0.4); }

/* ===== Filtro de Mandatos (pílulas) ===== */
.mandatos-row {
  background-color: #0A1A45;  /* navy */
  border-radius: 14px;
  padding: 10px 12px;
  --mand-fg: #F5FFE6;         /* texto claro */
  --mand-accent: #DBFC7E;     /* verde/amarelo claro selecionado */
  --mand-muted: rgba(245,255,230,0.85);
}

.mandatos-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.mandato-list {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: nowrap;          /* fica tudo na horizontal; rola se passar */
  padding: 4px 2px;
  margin: 0;
  list-style: none;
}

/* Pílulas (links) */
.mandato-pill {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .5rem .9rem;
  border-radius: 999px;
  background: rgba(245,255,230,0.10);
  border: 1px solid rgba(219,252,126,0.35);
  color: var(--mand-fg);
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
  transition: background .2s ease, transform .2s ease, box-shadow .2s ease, color .2s ease, border-color .2s ease;
}

.mandato-pill:hover {
  background: rgba(245,255,230,0.18);
  transform: translateY(-1px);
}

.mandato-pill.is-active {
  background: var(--mand-accent);
  color: #0A1A45;
  border-color: var(--mand-accent);
  box-shadow: 0 6px 12px rgba(0,0,0,0.15);
}

/* Acessibilidade: foco visível */
.mandato-pill:focus-visible {
  outline: 2px solid var(--mand-accent);
  outline-offset: 2px;
}

/* Ajuste responsivo (mais respiro em telas pequenas) */
@media (max-width: 991.98px) {
  .mandatos-row { padding: 12px; }
  .mandato-list { gap: 10px; }
}

/* Desativa o ícone só na faixa de mandatos */
.section-mandatos .bi-box-arrow-up-right { 
  display: none !important; 
}

.section-mandatos a::after {
  content: none !important;
  background: none !important;
}

footer {
    background-color: #0A1A45; /* Cor de fundo do footer */
}

footer a {
    color: #DBFC7E; /* Cor dos links */
}

footer p {
    color: #F5FFE6; /* Cor do texto no copyright */
}

footer h5 {
    color: #DBFC7E; /* Cor dos títulos das colunas */
}


.scroll {
    overflow: hidden;
    width: 100%;
    margin: 0 auto;
    white-space: nowrap; /* Evita quebra de linha nos elementos */
    background-color: #DBFC7E;
    opacity: 1;


}

.scroll__container {
    display: inline-flex;
    animation: scrollInfinito 20s linear infinite;
}

.scroll__item {
    display: inline-block;
    min-width: 25%; /* Cada item ocupa 25% da largura da tela */
    box-sizing: border-box;
    padding: 10px;
    margin-right: 10px;
}

/* ===== Stats Row (5 colunas) ===== */
.stats-row {
    background-color: #ff0062;           /* fundo pedido */
    border-radius: 14px;
    padding: 0px 10px 14px 10px;
    --stats-fg: #F5FFE6;                 /* texto principal (verde claro) */
    --stats-accent: #DBFC7E;             /* destaque/posição (amarelo claro) */
    --stats-muted: rgba(245, 255, 230, .85);
}

/* Colunas e cartões internos */
.stats-col { display: flex; }
.stats-item {
    background: rgba(10, 26, 69, 0.12);  /* leve contraste sobre o rosa */
    border: 1px solid rgba(245, 255, 230, 0.15);
    border-radius: 12px;
    padding: 12px 14px;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    width: 100%;
    transition: transform .2s ease, background .2s ease, box-shadow .2s ease;
}
.stats-item:hover {
    transform: translateY(-2px);
    background: rgba(10, 26, 69, 0.18);
    box-shadow: 0 8px 16px rgba(0,0,0,.15);
}

/* Ícone e textos */
.stats-icon i {
    color: var(--stats-fg);
    font-size: 1.5rem;        /* levemente maior para legibilidade no fundo */
    line-height: 1;
    filter: drop-shadow(0 1px 0 rgba(0,0,0,.15));
}
.stats-label {
    margin: 0;
    color: var(--stats-muted);
    font-weight: 700;
}
.stats-value {
    margin: 0;
    color: var(--stats-fg);
    font-weight: 700;
}

/* Destaque da posição (substitui estilos inline) */
.rank {
    color: var(--stats-accent);
}

/* Harmoniza textos existentes nessa área */
.stats-row .custom-card-text { 
    color: var(--stats-fg);
    line-height: 1.4;
}

/* Responsividade: respiro entre itens em telas pequenas */
@media (max-width: 991.98px) {
    .stats-item { padding: 14px; }
    .stats-icon i { font-size: 1.4rem; }
}


@keyframes scrollInfinito {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-100%);
    }
}

/* Paleta rápida (bate com o seu tema) */
:root {
  --navy: #0A1A45;
  --green: #DBFC7E;
  --green-dark: #789484;
  --sand: #969183;
  --ink-900: #333;
  --ink-700: #666;
  --paper: #F5FFE6;
}

/* Cabeçalho do card (avatar + nome) */
.card-head {
  display: flex;
  align-items: center;
  gap: .8rem;
  margin-bottom: .75rem;
}
.card-head h4 {
  font-family: 'Roboto', sans-serif;
  font-size: 1.25rem;
  color: var(--navy);
  margin: 0;
}

/* Avatar circular reaproveitável */
.avatar { --size: 56px; --ring: 3px; --ring-color: var(--navy);
  width: var(--size); height: var(--size);
  border-radius: 50%; border: var(--ring) solid var(--ring-color);
  overflow: hidden; display: inline-flex; align-items: center; justify-content: center;
  background: var(--navy); flex-shrink: 0;
}
.avatar > img { width:100%; height:100%; object-fit: cover; display:block; }
.avatar > i { color:#fff; font-size: calc(var(--size)*0.45); }

/* Timeline simples */
.timeline .timeline-item { display:flex; gap:.75rem; margin-bottom:1rem; }
.timeline .timeline-icon {
  width: 44px; height: 44px; border-radius: 50%;
  display:flex; align-items:center; justify-content:center; color:#fff;
}
.timeline .timeline-icon.nomeacao { background: var(--green-dark); }
.timeline .timeline-icon.exoneracao { background: var(--sand); }
.timeline h5 { font-size: 1.05rem; color: var(--ink-900); margin: 0 0 .25rem; }

/* Pares chave-valor */
.kv { margin: 0 0 .25rem; }
.kv dt { color: var(--ink-700); font-weight: 700; display:inline; }
.kv dd { color: var(--ink-900); display:inline; margin: 0 0 0 .25rem; }

/* Título de seção dentro do card */
.section-subtitle {
  color: var(--green-dark); font-weight: 700;
  padding-bottom: .5rem; border-bottom: 1px solid rgba(0,0,0,.08);
  margin: 0 0 .75rem;
}

/* Botão navy consistente c/ seu tema */
.btn-navy { background: var(--navy); border-color: var(--navy); color: #fff; }
.btn-navy:hover { background: var(--green); border-color: var(--green); color: var(--navy); }

/* Caixas internas */
.box-soft { background: var(--paper); border-radius: 6px; }
.box-muted { background: #E0E0E0; border-radius: 6px; }

/* Linhas internas */
.row-tight > [class*="col"] { margin-bottom: .5rem; }


/* Seções de Conteúdo */
.secao-dados {
    width: 100vw;
    padding: 30px 0;
    margin-left: calc(50% - 50vw); /* Centraliza a seção com fundo colorido */
    background-color: #DBFC7E;
    opacity: 1;
    background: linear-gradient(135deg, #ff006255 25%, transparent 25%) -15px 0/ 30px 30px, linear-gradient(225deg, #ff0062 25%, transparent 25%) -15px 0/ 30px 30px, linear-gradient(315deg, #ff006255 25%, transparent 25%) 0px 0/ 30px 30px, linear-gradient(45deg, #ff0062 25%, #DBFC7E 25%) 0px 0/ 30px 30px;    
    margin-bottom: -15px;
}

.secao-dados .container {
    max-width: 1140px; /* Limita a largura do conteúdo dentro da seção */
    margin-bottom: -15px;
}

.secao-dados h2, .secao-dados p {
    color: #0A1A45;
}

.secao-dados h2 {
    color: #0A1A45;
    margin-bottom: 2px;
}

.secao-dados p {
    color: #0A1A45;
}

.secao-dados img {
    border-radius: 10px;
}

/* Estilo Customizado para os Cards */
.custom-card {
    background-color: #EDFBD8; /* Cor de fundo suave */
    border-radius: 12px; /* Bordas arredondadas */
    transition: transform 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
    padding: 20px;
    position: relative;
}

.custom-card:hover {
    transform: translateY(-5px); /* Elevação ao passar o mouse */
    box-shadow: 0 10px 15px rgba(0, 0, 0, 0.1); /* Sombra mais destacada no hover */
    background-image: repeating-linear-gradient(
        45deg,
        rgba(0, 0, 0, 0.05),
        rgba(0, 0, 0, 0.05) 10px,
        transparent 10px,
        transparent 20px
    ); /* Padrão de listas no hover */
}

.card-title {
    font-family: 'Roboto', sans-serif;
    font-size: 1.2rem;
    font-weight: 700;
    color: #0A1A45;
}

.custom-link {
    color: #0A1A45;
    text-decoration: none;
    transition: color 0.3s ease;
}

.custom-link:hover {
    color: #789484; /* Efeito hover */
}

.custom-card-text {
    font-family: 'Roboto', sans-serif;
    color: #0A1A45;
    font-size: 0.9rem;
    line-height: 1.5;
}

.badge {
    background-color: #0A1A45;
    color: #DBFC7E;
    font-size: 0.85rem;
    font-weight: 600;
    margin-bottom: 5px;
    display: inline-block;
}

/* Estilo para as estrelas (cadeiras) */
.stars span {
    background-color: #DBFC7E; /* Cor de fundo para destacar os ícones */
    border-radius: 50%; /* Deixa o fundo arredondado */
    padding: 5px;
    margin: 2px;
    display: inline-block;
    transition: background-color 0.3s ease;
}

.stars span img {
    width: 22px; /* Tamanho da cadeira */
    height: auto;
}

.stars span:hover {
    background-color: #789484; /* Cor no hover das cadeiras */
}

/* Estilização do Título */
.section-title {
    font-family: 'Roboto', sans-serif;
    font-size: 1.5rem;  /* Tamanho maior */
    font-weight: 500;   /* Peso mais forte */
    color: #0A1A45;     /* Azul escuro */
    margin-bottom: 20px;
    position: relative;
    padding-bottom: 10px;
}

.section-title::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    height: 3px;
    width: 80px;          /* Linha decorativa abaixo do título */
    background-color: #DBFC7E; /* Amarelo da paleta */
    border-radius: 2px;
}

/* Customização dos Alert Boxes */
.alert-custom {
    border-radius: 10px; /* Bordas arredondadas */
    padding: 15px;
    background-color: #F5FFE6; /* Fundo verde claro */
    border-left: 5px solid #DBFC7E; /* Borda lateral */
    color: #0A1A45;  /* Cor do texto */
    font-family: 'Roboto', sans-serif;
    font-size: 1rem;
}

.alert-custom .btn-close {
    color: #789484; /* Cor do botão de fechar */
}

.alert-custom-success {
    background-color: #DBFC7E; /* Fundo amarelo claro para sucesso */
    border-left: 5px solid #0A1A45; /* Borda azul escuro */
}

.alert-custom-warning {
    background-color: #F5FFE6; /* Fundo verde claro para aviso */
    border-left: 5px solid #789484; /* Borda verde escuro */
}

/* Estilização geral do Modal */
.modal-content {
    background-color: #F5FFE6;  /* Fundo verde claro */
    border-radius: 15px;        /* Bordas arredondadas */
    border: 3px solid #0A1A45;  /* Borda azul escuro */
    padding: 20px;
}

.modal-header {
    border-bottom: none;        /* Remove a linha padrão */
    padding-bottom: 10px;
}

.modal-title {
    font-family: 'Roboto', sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    color: #0A1A45;             /* Azul escuro */
    position: relative;
}

.modal-header .btn-close {
    color: #789484;             /* Cor verde escuro */
    font-size: 1.2rem;
}

.modal-body {
    font-family: 'Roboto', sans-serif;
    color: #0A1A45;             /* Texto na cor azul escuro */
    font-size: 1rem;
}

.modal-footer {
    border-top: none;           /* Remove a linha padrão */
    padding-top: 10px;
}

/* Estilização para botões dentro do modal */
.modal-footer .btn {
    background-color: #DBFC7E;  /* Fundo amarelo */
    color: #0A1A45;             /* Texto azul escuro */
    border-radius: 5px;
    padding: 10px 20px;
    transition: background-color 0.3s ease;
}

.modal-footer .btn:hover {
    background-color: #789484;  /* Muda a cor para verde escuro no hover */
    color: #F5FFE6;             /* Texto muda para verde claro no hover */
}

/* Estilização do Título */
.page-title {
    font-family: 'Roboto', sans-serif;
    font-size: 2rem;  /* Tamanho maior */
    font-weight: 700;   /* Peso mais forte */
    color: #0A1A45;     /* Cor rosa forte */
    margin-bottom: 20px;
    position: relative;
    padding-bottom: 10px;
}

.page-title::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    height: 3px;
    width: 80px;          /* Linha decorativa abaixo do título */
    background-color: #DBFC7E; /* Amarelo da paleta */
    border-radius: 2px;
}

/* Customização dos Filtros */
.form-label {
    font-family: 'Roboto', sans-serif;
    font-weight: 500;
    color: #0A1A45; /* Azul escuro */
}

.form-select, .form-control {
    border-radius: 8px;    /* Bordas arredondadas */
    border: 1px solid #0A1A45; /* Borda azul escuro */
    background-color: #F5FFE6; /* Fundo verde claro */
    color: #0A1A45; /* Cor do texto */
    padding: 10px;
    transition: border-color 0.3s ease;
}

.form-select:focus, .form-control:focus {
    border-color: #ff0062; /* Borda rosa ao focar */
    box-shadow: 0 0 5px rgba(255, 0, 98, 0.3);
}

.btn-primary {
    background-color: #0A1A45;
    border-color: #0A1A45;
    color: #F5FFE6;
    padding: 10px 20px;
    font-size: 1rem;
    border-radius: 8px;
    transition: background-color 0.3s ease;
}

.btn-primary:hover {
    background-color: #DBFC7E;
    border-color: #DBFC7E;
    color: #0A1A45;
}

/* Customização da Tabela */
.table {
    background-color: #F5FFE6;
    border-radius: 10px;
    overflow: hidden;
}

.table thead th {
    font-family: 'Roboto', sans-serif;
    font-weight: 700;
    background-color: #0A1A45;
    color: #F5FFE6;
    padding: 15px;
    text-align: left;
}

.table tbody tr {
    transition: background-color 0.3s ease;
}

.table tbody tr:hover {
    background-color: #DBFC7E; /* Destaque ao passar o mouse */
}

.table td {
    font-family: 'Roboto', sans-serif;
    color: #0A1A45;
    padding: 15px;
}

.table a {
    color: #0A1A45;
    text-decoration: none;
}

.table a:hover {
    text-decoration: underline;
}

.logo-index {
    margin-top: 20px;
    height: 33px;
    width: 77px;
}


#sidebar.expanded .logo-index {
    margin: 15px 0px 0px 0px;
    height: 86px;
    width: 180px;

}

/* Estilo linear para informações compactadas */
.info-compact {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    font-size: 18px;
    margin-bottom: 20px;
}

/* Seção de dados, sem cartões */
.data-section {
    background-color: #DBFC7E;
    padding: 20px;
    margin-bottom: 30px;
    border-radius: 8px;
    line-height: 1.6;
}

.data-section h3 {
    font-size: 24px;
    margin-bottom: 15px;
}

.data-section p {
    font-size: 16px;
}

/* Estilo para listas de sócios e atividades */
ul.lista-socios, ul.lista-atividades {
    list-style: none;
    padding: 0;
}

ul.lista-socios li, ul.lista-atividades li {
    margin-bottom: 10px;
}

/* Estilo para o endereço compacto */
.endereco {
    font-size: 18px;
    line-height: 1.4;
}

/* Call to action */
.cta {
    background-color: #789484;
    padding: 30px;
    color: #F5FFE6;
    text-align: center;
    border-radius: 8px;
    margin-bottom: 30px;
}

.cta a {
    color: #F5FFE6;
    text-decoration: none;
    font-weight: bold;
}

.cta a:hover {
    color: #ff0062;
}

/* Seção final */
.alert {
    background-color: #F5FFE6;
    color: #0A1A45;
    text-align: center;
    padding: 15px;
    border-radius: 8px;
}

/********* Estilo personalizado para os cards dos sócios *********/


/* Card personalizado para sócios */
.socio-card {
    background-color: #F5FFE6; /* Fundo claro */
    padding: 20px;
    border-radius: 10px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); /* Sombra sutil */
    margin-bottom: 20px;
    position: relative;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    text-align: center; /* Garante centralização do conteúdo */
}

.socio-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 12px rgba(0, 0, 0, 0.15);
}

/* Padrão quadriculado no fundo do card */
.socio-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: linear-gradient(#0A1A45 1px, transparent 1px),
                      linear-gradient(to right, #0A1A45 1px, transparent 1px);
    background-size: 20px 20px;
    opacity: 0.1;
    z-index: 0;
}

.socio-info {
    z-index: 1;
    position: relative;
    color: #0A1A45;
}

.socio-info h5 {
    font-size: 1.2rem;
    margin-bottom: 10px;
    font-weight: bold;
    color: #789484;
}

.socio-info p {
    font-size: 0.9rem;
    color: #0A1A45;
    margin-bottom: 5px;
}


/* Estilo para o botão de Reportar Erro */
.btn-reportar-erro {
    background-color: #ff0062; /* Cor de fundo vermelho para destacar erros */
    color: white; /* Texto branco */
    border: none;
    padding: 10px 20px;
    font-size: 1rem;
    font-weight: bold;
    text-transform: uppercase;
    border-radius: 5px;
    transition: background-color 0.3s ease;
}

.btn-reportar-erro:hover {
    background-color: #D32F2F; /* Escurece o vermelho no hover */
}

/* Estilo para o botão de Sugestões/Críticas */
.btn-sugestoes {
    background-color: #ff0062; /* Cor azul escura (consistente com o tema) */
    color: white;
    border: none;
    padding: 10px 20px;
    font-size: 1rem;
    font-weight: bold;
    text-transform: uppercase;
    border-radius: 5px;
    transition: background-color 0.3s ease;
}

.btn-sugestoes:hover {
    background-color: #DBFC7E; /* Altera para o verde claro da paleta no hover */
}

.badge.bg-deepnavy {
  background-color: #0A1A45;
  color: #fff;
  margin-left: -22px;
  padding-left: 24px;
}


/* Adiciona um espaçamento entre os botões quando em telas menores */
@media (max-width: 576px) {
    .btn-reportar-erro, .btn-sugestoes {
        width: 100%;
        margin-bottom: 10px;
    }
}

/* ==== Leg: Tabela + Pílulas + Abas (compatível com sua paleta) ==== */
.leg-card { background: var(--paper); }
.leg-table { background: var(--paper); border-radius: 12px; overflow: hidden; }
.leg-table thead th {
  background: var(--navy);
  color: var(--paper);
  font-weight: 700;
  padding: 12px 14px;
  border: 0;
}
.leg-table tbody td {
  color: var(--navy);
  padding: 12px 14px;
  vertical-align: middle;
  border-top: 1px solid rgba(10,26,69,.08);
}
.leg-table tbody tr:hover { background: var(--green); }

/* Pílulas (substituem badges Bootstrap padrão) */
.pill {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .35rem .6rem;
  border-radius: 999px;
  font-weight: 700;
  font-size: .85rem;
  line-height: 1;
  border: 1px solid transparent;
  margin: 0 .35rem .35rem 0;
  text-decoration: none;
  white-space: nowrap;
}
.pill--muted {
  background: rgba(10,26,69,.06);
  color: var(--navy);
  border-color: rgba(10,26,69,.15);
}
.pill--high {
  background: var(--green);
  color: var(--navy);
  border-color: var(--green);
  box-shadow: 0 4px 8px rgba(0,0,0,.12);
}
.pill--low {
  background: rgba(10,26,69,.10);
  color: var(--navy);
  border-color: rgba(10,26,69,.25);
}

/* Ícones/contadores dentro da pill (opcional) */
.pill i { font-size: .95em; }
.pill .count { opacity: .9; }

/* Aba temática (para Bootstrap .nav-tabs) */
.nav-tabs.nav-tabs-theme {
  border-bottom: 2px solid rgba(10,26,69,.12);
  margin-bottom: 10px;
}
.nav-tabs.nav-tabs-theme .nav-link {
  color: var(--navy);
  font-weight: 700;
  border: 0;
  border-bottom: 3px solid transparent;
  border-radius: 0;
  padding: .6rem .9rem;
}
.nav-tabs.nav-tabs-theme .nav-link:hover {
  background: rgba(10,26,69,.06);
  border-color: transparent;
}
.nav-tabs.nav-tabs-theme .nav-link.active {
  color: var(--navy);
  background: transparent;
  border-color: var(--green);
  box-shadow: inset 0 -2px 0 var(--green);
}

/* Utilitário para cabeçalhos de coluna estreitos (evita inline styles) */
.col-w-120 { width: 120px; }
.col-w-90  { width: 90px; }

/* Espaçamento fino no container da tabela */
.leg-table-wrap { margin-top: 2px; }
