:root {
  color-scheme: dark;
  --fundo: #06131c;
  --painel: #0c2230;
  --painel-claro: #113247;
  --texto: #f5fbff;
  --suave: #a9c3d2;
  --verde: #41d99a;
  --azul: #4db7ff;
  --erro: #ff8c8c;
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

body {
  margin: 0;
  min-height: 100vh;
  min-height: 100dvh;
  overflow-x: hidden;
  background:
    radial-gradient(circle at 80% 15%, rgba(77, 183, 255, .16), transparent 34rem),
    linear-gradient(145deg, #041018, var(--fundo));
  color: var(--texto);
  font-family: Inter, "Segoe UI", Arial, sans-serif;
}

button,
input {
  font: inherit;
}

select {
  width: 100%;
  padding: 1rem 1.1rem;
  border: 1px solid rgba(169, 195, 210, .35);
  border-radius: .9rem;
  outline: none;
  background: #071923;
  color: var(--texto);
  font: inherit;
}

.configuracao-local button {
  width: 100%;
  margin-top: 1rem;
}

.tela {
  min-height: 100vh;
  min-height: 100dvh;
}

.acesso {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .75rem;
  padding: 2rem;
}

.marca {
  position: fixed;
  top: 1.2rem;
  left: 1.2rem;
  z-index: 2;
  color: var(--verde);
  font-weight: 800;
  letter-spacing: .08em;
}

.cartao-acesso {
  width: min(42rem, 100%);
  padding: clamp(2rem, 5vw, 4rem);
  border: 1px solid rgba(169, 195, 210, .18);
  border-radius: 2rem;
  background: rgba(12, 34, 48, .88);
  box-shadow: 0 2rem 6rem rgba(0, 0, 0, .35);
}

.cabecalho-acesso {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(15rem, 22rem);
  align-items: end;
  gap: 2rem;
}

.cabecalho-acesso h1 {
  margin-bottom: .65rem;
}

.cidade-configuracao {
  margin: 0 0 .7rem;
  color: var(--verde);
  font-size: clamp(.85rem, 1.4vw, 1.05rem);
  font-weight: 850;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.cabecalho-acesso .instrucao {
  margin-bottom: 0;
}

.unidade-confirmada {
  margin-top: 1.2rem;
  padding: .8rem 1rem;
  border: 1px solid rgba(65, 217, 154, .35);
  border-radius: .85rem;
  background: rgba(65, 217, 154, .08);
}

.menu-configuracao {
  display: flex;
  justify-content: flex-end;
  gap: .45rem;
  margin-top: .7rem;
  padding: .35rem;
  border: 1px solid rgba(169, 195, 210, .18);
  border-radius: .9rem;
  background: rgba(7, 25, 35, .7);
}

.menu-configuracao a {
  padding: .6rem .8rem;
  border-radius: .65rem;
  color: var(--suave);
  text-decoration: none;
  font-size: .82rem;
  font-weight: 750;
}

.menu-configuracao a:hover,
.menu-configuracao a.ativo {
  background: var(--painel-claro);
  color: var(--texto);
}

.menu-configuracao a.bloqueado {
  pointer-events: none;
  opacity: .4;
}

.unidade-confirmada span,
.unidade-confirmada strong {
  display: block;
}

.unidade-confirmada span {
  margin-bottom: .2rem;
  color: var(--verde);
  font-size: .72rem;
  font-weight: 850;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.unidade-confirmada strong {
  font-size: clamp(1rem, 1.8vw, 1.5rem);
}

.configuracoes-paisagem {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-top: 1rem;
}

.painel-config {
  min-width: 0;
  padding: 1.1rem;
  border: 1px solid rgba(169, 195, 210, .18);
  border-radius: 1rem;
  background: rgba(7, 25, 35, .55);
}

.painel-config h2 {
  margin-bottom: .45rem;
}

.painel-config .instrucao {
  min-height: 2.6rem;
  margin-bottom: .5rem;
  font-size: .9rem;
}

.painel-config label {
  margin-top: .7rem;
}

.rodape-acesso {
  display: flex;
  justify-content: flex-end;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(169, 195, 210, .18);
}

.rodape-acesso button {
  min-width: min(100%, 22rem);
}

.rodape-acesso button:disabled {
  cursor: not-allowed;
  opacity: .45;
}

.marcas-acesso {
  display: flex;
  width: min(72rem, 96vw);
  min-height: 3.2rem;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .35rem .85rem;
  color: var(--texto);
}

.marca-rodape-cidade {
  display: flex;
  height: 2.8rem;
  align-items: center;
}

.marca-rodape-cidade img {
  width: auto;
  max-width: 9.5rem;
  height: 100%;
  object-fit: contain;
  border-radius: .4rem;
  background: white;
}

.marca-rodape-novetech {
  text-align: center;
  line-height: 1;
}

.marca-rodape-novetech strong,
.marca-rodape-novetech small {
  display: block;
}

.marca-rodape-novetech strong {
  font-size: 1rem;
  letter-spacing: .14em;
}

.marca-rodape-novetech small {
  margin-top: .2rem;
  font-size: .57rem;
}

@media (min-width: 851px) {
  .acesso {
    align-items: center;
    overflow-y: auto;
    padding: .6rem;
  }

  .cartao-acesso {
    width: min(72rem, 96vw);
    padding: clamp(1rem, 1.5vw, 1.5rem);
  }

  .cabecalho-acesso {
    gap: 1.25rem;
  }

  .cartao-acesso h1 {
    margin-bottom: .4rem;
    font-size: clamp(1.8rem, 3vw, 2.8rem);
  }

  .cartao-acesso .instrucao {
    font-size: .88rem;
  }

  .cartao-acesso label {
    margin: .65rem 0 .35rem;
    font-size: .82rem;
  }

  .cartao-acesso input,
  .cartao-acesso select {
    padding: .65rem .75rem;
  }

  .unidade-confirmada {
    margin-top: .7rem;
    padding: .55rem .75rem;
  }

  .configuracoes-paisagem {
    margin-top: .7rem;
  }

  .painel-config {
    padding: .75rem;
  }

  .painel-config h2 {
    margin-bottom: .25rem;
    font-size: 1.15rem;
  }

  .painel-config .instrucao {
    min-height: 2rem;
    font-size: .78rem;
  }

  .painel-config button {
    margin-top: .65rem;
    padding: .65rem .8rem;
  }

  .estado-upload,
  .erro {
    min-height: 1rem;
    margin-top: .35rem;
    font-size: .78rem;
  }

  .rodape-acesso {
    margin-top: .65rem;
    padding-top: .65rem;
  }

  .rodape-acesso button {
    padding: .75rem 1rem;
  }
}

@media (max-width: 850px) {
  .acesso {
    overflow-y: auto;
    padding: 1rem;
  }

  .marcas-acesso {
    width: 100%;
    padding-inline: .25rem;
  }

  .cartao-acesso {
    width: min(44rem, 100%);
    padding: 1.25rem;
  }

  .cabecalho-acesso,
  .configuracoes-paisagem {
    grid-template-columns: 1fr;
    gap: .75rem;
  }

  .painel-config .instrucao {
    min-height: 0;
  }

  .rodape-acesso button {
    width: 100%;
  }

  .menu-configuracao {
    display: grid;
    grid-template-columns: 1fr;
  }

  .menu-configuracao a {
    text-align: center;
  }
}

.divisor {
  height: 1px;
  margin: 2.2rem 0;
  background: rgba(169, 195, 210, .18);
}

.form-propaganda h2 {
  margin-bottom: .7rem;
}

.form-propaganda label {
  margin-top: 1rem;
}

.form-propaganda button {
  width: 100%;
  margin-top: 1rem;
}

.arquivo {
  width: 100%;
  padding: .75rem;
  font-size: .95rem;
  letter-spacing: 0;
}

.estado-upload {
  min-height: 1.4rem;
  margin: .8rem 0 0;
  color: var(--suave);
}

.rotulo,
.cidade {
  margin: 0 0 .65rem;
  color: var(--verde);
  font-size: .9rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

.cartao-acesso h1 {
  margin-bottom: 1rem;
  font-size: clamp(2.2rem, 6vw, 4rem);
  line-height: 1;
}

.instrucao {
  color: var(--suave);
  font-size: 1.08rem;
}

label {
  display: block;
  margin: 2rem 0 .65rem;
  font-weight: 700;
}

.linha-cnes {
  display: flex;
  gap: .75rem;
}

input {
  min-width: 0;
  flex: 1;
  padding: 1rem 1.1rem;
  border: 1px solid rgba(169, 195, 210, .35);
  border-radius: .9rem;
  outline: none;
  background: #071923;
  color: var(--texto);
  font-size: 1.25rem;
  letter-spacing: .12em;
}

input:focus {
  border-color: var(--azul);
  box-shadow: 0 0 0 .22rem rgba(77, 183, 255, .14);
}

button {
  padding: 1rem 1.4rem;
  border: 0;
  border-radius: .9rem;
  background: var(--verde);
  color: #052118;
  cursor: pointer;
  font-weight: 850;
}

.botao-secundario {
  padding: .7rem .9rem;
  border: 1px solid rgba(169, 195, 210, .28);
  background: rgba(7, 25, 35, .75);
  color: var(--texto);
  font-size: .9rem;
}

.botao-secundario[disabled] {
  cursor: not-allowed;
  opacity: .45;
}

.erro {
  min-height: 1.3rem;
  margin: .75rem 0 0;
  color: var(--erro);
}

.painel {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: clamp(.75rem, 1.6vmin, 1.4rem);
  padding: clamp(.8rem, 2.2vmin, 2.5rem);
}

header,
.titulo-lista,
footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.assinatura-painel {
  display: flex;
  align-items: center;
  gap: .55rem;
  line-height: 1;
}

.assinatura-painel img {
  width: auto;
  height: 1.8rem;
  border-radius: .25rem;
  object-fit: contain;
  background: white;
}

.assinatura-painel > span,
.assinatura-painel strong,
.assinatura-painel small {
  display: block;
}

.assinatura-painel strong {
  font-size: .72rem;
  letter-spacing: .13em;
}

.assinatura-painel small {
  margin-top: .12rem;
  font-size: .45rem;
}

.identidade-unidade {
  display: flex;
  align-items: center;
  gap: clamp(.55rem, 1vw, 1rem);
  min-width: 0;
}

.logo-marca {
  display: grid;
  place-items: center;
  overflow: hidden;
}

.logo-marca img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.logo-marca img.logo-indisponivel {
  display: none;
}

.logo-fallback {
  display: none;
}

.logo-marca:has(img.logo-indisponivel) .logo-fallback {
  display: flex;
}

.logo-cidade {
  width: clamp(8rem, 16vw, 18rem);
  height: clamp(2.5rem, 4.2vw, 4.7rem);
  flex: 0 0 auto;
  border-radius: .5rem;
  background: #fff;
}

.logo-cidade .logo-fallback {
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  padding: .35rem;
  color: var(--verde);
  font-size: clamp(.42rem, .58vw, .65rem);
  font-weight: 900;
  line-height: 1.1;
  text-align: center;
}

header h1 {
  margin: 0;
  font-size: clamp(1.35rem, 2.4vw, 3rem);
  overflow-wrap: anywhere;
}

.status-conexao {
  display: flex;
  align-items: center;
  gap: .55rem;
  color: var(--suave);
}

.controles-painel {
  display: flex;
  align-items: center;
  gap: .7rem;
}

.indicador-fila {
  display: flex;
  align-items: center;
  gap: .45rem;
  padding: .55rem .75rem;
  border: 1px solid rgba(77, 183, 255, .25);
  border-radius: .8rem;
  background: rgba(7, 25, 35, .75);
  color: var(--suave);
  font-size: .82rem;
}

.indicador-fila strong {
  display: grid;
  min-width: 1.65rem;
  height: 1.65rem;
  place-items: center;
  border-radius: 50%;
  background: var(--azul);
  color: #04131d;
  font-size: .9rem;
}

.indicador-fila.tem-fila {
  border-color: rgba(255, 180, 77, .65);
}

.indicador-fila.tem-fila strong {
  background: #ffb44d;
}

.sinal {
  width: .75rem;
  height: .75rem;
  border-radius: 50%;
  background: #ffb44d;
  box-shadow: 0 0 1rem currentColor;
}

.sinal.online {
  background: var(--verde);
}

.sinal.offline {
  background: var(--erro);
}

.chamada-atual {
  display: grid;
  place-content: center;
  min-width: 0;
  padding: clamp(1rem, 2.5vmin, 2.5rem);
  border: 1px solid rgba(77, 183, 255, .25);
  border-radius: 2rem;
  overflow: hidden;
  text-align: center;
  background:
    linear-gradient(135deg, rgba(77, 183, 255, .12), rgba(65, 217, 154, .05)),
    var(--painel);
  box-shadow: inset 0 1px rgba(255, 255, 255, .05);
}

.conteudo-principal {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(.75rem, 1.5vmin, 1.4rem);
  min-height: 0;
}

.conteudo-principal.com-propaganda {
  grid-template-columns: minmax(0, 1fr) minmax(13rem, 27vw);
}

.coluna-chamadas {
  display: grid;
  grid-template-rows: minmax(15rem, 1.25fr) minmax(12rem, .75fr);
  gap: clamp(.75rem, 1.5vmin, 1.4rem);
  min-width: 0;
  min-height: 0;
}

.area-propaganda {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
  border: 1px solid rgba(65, 217, 154, .25);
  border-radius: 1.5rem;
  background: #02080c;
}

.moldura-video {
  min-height: 0;
  overflow: hidden;
}

.area-propaganda video {
  display: block;
  width: 100%;
  height: 100%;
  aspect-ratio: 9 / 16;
  object-fit: cover;
  background: #02080c;
}

.logo-novetech {
  min-height: clamp(2.5rem, 5vh, 4rem);
  padding: clamp(.3rem, .7vmin, .65rem);
  border-top: 1px solid rgba(65, 217, 154, .25);
  position: relative;
  background:
    linear-gradient(90deg,
      #d62f31 0 14%,
      #cf78a2 14% 28%,
      #dd8b32 28% 42%,
      #5b4095 42% 56%,
      #4164aa 56% 70%,
      #397746 70% 84%,
      #8f3038 84% 100%);
}

.logo-novetech::before {
  position: absolute;
  inset: .22rem;
  border-radius: .45rem;
  background: #050505;
  content: "";
}

.logo-novetech img {
  max-height: clamp(2rem, 4vh, 3.25rem);
}

.logo-novetech .logo-fallback {
  position: relative;
  z-index: 1;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  color: var(--texto);
  line-height: 1;
  text-align: center;
}

.logo-novetech .logo-fallback strong {
  color: #fff;
  font-size: clamp(.75rem, 1.1vw, 1.2rem);
  letter-spacing: .08em;
}

.logo-novetech .logo-fallback small {
  margin-top: .2rem;
  color: #fff;
  font-size: clamp(.5rem, .62vw, .68rem);
}

.simbolo-novetech {
  position: absolute;
  left: clamp(.5rem, 1vw, 1rem);
  color: #fff;
  font-size: clamp(1.25rem, 2vw, 2rem);
  font-style: italic;
  font-weight: 900;
}

.chamada-atual h2 {
  margin: .25rem 0 1rem;
  font-size: clamp(2.4rem, 6.1vw, 7.5rem);
  line-height: .98;
  overflow-wrap: anywhere;
  text-wrap: balance;
}

.destino {
  margin: 0;
  color: var(--suave);
  font-size: clamp(1.1rem, 2.1vw, 2.7rem);
  overflow-wrap: anywhere;
}

.destino strong {
  color: var(--verde);
}

.chamada-atual.animar {
  animation: destacar 1.2s ease;
}

.chamada-atual.falando {
  animation: respirando 1.45s ease-in-out infinite;
  border-color: rgba(65, 217, 154, .62);
  will-change: transform, box-shadow;
}

@keyframes destacar {
  0%, 100% { transform: scale(1); }
  35% { transform: scale(1.012); box-shadow: 0 0 4rem rgba(65, 217, 154, .25); }
}

@keyframes respirando {
  0%, 100% {
    transform: scale(.992);
    box-shadow:
      inset 0 1px rgba(255, 255, 255, .05),
      0 0 1rem rgba(65, 217, 154, .08);
  }
  50% {
    transform: scale(1.012);
    box-shadow:
      inset 0 1px rgba(255, 255, 255, .08),
      0 0 4.5rem rgba(65, 217, 154, .32);
  }
}

@media (prefers-reduced-motion: reduce) {
  .chamada-atual.animar,
  .chamada-atual.falando {
    animation: none;
  }
}

.listas-situacao {
  display: block;
  min-height: 0;
  height: 100%;
}

.painel-listas {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .75rem;
  min-height: 0;
  height: 100%;
}

.painel-listas .ultimas {
  overflow: hidden;
}

.painel-listas ol {
  grid-template-columns: 1fr;
}

.lista-compacta li {
  padding: .65rem .75rem;
}

.lista-compacta li span {
  font-size: .8rem;
}

.ultimas {
  min-height: 0;
  height: 100%;
  padding: 1.3rem 1.5rem;
  border-radius: 1.2rem;
  background: rgba(12, 34, 48, .72);
  overflow: hidden;
}

.bloco-situacao {
  min-width: 0;
}

.realizados {
  border: 1px solid rgba(65, 217, 154, .2);
}

.titulo-lista h3 {
  margin: 0;
}

.rotulo-lista {
  margin: 0 0 .25rem;
  color: var(--azul);
  font-size: .72rem;
  font-weight: 850;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.realizados .rotulo-lista {
  color: var(--verde);
}

.atualizacao,
footer {
  color: var(--suave);
}

ol {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: clamp(.45rem, .8vw, .75rem);
  margin: 1rem 0 0;
  padding: 0;
  list-style: none;
}

li {
  min-width: 0;
  padding: clamp(.65rem, 1vw, 1rem);
  border-radius: .8rem;
  background: var(--painel-claro);
}

li strong,
li span {
  display: block;
  overflow-wrap: anywhere;
}

li span {
  margin-top: .3rem;
  color: var(--suave);
  font-size: .9rem;
}

.vazio {
  grid-column: 1 / -1;
  color: var(--suave);
}

.trocar {
  color: var(--azul);
}

.aviso-som {
  position: fixed;
  z-index: 20;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 1.5rem;
  background: rgba(1, 10, 15, .82);
  backdrop-filter: blur(.65rem);
}

.cartao-som {
  width: min(34rem, 100%);
  padding: 2.3rem;
  border: 1px solid rgba(77, 183, 255, .3);
  border-radius: 1.5rem;
  background: var(--painel);
  box-shadow: 0 2rem 6rem rgba(0, 0, 0, .55);
  text-align: center;
}

.cartao-som h2 {
  margin-bottom: .8rem;
  font-size: 2rem;
}

.cartao-som p:not(.rotulo) {
  color: var(--suave);
  line-height: 1.55;
}

.estado-som {
  min-height: 1.4rem;
  margin: .8rem 0 0;
}

@media (max-width: 1100px) {
  ol {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 700px) {
  .linha-cnes,
  header,
  .titulo-lista,
  .controles-painel {
    align-items: stretch;
    flex-direction: column;
  }

  ol {
    grid-template-columns: 1fr;
  }

  .painel {
    display: flex;
    min-height: 100dvh;
    flex-direction: column;
    padding: .75rem;
  }

  .conteudo-principal,
  .conteudo-principal.com-propaganda {
    display: flex;
    flex-direction: column;
  }

  .painel-listas {
    grid-template-columns: 1fr;
  }

  .coluna-chamadas {
    display: contents;
  }

  header {
    gap: .7rem;
  }

  header h1 {
    font-size: clamp(1.25rem, 7vw, 2rem);
  }

  .cidade {
    margin-bottom: .3rem;
    font-size: .72rem;
  }

  .controles-painel {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .5rem;
  }

  .status-conexao {
    grid-column: 1 / -1;
    justify-content: center;
  }

  .indicador-fila {
    justify-content: center;
  }

  .chamada-atual {
    min-height: clamp(15rem, 40dvh, 22rem);
    padding: 1.15rem .85rem;
    border-radius: 1.25rem;
  }

  .conteudo-principal.com-propaganda {
    grid-template-columns: minmax(0, 1fr);
  }

  .area-propaganda {
    order: 3;
    width: min(78vw, 22rem);
    max-height: 75dvh;
    justify-self: center;
  }

  .area-propaganda video {
    height: auto;
  }

  .chamada-atual h2 {
    font-size: clamp(2.25rem, 12vw, 4.5rem);
  }

  .destino {
    font-size: clamp(1.05rem, 5.4vw, 1.65rem);
  }

  .ultimas {
    padding: 1rem;
  }

  footer {
    align-items: flex-start;
    flex-direction: column;
    font-size: .85rem;
  }

  .cartao-som {
    max-height: calc(100dvh - 2rem);
    overflow-y: auto;
    padding: 1.5rem;
  }

  .cartao-som h2 {
    font-size: 1.6rem;
  }
}

/* Ajustes finais das marcas oficiais. */
.logo-cidade {
  display: grid;
  width: clamp(5.5rem, 8vw, 9rem);
  height: clamp(2rem, 3.2vw, 3.4rem);
  border: 0;
  padding: .12rem;
  box-shadow: none;
  background: #fff;
}

.logo-cidade img {
  transform: none;
  object-fit: contain;
  object-position: center;
}

.logo-novetech {
  min-height: clamp(3.2rem, 6vh, 4.8rem);
  border: 0;
  background: #050505;
}

.area-propaganda {
  grid-template-rows: minmax(0, 1fr) clamp(3.2rem, 6vh, 4.8rem);
}

.area-propaganda .moldura-video {
  height: auto;
  min-height: 0;
}

.logo-novetech::before {
  display: none;
}

.logo-novetech .logo-fallback {
  padding-left: 0;
}

.logo-novetech .logo-fallback strong {
  font-size: clamp(.9rem, 1.35vw, 1.45rem);
}

.logo-novetech .logo-fallback small {
  font-size: clamp(.52rem, .68vw, .76rem);
}


@media (min-width: 1500px) and (min-height: 850px) {
  .painel {
    grid-template-rows: auto minmax(0, 1fr) auto;
    padding: clamp(1.8rem, 2.4vmin, 3rem);
  }

  header h1 {
    font-size: clamp(2.3rem, 2.8vw, 4rem);
  }

  .chamada-atual h2 {
    font-size: clamp(4.5rem, 6.2vw, 8rem);
  }

  .ultimas {
    padding: 1.5rem 1.8rem;
  }

  li {
    padding: 1.1rem 1.2rem;
  }
}

/* Modo painel: toda a interface cabe em uma única tela. */
body {
  height: 100vh;
  height: 100dvh;
  overflow: hidden;
}

.painel {
  height: 100vh;
  height: 100dvh;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: clamp(.4rem, .8vmin, .7rem);
  overflow: hidden;
  padding: clamp(.45rem, 1vmin, 1rem);
}

header {
  min-height: 0;
}

header h1 {
  font-size: clamp(1.1rem, 1.8vw, 2.2rem);
}

.cidade {
  margin-bottom: .2rem;
  font-size: clamp(.58rem, .7vw, .75rem);
}

.controles-painel {
  gap: .35rem;
}

.botao-secundario {
  padding: .42rem .62rem;
  font-size: clamp(.65rem, .72vw, .78rem);
}

.indicador-fila {
  padding: .32rem .5rem;
}

.conteudo-principal,
.coluna-chamadas,
.listas-situacao,
.painel-listas,
.ultimas {
  min-height: 0;
  overflow: hidden;
}

.conteudo-principal {
  height: 100%;
  gap: clamp(.4rem, .8vmin, .7rem);
}

.conteudo-principal.com-propaganda {
  grid-template-columns: minmax(0, 1fr) minmax(11rem, 24vw);
}

.coluna-chamadas {
  grid-template-rows: minmax(0, 1.4fr) minmax(0, .6fr);
  gap: clamp(.4rem, .8vmin, .7rem);
}

.chamada-atual {
  min-height: 0;
  padding: clamp(.55rem, 1.3vmin, 1.2rem);
  border-radius: 1.25rem;
}

.chamada-atual h2 {
  margin: .3rem 0 .4rem;
  font-size: clamp(1.75rem, 4.45vw, 5.35rem);
  line-height: .94;
}

.destino {
  font-size: clamp(.9rem, 1.65vw, 2rem);
}

.chamada-atual > .rotulo {
  margin-bottom: .45rem;
  font-size: clamp(.78rem, 1.05vw, 1.15rem);
  letter-spacing: .16em;
}

.chamada-atual.nome-curto h2 {
  font-size: clamp(2rem, 5vw, 6rem);
}

.ultimas {
  height: 100%;
  padding: clamp(.4rem, .75vmin, .7rem);
}

.painel-listas {
  gap: clamp(.3rem, .5vw, .5rem);
}

.titulo-lista h3 {
  font-size: clamp(.78rem, 1vw, 1.05rem);
}

.rotulo-lista {
  margin-bottom: .1rem;
  font-size: clamp(.5rem, .58vw, .65rem);
}

.painel-listas ol {
  gap: clamp(.2rem, .35vw, .35rem);
  margin-top: .35rem;
}

.lista-compacta li {
  padding: clamp(.25rem, .42vw, .45rem);
}

.lista-compacta li strong {
  font-size: clamp(.62rem, .7vw, .8rem);
  line-height: 1.1;
}

.lista-compacta li span {
  margin-top: .15rem;
  font-size: clamp(.58rem, .64vw, .72rem);
  line-height: 1.1;
}

.area-propaganda,
.moldura-video,
.area-propaganda video {
  height: 100%;
  max-height: 100%;
}

footer {
  min-height: 1rem;
  font-size: clamp(.58rem, .65vw, .75rem);
}

@media (max-width: 700px) {
  .painel {
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
    height: 100dvh;
    min-height: 100dvh;
    padding: .35rem;
  }

  header {
    gap: .25rem;
  }

  header h1 {
    font-size: clamp(1rem, 5.4vw, 1.55rem);
  }

  .controles-painel {
    gap: .25rem;
  }

  .conteudo-principal,
  .conteudo-principal.com-propaganda {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr);
    overflow: hidden;
  }

  .coluna-chamadas {
    display: grid;
    grid-template-rows: minmax(0, 1.15fr) minmax(0, .85fr);
    gap: .35rem;
  }

  .area-propaganda {
    display: none !important;
  }

  .logo-cidade {
    width: 6.5rem;
    height: 2.2rem;
  }

  .chamada-atual {
    min-height: 0;
    padding: .4rem;
  }

  .chamada-atual h2 {
    font-size: clamp(1.45rem, 8vw, 2.7rem);
  }

  .destino {
    font-size: clamp(.75rem, 3.8vw, 1.1rem);
  }

  .painel-listas {
    grid-template-columns: 1fr 1fr;
    gap: .25rem;
  }

  .ultimas {
    padding: .3rem;
  }

  .lista-compacta li {
    padding: .22rem;
  }

  .lista-compacta li strong {
    font-size: clamp(.52rem, 2.5vw, .65rem);
  }

  .lista-compacta li span {
    font-size: clamp(.48rem, 2.2vw, .6rem);
  }

  footer {
    align-items: center;
    flex-direction: row;
    font-size: .55rem;
  }
}
