/* 
 * Estilos para Mural Digital Corporativo
 * Design focado em alto contraste e visualização à distância
 * Data: 06/11/2025
 */

/* Reset e configurações globais */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html,
body {
  height: 100%;
  overflow: hidden; /* Remove scroll para tela cheia */
  font-family:
    "Arial", "Helvetica", sans-serif, "Segoe UI Emoji", "Noto Color Emoji",
    "Apple Color Emoji";
}

/* Fundo do mural apenas quando exibindo conteúdo (não na tela de login/seleção) */
body:not(.login-page) {
  background: linear-gradient(
    135deg,
    #ffffff 0%,
    var(--brand-secondary) 100%
  );
}

/* Layout principal - Tela cheia */
.mural-container {
  height: 100vh;
  width: 100vw;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}

/* Header com informações básicas */
.mural-header {
  /* Fundo suavizado para melhor visibilidade da logo (antes: rgba(0,0,0,0.8)) */
  background: rgba(0, 0, 0, 0.55);
  /* Leve gradiente opcional para profundidade */
  background: linear-gradient(
    90deg,
    rgba(0, 0, 0, 0.55) 0%,
    rgba(20, 30, 45, 0.55) 60%,
    rgba(30, 50, 70, 0.55) 100%
  );
  color: white;
  padding: 5px 30px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 24px;
  font-weight: bold;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
  flex-shrink: 0;  /* Nunca encolher o header */
  z-index: 2;      /* Acima do conteúdo para sombra */
}

/* Aumenta ligeiramente o brilho da imagem da logo para destacar sobre fundo mais claro */
.mural-header .logo-empresa img {
  filter: brightness(1.15) contrast(1.05);
}

.logo-empresa {
  font-size: 28px;
  color: var(--brand-primary);
  display: flex;
  align-items: center;
  /* Fundo claro sutil atrás da logo para aumentar contraste do logotipo (preto/vermelho) */
  /*background: rgba(255, 255, 255, 0.18);*/
  padding: 6px 10px;
  border-radius: 10px;
}

.info-tempo {
  display: flex;
  gap: 40px;
  font-size: 20px;
}

.data-atual,
.hora-atual {
  background: rgba(255, 255, 255, 0.1);
  padding: 8px 16px;
  border-radius: 8px;
}

/* Área principal do carrossel */
.mural-content {
  flex: 1 1 0;
  min-height: 0;        /* Permite flex shrink abaixo do conteúdo natural */
  position: relative;
  overflow: hidden;
  z-index: 1;
}

/* Container das publicações */
.carousel-container {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
}

.publicacao {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: none;
  padding: 40px;
  opacity: 0;
  transition: opacity 0.8s ease-in-out;
}

.publicacao.active {
  display: flex;
  opacity: 1;
}

/* Layout da publicação - Normal */
.publicacao.prioridade-normal {
  background: linear-gradient(
    135deg,
    var(--brand-primary) 0%,
    var(--brand-secondary) 100%
  );
  color: white;
  flex-direction: row;
  align-items: center;
}

/* Layout da publicação - Urgente */
.publicacao.prioridade-urgente {
  background: linear-gradient(135deg, #ff6b6b 0%, #ee5a24 100%);
  color: white;
  flex-direction: column;
  justify-content: center;
  text-align: center;
  animation: pulse 2s infinite;
}

/* Quando tem imagem de fundo, remover gradiente de prioridade */
.publicacao.prioridade-normal.publicacao-fullbg,
.publicacao.prioridade-urgente.publicacao-fullbg {
  background-image: none; /* Será sobrescrito pelo JS */
  animation: none;
}

@keyframes pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(255, 107, 107, 0.7);
  }
  70% {
    box-shadow: 0 0 0 20px rgba(255, 107, 107, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(255, 107, 107, 0);
  }
}

/* Conteúdo da publicação */
.publicacao-texto {
  flex: 1;
  padding-right: 40px;
  max-height: 100%;
  overflow: hidden; /* evita vazar texto fora da área visível */
}

.publicacao-urgente .publicacao-texto {
  padding-right: 0;
  margin-bottom: 30px;
}

