
/* Root wrapper – keeps everything isolated */
.kmx-osb-root {
  --kmx-bg: #020617;
  --kmx-bg-elevated: rgba(15,23,42,0.98);
  --kmx-bg-soft: rgba(15,23,42,0.92);
  --kmx-border-subtle: rgba(148,163,184,0.25);
  --kmx-border-strong: rgba(148,163,184,0.45);
  --kmx-text-main: #e5e7eb;
  --kmx-text-muted: #9ca3af;
  --kmx-accent: #38bdf8;
  --kmx-accent-soft: rgba(56,189,248,0.16);
  --kmx-accent-strong: #6366f1;
  --kmx-danger: #f97373;
  --kmx-success: #22c55e;
  --kmx-warning: #eab308;
  --kmx-radius-lg: 18px;
  --kmx-radius-md: 12px;
  --kmx-radius-pill: 999px;
  --kmx-shadow-soft: 0 18px 45px rgba(15,23,42,0.85);
  --kmx-shadow-strong: 0 25px 70px rgba(15,23,42,0.95);
  --kmx-blur: 18px;
  --kmx-transition-fast: 150ms ease-out;
  --kmx-transition-med: 200ms ease;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif;
}

/* Core layout */
.kmx-osb-root .osb-main-section.osb-fullwidth {
  width: 100%;
  max-width: 1240px;
  margin: 0 auto 26px;
  padding: 20px 20px 22px;
  background:
    radial-gradient(circle at top left, rgba(56,189,248,0.16), transparent 55%),
    radial-gradient(circle at bottom right, rgba(99,102,241,0.18), transparent 55%),
    linear-gradient(135deg, rgba(15,23,42,0.98), rgba(15,23,42,1));
  border-radius: var(--kmx-radius-lg);
  border: 1px solid rgba(148,163,184,0.32);
  box-shadow: var(--kmx-shadow-soft);
  color: var(--kmx-text-main);
  position: relative;
  overflow: hidden;
}

.kmx-osb-root .osb-main-section.osb-fullwidth::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top, rgba(15,23,42,0.35), transparent 65%);
  mix-blend-mode: soft-light;
  pointer-events: none;
}

/* Header */
.kmx-osb-root .osb-tab-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
  position: relative;
  z-index: 1;
}

.kmx-osb-root .osb-tab-header h1 {
  margin: 0;
  font-size: 20px;
  font-weight: 600;
  letter-spacing: 0.01em;
}

.kmx-osb-root .osb-tab-header p {
  margin: 4px 0 0;
  font-size: 13px;
  color: var(--kmx-text-muted);
}

/* Subtle header accent line */
.kmx-osb-root .osb-main-section.osb-fullwidth > .osb-tab-header::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -8px;
  height: 1px;
  background: linear-gradient(90deg,
    transparent,
    rgba(148,163,184,0.45),
    transparent);
  opacity: 0.75;
}

/* Cards row (stats) */
.kmx-osb-root .osb-card-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 14px;
  margin: 22px 0 20px;
}

.kmx-osb-root .osb-stat-card {
  border-radius: 14px;
  padding: 12px 14px;
  background:
    linear-gradient(145deg, rgba(15,23,42,0.9), rgba(15,23,42,1)),
    radial-gradient(circle at top right, rgba(56,189,248,0.22), transparent 60%);
  border: 1px solid rgba(148,163,184,0.35);
  box-shadow: 0 12px 35px rgba(15,23,42,0.7);
  position: relative;
  overflow: hidden;
  transition: transform var(--kmx-transition-fast), box-shadow var(--kmx-transition-fast), border-color var(--kmx-transition-fast);
}

.kmx-osb-root .osb-stat-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top right, rgba(148,163,184,0.16), transparent 55%);
  mix-blend-mode: soft-light;
  opacity: 0;
  transition: opacity var(--kmx-transition-fast);
}

.kmx-osb-root .osb-stat-card:hover {
  transform: translateY(-1px);
  box-shadow: var(--kmx-shadow-soft);
  border-color: rgba(148,163,184,0.6);
}

.kmx-osb-root .osb-stat-card:hover::after {
  opacity: 1;
}

