/* ==========================================================================
   LAFER — Cleaned Stylesheet
   - Indentation normalized (2 spaces)
   - Duplicates/overwrites consolidated
   - Unused vendor prefixes trimmed
   - Sections grouped logically
   ========================================================================== */

/* --------------------------------------------------------------------------
   1) ROOT & TOKENS
   -------------------------------------------------------------------------- */
:root {
  --lafer-blue: #0c183b;
  --lafer-blue-dark: #001843;
  --lafer-gold: #C8A24B;
  --lafer-gold-soft: #ffe0a9;
  --lafer-gold-alt: #c89d5d;
  --white: #ffffff;
  --black: #000000;

  --shadow-outer: 0 8px 20px rgba(12, 24, 59, 0.6);
  --shadow-inner: 0 0 15px rgba(12, 24, 59, 0.5) inset;
  --shadow-depth: 0 4px 8px rgba(12, 24, 59, 0.4);
}

/* --------------------------------------------------------------------------
   2) BASE
   -------------------------------------------------------------------------- */
html, body {
  height: 100%;
  font-family: 'Montserrat', sans-serif;
  font-size: 14px;
  font-weight: 300;
  color: inherit;
}

a,
a:hover {
  text-decoration: none;
  color: inherit;
}

/* Typography scale */
h1, .h1 { font-size: 4em; }
h2, .h2 { font-size: 3em; }
h3, .h3 { font-size: 2em; }
h4, .h4 { font-size: 1.8em; }
h5, .h5 { font-size: 1.6em; }
h6, .h6 { font-size: 1.4em; }
.h7       { font-size: 1.1em; }