.publicacao-titulo {
  font-size: 64px;
  font-weight: bold;
  margin-bottom: 30px;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
  line-height: 1.2;
  white-space: pre-wrap; /* respeita quebras digitadas */
  overflow-wrap: anywhere; /* evita overflow lateral */
  word-break: break-word;
}

.publicacao-urgente .publicacao-titulo {
  font-size: 80px;
  margin-bottom: 40px;
}

.publicacao-conteudo {
  font-size: 36px;
  line-height: 1.5;
  margin-bottom: 30px;
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.5);
  white-space: pre-wrap; /* respeita quebras digitadas */
  overflow-wrap: anywhere; /* evita overflow lateral com palavras longas */
  word-break: break-word;
}

.publicacao-urgente .publicacao-conteudo {
  font-size: 48px;
  margin-bottom: 40px;
}

.publicacao-categoria {
  display: inline-block;
  background: rgba(255, 255, 255, 0.2);
  color: white;
  padding: 12px 24px;
  border-radius: 25px;
  font-size: 12px;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.publicacao-urgente .publicacao-categoria {
  font-size: 28px;
  background: rgba(255, 255, 255, 0.9);
  color: #ee5a24;
}

/* Área de imagem/vídeo */
.publicacao-media {
  width: 400px;
  height: 400px;
  border-radius: 15px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
}

.publicacao-urgente .publicacao-media {
  width: 500px;
  height: 300px;
  margin: 0 auto;
}

.publicacao-media img,
.publicacao-media video {
  width: 100%;
  height: 100%;
  object-fit: contain; /* exibir mídia completa sem corte */
  object-position: center center;
  background: #000; /* letterbox */
}

/* Vídeo em tela cheia como background */
.publicacao.has-video {
  position: absolute;
  inset: 0;
}

.publicacao.has-video .background-video {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.publicacao.has-video .background-video video {
  width: 100%;
  height: 100%;
  object-fit: contain; /* padrão: vídeo completo */
  object-position: center center;
  background: #000;
  display: block;
}

.publicacao.has-video .publicacao-texto {
  position: relative;
  z-index: 1;
}

/* Imagem ocupando toda a área entre header e footer */
.publicacao.publicacao-fullbg {
  background-size: contain; /* imagem completa */
  background-position: center center;
  background-repeat: no-repeat;
  /* Colocar o texto como overlay no rodapé da área */
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  text-align: left;
  padding: 40px;
  position: absolute;
  inset: 0;
  background-color: #000; /* fundo para barras */
}

/* Quando COVER e texto oculto, sem padding */
.publicacao.publicacao-fullbg.midia-cover.no-text-overlay {
  padding: 0;
}

/* Modos de ajuste de mídia */
.publicacao.publicacao-fullbg.midia-cover {
  background-size: cover !important;
  background-position: center center !important;
}
.publicacao.publicacao-fullbg.midia-contain {
  background-size: contain !important;
  background-position: center center !important;
}
.publicacao.has-video.midia-cover .background-video video {
  object-fit: cover;
}
.publicacao.has-video.midia-contain .background-video video {
  object-fit: contain;
}

.publicacao.publicacao-fullbg::before {
  content: "";
  position: absolute;
  inset: 0;
  /* leve escurecimento para legibilidade do texto */
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.15) 0%,
    rgba(0, 0, 0, 0.35) 60%,
    rgba(0, 0, 0, 0.55) 100%
  );
  z-index: 0;
}

.publicacao-fullbg .publicacao-texto {
  position: relative;
  z-index: 1;
  /*  background: rgba(0, 0, 0, 0.35);*/
  border-radius: 16px;
  padding: 24px 32px;
  color: #fff;
  max-width: 70vw;
  flex: 0 1 auto;
}

.publicacao-fullbg .publicacao-titulo {
  margin-bottom: 16px;
}

.publicacao-fullbg .publicacao-categoria {
  background: rgba(255, 255, 255, 0.2);
}

