/* ── Tokens ── */
:root {
  --public-radius: 1.25rem;
  --public-radius-lg: 1.5rem;
  --public-border-alpha: 0.08;
  --public-bg-alpha: 0.03;
  --public-icon-size: 3.5rem;
  --public-icon-radius: 1rem;
  --public-icon-bg-alpha: 0.12;
}

/* ── Tipografia ── */
body {
  font-family: "Geist", var(--bs-body-font-family);
}

/* ── View Transitions (cross-document, MPA) ──
   Fade-up por defecto entre paginas publicas (home, directorio,
   repuestos, precios). Cada pagina puede sobreescribir:
   - login.css        → zoom-in modal
   - seguimiento.css  → zoom-in ligero
   - legal_transitions.css → slide horizontal */
@view-transition {
  navigation: auto;
}

::view-transition-new(root) {
  animation-name: public-zoom-in;
  animation-duration: 1000ms;
  animation-timing-function: cubic-bezier(0.16, 1, 0.3, 1);
}

::view-transition-old(root) {
  animation-name: public-zoom-out;
  animation-duration: 750ms;
  animation-timing-function: cubic-bezier(0.65, 0, 0.35, 1);
}

@keyframes public-zoom-in {
  from { transform: scale(0.80); opacity: 0; }
  to   { transform: scale(1);    opacity: 1; }
}

@keyframes public-zoom-out {
  from { transform: scale(1);    opacity: 1; }
  to   { transform: scale(0.80); opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
  ::view-transition-old(root),
  ::view-transition-new(root) {
    animation: none !important;
  }
}

/* ── Titulo hero ── */
/* ── Shell publico ── */
.public-shell {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(var(--bs-primary-rgb), 0.1), transparent 24rem),
    radial-gradient(circle at bottom right, rgba(var(--bs-info-rgb), 0.08), transparent 24rem),
    var(--bs-body-bg);
}

.public-main {
  flex: 1 0 auto;
}

/* Variante stacked: permite que un hijo marcado con flex:1 estire y centre */
.public-main--stack {
  display: flex;
  flex-direction: column;
}

.public-main--stack > .public-centered-section {
  align-items: center;
  display: flex;
  flex: 1 0 auto;
  justify-content: center;
  padding: 2rem 0;
}

/* Footer minimal: solo copyright */
.public-footer--minimal {
  border-top: 1px solid rgba(var(--bs-body-color-rgb), var(--public-border-alpha));
  margin-top: 2rem;
  padding: 1.5rem 0;
  text-align: center;
}

/* ── Navbar ──
   Fondo sólido (sin transparencia ni backdrop-filter) para máxima
   legibilidad y cumplir con accesibilidad visual. Padding vertical
   aumentado para que el header respire. */
/* Navbar con efecto glassmorphism (Apple/Samsung style). Fondo
 * semi-transparente + backdrop-filter para que el contenido scrolled
 * se vea sutilmente a traves. Tema-aware: blanco con 80% alpha en
 * light, negro azulado con 75% alpha en dark. */
.public-navbar {
  background-color: rgba(var(--bs-body-bg-rgb), 0.8);
  backdrop-filter: blur(15px) saturate(180%);
  -webkit-backdrop-filter: blur(15px) saturate(180%);
  border-bottom: 1px solid rgba(var(--bs-body-color-rgb), var(--public-border-alpha));
  padding: 0.75rem 0;
  transition: background-color 0.3s ease;
}

[data-bs-theme="dark"] .public-navbar {
  background-color: rgba(15, 17, 21, 0.75);
  border-bottom-color: rgba(255, 255, 255, 0.1);
}

/* Variante para paginas tipo webapp movil: mismos estilos que .public-navbar
   pero se usa desde partials/header_public_webapp.html (sin sticky). */
.public-navbar-webapp {
  background-color: var(--bs-body-bg);
  border-bottom: 1px solid rgba(var(--bs-body-color-rgb), var(--public-border-alpha));
  padding: 0.75rem 0;
}

/* Logo del header un pelín más grande para mejor presencia visual. */
.public-navbar .averiado-logo--horizontal,
.public-navbar-webapp .averiado-logo--horizontal {
  height: 2rem;
  width: auto;
}

