/* Estilos globais e componentes anteriores */
body {
  background: var(--bs-dark);
}

/* Novas classes para remover estilos inline do HTML */
.body-black-bg {
  background: #000000;
}

.carousel-container-custom {
  text-align: center;
  padding: 0;
}

.hero-bg-custom {
  background: url("/assets/img/bg_site_novo.jpg");
  background-blend-mode: darken;
  background-color: rgba(0, 0, 0, 0.6);
  height: 650px;
}

.news-card-img {
  height: 200px;
}

.footer-logo {
  text-align: center;
}

.footer-copyright {
  font-size: 12px;
}

.city-fw {
  font-weight: 800;
}

.freq-fs {
  font-size: 0.7rem;
}

.icon-white {
  color: rgb(255,255,255);
}

.title-fs-ls {
  font-size: 0.65rem;
  letter-spacing: 1px;
}

/* Fim das novas classes */

.bs-icon {
  --bs-icon-size: .75rem;
  display: flex;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  font-size: var(--bs-icon-size);
  width: calc(var(--bs-icon-size) * 2);
  height: calc(var(--bs-icon-size) * 2);
  color: var(--bs-primary);
}

.bs-icon-xs {
  --bs-icon-size: 1rem;
  width: calc(var(--bs-icon-size) * 1.5);
  height: calc(var(--bs-icon-size) * 1.5);
}

.bs-icon-sm {
  --bs-icon-size: 1rem;
}

.bs-icon-md {
  --bs-icon-size: 1.5rem;
}

.bs-icon-lg {
  --bs-icon-size: 2rem;
}

.bs-icon-xl {
  --bs-icon-size: 2.5rem;
}

.bs-icon.bs-icon-primary {
  color: var(--bs-white);
  background: var(--bs-primary);
}

.bs-icon.bs-icon-primary-light {
  color: var(--bs-primary);
  background: rgba(var(--bs-primary-rgb), .2);
}

.bs-icon.bs-icon-semi-white {
  color: var(--bs-primary);
  background: rgba(255, 255, 255, .5);
}

.bs-icon.bs-icon-rounded {
  border-radius: .5rem;
}

.bs-icon.bs-icon-circle {
  border-radius: 50%;
}

.horizontal-player {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 65px;
  background-color: var(--bs-dark);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  z-index: 9500;
  display: flex;
  align-items: center;
}