/* Ajustes visuais para aproximar do preview do admin */
.publicacao .publicacao-texto {
  /*  background: rgba(0, 0, 0, 0.35);*/
  border-radius: 16px;
  padding: 24px 32px;
}

/* Modo compacto quando o texto é muito longo */
.publicacao .publicacao-texto.compact {
  padding: 12px 16px;
  border-radius: 12px;
}
.publicacao .publicacao-texto.compact .publicacao-titulo {
  margin-bottom: 12px;
}
.publicacao .publicacao-texto.compact + .publicacao-categoria,
.publicacao .publicacao-texto .hide-category {
  display: none !important;
}

.publicacao .publicacao-titulo {
  font-weight: 700;
}

.publicacao .publicacao-categoria {
  margin-top: 10px;
}

.publicacao .publicacao-footer .badge {
  padding: 8px 12px;
}

/* Indicadores do carrossel */
.carousel-indicators {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 15px;
  z-index: 10;
}

.indicator {
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.5);
  cursor: pointer;
  transition: all 0.3s ease;
}

.indicator.active {
  background: white;
  transform: scale(1.2);
}

/* Barra de progresso */
.progress-bar {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 4px;
  background: #00d4ff;
  transition: width 0.1s linear;
  z-index: 10;
}

/* Footer com avisos críticos — posição absoluta para não afetar flex */
.mural-footer {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(0, 0, 0, 0.8);
  color: white;
  padding: 15px 30px;
  font-size: 20px;
  display: none; /* Mostrar apenas quando houver avisos críticos */
  z-index: 5;
}

/* ===== MURALFLIX EXPERIENCE REFRESH ===== */
html,
body {
  background:
    radial-gradient(circle at top, rgba(var(--brand-primary-rgb, 229, 9, 20), 0.12) 0%, rgba(var(--brand-primary-rgb, 229, 9, 20), 0) 28%),
    linear-gradient(180deg, #050505 0%, #111111 100%);
}

.mural-container {
  background:
    radial-gradient(circle at top, rgba(var(--brand-primary-rgb, 229, 9, 20), 0.12) 0%, rgba(var(--brand-primary-rgb, 229, 9, 20), 0) 28%),
    linear-gradient(180deg, #050505 0%, #111111 100%);
}

.mural-header {
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.82) 0%, rgba(20, 20, 20, 0.88) 55%, rgba(var(--brand-primary-rgb, 229, 9, 20), 0.16) 100%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.32);
}

.mural-header .logo-empresa img {
  filter: none;
}

.logo-empresa {
  color: #ffffff;
  gap: 0.5rem;
}