/* Font utilities */
.font-thin    { font-weight: 200; }
.font-normal  { font-weight: 300; }
.font-medium  { font-weight: 400; }
.font-bold    { font-weight: 600; }
.font-white   { color: var(--white); }
.font-blue    { color: #0c183b; }
.font-gold    { color: var(--lafer-gold-soft) !important; }
.font-dark-gold { color: var(--lafer-gold-alt) !important; }

/* Background utilities */
.bg-white { background: var(--white); }
.bg-gold  { background: var(--lafer-gold-soft); }
.bg-blue  { background: var(--lafer-blue-dark); }

/* Media */
img.logo { max-width: 70px; }

/* --------------------------------------------------------------------------
   3) DIVIDERS
   -------------------------------------------------------------------------- */
.divider {
  position: relative;
  width: 130%;
  margin: 15px 0;
  border-bottom: 1px solid #a47044;
  z-index: 1;
}

.divider-slider {
  width: 150px;
  margin: 30px 0;
  border-bottom: 2px solid var(--lafer-gold-soft);
}

.divider-integer {
  width: 170%;
  margin-bottom: 50px;
  border-bottom: 2px solid #bc9d64;
}

.divider-right {
  margin-left: -100px;
  margin-bottom: 30px;
  border-bottom: 1px solid #bc9d64;
}

/* --------------------------------------------------------------------------
   4) BUTTONS
   -------------------------------------------------------------------------- */
.btn-style1 {
  padding: 12px 40px;
  border-radius: 0;
  border: 2px solid var(--lafer-blue);
  border-bottom: none !important;
  background: var(--white);
  color: var(--lafer-blue) !important;
  font-weight: 600;
  font-size: 1.2em;
  transition: background .2s ease;
}

.btn-style1:hover {
  background: var(--lafer-blue);
  color: var(--lafer-gold-soft) !important;
  text-decoration: none;
}

/* Elegant gold CTA */
.btn-gold {
  display: inline-block;
  padding: 12px 24px;
  border-radius: 9999px;
  font-weight: 600;
  letter-spacing: .3px;
  text-decoration: none;
  background: linear-gradient(135deg, #c8a158, #e0c27a);
  color: #1d1d1f;
  box-shadow: 0 6px 14px rgba(200, 161, 88, 0.35), inset 0 1px 0 rgba(255,255,255,.35);
  border: 1px solid rgba(84, 62, 21, .15);
  transition: transform .15s ease, box-shadow .2s ease, filter .2s ease;
}

.btn-gold:hover,
.btn-gold:focus {
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(200, 161, 88, 0.45);
  filter: brightness(1.03);
  color: #1d1d1f;
}

.btn-gold:active {
  transform: translateY(0);
  box-shadow: 0 4px 10px rgba(200, 161, 88, 0.35);
}

/* Keyboard accessibility */
.btn-gold:focus-visible {
  outline: 3px solid #b38b42;
  outline-offset: 2px;
}

/* --------------------------------------------------------------------------
   5) HERO / SLIDER (Nivo)
   -------------------------------------------------------------------------- */
.nivo-caption {
  position: absolute;
  top: 40%;
  left: 10%;
  width: 80%;
  background: transparent;
}

.nivo-caption .h2 {
  font-size: 3em;
  font-weight: 700;
  color: #FFD700;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, .8);
}

.nivo-caption .h4 {
  font-size: 1.8em;
  font-weight: 600;
  color: var(--white);
  text-shadow: 1px 1px 3px rgba(0, 0, 0, .7);
}

/* --------------------------------------------------------------------------
   6) TITLES
   -------------------------------------------------------------------------- */
.detail-title       { color: #a47044; position: relative; }
.detail-title:before {
  content: "";
  position: absolute;
  top: -10px;
  width: 100px;
  height: 3px;
  border: 4px solid var(--lafer-blue);
}

.detail-title-invert { color: var(--lafer-blue); position: relative; }
.detail-title-invert:before {
  content: "";
  position: absolute;
  top: -10px;
  width: 100px;
  height: 3px;
  border: 4px solid #a47044;
}

.detail-title2 { color: var(--lafer-blue); position: relative; }
.detail-title2:before {
  content: "";
  position: absolute;
  top: -10px;
  width: 100px;
  height: 3px;
  border: 4px solid var(--lafer-blue);
}

.detail-title3 { color: var(--lafer-blue); position: relative; }
.detail-title3:before {
  content: "";
  position: absolute;
  bottom: -10px;
  width: 100px;
  border: 3px solid #cba265;
  background: var(--lafer-gold-alt);
}

/* Optional small gold subtitle used within .h5 containers */
.h5 .gold-title-sm {
  color: var(--lafer-gold);
  font-weight: 500;
  font-size: clamp(1.5rem, 1.6vw, 1.8rem);
  line-height: 1.2;
}

/* --------------------------------------------------------------------------
   7) LAYOUT SECTIONS
   -------------------------------------------------------------------------- */
section#title .services > .row,
section#title .contact > .row,
section#title.faq .row {
  min-height: 750px;
}

section#title.faq {
  background: url('../img/bg_faq.jpg') top center no-repeat;
  min-height: 750px;
}

section#about-content,
section#como-funciona,
section#faq-content {
  margin-top: 50px;
  position: relative;
  z-index: 1;
}

/* Content card look */
.about-content-shadow {
  box-shadow: 0 2px 5px 3px rgba(0,0,0,.1);
  background: #fff;
  padding: 100px;
}

/* Recolored, unified cards for multiple sections */
#about-content .about-content-shadow,
#como-funciona .about-content-shadow,
#faq-content .about-content-shadow,
#fale-conosco .about-content-shadow {
  box-shadow: var(--shadow-outer), var(--shadow-inner), var(--shadow-depth);
  background: rgba(12, 24, 59, .9) !important;
  color: var(--white);
  border-radius: 10px;
}

/* Specific spacing tweaks */
section#como-funciona .about-content-shadow { padding-left: 50px !important; padding-right: 50px !important; }
section#about-content .about-content-shadow { padding: 50px; }

/* Contact (Fale Conosco) container width */
#fale-conosco .about-content-shadow {
  width: 95%;
  margin: 0 auto;
  text-align: left;
  padding: 1rem;
}

/* Contact info colors */
#fale-conosco .contact-info,
#fale-conosco .contact-info a,
#fale-conosco .contact-info h4 {
  color: var(--white) !important;
}
#fale-conosco .contact-info a i.fa-envelope { color: var(--white) !important; }