.kmx-osb-root .osb-stat-card.osb-stat-success { border-color: rgba(34,197,94,0.65); }
.kmx-osb-root .osb-stat-card.osb-stat-danger  { border-color: rgba(248,113,113,0.7); }
.kmx-osb-root .osb-stat-card.osb-stat-warning { border-color: rgba(234,179,8,0.7); }

.kmx-osb-root .osb-stat-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .09em;
  color: var(--kmx-text-muted);
}

.kmx-osb-root .osb-stat-value {
  margin-top: 6px;
  font-size: 23px;
  font-weight: 600;
}

/* Generic card */
.kmx-osb-root .osb-card {
  border-radius: 16px;
  padding: 14px 16px 16px;
  background: radial-gradient(circle at top, rgba(15,23,42,0.96), rgba(15,23,42,1));
  border: 1px solid rgba(148,163,184,0.32);
  box-shadow: 0 16px 48px rgba(15,23,42,0.9);
  margin-bottom: 18px;
  position: relative;
  overflow: hidden;
}

.kmx-osb-root .osb-card::before {
  content: "";
  position: absolute;
  inset: -40%;
  background: conic-gradient(from 220deg, transparent, rgba(56,189,248,0.08), transparent 45%);
  opacity: 0.6;
  mix-blend-mode: soft-light;
  pointer-events: none;
}

.kmx-osb-root .osb-card-title {
  margin: 0 0 10px;
  font-size: 15px;
  font-weight: 500;
}

/* Funnel bar */
.kmx-osb-root .osb-analytics-bar {
  display: flex;
  width: 100%;
  border-radius: 999px;
  overflow: hidden;
  border: 1px solid rgba(148,163,184,0.4);
  background: rgba(15,23,42,0.95);
  font-size: 11px;
}

.kmx-osb-root .osb-bar-segment {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5px 0;
  white-space: nowrap;
  font-weight: 500;
  color: #0b0f19;
}

.kmx-osb-root .osb-bar-approved {
  background: linear-gradient(90deg, rgba(34,197,94,0.9), rgba(16,185,129,0.95));
}

.kmx-osb-root .osb-bar-pending {
  background: linear-gradient(90deg, rgba(234,179,8,0.96), rgba(249,115,22,0.98));
}

.kmx-osb-root .osb-bar-rejected {
  background: linear-gradient(90deg, rgba(248,113,113,0.95), rgba(190,24,93,0.98));
}

/* Sections & layout */
.kmx-osb-root .osb-section {
  margin-bottom: 16px;
}

.kmx-osb-root .osb-section-title {
  font-size: 14px;
  margin: 0 0 8px;
  color: var(--kmx-text-main);
}

.kmx-osb-root .osb-two-column {
  display: grid;
  grid-template-columns: minmax(0,1.1fr) minmax(0,1fr);
  gap: 18px;
}

/* List layout */
.kmx-osb-root .osb-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.kmx-osb-root .osb-list-item {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: var(--kmx-radius-md);
  background: linear-gradient(125deg, rgba(15,23,42,0.96), rgba(15,23,42,1));
  border: 1px solid rgba(51,65,85,0.95);
  box-shadow: 0 10px 28px rgba(15,23,42,0.85);
  position: relative;
  overflow: hidden;
  transition: transform var(--kmx-transition-fast), box-shadow var(--kmx-transition-fast), border-color var(--kmx-transition-fast);
}

.kmx-osb-root .osb-list-item::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top left, rgba(56,189,248,0.14), transparent 60%);
  opacity: 0;
  transition: opacity var(--kmx-transition-fast);
}

.kmx-osb-root .osb-list-item:hover {
  transform: translateY(-1px);
  border-color: rgba(148,163,184,0.7);
  box-shadow: var(--kmx-shadow-soft);
}

.kmx-osb-root .osb-list-item:hover::before {
  opacity: 1;
}

.kmx-osb-root .osb-list-main { flex: 1; }

.kmx-osb-root .osb-list-title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
}

.kmx-osb-root .osb-list-name {
  font-weight: 500;
  font-size: 13px;
}

.kmx-osb-root .osb-list-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 11px;
  color: var(--kmx-text-muted);
}

.kmx-osb-root .osb-list-meta strong { color: var(--kmx-text-main); }

.kmx-osb-root .osb-list-actions {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: flex-end;
  justify-content: center;
}

