[data-fui-comp="ui-banner"] {
  display: flex;
  gap: var(--spacing-md, 12px);
  align-items: flex-start;
  padding: var(--spacing-md, 12px) var(--spacing-lg, 16px);
  border: 1px solid var(--color-border, #E4E4E7);
  border-left: 4px solid var(--color-info, #3B82F6);
  border-radius: var(--radii-md, 8px);
  background: var(--color-surface, #FFFFFF);
  color: var(--color-text, #18181B);
}
[data-fui-comp="ui-banner"] .ui-banner__icon {
  flex: 0 0 auto;
  display: inline-flex;
  color: var(--color-info, #3B82F6);
  margin-top: 2px;
}
[data-fui-comp="ui-banner"] .ui-banner__content {
  flex: 1 1 auto;
  min-width: 0;
  display: grid;
  gap: 2px;
}
[data-fui-comp="ui-banner"] .ui-banner__title {
  margin: 0;
  font-weight: 600;
  font-size: 0.95rem;
}
[data-fui-comp="ui-banner"] .ui-banner__body {
  margin: 0;
  color: var(--color-text-muted, #52525B);
  font-size: 0.9rem;
  line-height: 1.45;
}
[data-fui-comp="ui-banner"] .ui-banner__action {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
}
[data-fui-comp="ui-banner"] .ui-banner__dismiss {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  /* WCAG 2.5.5 — even the dismiss X needs the 44px tap floor. */
  min-block-size: var(--spacing-touch-target, 44px);
  min-inline-size: var(--spacing-touch-target, 44px);
  background: transparent;
  border: 0;
  color: var(--color-text-muted, #52525B);
  cursor: pointer;
  border-radius: var(--radii-sm, 4px);
  margin: -8px -8px -8px 0;
}
[data-fui-comp="ui-banner"] .ui-banner__dismiss:hover {
  background: var(--color-surface-soft, #F4F4F5);
  color: var(--color-text, #18181B);
}
[data-fui-comp="ui-banner"] .ui-banner__dismiss:focus-visible {
  outline: 2px solid var(--color-primary, #4F46E5);
  outline-offset: 2px;
}

/* Variants — recolor border-left + icon. */
.ui-banner--success { border-left-color: var(--color-success, #16A34A); }
.ui-banner--success .ui-banner__icon { color: var(--color-success, #16A34A); }
.ui-banner--warn { border-left-color: var(--color-warning, #D97706); }
.ui-banner--warn .ui-banner__icon { color: var(--color-warning, #D97706); }
.ui-banner--danger { border-left-color: var(--color-danger, #DC2626); }
.ui-banner--danger .ui-banner__icon { color: var(--color-danger, #DC2626); }

/* Hidden state for runtime dismiss. */
[data-fui-comp="ui-banner"][hidden] { display: none; }