@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

:root {
  --background: #f8fafc;
  --foreground: #0f172a;
  --card: #ffffff;
  --card-foreground: #0f172a;
  --muted: #f1f5f9;
  --muted-foreground: #64748b;
  --border: #e2e8f0;
  --accent: #eef2ff;
  --primary: #4f46e5;
  --primary-foreground: #ffffff;
  --success: #16a34a;
  --warning: #ca8a04;
  --danger: #e11d48;
  --ring: #818cf8;
  --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.06);
  --shadow-md: 0 10px 28px rgba(15, 23, 42, 0.08);
  --radius: 14px;
  --radius-sm: 10px;
  --transition-fast: 160ms ease-out;
  --transition-normal: 240ms ease-out;
}

body.theme-dark {
  --background: #090e1a;
  --foreground: #e5e7eb;
  --card: #111827;
  --card-foreground: #e5e7eb;
  --muted: #1f2937;
  --muted-foreground: #94a3b8;
  --border: #243145;
  --accent: #1f2a44;
  --primary: #6366f1;
  --primary-foreground: #ffffff;
  --success: #22c55e;
  --warning: #f59e0b;
  --danger: #f43f5e;
  --ring: #818cf8;
}

* { box-sizing: border-box; }
*::before,
*::after { box-sizing: border-box; }
body {
  margin: 0;
  font-family: 'Plus Jakarta Sans', sans-serif;
  background:
    radial-gradient(circle at top right, rgba(79, 70, 229, 0.10), transparent 45%),
    radial-gradient(circle at top left, rgba(14, 165, 233, 0.08), transparent 40%),
    var(--background);
  color: var(--foreground);
  transition: background var(--transition-normal), color var(--transition-normal);
}

a { color: inherit; }
:focus-visible {
  outline: 2px solid var(--ring);
  outline-offset: 2px;
}

.app-shell { display: grid; grid-template-columns: 250px 1fr; min-height: 100vh; }
.sidebar {
  background: color-mix(in srgb, var(--card) 88%, transparent);
  border-right: 1px solid var(--border);
  backdrop-filter: blur(10px);
  padding: 1rem;
}
.main { padding: 1.5rem; }
.topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
  gap: .75rem;
}
.card {
  background: var(--card);
  color: var(--card-foreground);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  padding: 1rem;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);
}
.card:hover { border-color: color-mix(in srgb, var(--primary) 18%, var(--border)); }
.metrics { display: grid; gap: 0.75rem; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); }
.table-wrap { overflow-x: auto; }
.table { width: 100%; border-collapse: collapse; }
.table th, .table td {
  padding: .8rem;
  border-bottom: 1px solid var(--border);
  text-align: left;
  font-size: 0.9rem;
  vertical-align: top;
}
.table th {
  color: var(--muted-foreground);
  font-weight: 600;
  letter-spacing: .01em;
}
.table tbody tr { transition: background var(--transition-fast); }
.table tbody tr:hover { background: color-mix(in srgb, var(--accent) 60%, transparent); }

.input, .select, .textarea {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 0.6rem 0.75rem;
  background: var(--card);
  color: var(--foreground);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.input:focus, .select:focus, .textarea:focus {
  border-color: color-mix(in srgb, var(--primary) 45%, var(--border));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 22%, transparent);
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.5rem 0.85rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--foreground);
  text-decoration: none;
  cursor: pointer;
  transition: transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
}
.button:hover { transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.button:active { transform: translateY(0); }
.button.primary {
  background: linear-gradient(180deg, color-mix(in srgb, var(--primary) 92%, white) 0%, var(--primary) 100%);
  border-color: var(--primary);
  color: var(--primary-foreground);
}

.nav-link {
  display:block;
  border-radius: var(--radius-sm);
  padding:.55rem .7rem;
  color:var(--muted-foreground);
  text-decoration:none;
  font-size:.92rem;
  font-weight:600;
  transition: background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);
}
.nav-link:hover { background: var(--muted); color: var(--foreground); transform: translateX(2px); }
.nav-link.active {
  background: linear-gradient(120deg, color-mix(in srgb, var(--primary) 20%, transparent), color-mix(in srgb, var(--accent) 70%, transparent));
  color: var(--primary);
  border: 1px solid color-mix(in srgb, var(--primary) 20%, var(--border));
}