.kmx-osb-root .osb-list-credentials {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.kmx-osb-root .osb-empty {
  font-size: 13px;
  color: var(--kmx-text-muted);
}

/* Pills & badges */
.kmx-osb-root .osb-pill-id,
.kmx-osb-root .osb-pill {
  font-size: 10px;
  padding: 3px 8px;
  border-radius: var(--kmx-radius-pill);
  border-width: 1px;
  border-style: solid;
}

.kmx-osb-root .osb-pill-id {
  border-color: rgba(148,163,184,0.75);
  background: rgba(15,23,42,0.9);
}

.kmx-osb-root .osb-pill {
  background: var(--kmx-accent-soft);
  border-color: rgba(56,189,248,0.65);
}

.kmx-osb-root .osb-pill-muted {
  background: rgba(55,65,81,0.75);
  border-color: rgba(75,85,99,0.9);
}

.kmx-osb-root .osb-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px 7px;
  border-radius: var(--kmx-radius-pill);
  font-size: 10px;
}

.kmx-osb-root .osb-badge-active {
  background: rgba(34,197,94,0.16);
  color: #4ade80;
}

.kmx-osb-root .osb-badge-expired {
  background: rgba(248,113,113,0.18);
  color: #fecaca;
}

/* Buttons */
.kmx-osb-root .osb-btn {
  border-radius: var(--kmx-radius-pill);
  border: 1px solid rgba(148,163,184,0.5);
  background: rgba(15,23,42,0.96);
  color: var(--kmx-text-main);
  font-size: 11px;
  padding: 5px 10px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition:
    background-color var(--kmx-transition-fast),
    border-color var(--kmx-transition-fast),
    color var(--kmx-transition-fast),
    transform var(--kmx-transition-fast),
    box-shadow var(--kmx-transition-fast);
}

.kmx-osb-root .osb-btn:hover {
  background: rgba(30,64,175,0.96);
  border-color: rgba(59,130,246,0.95);
  box-shadow: 0 8px 20px rgba(30,64,175,0.45);
  transform: translateY(-0.5px);
}

.kmx-osb-root .osb-btn-primary {
  background: linear-gradient(120deg, var(--kmx-accent), var(--kmx-accent-strong));
  border-color: transparent;
  color: #020617;
  font-weight: 500;
}

.kmx-osb-root .osb-btn-primary:hover {
  filter: brightness(1.05);
}

.kmx-osb-root .osb-btn-danger {
  background: rgba(239,68,68,0.15);
  border-color: rgba(239,68,68,0.85);
  color: #fecaca;
}

.kmx-osb-root .osb-btn-outline {
  background: transparent;
  border-style: dashed;
}

.kmx-osb-root .osb-btn-ghost {
  background: transparent;
}

.kmx-osb-root .osb-btn-small {
  font-size: 10px;
  padding: 4px 9px;
}

/* Forms */
.kmx-osb-root .osb-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.kmx-osb-root .osb-form-inline {
  flex-direction: row;
  flex-wrap: wrap;
  gap: 12px;
}

.kmx-osb-root .osb-form label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 12px;
  color: var(--kmx-text-muted);
}

.kmx-osb-root .osb-form input[type="text"],
.kmx-osb-root .osb-form input[type="date"],
.kmx-osb-root .osb-form textarea,
.kmx-osb-root .osb-form select {
  border-radius: 10px;
  border: 1px solid rgba(55,65,81,0.95);
  background: rgba(15,23,42,0.95);
  color: var(--kmx-text-main);
  padding: 6px 9px;
  font-size: 12px;
  outline: none;
  transition: border-color var(--kmx-transition-fast), box-shadow var(--kmx-transition-fast), background-color var(--kmx-transition-fast);
}

.kmx-osb-root .osb-form input[type="text"]:focus,
.kmx-osb-root .osb-form input[type="date"]:focus,
.kmx-osb-root .osb-form textarea:focus,
.kmx-osb-root .osb-form select:focus {
  border-color: rgba(56,189,248,0.9);
  box-shadow: 0 0 0 1px rgba(56,189,248,0.5);
  background: rgba(15,23,42,0.98);
}

.kmx-osb-root .osb-form textarea {
  min-height: 80px;
  resize: vertical;
}

.kmx-osb-root .osb-label-inline-inner {
  display: flex;
  align-items: center;
  gap: 8px;
}

.kmx-osb-root .osb-help-text {
  font-size: 11px;
  color: var(--kmx-text-muted);
}