/* Contact submit button */
#fale-conosco button[type="submit"] {
  background: var(--lafer-gold-alt) !important;
  color: var(--white) !important;
  border: none;
  padding: 12px 40px;
  border-radius: 5px;
  font-size: 1.2em;
  font-weight: bold;
  transition: background .3s ease-in-out;
}
#fale-conosco button[type="submit"]:hover {
  background: var(--lafer-gold-soft) !important;
  color: var(--lafer-blue) !important;
}

/* --------------------------------------------------------------------------
   8) NAVBAR & DROPDOWNS
   -------------------------------------------------------------------------- */
nav.navbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100px;
  line-height: 50px;
  background: var(--white) !important;
  box-shadow: 0 4px 6px rgba(0,0,0,.1);
  z-index: 1050;
}

nav.navbar .container {
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex;
  justify-content: center;
  align-items: center;
}

.navbar-brand {
  display: flex;
  align-items: center;
  margin-right: 25px;
  padding-left: 20px;
}

.navbar-toggler {
  display: flex;
  align-items: center;
  border: 2px solid var(--lafer-blue) !important;
  background: transparent;
  border-radius: 5px;
  padding: 5px 10px;
}
.navbar-toggler:focus,
.navbar-toggler:active {
  border-color: var(--lafer-blue) !important;
  outline: none;
  box-shadow: 0 0 5px rgba(34,61,103,.5);
}
.custom-toggler .navbar-toggler-icon {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='%230c183b' stroke-width='3' stroke-linecap='round' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E");
}

/* Top-level nav links */
ul.navbar-nav .nav-item .nav-link {
  font-weight: 700;
  color: #000 !important;
  border-left: 2px solid var(--lafer-blue);
  padding: 0 50px;
  font-size: 1.05em !important;
}
ul.navbar-nav .nav-item:first-child .nav-link { border-left: none; }
ul.navbar-nav .nav-item .nav-link:hover,
ul.navbar-nav .nav-item.active .nav-link {
  color: var(--lafer-blue) !important;
  text-decoration: underline;
  background: #e8cb9c;
}

/* Dropdowns */
.dropdown-menu {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 1000;
  display: none;
  min-width: 10rem;
  font-size: 1rem;
  color: #212529;
  list-style: none;
  background-color: var(--lafer-blue);
  background-clip: padding-box;
  border: 1px solid rgba(0,0,0,.15);
  border-radius: 0;
}
.dropdown-item {
  display: block;
  width: 100%;
  padding: 10px 20px;
  font-weight: 300;
  color: var(--white);
  background-color: transparent;
  border: 0;
}
.dropdown-item:hover,
.dropdown-item:focus {
  color: #16181b;
  background: #e8cb9c;
  text-decoration: none;
}

/* Hover dropdown behavior */
.dropdown > .dropdown-menu { top: 200%; transition: .3s all ease-in-out; }
.dropdown:hover > .dropdown-menu { display: block; top: 100%; }
.dropdown > .dropdown-toggle:active { pointer-events: none; }

/* --------------------------------------------------------------------------
   9) ACCORDION (FAQ)
   -------------------------------------------------------------------------- */
/* OLD / Unused Rules - Kept for reference if needed */
.accordion .card-header {
  background: var(--lafer-blue);
  padding: 15px 50px;
  cursor: pointer;
}
.accordion .card-header:after {
  content: "\f068";
  float: right;
  color: #bc9d64;
  font-family: 'FontAwesome';
}
.accordion .card-header.collapsed:after { content: "\f067"; color: #bc9d64; }

.accordion .card-body {
  font-size: 1.3em;
  box-shadow: 0 2px 5px 3px rgba(0,0,0,.5);
  margin: 5px 0;
}

/* NEW — Custom Accordion for Readability */
.accordion-item { 
  /* Thicker, slightly more opaque line for better separation */
  border-bottom: 2px solid rgba(255, 255, 255, 0.15); 
}
.accordion-item:last-child { border-bottom: none; }

#faq-content .accordion-item button,
.accordion-item button {
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  outline: none;
  padding: 1.25rem 1.5rem;
  font-size: 1.2em;
  color: var(--white);
  font-weight: 600;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

#faq-content .accordion-item button:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.accordion-item .content {
  display: none;
  padding: 1.5rem 1.75rem;
  /* Increased font size and weight for desktop readability */
  font-size: 1.2rem; 
  font-weight: 400; 
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.9);
  background-color: rgba(0, 0, 0, 0.2);
}

