/* ==========================================================================
   NOTICE — Staff messages and site-wide announcements.
   ========================================================================== */

/* ---------- PER-PAGE STAFF MESSAGE ---------- */
/* Shown on individual content pages when field_staff_message has content. */

.otb-notice {
  border-left: 3px solid var(--color-primary);
  padding: var(--spacing-sm) var(--spacing-md);
  margin-bottom: var(--spacing-md);
  border-radius: var(--border-radius-sm);
  font-size: var(--font-size-xs);
  font-style: italic;
  background: var(--color-bg-surface, var(--color-gray-100));
  color: var(--color-text-primary, var(--color-gray-700));
}

.main--dark .otb-notice,
[data-theme="dark"] .otb-notice {
  background: var(--color-dark-charcoal);
  color: var(--color-gray-300);
}

.otb-notice p {
  margin: 0;
}

/* ---------- SITE-WIDE ANNOUNCEMENT ---------- */
/* Shown at the top of every page when set in OtB TV Settings. */

.otb-site-announcement {
  background: var(--color-primary);
  color: var(--color-white);
  text-align: center;
  padding: var(--spacing-sm) var(--spacing-md);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
}

.otb-site-announcement a {
  color: var(--color-white);
  text-decoration: underline;
}

.otb-site-announcement p {
  margin: 0;
}

/* ---------- INSTITUTIONAL ACCESS BANNER ---------- */
/* Shown to visitors accessing from an institutional IP range. */

.otb-institutional-banner {
  background: var(--color-status-info-bg);
  color: var(--color-status-info-text);
  text-align: center;
  padding: var(--spacing-xs) var(--spacing-md);
  font-size: var(--font-size-xs);
}

.otb-institutional-banner p {
  margin: 0;
}

.otb-institutional-banner__signin {
  color: inherit;
  font-weight: var(--font-weight-medium);
  text-decoration: underline;
  margin-left: var(--spacing-xs);
}

.otb-institutional-banner__signin:hover,
.otb-institutional-banner__signin:focus {
  text-decoration: none;
}
