/*
 * _base.css — utilidades comunes scope-eadas a .bs-*
 *
 * NO usa selectores universales (* { }) ni cambia html/body para no
 * pisar a Bricks ni al tema activo. Todo está bajo .bs-* explícito.
 */

/* Reset local — solo dentro del scope del plugin */
.bs-empresa *,
.bs-provincia *,
.bs-home *,
.bs-empty * {
  box-sizing: border-box;
}

.bs-empresa,
.bs-provincia,
.bs-home,
.bs-empty {
  font-family: var(--bs-font);
  color: var(--bs-text);
  line-height: 1.5;
  max-width: var(--bs-max-width);
  margin: 0 auto;
  padding: var(--bs-space-6) var(--bs-space-4);
}

/* ── Ocultar el H1 de "page title" que Bricks/tema añaden automáticamente.
   Plugin.php devuelve '' como título en el main loop de páginas gestionadas;
   estos selectores ocultan el <h1>/<h2> vacío resultante. */
body.borme-secciones-managed h1:empty,
body.borme-secciones-managed h2:empty,
body.borme-secciones-managed .entry-title:empty,
body.borme-secciones-managed .page-title:empty,
body.borme-secciones-managed .brxe-post-title:empty,
body.borme-secciones-managed [data-brxe-name="post-title"]:empty,
body.borme-secciones-managed [class*="post-title"]:empty {
  display: none !important;
}

/* Tipografía */
.bs-empresa h1, .bs-provincia h1, .bs-home h1,
.bs-empresa h2, .bs-provincia h2, .bs-home h2,
.bs-empresa h3, .bs-provincia h3, .bs-home h3,
.bs-empresa h4, .bs-provincia h4, .bs-home h4 {
  font-family: var(--bs-font);
  color: var(--bs-text);
  margin: 0;
  font-weight: 700;
  letter-spacing: -0.3px;
}

/* Enlaces dentro del plugin */
.bs-empresa a, .bs-provincia a, .bs-home a {
  color: var(--bs-accent);
  text-decoration: none;
  transition: color 0.15s;
}
.bs-empresa a:hover, .bs-provincia a:hover, .bs-home a:hover {
  color: var(--bs-accent-hover);
}

/* Botones */
.bs-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: var(--bs-radius);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  border: none;
  text-decoration: none;
  font-family: var(--bs-font);
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.bs-btn-primary {
  background: var(--bs-accent);
  color: #fff;
}
.bs-btn-primary:hover {
  background: var(--bs-accent-hover);
  color: #fff;
}
.bs-btn-ghost {
  background: #fff;
  color: var(--bs-text-2);
  border: 1.5px solid var(--bs-border);
}
.bs-btn-ghost:hover {
  background: var(--bs-bg-alt);
  color: var(--bs-text);
}

/* Avatares (iniciales) */
.bs-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 700;
  flex-shrink: 0;
  border-radius: var(--bs-radius);
  font-family: var(--bs-font);
}
.bs-avatar--lg {
  width: 72px;
  height: 72px;
  font-size: 22px;
  border-radius: var(--bs-radius-lg);
  box-shadow: var(--bs-shadow);
}
.bs-avatar--sm {
  width: 36px;
  height: 36px;
  font-size: 12px;
  border-radius: 8px;
}
.bs-avatar--muted {
  background: var(--bs-border-light) !important;
  color: var(--bs-text-light);
}

/* Badges */
.bs-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  white-space: nowrap;
  text-decoration: none;
}
.bs-badge .bs-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: currentColor;
  display: inline-block;
}
.bs-badge--activa {
  background: var(--bs-activa-bg);
  color: var(--bs-activa-text);
}
.bs-badge--activa .bs-dot { background: var(--bs-activa-dot); }
.bs-badge--liquidacion {
  background: var(--bs-liquidacion-bg);
  color: var(--bs-liquidacion-text);
}
.bs-badge--extinguida {
  background: var(--bs-extinguida-bg);
  color: var(--bs-extinguida-text);
}
.bs-badge--forma {
  background: var(--bs-bg-alt);
  color: var(--bs-text-2);
  border: 1px solid var(--bs-border);
}
.bs-badge--provincia {
  background: #eff6ff;
  color: #1d4ed8;
}
a.bs-badge--provincia:hover {
  background: #dbeafe;
  color: #1d4ed8;
}

/* Pills (chips pequeños) */
.bs-pill {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 700;
  background: var(--bs-accent-soft);
  color: var(--bs-accent);
  text-transform: uppercase;
  letter-spacing: 0.4px;
}

/* Cards */
.bs-card {
  background: var(--bs-bg);
  border: 1px solid var(--bs-border);
  border-radius: var(--bs-radius-lg);
  padding: var(--bs-space-5);
  margin-bottom: var(--bs-space-4);
}
.bs-card-title {
  font-size: 11.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  color: var(--bs-text-light);
  margin: 0 0 var(--bs-space-4) 0;
}

/* Listas clave-valor (definition list) */
.bs-list {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--bs-space-3);
}
.bs-list-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--bs-space-3);
  font-size: 13.5px;
}
.bs-list-row dt {
  color: var(--bs-text-light);
  font-weight: 500;
  flex-shrink: 0;
}
.bs-list-row dd {
  margin: 0;
  color: var(--bs-text);
  font-weight: 600;
  text-align: right;
  word-break: break-word;
}

/* Breadcrumb */
.bs-breadcrumb {
  font-size: 13px;
  color: var(--bs-text-light);
  margin-bottom: var(--bs-space-5);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.bs-breadcrumb a {
  color: var(--bs-text-muted);
  text-decoration: none;
}
.bs-breadcrumb a:hover {
  color: var(--bs-accent);
}
.bs-breadcrumb-sep {
  color: var(--bs-border);
}

/* Estado vacío */
.bs-empty-state {
  text-align: center;
  padding: var(--bs-space-12) var(--bs-space-4);
  color: var(--bs-text-light);
  font-size: 14px;
}

/* Página completa de "no encontrada" / "sin slug" */
.bs-empty {
  min-height: 50vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.bs-empty-inner {
  text-align: center;
  max-width: 520px;
}
.bs-empty-inner h2 {
  font-size: 28px;
  margin-bottom: var(--bs-space-3);
}
.bs-empty-inner p {
  color: var(--bs-text-muted);
  margin: 0 0 var(--bs-space-4);
}
.bs-empty-inner code {
  background: var(--bs-bg-alt);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 13px;
}
.bs-empty-inner .bs-btn { margin: 0 4px; }