/* Style for text elements inside the content area */
#faq-content .content p { margin-bottom: 1rem; }
#faq-content .content p:last-child { margin-bottom: 0; }

#faq-content .content ul {
  padding-left: 25px;
  margin: 1.25rem 0;
  list-style-type: '✓  '; /* Custom bullet */
  color: var(--lafer-gold-soft); /* Color for the custom bullet */
}
#faq-content .content ul li {
  padding-left: 10px;
  margin-bottom: 0.8rem;
  color: rgba(255, 255, 255, 0.9); /* Text color for list items */
}
#faq-content .content a {
  color: var(--lafer-gold-soft);
  text-decoration: underline;
  font-weight: 500;
}

.accordion-item.active .content { display: block; }


/* --------------------------------------------------------------------------
   10) FOOTER
   -------------------------------------------------------------------------- */
footer {
  background: var(--lafer-blue);
  padding: 60px 0 25px;
}

ul.info-bottom {
  list-style: none;
  margin: 0;
  padding: 0;
}
ul.info-bottom li {
  display: flex;
  align-items: center;
  color: var(--white);
  margin-bottom: 15px;
  padding: 0;
}
ul.info-bottom li img {
  width: 35px;
  margin-right: 10px;
  margin-top: -5px;
}
ul.info-bottom li .h6 { font-weight: 200; }

.copyright {
  background: var(--lafer-gold-alt);
  color: var(--white);
  padding: 10px 0;
  font-size: 1.2em;
}

/* --------------------------------------------------------------------------
   11) TABLES — COMPARATIVO
   -------------------------------------------------------------------------- */
.compare-table {
  border-collapse: separate;
  border-spacing: 0;
  font-size: .98rem;
}
.compare-table thead th {
  border: 2px solid rgba(0,0,0,.25) !important;
  padding: 14px 16px !important;
  vertical-align: middle;
}
.compare-table tbody th,
.compare-table tbody td {
  border: 2px solid rgba(0,0,0,.12) !important;
  padding: 14px 16px !important;
}
.compare-table thead th:first-child,
.compare-table tbody td:first-child {
  font-weight: 600;
  color: #243447;
  background: #f5f7fa;
  position: sticky;
  left: 0;
  z-index: 2;
}
.compare-table tbody tr:nth-child(even) td { background: #fbfcfe; }
.compare-table tbody tr:hover td { background: #fffbe9; }
.compare-table thead th:nth-child(2),
.compare-table tbody td:nth-child(2) {
  border-left-width: 3px !important;
  border-right-width: 3px !important;
}
.compare-table thead th:nth-child(3),
.compare-table tbody td:nth-child(3) {
  border-right-width: 3px !important;
}

/* --------------------------------------------------------------------------
   12) RESPONSIVE
   -------------------------------------------------------------------------- */

/* <= 1199px : collapse menu; tune containers */
@media (max-width: 1329px) {
  .navbar-expand-xl .navbar-collapse { display: none !important; }
  .navbar-expand-xl .navbar-toggler { display: block !important; }
}

/* <= 991px : mobile layout */
@media (max-width: 991px) {
  /* Hero captions */
  .nivo-caption { top: 50%; width: 90%; }
  .nivo-caption .h2 { font-size: 1.8em; }
  .nivo-caption .h4 { font-size: 1.2em; }

  /* Cards spacing and padding */
  section#about-content { margin-top: 0; }
  section#como-funciona .about-content-shadow {
    margin-top: 0 !important;
    padding: 40px 50px 0 !important;
    margin-bottom: 0 !important;
  }
  section#about-content .about-content-shadow {
    width: 100% !important;
    padding: 30px !important;
  }

  /* Columns re-ordering */
  #about-content .col-md-4,
  #como-funciona .col-md-4,
  #faq-content .col-md-4 { order: 1; text-align: center; margin-bottom: 30px; }
  #about-content .col-md-8,
  #como-funciona .col-md-8,
  #faq-content .col-md-8 { order: 2; }
  #faq-content .col-md-8 .about-content-shadow { padding: 20px !important; }

  /* FAQ buttons full width */
  #faq-content .accordion-item button {
    padding-left: 0 !important;
    padding-right: 0 !important;
    width: 100% !important;
  }

  /* CTA vertical rhythm */
  #about-content .about-content-shadow,
  #como-funciona .about-content-shadow { padding-bottom: 32px !important; }
  #about-content .about-content-shadow .btn-gold,
  #como-funciona .about-content-shadow .btn-gold {
    display: inline-block;
    margin: 20px 0;
  }

  /* Mobile nav dropdown surface */
  .navbar-collapse {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0; /* Garante que ocupe 100% da largura */
    background: var(--white);
    box-shadow: 0 10px 5px rgba(0,0,0,.2);
    padding: 15px 0; /* Remove o padding lateral */
    z-index: 1000;
  }
}

