/* NAVBAR E HEADER */

.collapse.navbar-collapse {
  margin-top: 50px;
}

/* @media (max-width: 576px) {
  .navbar-brand img {
    max-width: 150px; 
    content: url("https://www.caraguatatuba.sp.gov.br/assets/logos/brasao.png");
  }
} */


/* INDEX */
 .separator {
     display: flex;
     align-items: center;
     text-align: center;
 }

 .separator::before,
 .separator::after {
     content: '';
     flex: 1;
     border-bottom: 1px solid #000;
 }

 .separator:not(:empty)::before {
     margin-right: .25em;
 }

 .separator:not(:empty)::after {
     margin-left: .25em;
 }

 .titulo-assunto {
     font-size: 1.7rem;
 }

 .separator {
     margin-top: 30px;
 }

 .icones-destaque {
     margin-bottom: 70px;
 }


 /* MAPA */
 .map {
     width: 1080px;
     height: 580px;
     margin: 0 auto;
     border-radius: 10px;
     margin-bottom: 30px;
     position: relative;
 }

 .mapboxgl-popup {
     max-width: 400px;
     font: 12px/20px 'Helvetica Neue', Arial, Helvetica, sans-serif;
 }

 @media (max-width: 1440px) {
  .map {
    width: 100%;
  }
 }


 /* BARRA DE ACESSIBILIDADE */
 .acessibilidade-menu {
  background: #fff;
  border-bottom: 1px solid #e5e5e5;
  font-size: 1rem;
  padding: 0.5rem 0; 
  box-shadow: 0 2px 4px rgba(0,0,0,0.03);
  z-index: 1000;
}

.acessibilidade-menu ul {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0 1rem;
  justify-content: space-between;
  align-items: center;
}

.acessibilidade-menu-group {
  display: flex;
  width: 50%;
  justify-content: flex-start;
}

.acessibilidade-menu-group:last-child {
  justify-content: flex-end;
}

.acessibilidade-menu li {
  margin-right: 1.2rem;
}

@media (max-width: 1440px) {
  .acessibilidade-menu ul {
    flex-direction: column;
    padding: 0 0.5rem;
  }
  .acessibilidade-menu-group {
    flex-direction: column;
    width: 100%;
    gap: 0.3rem;
    justify-content: flex-start;
  }
}

.acessibilidade-menu li {
  margin-right: 1.2rem;
}

.acessibilidade-menu a {
  color: #0056b3;
  text-decoration: none;
  font-weight: 500;
  padding: 4px 8px;
  border-radius: 3px;
  transition: background 0.2s, color 0.2s;
  outline: none;
  font-family: 'Oswald', Arial, sans-serif;
  position: relative;
}

.acessibilidade-menu a::after {
  content: attr(accesskey);
  display: inline-block;
  background: #003366;
  color: #fff;
  font-size: 0.8em;
  font-weight: bold;
  border-radius: 2px;
  padding: 2px 6px;
  margin-left: 6px;
  vertical-align: middle;
  letter-spacing: 1px;
}

.acessibilidade-menu a:hover,
.acessibilidade-menu a:focus {
  color: #007bff;
}