.prog-img-container img {
  width: 56px;
  height: 56px;
  border-radius: 8px;
  object-fit: cover;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.text-primary-conecta {
  color: var(--bs-primary);
}

.btn-play-slim {
  color: var(--bs-primary);
  border: none;
  width: 50px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s;
}

.station-select {
  background-color: #2a2a2a;
  color: white;
  border: 1px solid rgba(255, 255, 255, 0.1);
  font-size: 0.8rem;
  border-radius: 8px;
  padding: 5px 10px;
}

.track-info-border {
  border-left: 1px solid rgba(255, 255, 255, 0.1);
  padding-left: 15px;
  max-width: 200px;
}

.herobantxt {
  font-size: 4em;
  margin: 0px;
  height: 70px;
  color: #dfdbd5;
}

.herobantxtcolor {
  font-size: 4rem;
  color: var(--bs-primary);
  margin: 0px;
  height: 70px;
}

.track-tight {
  letter-spacing: -0.05em;
}

.btn-programa:hover {
  color: var(--bs-light);
  background-color: var(--bs-border-color-translucent);
  border-color: var(--bs-light);
}

.header_page {
  font-size: 4vw;
  margin: 2vw 0 4vw 0;
}

.accentprimary {
  color: var(--bs-primary);
}

.prog-item-img {
  height: 120px;
  object-fit: cover;
  border-radius: 12px;
}

.prog-item-container {
  display: flex;
  margin-bottom: 20px;
  gap: 15px;
}

.prog-item-time {
  font-weight: 800;
  color: var(--bs-primary);
  text-transform: uppercase;
  font-size: 1em;
  margin-bottom: 4px;
}

.prog-item-title {
  font-size: 30px;
  display: block;
  font-weight: bold;
  unicode-bidi: isolate;
  color: whitesmoke;
  margin-bottom: -10px;
  line-height: 28px;
}

.prog-item-desc {
  font-size: 0.8em;
  display: block;
  margin-block-start: 1.33em;
  margin-block-end: 1.33em;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
  unicode-bidi: isolate;
  color: whitesmoke;
}

.nav-pills {
  --bs-nav-pills-border-radius: 50px;
  --bs-nav-pills-link-active-color: #fff;
  --bs-nav-pills-link-active-bg: var(--bs-primary);
}

.tab-link {
  display: block;
  padding: var(--bs-nav-link-padding-y) var(--bs-nav-link-padding-x);
  font-size: var(--bs-nav-link-font-size);
  font-weight: var(--bs-nav-link-font-weight);
  color: #dfdbd5;
  text-decoration: none;
  background: #333333;
  border: 0;
  transition: color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out;
}

.tab-link.today {
  box-shadow: 0 0 10px 0px var(--bs-primary);
  color: var(--bs-nav-link-hover-color);
}

.tab-link:hover {
  color: var(--bs-carousel-indicator-active-bg);
  background: #dfdfdf;
}

.small-sub {
  font-size: smaller;
}

.fixed-height {
  height: 350px;
}

.side-banner {
  width: 100%;
  margin: 10px;
  max-width: 200px;
}

.card {
  padding: 5px;
  margin: 10px;
}

@media (max-width: 992px) {
  .logo {
    width: 210px;
  }
}

.accordion-button:not(.collapsed) {
  color: white;
  background-color: var(--bs-secondary-bg);
  box-shadow: inset 0 calc(-1 * var(--bs-accordion-border-width)) 0 var(--bs-accordion-border-color);
}

.news-text {
  font-size: 12px;
}

.social-links {
  font-size: 25px;
  color: var(--bs-secondary-color);
}

.mini-txt {
  font-size: small;
  color: var(--bs-primary);
}

@media (max-width: 992px) {
  .nav-link {
    font-size: smaller;
  }
}

.icon-especiais {
  width: 100px;
  margin-right: 15px;
}

.play-especial {
  font-size: 30px;
}

.div-especial {
  padding: 10px;
}

#scroll-to-top {
  position: fixed;
  bottom: 90px;
  right: 10px;
  width: 40px;
  height: 40px;
  text-align: center;
  border-radius: 50%;
  background-color: rgba(244,50,0,0.5);
  color: #fff;
  padding-top: 7px;
}

/* --- Novo Botão Play/Pause Transparente (FontAwesome) --- */
.play-wrapper {
  cursor: pointer;
  color: var(--bs-primary); /* Aplica a cor primária diretamente nos ícones */
  font-size: 2.8rem; /* Ajuste este valor para aumentar/diminuir o ícone */
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.1s ease;
}

/* Efeito de "pressionado" ao clicar */
.play-wrapper:active {
  transform: scale(0.9);
}

/* Oculta o ícone "solid" (hover) por padrão */
.play-wrapper #icon-hover {
  display: none;
}

/* Ao passar o mouse, esconde o "regular" e exibe o "solid" */
.play-wrapper:hover #icon-normal {
  display: none;
}

.play-wrapper:hover #icon-hover {
  display: inline-block;
}

/* --- Novo Botão Play/Pause (Apenas Ícones) --- */
.play-wrapper {
  cursor: pointer;
  color: var(--bs-primary);
  font-size: 3rem; /* Aumentado para compensar a ausência do fundo antigo */
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.1s ease;
}

/* Efeito de clique */
.play-wrapper:active {
  transform: scale(0.9);
}

/* Oculta a versão "Solid" por padrão */
.play-wrapper #icon-hover {
  display: none;
}

/* No hover: esconde a versão "Regular" e mostra a "Solid" */
.play-wrapper:hover #icon-normal {
  display: none;
}

.play-wrapper:hover #icon-hover {
  display: inline-block;
}

/* Adiciona espaço no final da página para o conteúdo não ficar sob o player */
body {
  padding-bottom: 80px; /* Altura do player (80px) + 20px de margem de segurança */
}

