/* SR Power shared component contract. Rules are namespaced to avoid legacy regressions. */
.srp-context-storefront,
.srp-context-operational {
  font-family: var(--srp-font-sans);
  color: var(--srp-foreground);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

.srp-context-storefront :where(button, input, select, textarea),
.srp-context-operational :where(button, input, select, textarea) {
  font: inherit;
}

.srp-context-storefront :where(a, button, input, select, textarea, summary, [tabindex]):focus-visible,
.srp-context-operational :where(a, button, input, select, textarea, summary, [tabindex]):focus-visible {
  outline: 2px solid var(--srp-primary);
  outline-offset: 2px;
  box-shadow: var(--srp-shadow-focus);
}

.srp-context-storefront :where(button, [role="button"], input[type="submit"], input[type="button"]),
.srp-context-operational :where(button, [role="button"], input[type="submit"], input[type="button"]) {
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

.srp-ui-button {
  min-height: var(--srp-control-height);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--srp-space-2);
  padding: .625rem 1rem;
  border: 1px solid transparent;
  border-radius: var(--srp-radius-md);
  background: var(--srp-primary);
  color: var(--srp-primary-foreground);
  font-size: var(--srp-text-sm);
  font-weight: var(--srp-weight-semibold);
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  transition: background-color var(--srp-duration-normal) var(--srp-ease-standard), border-color var(--srp-duration-normal) var(--srp-ease-standard), box-shadow var(--srp-duration-normal) var(--srp-ease-standard), transform var(--srp-duration-fast) var(--srp-ease-standard);
}
.srp-ui-button:hover { background: var(--srp-primary-hover); }
.srp-ui-button:active { transform: translateY(1px); }
.srp-ui-button:disabled,
.srp-ui-button[aria-disabled="true"] { opacity: .5; pointer-events: none; cursor: not-allowed; }
.srp-ui-button--secondary { background: var(--srp-secondary); color: var(--srp-secondary-foreground); border-color: var(--srp-border); }
.srp-ui-button--secondary:hover { background: var(--srp-secondary-hover); }
.srp-ui-button--outline { background: var(--srp-surface); color: var(--srp-foreground); border-color: var(--srp-border-strong); }
.srp-ui-button--outline:hover { background: var(--srp-muted); }
.srp-ui-button--ghost { background: transparent; color: var(--srp-foreground); }
.srp-ui-button--ghost:hover { background: var(--srp-muted); }
.srp-ui-button--destructive { background: var(--srp-destructive); color: var(--srp-destructive-foreground); }
.srp-ui-button--destructive:hover { background: var(--srp-destructive-hover); }
.srp-ui-button--sm { min-height: var(--srp-control-height-sm); padding: .45rem .75rem; }
.srp-ui-button--lg { min-height: var(--srp-control-height-lg); padding: .75rem 1.25rem; }
.srp-ui-button--icon { width: var(--srp-control-height); padding: 0; }

.srp-ui-field { display: grid; gap: var(--srp-space-2); }
.srp-ui-label { font-size: var(--srp-text-sm); font-weight: var(--srp-weight-semibold); color: var(--srp-slate-700); }
.srp-ui-help { margin: 0; color: var(--srp-muted-foreground); font-size: var(--srp-text-xs); line-height: var(--srp-leading-normal); }
.srp-ui-error { margin: 0; color: var(--srp-danger-700); font-size: var(--srp-text-xs); font-weight: var(--srp-weight-medium); }
.srp-ui-input,
.srp-ui-select,
.srp-ui-textarea {
  width: 100%;
  min-height: var(--srp-control-height);
  border: 1px solid var(--srp-input);
  border-radius: var(--srp-radius-md);
  background: var(--srp-surface);
  color: var(--srp-foreground);
  padding: .625rem .75rem;
  transition: border-color var(--srp-duration-normal) var(--srp-ease-standard), box-shadow var(--srp-duration-normal) var(--srp-ease-standard);
}
.srp-ui-textarea { min-height: 7rem; resize: vertical; }
.srp-ui-input::placeholder,
.srp-ui-textarea::placeholder { color: var(--srp-slate-400); }
.srp-ui-input[aria-invalid="true"],
.srp-ui-select[aria-invalid="true"],
.srp-ui-textarea[aria-invalid="true"] { border-color: var(--srp-danger-600); }

.srp-ui-card {
  border: 1px solid var(--srp-border);
  border-radius: var(--srp-radius-xl);
  background: var(--srp-surface-raised);
  box-shadow: var(--srp-shadow-sm);
  overflow: hidden;
}
.srp-ui-card__header,
.srp-ui-card__body,
.srp-ui-card__footer { padding: var(--srp-density-padding); }
.srp-ui-card__header { border-bottom: 1px solid var(--srp-border); }
.srp-ui-card__footer { border-top: 1px solid var(--srp-border); background: var(--srp-surface-subtle); }

.srp-ui-badge {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: .2rem .55rem;
  border: 1px solid var(--srp-border);
  border-radius: var(--srp-radius-full);
  background: var(--srp-muted);
  color: var(--srp-slate-700);
  font-size: var(--srp-text-xs);
  font-weight: var(--srp-weight-semibold);
  line-height: 1;
  white-space: nowrap;
}
.srp-ui-badge--success { background: var(--srp-success-50); border-color: var(--srp-success-200); color: var(--srp-success-700); }
.srp-ui-badge--warning { background: var(--srp-warning-50); border-color: var(--srp-warning-200); color: var(--srp-warning-700); }
.srp-ui-badge--danger { background: var(--srp-danger-50); border-color: var(--srp-danger-200); color: var(--srp-danger-700); }
.srp-ui-badge--info { background: var(--srp-info-50); border-color: var(--srp-info-200); color: var(--srp-info-600); }

.srp-ui-table-wrap { width: 100%; overflow-x: auto; overscroll-behavior-inline: contain; border: 1px solid var(--srp-border); border-radius: var(--srp-radius-lg); background: var(--srp-surface); }
.srp-ui-table { width: 100%; border-collapse: collapse; font-size: var(--srp-text-sm); }
.srp-ui-table th,
.srp-ui-table td { min-height: var(--srp-density-row); padding: .7rem .8rem; border-bottom: 1px solid var(--srp-border); text-align: left; vertical-align: middle; }
.srp-ui-table th { background: var(--srp-surface-subtle); color: var(--srp-slate-600); font-size: var(--srp-text-xs); font-weight: var(--srp-weight-bold); letter-spacing: .03em; text-transform: uppercase; }
.srp-ui-table tbody tr:last-child td { border-bottom: 0; }

.srp-ui-dialog,
.srp-ui-sheet {
  position: fixed;
  z-index: var(--srp-z-dialog);
  background: var(--srp-surface);
  color: var(--srp-foreground);
  box-shadow: var(--srp-shadow-lg);
}
.srp-ui-dialog { inset: 50% auto auto 50%; width: min(calc(100% - 2rem), 36rem); max-height: min(85dvh, 48rem); transform: translate(-50%, -50%); border: 1px solid var(--srp-border); border-radius: var(--srp-radius-xl); overflow: auto; }
.srp-ui-sheet { inset: 0 0 0 auto; width: min(92vw, 26rem); padding-bottom: var(--srp-safe-bottom); overflow-y: auto; }
.srp-ui-backdrop { position: fixed; inset: 0; z-index: var(--srp-z-overlay); background: var(--srp-overlay); backdrop-filter: blur(2px); }

.srp-ui-tabs { display: flex; gap: var(--srp-space-1); padding: var(--srp-space-1); border: 1px solid var(--srp-border); border-radius: var(--srp-radius-lg); background: var(--srp-muted); overflow-x: auto; }
.srp-ui-tab { min-height: var(--srp-control-height-sm); flex: 0 0 auto; border: 0; border-radius: var(--srp-radius-md); background: transparent; color: var(--srp-muted-foreground); padding: .5rem .75rem; font-weight: var(--srp-weight-semibold); cursor: pointer; }
.srp-ui-tab[aria-selected="true"], .srp-ui-tab.is-active { background: var(--srp-surface); color: var(--srp-foreground); box-shadow: var(--srp-shadow-xs); }

.srp-ui-accordion { border: 1px solid var(--srp-border); border-radius: var(--srp-radius-lg); background: var(--srp-surface); overflow: hidden; }
.srp-ui-accordion > summary { min-height: var(--srp-control-height); display: flex; align-items: center; cursor: pointer; padding: .75rem 1rem; font-weight: var(--srp-weight-semibold); }
.srp-ui-accordion[open] > summary { border-bottom: 1px solid var(--srp-border); }
.srp-ui-accordion__content { padding: 1rem; }

.srp-ui-toast-region { position: fixed; z-index: var(--srp-z-toast); right: max(1rem, var(--srp-safe-right)); bottom: max(1rem, var(--srp-safe-bottom)); width: min(calc(100% - 2rem), 24rem); display: grid; gap: .75rem; pointer-events: none; }
.srp-ui-toast { pointer-events: auto; padding: .875rem 1rem; border: 1px solid var(--srp-border); border-radius: var(--srp-radius-lg); background: var(--srp-surface); box-shadow: var(--srp-shadow-md); font-size: var(--srp-text-sm); }

.srp-ui-skeleton { position: relative; overflow: hidden; border-radius: var(--srp-radius-sm); background: var(--srp-slate-200); color: transparent !important; }
.srp-ui-skeleton::after { content: ""; position: absolute; inset: 0; transform: translateX(-100%); background: linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent); animation: srp-skeleton 1.4s infinite; }
@keyframes srp-skeleton { to { transform: translateX(100%); } }