/* CONTRASTE */
body.contraste-ativo a:hover:not(#legend):not(#legend *),
body.contraste-ativo a:focus:not(#legend):not(#legend *),
body.contraste-ativo span:hover:not(#legend):not(#legend *),
body.contraste-ativo i:hover:not(#legend):not(#legend *),
body.contraste-ativo a:not(#legend):not(#legend *),
body.contraste-ativo span:not(#legend):not(#legend *),
body.contraste-ativo h2:not(#legend):not(#legend *),
body.contraste-ativo i:not(#legend):not(#legend *) {
  color: #FFF333 !important;
}

body.contraste-ativo a,
body.contraste-ativo span:not(#legend):not(#legend *) {
  color: #FFF333 !important;
  text-decoration: underline;
}

body.contraste-ativo,
body.contraste-ativo *:not(#legend):not(#legend *) {
  background: #222 !important;
  color: #fff !important;
  border-color: #fff !important;
}

body.contraste-ativo .mapboxgl-ctrl button.mapboxgl-ctrl-zoom-in .mapboxgl-ctrl-icon:not(#legend):not(#legend *){
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg width='29' height='29' viewBox='0 0 29 29' xmlns='http://www.w3.org/2000/svg' fill='%23fff'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5z'/%3E%3C/svg%3E") !important;
}

body.contraste-ativo .mapboxgl-ctrl button.mapboxgl-ctrl-zoom-out .mapboxgl-ctrl-icon:not(#legend):not(#legend *) {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg width='29' height='29' viewBox='0 0 29 29' xmlns='http://www.w3.org/2000/svg' fill='%23fff'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-9z'/%3E%3C/svg%3E") !important;
}

body.contraste-ativo .mapboxgl-ctrl button.mapboxgl-ctrl-compass .mapboxgl-ctrl-icon:not(#legend):not(#legend *) {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg width='29' height='29' viewBox='0 0 29 29' xmlns='http://www.w3.org/2000/svg' fill='%23ff0'%3E%3Cpath d='M10.5 14l4-8 4 8h-8z'/%3E%3Cpath d='M10.5 16l4 8 4-8h-8z' fill='%23fff'/%3E%3C/svg%3E") !important;
}

body.contraste-ativo .mapboxgl-ctrl-logo:not(#legend):not(#legend *) {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg width='88' height='23' viewBox='0 0 88 23' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' fill-rule='evenodd'%3E%3Cdefs%3E%3Cpath id='a' d='M11.5 2.25c5.105 0 9.25 4.145 9.25 9.25s-4.145 9.25-9.25 9.25-9.25-4.145-9.25-9.25 4.145-9.25 9.25-9.25zM6.997 15.983c-.051-.338-.828-5.802 2.233-8.873a4.395 4.395 0 013.13-1.28c1.27 0 2.49.51 3.39 1.42.91.9 1.42 2.12 1.42 3.39 0 1.18-.449 2.301-1.28 3.13C12.72 16.93 7 16 7 16l-.003-.017zM15.3 10.5l-2 .8-.8 2-.8-2-2-.8 2-.8.8-2 .8 2 2 .8z'/%3E%3Cpath id='b' d='M50.63 8c.13 0 .23.1.23.23V9c.7-.76 1.7-1.18 2.73-1.18 2.17 0 3.95 1.85 3.95 4.17s-1.77 4.19-3.94 4.19c-1.04 0-2.03-.43-2.74-1.18v3.77c0 .13-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V8.23c0-.12.1-.23.23-.23h1.4zm-3.86.01c.01 0 .01 0 .01-.01.13 0 .22.1.22.22v7.55c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V15c-.7.76-1.69 1.19-2.73 1.19-2.17 0-3.94-1.87-3.94-4.19 0-2.32 1.77-4.19 3.94-4.19 1.03 0 2.02.43 2.73 1.18v-.75c0-.12.1-.23.23-.23h1.4zm26.375-.19a4.24 4.24 0 00-4.16 3.29c-.13.59-.13 1.19 0 1.77a4.233 4.233 0 004.17 3.3c2.35 0 4.26-1.87 4.26-4.19 0-2.32-1.9-4.17-4.27-4.17zM60.63 5c.13 0 .23.1.23.23v3.76c.7-.76 1.7-1.18 2.73-1.18 1.88 0 3.45 1.4 3.84 3.28.13.59.13 1.2 0 1.8-.39 1.88-1.96 3.29-3.84 3.29-1.03 0-2.02-.43-2.73-1.18v.77c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V5.23c0-.12.1-.23.23-.23h1.4zm-34 11h-1.4c-.13 0-.23-.11-.23-.23V8.22c.01-.13.1-.22.23-.22h1.4c.13 0 .22.11.23.22v.68c.5-.68 1.3-1.09 2.16-1.1h.03c1.09 0 2.09.6 2.6 1.55.45-.95 1.4-1.55 2.44-1.56 1.62 0 2.93 1.25 2.9 2.78l.03 5.2c0 .13-.1.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.8 0-1.46.7-1.59 1.62l.01 4.68c0 .13-.11.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.85 0-1.54.79-1.6 1.8v4.5c0 .13-.1.23-.23.23zm53.615 0h-1.61c-.04 0-.08-.01-.12-.03-.09-.06-.13-.19-.06-.28l2.43-3.71-2.39-3.65a.213.213 0 01-.03-.12c0-.12.09-.21.21-.21h1.61c.13 0 .24.06.3.17l1.41 2.37 1.4-2.37a.34.34 0 01.3-.17h1.6c.04 0 .08.01.12.03.09.06.13.19.06.28l-2.37 3.65 2.43 3.7c0 .05.01.09.01.13 0 .12-.09.21-.21.21h-1.61c-.13 0-.24-.06-.3-.17l-1.44-2.42-1.44 2.42a.34.34 0 01-.3.17zm-7.12-1.49c-1.33 0-2.42-1.12-2.42-2.51 0-1.39 1.08-2.52 2.42-2.52 1.33 0 2.42 1.12 2.42 2.51 0 1.39-1.08 2.51-2.42 2.52zm-19.865 0c-1.32 0-2.39-1.11-2.42-2.48v-.07c.02-1.38 1.09-2.49 2.4-2.49 1.32 0 2.41 1.12 2.41 2.51 0 1.39-1.07 2.52-2.39 2.53zm-8.11-2.48c-.01 1.37-1.09 2.47-2.41 2.47s-2.42-1.12-2.42-2.51c0-1.39 1.08-2.52 2.4-2.52 1.33 0 2.39 1.11 2.41 2.48l.02.08zm18.12 2.47c-1.32 0-2.39-1.11-2.41-2.48v-.06c.02-1.38 1.09-2.48 2.41-2.48s2.42 1.12 2.42 2.51c0 1.39-1.09 2.51-2.42 2.51z'/%3E%3C/defs%3E%3Cmask id='c'%3E%3Crect width='100%25' height='100%25' fill='%23ff0'/%3E%3Cuse xlink:href='%23a'/%3E%3Cuse xlink:href='%23b'/%3E%3C/mask%3E%3Cg opacity='.3' stroke='%23000' stroke-width='3'%3E%3Ccircle mask='url(%23c)' cx='11.5' cy='11.5' r='9.25'/%3E%3Cuse xlink:href='%23b' mask='url(%23c)'/%3E%3C/g%3E%3Cg opacity='.9' fill='%23ff0'%3E%3Cuse xlink:href='%23a'/%3E%3Cuse xlink:href='%23b'/%3E%3C/g%3E%3C/svg%3E") !important;
}

@media (max-width: 1440px) {
  .acessibilidade-menu ul {
    flex-direction: column;
    padding: 0 0.5rem;
  }
  .acessibilidade-menu li {
    margin: 0.3rem 0;
  }
}

.img-fluid {
  height: 113.75px !important;
}

.main-content-container {
  display: flex;
  flex-direction: column; /* empilha mapa e legenda */
  width: 100%;
}

#legend {
  background-color:#e5e5e5;
  padding: 15px;
  border-radius: 10px;
  font-family: 'Oswald', Arial, sans-serif;
  margin-top: 10px;
  width: 1080px;
  margin: 0 auto;
  margin-bottom: 30px;
}

#legend .title {
  font-weight: 600;
  font-size: 1.1em;
  margin-bottom: 10px;
  color: #333;
}

#legend ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap; /* quebra linhas em telas pequenas */
  gap: 10px;
}

#legend li {
  display: flex;
  align-items: center;
  font-size: 0.95em;
  color: #333;
}

#legend .ball {
  width: 15px;
  height: 15px;
  border-radius: 50%;
  display: inline-block;
  margin-right: 8px;
  border: 1px solid #e5e5e5;
}

@media (max-width: 1440px) {
  #legend{
    width: 100%;
  }
 }