/* Altura uniforme 2.5rem (40px) para el botón hamburguesa, para que
   visualmente sea coherente con los botones Entrar y Tema del header
   desktop cuando cambias entre breakpoints. */
.public-navbar .navbar-toggler,
.public-navbar-webapp .navbar-toggler {
  height: 2.5rem;
  padding: 0.5rem 0.75rem;
}

/* ── Acciones del header desktop ──
   Botones Entrar (CTA primary) y Tema (icon-only minimalista) con
   altura uniforme (igual que el hamburguesa) y orden:
   Entrar → Tema (al extremo derecho, como ajuste separado del menú). */
.public-actions .btn {
  height: 2.5rem;
}

.public-actions .public-entrar-btn {
  min-width: 6.5rem;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}

/* `.public-theme-btn` reutilizado tambien en el header del login
 * (login/_header.html). Selectores sin scope `.public-actions` para
 * que apliquen en ambos contextos. Margen izquierdo restringido al
 * header publico para no romper el layout del login. */
.public-theme-btn {
  align-items: center;
  background-color: var(--bs-body-bg);
  border: 1px solid rgba(var(--bs-body-color-rgb), 0.12);
  color: var(--bs-secondary-color);
  display: inline-flex;
  justify-content: center;
  padding: 0;
  width: 2.5rem;
  height: 2.5rem;
}

.public-actions .public-theme-btn {
  margin-left: 0.5rem;
}

.public-theme-btn:hover {
  background-color: rgba(var(--bs-body-color-rgb), 0.04);
  color: var(--bs-body-color);
  /* Override del glow general: un halo centrado (sin offset vertical)
   * rinde mejor en un boton redondo pequenyo de 40x40. `!important`
   * porque la regla `.public-actions .btn:hover` de mas abajo ya
   * setea una shadow con offset que opacaria esta. */
  box-shadow: 0 0 24px rgba(0, 122, 255, 0.55) !important;
}

[data-bs-theme="dark"] .public-theme-btn:hover {
  box-shadow: 0 0 28px rgba(0, 122, 255, 0.75) !important;
}

.public-theme-btn .bi {
  font-size: 1.1rem;
}

/* Toggle de iconos dark/light — el boton ubica los 2 iconos
 * `<i class="bi bi-moon-stars js-theme-icon-dark">` y
 * `<i class="bi bi-sun js-theme-icon-light">`, y el CSS elige cual
 * mostrar segun `data-bs-theme` del <html>. En light vemos la luna
 * (pulsa para ir a dark), en dark vemos el sol (pulsa para ir a light).
 * Util para header publico + header login + cualquier otro toggle. */
[data-bs-theme="light"] .js-theme-icon-dark { display: inline-block; }
[data-bs-theme="light"] .js-theme-icon-light { display: none; }
[data-bs-theme="dark"] .js-theme-icon-dark { display: none; }
[data-bs-theme="dark"] .js-theme-icon-light { display: inline-block; }

/* -------------------------------------------------------------------
   Glow azul apple en hover — unifica el sistema con las cards de
   directorio/repuestos/precios. Se aplica a:

   1. Nav pills y botones del header publico.
   2. Botones grandes (btn-lg) de la home publica (Entrar, Buscar
      taller, Consultar estado).
   3. Pills de Preferencias en el footer (Activar voz, Ajustes cookies).

   Valores: light 0.30 alpha / dark 0.45 alpha. Coherente con el glow
   hover de cards (dir-card-v2, inventory-public-card, login-card).
   ------------------------------------------------------------------- */
.public-header-desktop .navbar-nav .nav-link:hover,
.public-actions .btn:hover,
.public-navbar .navbar-toggler:hover,
.public-navbar .navbar-brand:hover,
.public-footer-pref-btn:hover,
.public-footer-pref-btn:focus {
  box-shadow: 0 10px 28px rgba(0, 122, 255, 0.3);
}