/* Users grid */
.kmx-osb-root .osb-users-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
  margin-top: 12px;
}

.kmx-osb-root .osb-user-card {
  border-radius: 16px;
  padding: 12px 13px;
  background: linear-gradient(135deg, rgba(15,23,42,0.98), rgba(15,23,42,1));
  border: 1px solid rgba(51,65,85,0.98);
  display: flex;
  flex-direction: column;
  gap: 8px;
  box-shadow: 0 14px 35px rgba(15,23,42,0.9);
  position: relative;
  overflow: hidden;
  transition: transform var(--kmx-transition-fast), box-shadow var(--kmx-transition-fast), border-color var(--kmx-transition-fast);
}

.kmx-osb-root .osb-user-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top, rgba(56,189,248,0.14), transparent 60%);
  opacity: 0;
  transition: opacity var(--kmx-transition-fast);
}

.kmx-osb-root .osb-user-card:hover {
  transform: translateY(-1.5px);
  border-color: rgba(56,189,248,0.7);
  box-shadow: var(--kmx-shadow-soft);
}

.kmx-osb-root .osb-user-card:hover::before {
  opacity: 1;
}

.kmx-osb-root .osb-user-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}

.kmx-osb-root .osb-user-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 4px;
}

.kmx-osb-root .osb-user-creds-block { margin-top: 10px; }
.kmx-osb-root .osb-user-creds-title { font-size: 12px; margin-bottom: 6px; }
.kmx-osb-root .osb-user-creds-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
}
.kmx-osb-root .osb-cred-option {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
}

/* Endpoint list */
.kmx-osb-root .osb-endpoint-list {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 11px;
}
.kmx-osb-root .osb-endpoint-list li { margin-bottom: 6px; }
.kmx-osb-root .osb-endpoint-list code {
  background: rgba(15,23,42,0.98);
  padding: 3px 7px;
  border-radius: 7px;
  border: 1px solid rgba(30,64,175,0.8);
  font-size: 11px;
}

/* Modals */
.kmx-osb-root .osb-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15,23,42,0.82);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 999999;
  backdrop-filter: blur(var(--kmx-blur));
}

.kmx-osb-root .osb-modal-backdrop.osb-open {
  display: flex;
}

.kmx-osb-root .osb-modal {
  width: 100%;
  max-width: 520px;
  background:
    radial-gradient(circle at top, rgba(15,23,42,0.96), rgba(15,23,42,1));
  border-radius: 18px;
  border: 1px solid rgba(59,130,246,0.8);
  box-shadow: var(--kmx-shadow-strong);
  padding: 16px 18px 14px;
  position: relative;
  overflow: hidden;
}

.kmx-osb-root .osb-modal::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top, rgba(56,189,248,0.14), transparent 60%);
  opacity: 0.8;
  mix-blend-mode: soft-light;
  pointer-events: none;
}

.kmx-osb-root .osb-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 12px;
}

.kmx-osb-root .osb-modal-header h2 {
  margin: 0;
  font-size: 15px;
}

.kmx-osb-root .osb-modal-close {
  border: none;
  background: transparent;
  color: var(--kmx-text-muted);
  font-size: 20px;
  cursor: pointer;
  transition: color var(--kmx-transition-fast), transform var(--kmx-transition-fast);
}

.kmx-osb-root .osb-modal-close:hover {
  color: var(--kmx-text-main);
  transform: rotate(4deg);
}

.kmx-osb-root .osb-modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 12px;
}

/* Responsive tweaks */
@media (max-width: 1024px) {
  .kmx-osb-root .osb-card-row {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
  .kmx-osb-root .osb-users-grid {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}

@media (max-width: 768px) {
  .kmx-osb-root .osb-main-section.osb-fullwidth {
    padding: 16px 14px 18px;
  }
  .kmx-osb-root .osb-tab-header {
    flex-direction: column;
    align-items: flex-start;
  }
  .kmx-osb-root .osb-two-column {
    grid-template-columns: minmax(0,1fr);
  }
}

@media (max-width: 600px) {
  .kmx-osb-root .osb-card-row {
    grid-template-columns: minmax(0,1fr);
  }
  .kmx-osb-root .osb-users-grid {
    grid-template-columns: minmax(0,1fr);
  }
}