.capa-miniatura-accordion { 
  width: 30px; height: 30px; object-fit: cover; 
}

.icone-play-clicavel { 
  cursor: pointer; transition: transform 0.2s; 
}

.icone-play-clicavel:hover { 
  transform: scale(1.1); 
}

/* assets/css/style.css - Animação de Crossfade */

/* Classe base para a imagem frontal */
#current-prog-img {
    transition: opacity 0.5s ease-in-out; /* Define a suavidade (0.5 segundos) */
}

/* Estado de Fade-In: Quando o JS adiciona essa classe, a imagem aparece */
.fade-in-capa {
    animation: smoothFadeIn 0.5s forwards;
}

@keyframes smoothFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}
/* ── AGENDA CULTURAL ─────────────────────────────────────────────────────── */
.agenda-card {
    background: var(--bs-dark);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 12px;
    overflow: hidden;
    height: 100%;
    display: flex;
    flex-direction: column;
    transition: border-color .2s, transform .2s;
}
.agenda-card:hover {
    border-color: rgba(255,255,255,.2);
    transform: translateY(-3px);
}

/* Imagem 4:3 cover */
.agenda-card-capa {
    position: relative;
    width: 100%;
    padding-top: 75%; /* 4:3 */
    overflow: hidden;
    background: #111;
    flex-shrink: 0;
}
.agenda-card-capa img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .4s;
}
.agenda-card:hover .agenda-card-capa img {
    transform: scale(1.04);
}