.srp-ui-command { overflow: hidden; border: 1px solid var(--srp-border); border-radius: var(--srp-radius-xl); background: var(--srp-surface); box-shadow: var(--srp-shadow-lg); }
.srp-ui-command__input { width: 100%; min-height: 48px; border: 0; border-bottom: 1px solid var(--srp-border); padding: .75rem 1rem; outline: 0; }
.srp-ui-command__list { max-height: min(50dvh, 24rem); overflow-y: auto; padding: .5rem; }
.srp-ui-command__item { min-height: var(--srp-control-height); display: flex; align-items: center; gap: .75rem; border-radius: var(--srp-radius-md); padding: .625rem .75rem; cursor: pointer; }
.srp-ui-command__item:hover, .srp-ui-command__item[aria-selected="true"] { background: var(--srp-muted); }

.srp-ui-status-dot { width: .55rem; height: .55rem; flex: 0 0 auto; border-radius: var(--srp-radius-full); background: currentColor; }
.srp-ui-empty { padding: clamp(2rem, 8vw, 5rem) 1rem; text-align: center; color: var(--srp-muted-foreground); }
.srp-ui-actions { display: flex; flex-wrap: wrap; align-items: center; gap: var(--srp-space-2); }
.srp-ui-stack { display: grid; gap: var(--srp-density-gap); }
.srp-ui-cluster { display: flex; flex-wrap: wrap; align-items: center; gap: var(--srp-density-gap); }

[hidden] { display: none !important; }
[aria-busy="true"] { cursor: progress; }
body.srp-ui-scroll-lock { overflow: hidden; touch-action: none; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
}