/* <= 650px : banner spacing */
@media (max-width: 650px) {
  .nivoSlider .nivo-caption,
  .nivoSlider .nivo-html-caption { top: 20% !important; }
  #banner { margin-top: 80px; }
}

/* <= 500px : hide big CTA button in slider */
@media (max-width: 500px) {
  .nivoSlider .btn-style1 { display: none !important; }
}

/* <= 400px : shrink hero text further */
@media (max-width: 400px) {
  .nivo-caption .h2 { font-size: 1.25em !important; }
  .nivo-caption .h4 { font-size: .95em !important; }
}

/* <= 319px : extreme small devices */
@media (max-width: 319px) {
  #banner { display: none !important; }
  #about-content {
    margin-top: 100px;
    padding-top: 100px;
  }
}

/* Between 768px and 1090px : contact padding refinement */
@media (min-width: 768px) and (max-width: 1090px) {
  #fale-conosco .contact-info {
    padding-left: 5%;
    padding-top: 5%;
  }
}

/* >= 1090px : contact padding */
@media (min-width: 1090px) {
  #fale-conosco .contact-info {
    padding-left: 12%;
    padding-top: 5%;
  }
}

/* === NAVBAR: centralizado + separadores verticais === */
nav.navbar { justify-content: center; }
nav.navbar .container { justify-content: center; }
.navbar-collapse { flex-grow: 0; }              /* largura só do conteúdo */
ul.navbar-nav { display: flex; align-items: center; }

/* Espaçamento dos links */
ul.navbar-nav .nav-link {
  padding: 0 32px;
  line-height: 50px;
}

/* Separadores: só entre itens adjacentes */
@media (min-width: 992px) {
  ul.navbar-nav .nav-item + .nav-item .nav-link {
    border-left: 2px solid var(--lafer-blue);
  }
  /* Sem borda no primeiro nem no último */
  ul.navbar-nav .nav-item:first-child .nav-link { border-left: none; }
  ul.navbar-nav .nav-item:last-child .nav-link { border-right: none; }
}

/* Mobile (menu colapsado): sem separadores verticais; usa divisor horizontal sutil */
@media (max-width: 991.98px) {
  ul.navbar-nav .nav-link {
    border: none;
    padding: 10px 20px;
  }
  .navbar-collapse .nav-item + .nav-item .nav-link {
    border-top: 1px solid rgba(0,0,0,.1);
  }
}

/* === Emphasis for 'Bancos Tradicionais' e 'FIDC Convencionais' === */
.about-content-shadow table thead th:nth-child(3),
.about-content-shadow table tbody td:nth-child(3),
.about-content-shadow table thead th:nth-child(4),
.about-content-shadow table tbody td:nth-child(4) {
  font-weight: 500 !important;
  font-size: 1.02em;
}

/* Bordas mais fortes nas colunas 3 e 4 */
.about-content-shadow table thead th:nth-child(3),
.about-content-shadow table tbody td:nth-child(3) {
  border-left-width: 3px !important;
  border-right-width: 3px !important;
}

.about-content-shadow table thead th:nth-child(4),
.about-content-shadow table tbody td:nth-child(4) {
  border-right-width: 3px !important;
}

