/* app.css */
:root{
  --espe-red:   #e53935;   /* espe */
  --ctro-blue:  #1e88e5;   /* ctro */
  --b-green:    #43a047;   /* B */
  --r-yellow:   #fbc02d;   /* R */

  --bg-soft:    #f7f9fc;
  --card-glass: rgba(255,255,255,.85);
  --text-muted: #6b7280;
}

body{
  background: var(--bg-soft);
}

.card-glass{
  background: var(--card-glass);
  border-radius: 12px;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}

.small-muted{ color: var(--text-muted); }

.brand-link{
  text-decoration:none;
  color:inherit;
}

.brand-link:hover{
  opacity:.9;
}

/* ======================================================
   LOGO
====================================================== */
.brand {
  font-size: 2.5rem;
  font-weight: 800;
  letter-spacing: 0.4px;
}

.logo-espe { color: var(--espe-red); }
.logo-ctro { color: var(--ctro-blue); }
.logo-b    { color: var(--b-green); }
.logo-r    { color: var(--r-yellow); }

/* ======================================================
   CARDS
====================================================== */
.card-glass {
  background: var(--card-bg);
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  box-shadow: 0 4px 14px rgba(0,0,0,0.04);
}

/* ======================================================
   TEXTO
====================================================== */
.small-muted {
  color: var(--text-muted);
}

/* ======================================================
   FORMULÁRIOS
====================================================== */
.form-label {
  font-weight: 600;
  color: #374151;
}

.form-control,
.form-select {
  background-color: #ffffff;
  border: 1px solid #cfd6df;
  color: var(--text-main);
}

.form-control::placeholder {
  color: #9ca3af;
}

.form-control:focus,
.form-select:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 0.15rem rgba(25,118,210,.2);
}

/* ======================================================
   BOTÕES
====================================================== */
.btn-buscar{
  background:#1e88e5;
  color:#fff;
  font-weight:600;
  border:none;
  padding:10px 18px;
  border-radius:8px;
  transition:all .2s ease;
}

.btn-buscar:hover{
  background:#1565c0;
  transform:translateY(-1px);
}

/* ======================================================
   TABELA
====================================================== */
.table {
  color: var(--text-main);
}

.table thead th {
  background-color: #f1f4f8;
  border-bottom: 1px solid var(--border-soft);
  color: #374151;
}

.table tbody td {
  border-color: #e5e7eb;
}

.table-hover tbody tr:hover {
  background-color: #f9fafb;
}

.table-active {
  background-color: #e3f2fd !important;
}


/* ======================================================
   LINKS
====================================================== */
a.link-entity {
  color: var(--primary);
  text-decoration: none;
}

.link-entity{
  color:inherit;
  text-decoration:none;
}

.link-entity:hover{
  text-decoration:underline;
}

/* ======================================================
   MAPA
====================================================== */
.map-container{
  position: relative;
  width: 100%;
  height: 420px; /* ESSENCIAL */
}

@media (max-width:768px){
  .map-container{
    height:300px;
  }
}

/* ===============================
   LEGENDA DO MAPA
=============================== */
.map-legend{
  position:absolute;
  bottom:14px;
  left:14px;

  background:rgba(255,255,255,.95);
  backdrop-filter: blur(2px);

  border-radius:8px;
  padding:6px 10px;

  font-size:12px;
  line-height:1;

  box-shadow:0 4px 12px rgba(0,0,0,.15);
  display:flex;
  gap:12px;

  z-index:500; /* acima do mapa, abaixo dos controles Leaflet */
  pointer-events:none; /* não bloqueia zoom/drag */
}

.map-legend span{
  display:flex;
  align-items:center;
  gap:6px;
  white-space:nowrap;
}

.map-legend .dot{
  width:10px;
  height:10px;
  border-radius:50%;
  display:inline-block;
}

.map-legend .fm{ background:#1e88e5; } /* azul FM */
.map-legend .tv{ background:#e53935; } /* vermelho TV */

.titulo-servico{
  font-size:.9rem;
  font-weight:700;
  color:#374151;
  margin-bottom:.25rem;
}

.resultado-item{
  padding:4px 0;
}

.resultado-item a{
  text-decoration:none;
  font-weight:500;
}

.resultado-item a:hover{
  text-decoration:underline;
}
.resultado-vago{
  padding:6px 8px;
  border-left:4px solid #f9a825; /* amarelo regulatório */
  background:#fff8e1;
  border-radius:6px;
}

.resultado-vago strong{
  color:#f57f17;
  font-size:0.9rem;
  letter-spacing:.3px;
}