.logo-empresa span {
  color: #ffffff;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.data-atual,
.hora-atual {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(8px);
}

.publicacao.prioridade-normal {
  background:
    linear-gradient(90deg, rgba(0, 0, 0, 0.86) 0%, rgba(0, 0, 0, 0.62) 42%, rgba(0, 0, 0, 0.78) 100%),
    linear-gradient(180deg, #1a0b0c 0%, #090909 100%);
}

.publicacao.prioridade-urgente {
  background: linear-gradient(180deg, #3b0a0d 0%, #150607 100%);
}

.publicacao-titulo {
  font-size: 68px;
  letter-spacing: 0.01em;
}

.publicacao-categoria {
  background: rgba(var(--brand-primary-rgb, 229, 9, 20), 0.18);
  border: 1px solid rgba(var(--brand-primary-rgb, 229, 9, 20), 0.26);
}

.publicacao-media {
  box-shadow: 0 22px 48px rgba(0, 0, 0, 0.42);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.carousel-indicators .indicator,
.carousel-indicators button {
  background: rgba(255, 255, 255, 0.22);
}

.carousel-indicators .active,
.carousel-indicators button.active {
  background: var(--brand-primary);
}

.progress-bar {
  background: linear-gradient(90deg, var(--brand-primary) 0%, var(--brand-secondary) 100%);
  box-shadow: 0 0 22px rgba(var(--brand-primary-rgb, 229, 9, 20), 0.3);
}

.mural-footer {
  background: linear-gradient(90deg, rgba(0,0,0,0.78) 0%, rgba(20,20,20,0.82) 100%);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.btn-ativar-som {
  background: linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-secondary) 100%);
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.34);
}

.mural-footer.show {
  display: block;
  animation: slideUp 0.5s ease;
}

@keyframes slideUp {
  from {
    transform: translateY(100%);
  }
  to {
    transform: translateY(0);
  }
}

.aviso-critico {
  background: linear-gradient(90deg, #ff4757, #ff6b7d);
  padding: 10px 20px;
  border-radius: 8px;
  font-weight: bold;
  text-align: center;
  animation: blink 1.5s infinite;
}

@keyframes blink {
  0%,
  50% {
    opacity: 1;
  }
  51%,
  100% {
    opacity: 0.7;
  }
}

/* Responsividade para diferentes tamanhos de tela */
@media (max-width: 1366px) {
  .publicacao-titulo {
    font-size: 48px;
  }

  .publicacao-conteudo {
    font-size: 28px;
  }

  .publicacao-media {
    width: 300px;
    height: 300px;
  }
}

@media (max-height: 768px) {
  .publicacao {
    padding: 20px;
  }

  .publicacao-titulo {
    font-size: 42px;
    margin-bottom: 20px;
  }

  .publicacao-conteudo {
    font-size: 24px;
    margin-bottom: 15px;
  }
}

/* Animações de transição */
.fade-in {
  animation: fadeIn 0.8s ease-in-out;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.slide-left {
  animation: slideLeft 0.8s ease-in-out;
}

@keyframes slideLeft {
  from {
    opacity: 0;
    transform: translateX(100px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* Estilos para diferentes categorias */
.categoria-rh {
  background: linear-gradient(135deg, #4ecdc4 0%, #44a08d 100%) !important;
}

.categoria-seguranca {
  background: linear-gradient(135deg, #ff9a9e 0%, #fecfef 100%) !important;
}

.categoria-metas {
  background: linear-gradient(135deg, #a8edea 0%, #fed6e3 100%) !important;
}

.categoria-evento {
  background: linear-gradient(135deg, #ffecd2 0%, #fcb69f 100%) !important;
}

/* Botão para ativar som */
.btn-ativar-som {
  position: fixed;
  bottom: 80px;
  right: 30px;
  background: linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-secondary) 100%);
  color: white;
  border: none;
  border-radius: 50px;
  padding: 15px 30px;
  font-size: 18px;
  font-weight: bold;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 10px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
  z-index: 9999;
  animation: pulse-sound 2s infinite;
  transition: all 0.3s ease;
}

.btn-ativar-som:hover {
  transform: scale(1.05);
  box-shadow: 0 6px 25px rgba(0, 0, 0, 0.5);
}

.btn-ativar-som i {
  font-size: 24px;
}

@keyframes pulse-sound {
  0%,
  100% {
    box-shadow: 0 4px 20px rgba(102, 126, 234, 0.4);
  }
  50% {
    box-shadow: 0 4px 30px rgba(102, 126, 234, 0.8);
  }
}
/* ============================================
   ESTILOS PARA EDITOR VISUAL (LAYOUTS JSON)
   ============================================ */

.publicacao-visual-layout {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100% !important;
  height: 100% !important;
  overflow: hidden;
  padding: 0 !important;  /* Remover padding para visual layout usar area total */
  /* Fundo do layout visual e definido inline pelo JS (backgroundColor do layout) */
  background: none !important;
}

.visual-layout-container {
  transform-origin: top left;
  position: absolute !important;
  top: 0;
  left: 0;
  /* Escala calculada dinamicamente por JS via scaleVisualLayout() */
}

/* Elementos do layout visual */
.visual-element {
  box-sizing: border-box;
}

.visual-element-text {
  overflow: hidden;
  word-wrap: break-word;
  white-space: pre-wrap;
}

.visual-element-image img,
.visual-element-video video {
  display: block;
  max-width: 100%;
  max-height: 100%;
}

.visual-element-shape {
  display: block;
}

/* Escala de layouts visuais agora é calculada dinamicamente pelo JS */