/* Tamanho maior para o CTA "Fale com quem decide" sem mudar o estilo base */
.cta .btn-gold.btn-xl {
  /* aumenta a hierarquia apenas com tamanho e respiro */
  font-size: clamp(18px, 2.4vw, 22px);
  padding: 18px 44px;
  line-height: 1.15;
  display: inline-block;
  /* mantém o mesmo "look", só que maior */
}

/* Em telas pequenas, deixar bem proeminente (largura total e centralizado) */
@media (max-width: 576px) {
  .cta .btn-gold.btn-xl {
    display: block;
    width: 100%;
    text-align: center;
  }
}

/* Opcional: leve prioridade visual na coluna direita */
@media (min-width: 768px) {
  .cta { text-align: left; } /* já costuma estar, mas garantimos */
  .cta .btn-gold.btn-xl { margin-top: 8px; }
}

/* Dropdown "Saiba mais" visível no hover (desktop) */
@media (min-width: 992px){
  .navbar .dropdown.has-saiba:hover > .dropdown-menu{
    display: block;
  }
  .navbar .dropdown-menu{
    margin-top: 0;              /* encosta no item do menu */
    border-radius: 8px;
    border: 0;
    box-shadow: 0 10px 25px rgba(0,0,0,.12);
  }
  .navbar .dropdown-item{
    font-weight: 600;
  }
}

/* Mobile: controlamos via classe .show no <li> */
@media (max-width: 991.98px){
  .navbar .dropdown-menu{
    display: none;
  }
  .navbar .dropdown.show > .dropdown-menu{
    display: block;
  }
}

/* === Tornar 990–1199px idêntico a < 990px para o menu === */
@media (min-width: 990px) and (max-width: 1329.98px) {
  /* barra fixa (top strip) como no mobile */
  nav.navbar {
    background: #fff !important;
    box-shadow: 0 10px 5px rgba(0,0,0,.2);
  }

  /* painel colapsado idêntico ao mobile */
  .navbar-collapse {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0; /* Garante que ocupe 100% da largura */
    background: #fff !important;
    box-shadow: 0 10px 5px rgba(0,0,0,.2);
    padding: 15px 0; /* Remove o padding lateral */
    z-index: 1000;
  }

  /* links e divisores como no mobile */
  ul.navbar-nav .nav-link {
    border: none;
    padding: 10px 20px;
  }
  .navbar-collapse .nav-item + .nav-item .nav-link {
    border-top: 1px solid rgba(0,0,0,.1);
  }
}

/* === Clonar comportamento do mobile (Saiba mais visível) em 992–1199px === */
@media (min-width: 992px) and (max-width: 1329.98px) {
  /* Quando a barra estiver aberta (colapsada), mostre o submenu abaixo do item pai */
  .navbar.navbar-expand-xl .navbar-collapse.show .dropdown.has-saiba > .dropdown-menu {
    display: block !important;     /* igual ao mobile */
    position: static !important;
    float: none !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0.15rem 0 0.35rem 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
  }

  .navbar.navbar-expand-xl .navbar-collapse.show
  .dropdown.has-saiba > .dropdown-menu .dropdown-item {
    display: block;
    padding: .25rem 1rem .45rem 1.75rem;
    font-size: .95rem;
    font-weight: 600;
    opacity: .95;
  }

  .navbar.navbar-expand-xl .navbar-collapse.show
  .dropdown.has-saiba > .dropdown-menu .dropdown-item::before {
    content: "↳ ";
    margin-right: .15rem;
    opacity: .8;
  }
}

/* === Legibilidade no menu colapsado (mobile e 992–1199px) === */

/* 1) Mobile (< 992px): texto escuro no submenu que fica com bg transparente */
@media (max-width: 991.98px) {
  .navbar .dropdown.has-saiba > .dropdown-menu .dropdown-item {
    color: #0c183b !important;          /* azul-escuro da identidade */
    font-weight: 600;                    /* mantém destaque */
  }
  .navbar .dropdown.has-saiba > .dropdown-menu .dropdown-item:hover,
  .navbar .dropdown.has-saiba > .dropdown-menu .dropdown-item:focus {
    color: #0c183b !important;
    background: #e8cb9c;                 /* mesmo hover já usado no site */
  }
}

