/* =============================================================================
   cookies.css
   ----------------------------------------------------------------------------
   Estilos do banner de consentimento de cookies, do modal de preferências
   e do "placeholder" que substitui o mapa do Google quando o visitante
   ainda não consentiu com cookies funcionais.

   Funcionamento controlado por js/cookies.js.
   ============================================================================= */

/* =============================================================================
   BANNER (fixo no rodapé até decisão do visitante)
   ============================================================================= */
.cookies-banner {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 200;
  background: var(--cor-azul-marinho);
  color: var(--cor-off-white);
  box-shadow: 0 -4px 16px rgba(0, 0, 0, 0.12);
  /* Estado inicial: oculto por baixo, JS revela com transform 0. */
  transform: translateY(110%);
  transition: transform 350ms ease-out;
  /* Garante que o conteúdo respeite a barra de navegação dos celulares. */
  padding-bottom: env(safe-area-inset-bottom, 0);
}

.cookies-banner[data-visivel="true"] {
  transform: translateY(0);
}

.cookies-banner__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--padding-lateral);
  max-width: var(--largura-max);
  margin-inline: auto;
}

.cookies-banner__texto {
  flex: 1 1 18rem;
  margin: 0;
  font-size: var(--fs-sm);
  color: var(--cor-bege-suave);
  line-height: 1.55;
  max-width: none;
}

.cookies-banner__texto a {
  color: var(--cor-off-white);
  text-decoration: underline;
}

.cookies-banner__acoes {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}

/* Variantes de botão dentro do banner (fundo verde escuro). */
.cookies-banner .botao {
  font-size: var(--fs-sm);
  padding: var(--space-2) var(--space-4);
  white-space: nowrap;
}

.cookies-banner .botao--secundario {
  background: transparent;
  color: var(--cor-off-white);
  border-color: rgba(248, 247, 244, 0.5);
}

.cookies-banner .botao--secundario:hover,
.cookies-banner .botao--secundario:focus-visible {
  background: rgba(248, 247, 244, 0.1);
  color: var(--cor-off-white);
  border-color: var(--cor-off-white);
}

/* Botão "Preferências" — mais discreto, parece link. */
.cookies-banner__link {
  background: transparent;
  border: none;
  color: var(--cor-bege-suave);
  text-decoration: underline;
  text-underline-offset: 0.2em;
  cursor: pointer;
  font-size: var(--fs-sm);
  font-family: inherit;
  padding: var(--space-2);
}

.cookies-banner__link:hover,
.cookies-banner__link:focus-visible {
  color: var(--cor-off-white);
}

/* =============================================================================
   MODAL DE PREFERÊNCIAS (<dialog> nativo)
   ============================================================================= */
.cookies-modal {
  border: none;
  border-radius: var(--raio-grande);
  padding: 0;
  max-width: 32rem;
  width: calc(100% - 2rem);
  background: var(--bg-pagina);
  color: var(--cor-texto);
  box-shadow: var(--sombra-media);
  /* margin auto centraliza o <dialog> aberto via showModal().
     IMPORTANTE: o reset global "* { margin: 0 }" anula a margem padrão do
     <dialog>, então precisamos reaplicar explicitamente aqui. */
  margin: auto;
}

/* Fundo escurecido por trás do modal (backdrop padrão do <dialog>). */
.cookies-modal::backdrop {
  background: rgba(10, 53, 73, 0.55);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}

.cookies-modal__inner {
  padding: var(--space-6);
}

.cookies-modal__titulo {
  font-size: var(--fs-xl);
  color: var(--cor-azul-marinho);
  margin-bottom: var(--space-3);
}

.cookies-modal__intro {
  font-size: var(--fs-sm);
  color: var(--cor-texto-suave);
  margin-bottom: var(--space-5);
  max-width: none;
}

/* Cada categoria de cookies */
.cookies-categoria {
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio-medio);
  padding: var(--space-4);
  margin-bottom: var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.cookies-categoria__cabecalho {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.cookies-categoria__nome {
  font-weight: var(--fw-medium);
  color: var(--cor-azul-marinho);
}

.cookies-categoria__descricao {
  font-size: var(--fs-sm);
  color: var(--cor-texto-suave);
  margin: 0;
  max-width: none;
}

/* Toggle estilizado a partir de um <input type="checkbox">. */
.cookies-toggle {
  position: relative;
  display: inline-block;
  width: 2.5rem;
  height: 1.4rem;
  flex-shrink: 0;
}

.cookies-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
  margin: 0;
}

.cookies-toggle__slider {
  position: absolute;
  inset: 0;
  background: var(--cor-marrom-claro);
  border-radius: 999px;
  cursor: pointer;
  transition: background var(--transicao-rapida);
}

.cookies-toggle__slider::before {
  content: "";
  position: absolute;
  height: 1.05rem;
  width: 1.05rem;
  left: 0.175rem;
  top: 0.175rem;
  background: var(--cor-off-white);
  border-radius: 50%;
  transition: transform var(--transicao-rapida);
}

.cookies-toggle input:checked + .cookies-toggle__slider {
  background: var(--cor-azul-petroleo-principal);
}

.cookies-toggle input:checked + .cookies-toggle__slider::before {
  transform: translateX(1.1rem);
}

.cookies-toggle input:disabled + .cookies-toggle__slider {
  background: var(--cor-azul-turquesa);
  cursor: not-allowed;
  opacity: 0.7;
}

.cookies-toggle input:focus-visible + .cookies-toggle__slider {
  outline: 2px solid var(--cor-foco);
  outline-offset: 2px;
}

/* Rodapé do modal com botões */
.cookies-modal__rodape {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  justify-content: flex-end;
  margin-top: var(--space-5);
}

/* =============================================================================
   PLACEHOLDER DO MAPA (quando o consentimento funcional ainda não foi dado)
   ============================================================================= */
.mapa-bloqueado {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  text-align: center;
  padding: var(--space-5);
  background:
    linear-gradient(135deg, var(--cor-bege-suave), var(--cor-marrom-claro));
  color: var(--cor-azul-marinho);
}

.mapa-bloqueado__icone {
  width: 2.5rem;
  height: 2.5rem;
  color: var(--cor-azul-petroleo-principal);
}

.mapa-bloqueado__texto {
  margin: 0;
  font-size: var(--fs-sm);
  max-width: 28rem;
  color: var(--cor-azul-marinho);
}

.mapa-bloqueado__acoes {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  justify-content: center;
}
