/* Cross-template polish — mobar, footer, forms, focus */
.mobar {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 60;
  padding: 12px 16px;
  gap: 10px;
  align-items: stretch;
}
.mobar .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 700;
  font-size: 14px;
  padding: 14px 16px;
  border: 0;
  cursor: pointer;
  text-decoration: none;
  transition: opacity .15s, filter .15s;
}
.mobar .btn-outline {
  background: transparent;
  border: 2px solid currentColor;
}
.mobar .btn-primary { border: 0; }
.site-footer a:hover { opacity: .72; }
#foot-contact a { display: inline-block; margin: 2px 0; }
.areas-label {
  display: block; width: 100%; font-size: 11px; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase; opacity: .65; margin-bottom: 8px;
}
.form-msg:empty { display: none; }
input:focus-visible,
textarea:focus-visible,
button:focus-visible,
a.btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}

@media (prefers-reduced-motion: reduce) {
  .reveal { transition: none !important; }
  #serv-marquee .track { animation: none !important; }
}