/* 2) Barra colapsada entre 992–1199px: idêntico ao mobile */
@media (min-width: 992px) and (max-width: 1329.98px) {
  .navbar-collapse.show .dropdown.has-saiba > .dropdown-menu .dropdown-item {
    color: #0c183b !important;
    font-weight: 600;
  }
  .navbar-collapse.show .dropdown.has-saiba > .dropdown-menu .dropdown-item:hover,
  .navbar-collapse.show .dropdown.has-saiba > .dropdown-menu .dropdown-item:focus {
    color: #0c183b !important;
    background: #e8cb9c;
  }
}

/* === NAVBAR (colapsada): alinhamento e recuos === */
@media (max-width: 1329.98px) {
  /* Painel colapsado: tudo à esquerda */
  .navbar .navbar-collapse {
    text-align: left !important;
  }
  .navbar .navbar-collapse .navbar-nav {
    width: 100%;
    /* Adiciona o espaçamento lateral aqui, para que o fundo vá até as bordas */
    padding-left: 20px;
    padding-right: 20px;
  }
  .navbar .navbar-collapse .nav-item,
  .navbar .navbar-collapse .nav-link,
  .navbar .navbar-collapse .dropdown-item {
    text-align: left !important;
  }

  /* Itens de 1º nível (títulos das seções) */
  .navbar .navbar-collapse .nav-link {
    border: 0 !important;        /* sem divisores verticais no colapsado */
    padding: 10px 20px !important;
    line-height: 1.4;
  }
  .navbar .navbar-collapse .nav-item + .nav-item .nav-link {
    border-top: 1px solid rgba(0,0,0,.10); /* divisor horizontal sutil */
  }

  /* “Saiba mais”: leve indentação à direita do início do título */
  /* 20px (padding do título) + 16px (recuo extra) = 36px */
  .navbar .navbar-collapse .dropdown.has-saiba > .dropdown-menu {
    display: block !important;   /* visível abaixo do pai no colapsado */
    position: static !important;
    float: none !important;
    padding: 0 !important;
    margin: 4px 0 8px 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
  }
  .navbar .navbar-collapse .dropdown.has-saiba > .dropdown-menu .dropdown-item {
    padding: .25rem 1rem .45rem 36px !important; /* recuo calibrado */
    font-size: .95rem; font-weight: 600; opacity: .95;
  }
  .navbar .navbar-collapse .dropdown.has-saiba > .dropdown-menu .dropdown-item::before{
    content: "↳ ";
    margin-right: .15rem;
    opacity: .8;
  }
}

/* === Desktop (>=1200px): eliminar o vão e manter centralizado === */
@media (min-width: 1330px) {
  .navbar .dropdown.has-saiba { position: relative; }

  /* Centraliza sob o texto e cola no item (sem gap) */
  .navbar .dropdown.has-saiba > .dropdown-menu {
    left: 50% !important;
    transform: translateX(-50%) !important;
    right: auto !important;

    top: 100% !important;        /* substitui o top:50px herdado */
    margin-top: 0 !important;    /* encostado no item */
    z-index: 1050;               /* acima da barra */
  }

  /* Ponte invisível de 10px entre o item e o dropdown:
     o mouse pode atravessar sem perder o :hover no <li> */
  .navbar .dropdown.has-saiba::after {
    content: "";
    position: absolute;
    left: 0; right: 0;
    top: 100%;
    height: 10px;                /* ajuste fino: 8–14px */
  }

  /* Garante abertura por hover/foco (desktop) */
  .navbar .dropdown.has-saiba:hover > .dropdown-menu,
  .navbar .dropdown.has-saiba:focus-within > .dropdown-menu {
    display: block;
  }
}

/* === Navbar mobile (<= 1199.98px): logo central e hambúrguer à direita === */
@media (max-width: 1329.98px) {
  /* dá contexto para posicionar o logo no centro e define a altura */
  .navbar .container {
    position: relative;
    height: 100%; /* Faz o container ocupar a altura total da navbar */
  }

  /* centraliza o logo (sem alterações) */
  .navbar .navbar-brand {
    position: absolute !important;
    left: 50%;
    transform: translateX(-50%);
    margin: 0 !important;
    padding-left: 0 !important; /* anula recuo atual */
  }

  /* empurra o botão hambúrguer para a direita e o alinha na base */
  .navbar .navbar-toggler {
    margin-left: auto;           /* ocupa a borda direita do container */
    display: flex;
    align-items: center;
    align-self: flex-end;     /* Alinha o botão na parte inferior do container */
    margin-bottom: 12px;      /* Adiciona um respiro para não colar na borda inferior */
  }
}