[data-bs-theme="dark"] .public-header-desktop .navbar-nav .nav-link:hover,
[data-bs-theme="dark"] .public-actions .btn:hover,
[data-bs-theme="dark"] .public-navbar .navbar-toggler:hover,
[data-bs-theme="dark"] .public-navbar .navbar-brand:hover,
[data-bs-theme="dark"] .public-footer-pref-btn:hover,
[data-bs-theme="dark"] .public-footer-pref-btn:focus {
  box-shadow: 0 10px 28px rgba(0, 122, 255, 0.45);
}

/* El logo (<a class="navbar-brand"><svg>) hereda un `border-radius`
 * de Bootstrap 0, por lo que el halo seria cuadrado. Redondear un poco
 * para que el glow se vea natural. Transition suave. */
.public-navbar .navbar-brand {
  border-radius: 0.5rem;
  padding: 0.25rem 0.5rem;
  transition: box-shadow 0.2s ease;
}

/* Botones grandes publicos (Entrar del hero, Buscar taller, Consultar
 * estado). Bootstrap `btn-lg` ya tiene transition en box-shadow por
 * defecto, no necesita override. Scope = bases publicas solo (public.css
 * no se carga en base_private). */
.btn-lg:hover {
  box-shadow: 0 10px 28px rgba(0, 122, 255, 0.3) !important;
}
[data-bs-theme="dark"] .btn-lg:hover {
  box-shadow: 0 10px 28px rgba(0, 122, 255, 0.45) !important;
}

/* -------------------------------------------------------------------
   Glow azul Apple reutilizable para cards bento del home y bloques
   similares. Opt-in via clase `.ax-card-glow`. Mismos valores que
   dir-card-v2 / inventory-public-card: 0.30 light / 0.45 dark.
   ------------------------------------------------------------------- */
.ax-card-glow {
  transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1),
              box-shadow 0.25s ease;
}
.ax-card-glow:hover,
.ax-card-glow:focus-within {
  transform: translateY(-4px);
  /* !important para sobreescribir `.shadow` / `.shadow-sm` de Bootstrap
     que los usan con `!important` en su declaracion base. */
  box-shadow: 0 18px 52px rgba(0, 122, 255, 0.3) !important;
}
[data-bs-theme="dark"] .ax-card-glow:hover,
[data-bs-theme="dark"] .ax-card-glow:focus-within {
  box-shadow: 0 18px 52px rgba(0, 122, 255, 0.45) !important;
}

/* Marca del header webapp: ajuste de letter-spacing extraido del inline style
   original de header_public_webapp.html (regla del proyecto: sin CSS inline). */
.public-brand-webapp {
  letter-spacing: -0.03em;
}

/* ── Menu movil publico (offcanvas) ──
   Se abre con el boton hamburguesa del header cuando viewport < lg.
   Reutiliza nav_public.html + actions_movil_public.html. Sin transparencia
   para maxima legibilidad en movil. Items uniformes de 56px con icono
   + texto y separadores entre cada uno. */
.public-mobile-menu {
  background-color: var(--bs-body-bg);
  border-left: 1px solid rgba(var(--bs-body-color-rgb), var(--public-border-alpha));
}

.public-mobile-menu-header {
  border-bottom: 1px solid rgba(var(--bs-body-color-rgb), var(--public-border-alpha));
  padding: 1rem 1.25rem;
}

.public-mobile-menu-body {
  padding: 0;
}

.public-mobile-menu .navbar-nav {
  display: flex;
  flex-direction: column;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
  width: 100%;
}

.public-mobile-menu .nav-item {
  width: 100%;
}

.public-mobile-menu .nav-link {
  align-items: center;
  background: transparent;
  border: 0;
  border-bottom: 1px solid rgba(var(--bs-body-color-rgb), var(--public-border-alpha));
  color: var(--bs-body-color);
  display: flex;
  font-size: 1.0625rem;
  font-weight: 500;
  gap: 0.875rem;
  min-height: 56px;
  padding: 1rem 1.25rem;
  text-align: left;
  text-decoration: none;
  width: 100%;
}

.public-mobile-menu .nav-link .bi {
  color: var(--bs-primary);
  flex-shrink: 0;
  font-size: 1.25rem;
  text-align: center;
  width: 1.5rem;
}