/* Badge de tipo */
.agenda-card-tipo {
    position: absolute;
    top: 10px;
    left: 10px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    backdrop-filter: blur(6px);
}
.agenda-tipo-show_musical { background: rgba(66,133,244,.85);  color: #fff; }
.agenda-tipo-stand_up     { background: rgba(240,160,48,.85);  color: #000; }
.agenda-tipo-outro        { background: rgba(80,80,80,.85);    color: #fff; }

/* Corpo do card */
.agenda-card-corpo {
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1;
}
.agenda-card-nome {
    font-size: 15px;
    font-weight: 700;
    color: #fff;
    margin: 0;
    line-height: 1.3;
}
.agenda-card-desc {
    font-size: 12px;
    color: rgba(255,255,255,.55);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.agenda-card-info {
    margin-top: auto;
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.agenda-card-data,
.agenda-card-preco {
    font-size: 12px;
    color: rgba(255,255,255,.6);
}
.agenda-card-data {
    color: var(--bs-primary);
    font-weight: 600;
}
.agenda-card-btn-link {
    display: inline-block;
    margin-top: 12px;
    padding: 7px 16px;
    border-radius: 6px;
    background: var(--bs-primary);
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    text-align: center;
    transition: opacity .2s;
    align-self: flex-start;
}
.agenda-card-btn-link:hover { opacity: .85; color: #fff; }

/* Badge "N datas" na capa */
.agenda-card-ndatas {
    position: absolute;
    top: 10px;
    right: 10px;
    padding: 3px 9px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 700;
    background: rgba(0,0,0,.65);
    color: rgba(255,255,255,.9);
    backdrop-filter: blur(6px);
}

/* Lista de sessões dentro do card */
.agenda-card-sessoes {
    margin-top: auto;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.agenda-sess-lista {
    border-top: 1px solid rgba(255,255,255,.08);
    padding-top: 8px;
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.agenda-sess-linha {
    font-size: 11px;
    color: rgba(255,255,255,.6);
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    align-items: baseline;
}
.agenda-sess-data {
    color: var(--bs-primary);
    font-weight: 600;
    white-space: nowrap;
}
.agenda-sess-local {
    color: rgba(255,255,255,.5);
}
.agenda-sess-preco {
    color: rgba(255,255,255,.6);
    margin-left: auto;
    white-space: nowrap;
}
.agenda-sess-mais {
    background: none;
    border: none;
    padding: 2px 0;
    font-size: 11px;
    color: var(--bs-primary);
    cursor: pointer;
    text-align: left;
    font-family: inherit;
}
.agenda-sess-mais:hover { text-decoration: underline; }
.agenda-card-preco-unico {
    font-size: 12px;
    color: rgba(255,255,255,.6);
    padding-top: 4px;
    border-top: 1px solid rgba(255,255,255,.06);
}
.agenda-card-local {
    font-size: 12px;
    color: rgba(255,255,255,.5);
}
.agenda-card-sessoes .agenda-card-local {
    padding-top: 4px;
    border-top: 1px solid rgba(255,255,255,.06);
}

/* ── HASHTAGS ────────────────────────────────────────────────────────────── */
.noticia-hashtags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 12px;
}
.noticia-hashtag-pill {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    background: rgba(99,102,241,.15);
    color: #a5b4fc;
    border: 1px solid rgba(99,102,241,.35);
    text-decoration: none;
    transition: background .15s, color .15s;
    cursor: pointer;
}
.noticia-hashtag-pill:hover {
    background: rgba(99,102,241,.3);
    color: #c7d2fe;
}
.noticia-card-hashtags {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 6px;
}
.noticia-hashtag-pill-card {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    background: rgba(99,102,241,.12);
    color: #a5b4fc;
    border: 1px solid rgba(99,102,241,.25);
    cursor: pointer;
    transition: background .15s;
}
.noticia-hashtag-pill-card:hover { background: rgba(99,102,241,.25); }

/* Banner de filtro ativo por hashtag */
.hashtag-filtro-banner {
    display: none;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    margin-bottom: 16px;
    border-radius: 8px;
    background: rgba(99,102,241,.12);
    border: 1px solid rgba(99,102,241,.3);
    font-size: 13px;
    color: #c7d2fe;
}
.hashtag-filtro-limpar {
    background: none;
    border: none;
    color: #a5b4fc;
    font-size: 14px;
    cursor: pointer;
    margin-left: auto;
    padding: 0 4px;
    line-height: 1;
}
.hashtag-filtro-limpar:hover { color: #fff; }

/* ── NOTÍCIAS ────────────────────────────────────────────────────────────── */
.noticia-card {
    background: var(--bs-dark);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 12px;
    overflow: hidden;
    height: 100%;
    display: flex;
    flex-direction: column;
    cursor: pointer;
    transition: border-color .2s, transform .2s;
}
.noticia-card:hover {
    border-color: rgba(255,255,255,.25);
    transform: translateY(-3px);
}
.noticia-card-capa {
    position: relative;
    width: 100%;
    padding-top: 56.25%; /* 16:9 */
    overflow: hidden;
    background: #111;
    flex-shrink: 0;
}
.noticia-card-capa img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .4s;
}
.noticia-card:hover .noticia-card-capa img { transform: scale(1.04); }
.noticia-card-corpo {
    padding: 16px;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.noticia-card-sub {
    font-size: 15px;
    color: #d0d0d0;
    margin-top: 6px;
    margin-bottom: 8px;
    font-weight: 400;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.noticia-card-titulo {
    font-size: 20px;
    font-weight: 700;
    line-height: 1.3;
    color: #ffffff;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin-bottom: 0;
}
.noticia-card-meta {
    font-size: 11px;
    color: #d0d0d0;
    display: flex;
    gap: 10px;
    margin-bottom: 12px;
    margin-top: auto;
    padding-top: 8px;
}
.noticia-card-tipo {
    position: absolute;
    top: 10px;
    left: 10px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: #fff;
    backdrop-filter: blur(6px);
}
.noticia-hero-tipo {
    display: inline-block;
    padding: 3px 12px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: #fff;
}
.noticia-card-btn {
    display: inline-block;
    margin-top: 12px;
    padding: 7px 16px;
    border: none;
    border-radius: 6px;
    background: var(--bs-primary);
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: opacity .2s;
    align-self: flex-start;
}
.noticia-card-btn:hover { opacity: .85; }
.noticia-favicon-autor {
    vertical-align: middle;
    margin-right: 3px;
    opacity: .75;
    border-radius: 2px;
}

/* ── Overlay ─────────────────────────────────────────────────────────────── */
#noticia-overlay {
    position: fixed;
    inset: 0;
    z-index: 8900;
    background: var(--bs-body-bg);
    transform: translateY(100%);
    transition: transform .35s cubic-bezier(.4,0,.2,1);
    overflow-y: auto;
    overscroll-behavior: contain;
    padding-bottom: 80px; /* não sobrepor o player */
}
#noticia-overlay.aberto { transform: translateY(0); }

#noticia-overlay-topo {
    position: sticky;
    top: 0;
    z-index: 10;
    background: var(--bs-body-bg);
    border-bottom: 1px solid rgba(255,255,255,.08);
    padding: 10px 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
#btn-fechar-noticia.noticia-card-btn {
    margin-top: 0;
    align-self: center;
}
.noticia-overlay-logo {
    height: 28px;
    width: auto;
}

/* ── Artigo — cabeçalho hero ─────────────────────────────────────────────── */
.noticia-artigo-header {
    position: relative;
    min-height: 400px;
    background: #0a0a0a;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    overflow: hidden;
}
.noticia-artigo-header-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    opacity: 0.5;
    -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 0%, rgba(0,0,0,0) 100%);
    mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 0%, rgba(0,0,0,0) 100%);
}
.noticia-artigo-header-conteudo {
    position: relative;
    z-index: 1;
    padding: 60px 0 28px;
    background: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,.75) 100%);
}
.noticia-artigo-wrap {
    max-width: 740px;
    margin: 0 auto;
    padding: 0 16px;
}
.noticia-artigo-wrap-corpo {
    max-width: 740px;
    margin: 32px auto 48px;
    padding: 0 16px;
}
.noticia-artigo-titulo {
    font-size: clamp(1.5rem, 4vw, 2.4rem);
    font-weight: 800;
    line-height: 1.2;
    margin-bottom: 10px;
    color: #fff;
}
.noticia-artigo-subtitulo {
    font-size: 1.1rem;
    color: rgba(255,255,255,.75);
    margin-bottom: 12px;
    line-height: 1.4;
}
.noticia-artigo-meta {
    display: flex;
    align-items: center;
    gap: 16px;
    font-size: 13px;
    color: rgba(255,255,255,.7);
    margin-bottom: 12px;
    flex-wrap: wrap;
}
.noticia-autor-meta {
    display: flex;
    align-items: center;
    gap: 8px;
}
.noticia-autor-foto {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid rgba(255,255,255,.3);
    flex-shrink: 0;
}
.noticia-artigo-fonte-principal {
    font-size: 11px;
    color: rgba(255,255,255,.45);
    padding-top: 8px;
    font-style: italic;
}
.noticia-corpo {
    font-size: 16px;
    line-height: 1.85;
    color: #fff;
}
.noticia-corpo p { margin-bottom: 1em; }
.noticia-corpo span { color: #fff !important; }
.noticia-corpo a { color: var(--bs-primary) !important; }
.noticia-figura {
    margin: 28px 0;
    text-align: center;
}
.noticia-figura img {
    max-width: 100%;
    border-radius: 8px;
}
.noticia-figura figcaption {
    font-size: 12px;
    color: var(--bs-secondary);
    margin-top: 6px;
    font-style: italic;
}
.noticia-figura-w75 {
    width: 75%;
    margin-left: auto;
    margin-right: auto;
}
.noticia-figura-w50 {
    width: 50%;
    margin-left: auto;
    margin-right: auto;
}
@media (max-width: 576px) {
    .noticia-figura-w75,
    .noticia-figura-w50 { width: 100%; }
}

/* ── Link wrapper dos cards de notícia ──────────────────────────────────── */
.noticia-card-link {
    text-decoration: none;
    color: inherit;
    display: block;
}
.noticia-card-link:hover,
.noticia-card-link:focus {
    text-decoration: none;
    color: inherit;
}

/* ── Mais notícias (rodapé do artigo) ───────────────────────────────────── */
.noticia-mais-noticias {
    border-top: 1px solid rgba(255,255,255,.08);
    padding: 40px 0 60px;
    background: var(--bs-dark-bg-subtle);
}
.noticia-mais-titulo {
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: 20px;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--bs-secondary);
}

/* ── Botões de compartilhamento (cores oficiais das redes) ───────────────── */
.btn-share-whatsapp {
    background-color: #25D366;
    border-color: #25D366;
    color: #fff;
}
.btn-share-whatsapp:hover, .btn-share-whatsapp:focus {
    background-color: #1ab954;
    border-color: #1ab954;
    color: #fff;
}
.btn-share-facebook {
    background-color: #1877F2;
    border-color: #1877F2;
    color: #fff;
}
.btn-share-facebook:hover, .btn-share-facebook:focus {
    background-color: #0b63d4;
    border-color: #0b63d4;
    color: #fff;
}
.btn-share-x {
    background-color: #000;
    border-color: #000;
    color: #fff;
}
.btn-share-x:hover, .btn-share-x:focus {
    background-color: #222;
    border-color: #222;
    color: #fff;
}
.btn-share-linkedin {
    background-color: #0A66C2;
    border-color: #0A66C2;
    color: #fff;
}
.btn-share-linkedin:hover, .btn-share-linkedin:focus {
    background-color: #08509a;
    border-color: #08509a;
    color: #fff;
}
.btn-share-copy {
    background-color: rgba(255,255,255,.1);
    border-color: rgba(255,255,255,.18);
    color: #fff;
}
.btn-share-copy:hover, .btn-share-copy:focus {
    background-color: rgba(255,255,255,.2);
    border-color: rgba(255,255,255,.28);
    color: #fff;
}

/* ── Loading spinner ─────────────────────────────────────────────────────── */
.noticia-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 40vh;
}
.noticia-spinner {
    width: 40px;
    height: 40px;
    border: 3px solid rgba(255,255,255,.1);
    border-top-color: var(--bs-primary);
    border-radius: 50%;
    animation: noticia-spin .7s linear infinite;
}
@keyframes noticia-spin { to { transform: rotate(360deg); } }

/* --- LED pulsante: programa ao vivo na grade --- */
.prog-item-time {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;       /* horário nunca quebra linha */
    white-space: nowrap;
}

.prog-item-time-txt {
    white-space: nowrap;
    margin: 0;
}

.prog-ao-vivo-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.8em;        /* −20% em relação ao horário */
    font-weight: inherit;
    color: #ff3600;
    white-space: nowrap;
    margin: 0 0 0 0.75rem;
}