/* === SAFETY OVERRIDE: Navbar colapsada até 1330px === */
@media (max-width: 1329.98px) {
  .navbar.navbar-expand-xl .navbar-collapse { display: none !important; }
  .navbar.navbar-expand-xl .navbar-toggler  { display: block !important; }

  .navbar .navbar-collapse {
    position: absolute; top: 100%; left: 0; right: 0;
    background: #fff !important; box-shadow: 0 10px 5px rgba(0,0,0,.2);
    padding: 15px 0; z-index: 1000;
  }
  .navbar .navbar-collapse .nav-link {
    border: 0 !important; padding: 10px 20px; line-height: 1.4;
  }
  .navbar .navbar-collapse .nav-item + .nav-item .nav-link {
    border-top: 1px solid rgba(0,0,0,.10);
  }
  .navbar .navbar-collapse .dropdown.has-saiba > .dropdown-menu{
    display:block !important; position:static !important; float:none !important;
    padding:0 !important; margin:4px 0 8px 0 !important;
    background:transparent !important; border:0 !important; box-shadow:none !important;
  }
  .navbar .navbar-collapse .dropdown.has-saiba > .dropdown-menu .dropdown-item{
    padding:.25rem 1rem .45rem 36px !important; font-size:.95rem; font-weight:600; opacity:.95;
  }
  .navbar .navbar-collapse .dropdown.has-saiba > .dropdown-menu .dropdown-item::before{
    content:"↳ "; margin-right:.15rem; opacity:.8;
  }
}

@media (min-width: 1330px) {
  .navbar.navbar-expand-xl .navbar-collapse { display: flex !important; }
  .navbar.navbar-expand-xl .navbar-toggler  { display: none !important; }
}

/* Centralizar o menu colapsado entre 1200–1329px */
@media (min-width: 1200px) and (max-width: 1329.98px) {
  /* Centraliza o conteúdo aberto do collapse */
  .navbar.navbar-expand-xl .navbar-collapse.show {
    justify-content: center !important;
  }

  /* Centraliza a pilha de itens */
  .navbar.navbar-expand-xl .navbar-collapse.show .navbar-nav {
    flex-direction: column !important;
    align-items: center !important;   /* <-- antes estava stretch */
    margin: 0 !important;
  }

  /* Dropdown como lista vertical, alinhado e centralizado */
  .navbar.navbar-expand-xl .navbar-collapse.show .dropdown-menu {
    display: block !important;
    position: static !important;
    float: none !important;
    width: auto !important;           /* mantém a largura do conteúdo */
    padding: 0.15rem 0 !important;
    margin: .15rem 0 .35rem 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    text-align: center !important;    /* centraliza o texto */
  }

  .navbar.navbar-expand-xl .navbar-collapse.show .nav-link,
  .navbar.navbar-expand-xl .navbar-collapse.show .dropdown-item {
    display: block !important;
    width: auto !important;           /* evita ocupar 100% e “puxar” à esquerda */
    padding: .25rem 1rem .45rem 1rem !important;
    text-align: center !important;
  }
}

/* Remover animação do Bootstrap Collapse globalmente (abre/fecha instantâneo) */
.collapse,
.navbar-collapse {
  /* Anula a var do BS5 e quaisquer transitions herdadas */
  --bs-collapse-transition: none !important;
  transition: none !important;
}

/* Estado intermediário que o Bootstrap aplica durante o toggle */
.collapsing {
  transition: none !important;
  height: auto !important;   /* evita tween de altura */
  overflow: visible !important;
}

/* (Opcional) Garante que nada dentro do menu cause micro-delays */
.navbar .navbar-collapse.show,
.navbar .navbar-collapse.show * {
  transition: none !important;
}