.public-mobile-menu .nav-link:hover,
.public-mobile-menu .nav-link:focus {
  background-color: rgba(var(--bs-body-color-rgb), 0.04);
  color: var(--bs-body-color);
  outline: none;
}

.public-mobile-menu .nav-link.active {
  background-color: rgba(var(--bs-primary-rgb), 0.08);
  color: var(--bs-primary);
  font-weight: 600;
}

/* CTA Entrar destacado: fondo primario, texto blanco, mismo tamaño. */
.public-mobile-menu .nav-link.public-mobile-nav-cta {
  background-color: var(--bs-primary);
  color: #fff;
  font-weight: 600;
}

.public-mobile-menu .nav-link.public-mobile-nav-cta .bi {
  color: #fff;
}

.public-mobile-menu .nav-link.public-mobile-nav-cta:hover,
.public-mobile-menu .nav-link.public-mobile-nav-cta:focus {
  background-color: var(--bs-primary);
  color: #fff;
  filter: brightness(1.08);
}

/* Divider grueso entre enlaces de navegacion y acciones (Tema/Entrar). */
.public-mobile-menu-divider {
  background-color: rgba(var(--bs-body-color-rgb), var(--public-border-alpha));
  border: 0;
  height: 0.5rem;
  margin: 0;
  opacity: 1;
  width: 100%;
}

/* Nav links desktop — estilo pill con icono + texto (look Apple/Samsung).
 * El offcanvas movil se rige por sus propias reglas mas abajo. */
.public-header-desktop .navbar-nav {
  gap: 0.25rem;
}

.public-header-desktop .navbar-nav .nav-link {
  align-items: center;
  border: 1px solid rgba(var(--bs-body-color-rgb), 0.12);
  border-radius: 999px;
  color: var(--bs-secondary-color);
  display: inline-flex;
  font-size: 0.95rem;
  font-weight: 500;
  gap: 0.5rem;
  padding: 0.45rem 0.95rem;
  transition: background-color 0.2s cubic-bezier(0.4, 0, 0.2, 1),
              border-color 0.2s cubic-bezier(0.4, 0, 0.2, 1),
              color 0.2s cubic-bezier(0.4, 0, 0.2, 1),
              box-shadow 0.2s ease;
}

.public-header-desktop .navbar-nav .nav-link .bi {
  font-size: 1rem;
}

.public-header-desktop .navbar-nav .nav-link:hover {
  background-color: rgba(var(--bs-body-color-rgb), 0.05);
  color: var(--bs-primary);
}

[data-bs-theme="dark"] .public-header-desktop .navbar-nav .nav-link:hover {
  background-color: rgba(255, 255, 255, 0.08);
}

.public-header-desktop .navbar-nav .nav-link:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px rgba(var(--bs-primary-rgb), 0.55);
}

.public-header-desktop .navbar-nav .nav-link.active {
  background-color: rgba(var(--bs-primary-rgb), 0.12);
  color: var(--bs-primary);
  font-weight: 600;
  box-shadow: 0 6px 18px rgba(var(--bs-primary-rgb), 0.18);
}

[data-bs-theme="dark"] .public-header-desktop .navbar-nav .nav-link.active {
  box-shadow: 0 6px 18px rgba(var(--bs-primary-rgb), 0.28);
}

/* ── Cards genericas ── */
.public-card {
  background-color: rgba(var(--bs-body-color-rgb), var(--public-bg-alpha));
  border: 1px solid rgba(var(--bs-body-color-rgb), var(--public-border-alpha));
  border-radius: var(--public-radius);
  height: 100%;
}

/* Cuando se aplica `.ax-radius-public` sobre un `.card` de Bootstrap,
   hay que reescribir tambien las variables internas de radio para que
   el header/footer hereden el radio correcto. Sin esto, el header
   mantiene el radio default de Bootstrap (~0.375rem) y asoma el fondo
   de la card por las esquinas superiores cuando el header usa
   `text-bg-primary` u otro fondo opaco. */
.ax-radius-public {
  --bs-card-border-radius: var(--public-radius);
  --bs-card-inner-border-radius: calc(var(--public-radius) - var(--bs-card-border-width, 1px));
}