/* --- Glow na imagem do programa ao vivo --- */
.prog-item-img-ao-vivo {
    box-shadow: 0 0 18px 6px rgba(255, 54, 0, 0.55);
    animation: progGlow 2s ease-in-out infinite alternate;
}

@keyframes progGlow {
    from { box-shadow: 0 0 12px 4px rgba(255, 54, 0, 0.35); }
    to   { box-shadow: 0 0 28px 10px rgba(255, 54, 0, 0.70); }
}

.prog-ao-vivo-led {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--bs-primary);
    flex-shrink: 0;
    animation: ledPulse 0.7s linear infinite;
}

@keyframes ledPulse {
    0%   { box-shadow: 0 0 0 0 #ff3600ff; }
    50%  { box-shadow: 0 0 0 7px #ff360055; }
    100% { box-shadow: 0 0 0 14px #ff360000; }
}

/* --- "OUÇA AO VIVO" hint no player --- */
.ouca-ao-vivo-hint {
    display: none;
    align-items: center;
    gap: 6px;
    color: var(--bs-white);
    font-size: 1rem;
    font-weight: 700;
   /* letter-spacing: 0.08em; */
    text-transform: uppercase;
    opacity: 0.85;
    white-space: nowrap;
}

.ouca-ao-vivo-hint i {
    font-size: 0.85rem;
    animation: hintArrow 1.2s ease-in-out infinite;
}

@keyframes hintArrow {
    0%, 100% { transform: translateX(0); opacity: 0.85; }
    50%       { transform: translateX(4px); opacity: 1; }
}

@media (min-width: 1000px) {
    .ouca-ao-vivo-hint { display: flex; }
}