.badge {
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:.2rem .55rem;
  font-size:.72rem;
  font-weight:600;
  border:1px solid var(--border);
  background: var(--muted);
  color: var(--muted-foreground);
}
.badge.success { background: color-mix(in srgb, var(--success) 14%, transparent); border-color: color-mix(in srgb, var(--success) 35%, var(--border)); color: var(--success); }
.badge.warning { background: color-mix(in srgb, var(--warning) 16%, transparent); border-color: color-mix(in srgb, var(--warning) 35%, var(--border)); color: var(--warning); }
.badge.danger { background: color-mix(in srgb, var(--danger) 16%, transparent); border-color: color-mix(in srgb, var(--danger) 35%, var(--border)); color: var(--danger); }
.badge.info { background: color-mix(in srgb, var(--primary) 16%, transparent); border-color: color-mix(in srgb, var(--primary) 35%, var(--border)); color: var(--primary); }
.badge.muted { background: var(--muted); border-color: var(--border); color: var(--muted-foreground); }

.flash-wrap { margin-bottom: 1rem; }
.flash { border-radius: var(--radius-sm); padding: 0.7rem 0.9rem; border: 1px solid; margin-bottom: 0.5rem; animation: fadeIn var(--transition-normal); }
.flash.notice { background: color-mix(in srgb, var(--primary) 10%, transparent); color: var(--primary); border-color: color-mix(in srgb, var(--primary) 35%, var(--border)); }
.flash.alert { background: color-mix(in srgb, var(--danger) 10%, transparent); color: var(--danger); border-color: color-mix(in srgb, var(--danger) 35%, var(--border)); }

.page-subtitle { margin:.2rem 0 0; color:var(--muted-foreground); }
.stack { display:flex; flex-direction:column; gap:1rem; }
.row { display:flex; align-items:center; justify-content:space-between; gap:.75rem; }
.meta { color: var(--muted-foreground); font-size: .86rem; }
.divider { border-top:1px solid var(--border); margin:1rem 0; }
.spacer { height: 1rem; }

pre.json {
  background: #0b1020;
  color: #e2e8f0;
  padding: 0.85rem;
  border-radius: var(--radius-sm);
  overflow: auto;
  font-size: 12px;
}

.skeleton {
  background: linear-gradient(90deg, color-mix(in srgb, var(--muted) 90%, transparent) 25%, color-mix(in srgb, white 30%, var(--muted)) 37%, color-mix(in srgb, var(--muted) 90%, transparent) 63%);
  background-size: 400% 100%;
  animation: shimmer 1.25s linear infinite;
  border-radius: 8px;
}

.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(2, 6, 23, .55);
  backdrop-filter: blur(4px);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 100;
}
.modal-backdrop.open { display: flex; animation: fadeIn var(--transition-normal); }
.modal {
  width: min(96vw, 560px);
  background: var(--card);
  color: var(--card-foreground);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  transform: translateY(4px) scale(.98);
  animation: modalIn var(--transition-normal);
}
.modal-head, .modal-foot { padding: 1rem; border-bottom: 1px solid var(--border); }
.modal-foot { border-bottom: 0; border-top: 1px solid var(--border); display:flex; justify-content:flex-end; gap:.6rem; }
.modal-body { padding: 1rem; }

@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes modalIn { from { opacity:0; transform: translateY(10px) scale(.97); } to { opacity:1; transform: translateY(0) scale(1); } }
@keyframes shimmer { 0% { background-position: 100% 0; } 100% { background-position: 0 0; } }

@media (max-width: 960px) {
  .app-shell { grid-template-columns: 1fr; }
  .sidebar { border-right: 0; border-bottom: 1px solid var(--border); }
  .main { padding: 1rem; }
  .topbar { flex-direction: column; align-items: flex-start; }
}

.grid-2,
.grid-3 {
  display: grid;
  gap: 1rem;
}

.grid-2 {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.grid-3 {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.actions-row {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  align-items: center;
}

.key-value-grid {
  display: grid;
  gap: 0.65rem;
}

.message-bubble {
  padding: 0.75rem;
  border-radius: 12px;
  border: 1px solid var(--border);
  margin-bottom: 0.75rem;
}

.message-bubble-inbound {
  background: color-mix(in oklab, var(--muted) 35%, var(--background));
}

.message-bubble-outbound {
  background: color-mix(in oklab, var(--primary) 14%, var(--background));
}