/* ── Iconos destacados ── */
.public-icon {
  align-items: center;
  background-color: rgba(var(--bs-primary-rgb), var(--public-icon-bg-alpha));
  border-radius: var(--public-icon-radius);
  color: var(--bs-primary);
  display: inline-flex;
  font-size: 1.4rem;
  height: var(--public-icon-size);
  justify-content: center;
  width: var(--public-icon-size);
}

/* Variante inline: sin fondo, color del texto, a la par del titulo */
.public-icon--inline {
  background-color: transparent;
  color: inherit;
  font-size: 1.25rem;
  height: auto;
  width: auto;
}

/* ── Hero de paginas publicas (titulo principal con icono) ── */
.public-hero {
  align-items: center;
  display: flex;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.public-hero-icon {
  align-items: center;
  background: transparent;
  border: 0;
  color: inherit;
  display: inline-flex;
  font-size: 1.8rem;
  height: auto;
  justify-content: center;
  width: auto;
}

.public-hero-title {
  font-size: clamp(2rem, 2.6vw, 3.2rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  margin-bottom: 0.25rem;
}

/* Titulo de card (equivalente a h5, responsivo) */
.public-card-title {
  font-size: clamp(1.1rem, 1rem + 0.35vw, 1.25rem);
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.3;
  margin: 0;
}

/* ── Barra de busqueda + caja de filtros colapsable (patron unificado) ── */
.public-search-bar {
  display: grid;
  gap: 1rem;
  position: relative;
  z-index: 30;
}

.public-search-bar > .form-control {
  border-radius: 999px;
  min-height: 3.4rem;
  padding-left: 3rem;
}

.public-search-icon {
  color: var(--bs-secondary-color);
  font-size: 1rem;
  left: 1rem;
  pointer-events: none;
  position: absolute;
  top: 1.12rem;
  z-index: 2;
}

.public-filter-box {
  background-color: rgba(var(--bs-body-bg-rgb), 0.96);
  border: 1px solid rgba(var(--bs-body-color-rgb), 0.12);
  border-radius: 1.4rem;
  overflow: visible;
  position: relative;
  z-index: 40;
}

[data-bs-theme="dark"] .public-filter-box {
  background-color: rgba(20, 30, 52, 0.9);
  border-color: rgba(255, 255, 255, 0.12);
}

.public-filter-header {
  align-items: center;
  cursor: pointer;
  display: flex;
  gap: 0.75rem;
  justify-content: space-between;
  padding: 1rem 1.2rem;
}

.public-filter-count {
  color: rgba(var(--bs-body-color-rgb), 0.72);
  font-size: 0.84rem;
  margin-left: auto;
}

[data-bs-theme="dark"] .public-filter-count {
  color: rgba(248, 251, 255, 0.72);
}

.public-filter-body {
  border-top: 1px solid rgba(var(--bs-body-color-rgb), 0.08);
  padding: 1rem 1.2rem 1.2rem;
}

.public-filter-box.collapsed .public-filter-body {
  display: none;
}

.public-filter-box.collapsed .public-filter-chevron {
  transform: rotate(-90deg);
}

.public-filter-chevron {
  transition: transform 0.18s ease;
}

/* ── Modal de imagen ampliada (patron unificado) ── */
.public-image-dialog {
  justify-content: center;
  margin: 1rem auto;
  max-width: none;
  width: auto;
}

.public-image-modal .modal-content {
  background-color: rgba(var(--bs-body-bg-rgb), 0.96);
  backdrop-filter: blur(10px);
  border-radius: 1.15rem;
  width: auto;
  /* Glow azul apple como halo permanente mientras el modal esta
   * abierto — coherente con el sistema de cards. */
  box-shadow: 0 18px 52px rgba(0, 122, 255, 0.3);
}

[data-bs-theme="dark"] .public-image-modal .modal-content {
  box-shadow: 0 18px 52px rgba(0, 122, 255, 0.45);
}

.public-image-modal .modal-header {
  padding: 0.5rem 0.5rem 0 0.5rem;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 2;
}

.public-image-modal .modal-body {
  padding: 0.75rem;
}

.public-modal-image {
  height: auto;
  max-height: min(82vh, 56rem);
  max-width: min(92vw, 72rem);
  width: auto;
}

.btn-close-custom {
  align-items: center;
  background-color: rgba(var(--bs-body-bg-rgb), 0.9);
  backdrop-filter: blur(6px);
  border: 1px solid var(--bs-border-color);
  border-radius: 50%;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
  color: var(--bs-body-color);
  display: inline-flex;
  font-size: 1.25rem;
  height: 2.5rem;
  justify-content: center;
  line-height: 1;
  padding: 0;
  transition: background-color 0.18s ease, transform 0.18s ease,
    box-shadow 0.18s ease, color 0.18s ease;
  width: 2.5rem;
}

.btn-close-custom:hover {
  background-color: var(--bs-body-bg);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.18);
  transform: scale(1.08);
}

.btn-close-custom:focus-visible {
  box-shadow: none;
  outline: 2px solid var(--bs-primary);
  outline-offset: 2px;
}

/* ── Footer ── */
.public-footer {
  border-top: 1px solid rgba(var(--bs-body-color-rgb), var(--public-border-alpha));
  /* margin-top eliminado 2026-04-21: dejaba un hueco feo entre el
   * contenido y el borde superior del footer. La separacion visual
   * ya viene del contraste de fondo (bg-body-tertiary del main vs
   * rgb(245,245,247) del footer paleta Apple) + el border-top. */
  padding: 3rem 0 2rem;
}

.public-footer-title {
  /* Tag semantico: <h5>. La clase pisa los defaults de heading para mantener
     tamanyo y layout identicos a los anteriores <p> / <h2>. Desde
     2026-04-21 tipografia uppercase + tracking para coherencia con
     otras secciones premium (tipo Apple). */
  color: var(--bs-secondary-color);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  margin-bottom: 1rem;
  text-transform: uppercase;
  line-height: 1.4;
  margin-top: 0;
  margin-bottom: 1rem;
}

.public-footer-link-pending {
  color: var(--bs-secondary-color);
  opacity: 0.75;
  cursor: default;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.public-footer-badge {
  background: transparent;
  border: 1px solid var(--bs-border-color);
  border-radius: 999px;
  color: var(--bs-secondary-color);
  font-weight: 500;
  padding: 0.05rem 0.5rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.public-footer-copy-link,
.public-footer-copy-link:hover,
.public-footer-copy-link:focus {
  color: inherit;
  text-decoration: none;
}

.public-footer-links {
  list-style: none;
  margin: 0;
  padding: 0;
}

.public-footer-links li + li {
  margin-top: 0.6rem;
}

.public-footer-links a {
  color: var(--bs-secondary-color);
  text-decoration: none;
}

.public-footer-links a:hover {
  color: var(--bs-body-color);
  text-decoration: underline;
}

.public-footer-divider {
  margin: 2.5rem 0 1.5rem;
  border: 0;
  border-top: 1px solid rgba(var(--bs-body-color-rgb), var(--public-border-alpha));
  opacity: 1;
}

.public-footer-copy {
  color: var(--bs-secondary-color);
  font-size: 0.85rem;
  /* Neutralizar estilos de heading por defecto cuando el tag es <h4>:
     Bootstrap / navegador aplican font-weight 500 y margenes verticales
     que romperian el aspecto del copy. Aqui forzamos los valores que
     hereda un parrafo normal para mantener el mismo tamanyo y layout
     independientemente del tag HTML usado. */
  font-weight: normal;
  line-height: normal;
  margin: 0;
}

/* -------------------------------------------------------------------
   Columna Preferencias: botones pill con icono (tema-aware).
   ------------------------------------------------------------------- */

.public-footer-pref-list {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.public-footer-pref-btn {
  align-items: center;
  background: rgba(var(--bs-body-color-rgb), 0.04);
  border: 1px solid rgba(var(--bs-body-color-rgb), 0.12);
  border-radius: var(--bs-border-radius-pill) !important;
  color: var(--bs-body-color);
  display: flex;
  font-size: 0.88rem;
  font-weight: 500;
  gap: 0.6rem;
  padding: 0.55rem 0.85rem;
  text-decoration: none;
  transition: background-color 0.18s ease, border-color 0.18s ease;
  width: 100%;
}

.public-footer-pref-btn:hover,
.public-footer-pref-btn:focus {
  background: rgba(var(--bs-body-color-rgb), 0.08);
  border-color: rgba(var(--bs-body-color-rgb), 0.2);
  color: var(--bs-body-color);
  text-decoration: none;
}

.public-footer-pref-icon {
  font-size: 1.15rem;
  flex-shrink: 0;
}

.public-footer-pref-icon--voice { color: var(--bs-primary); }
.public-footer-pref-icon--cookies { color: var(--bs-info); }

/* -------------------------------------------------------------------
   Bottom row (logo + copyright).
   ------------------------------------------------------------------- */

.public-footer-bottom {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  justify-content: space-between;
}

@media (min-width: 768px) {
  .public-footer-bottom {
    flex-direction: row;
  }
  .public-footer-bottom .public-footer-copy {
    text-align: right;
  }
}

.public-footer-brand {
  align-items: center;
  color: var(--bs-body-color);
  display: flex;
  gap: 0.5rem;
}
.public-footer-brand > .bi {
  color: var(--bs-primary);
  font-size: 1.25rem;
}
.public-footer-brand-name {
  font-size: 1.1rem;
  font-weight: 700;
  margin: 0;
}
.public-footer-brand-dot {
  color: var(--bs-primary);
}

/* -------------------------------------------------------------------
   Footer paleta estilo Apple (experimental, 2026-04-21).
   CSS propuesto por Juan — adaptado para respetar el toggle manual
   `data-bs-theme` del <html> (nuestra web NO usa `prefers-color-scheme`
   porque el tema es eleccion del usuario, no del SO) y limitado a
   `.public-footer` para no afectar otros <footer> del proyecto.
   ------------------------------------------------------------------- */
.public-footer {
  --footer-background: rgb(245, 245, 247);
  --footer-border-color: rgba(0, 0, 0, 0.16);
  --footer-text-color: rgba(0, 0, 0, 0.56);
  --footer-link-color: rgba(0, 0, 0, 0.72);

  background-color: var(--footer-background);
  color: var(--footer-text-color);
  border-top: 1px solid var(--footer-border-color);
  transition: background-color 0.3s ease, border-top-color 0.3s ease, color 0.3s ease;
}

[data-bs-theme="dark"] .public-footer {
  --footer-background: #161617; /* Apple dark */
  --footer-border-color: rgba(255, 255, 255, 0.16);
  --footer-text-color: rgba(255, 255, 255, 0.56);
  --footer-link-color: rgba(255, 255, 255, 0.72);
}

.public-footer a {
  color: var(--footer-link-color);
  text-decoration: none;
  transition: color 0.2s ease;
}
.public-footer a:hover,
.public-footer a:focus {
  color: var(--bs-body-color);
  text-decoration: underline;
}

/* ------------------------------------------------------------------
 * Inputs de consulta rapida de seguimiento (home + /seguimiento).
 * Ambos marcados con `data-seguimiento-input`. Reglas compartidas:
 *   - placeholder muy tenue para que no compita con el cursor
 *   - placeholder desaparece al recibir foco (Juan 2026-04-23)
 *   - `type="search"` evita el prompt de iCloud Passwords en Safari/Mac;
 *     ocultamos el boton X nativo de limpiar para preservar el layout.
 * ------------------------------------------------------------------ */
[data-seguimiento-input]::placeholder {
  color: rgba(var(--bs-body-color-rgb), 0.28);
  opacity: 1;
}
[data-seguimiento-input]:focus::placeholder {
  color: transparent;
}
[data-seguimiento-input]::-webkit-search-cancel-button,
[data-seguimiento-input]::-webkit-search-decoration,
[data-seguimiento-input]::-webkit-search-results-button,
[data-seguimiento-input]::-webkit-search-results-decoration {
  -webkit-appearance: none;
  appearance: none;
  display: none;
}
