/* ==========================================================================
   Antix Portal — Global Stylesheet
   Shared portal styles plus page-specific additions for keys, team, usage.
   ========================================================================== */

/* ==========================================================================
   RESET & BOX MODEL
   ========================================================================== */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* Smooth cross-document navigations (Chromium): the old page cross-fades
   into the new one instead of a hard white flip. The sidebar/topbar carry
   stable view-transition-names so they hold still while the content swaps.
   Unsupported browsers (Safari/Firefox) silently fall back to a normal load. */
@view-transition {
  navigation: auto;
}

/* ==========================================================================
   DESIGN TOKENS (CSS Custom Properties)
   ========================================================================== */
:root {
  --dashboard-bg: #101014;
  --dashboard-fg: #f5f6f8;
  --dashboard-sidebar: #141418;
  --dashboard-border: #2f3238;
  --dashboard-muted: #878787;
  --dashboard-secondary: #c8c9d0;
  --dashboard-accent: #c96f3d;
  --dashboard-card: #1a1a1d;
  --dashboard-hover: #23252b;
  --font-sans: 'Space Grotesk', 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --portal-page: #171512;
  --portal-paper: #f8f5ef;
  --portal-paper-soft: #f0ece4;
  --portal-ink: #1b1917;
  --portal-ink-muted: #7c706a;
  --portal-line: #e2d9cf;
  --portal-line-strong: #cfc4b8;
  /* Border Radius */
  --radius-xs: 2px;
  --radius-sm: 4px;
  --radius-md: 6px;
  --radius-lg: 8px;
  --radius-xl: 12px;
  --radius-full: 9999px;

  /* Transitions */
  --transition-fast: 80ms cubic-bezier(0.16, 1, 0.3, 1);
  --transition-normal: 150ms cubic-bezier(0.16, 1, 0.3, 1);

  --portal-shadow-soft: 0 4px 12px rgba(18, 15, 10, 0.05);
  --portal-shadow-tight: 0 1px 2px rgba(20, 17, 12, 0.04), 0 2px 6px rgba(20, 17, 12, 0.03);

  /* Sidebar width — collapsed override on <html data-sidebar="collapsed">.
     A head bootstrap snippet sets the attribute before paint (no flash);
     toggleSidebar() in js/app.js flips it. --topbar-h keeps the sidebar
     logo bar and the page topbar the same height so their borders align. */
  --sidebar-width: 220px;
  --sidebar-collapsed: 64px;
  --topbar-h: 56px;

  /* Extended tokens for tables, forms, modals */
  --dashboard-danger: #d84b3a;
  --dashboard-danger-hover: #bd392b;
  --dashboard-success: #2f8f63;
  --dashboard-warning: #b97812;
  --dashboard-input-bg: #141418;
  --dashboard-input-focus: rgba(201, 111, 61, 0.28);
  --dashboard-overlay: rgba(0, 0, 0, 0.6);

  /* Semantic foreground/surface tokens. The dark values are the lightened
     tints previously hardcoded; the light theme swaps them for darkened
     shades that stay readable on white. */
  --dashboard-success-fg: #8ed3ad;
  --dashboard-danger-fg: #ff9b8d;
  --dashboard-warning-fg: #f5c06a;
  --dashboard-info-fg: #b8c7e4;
  --dashboard-accent-fg: #f0a979;
  --dashboard-primary: #c96f3d;
  --dashboard-primary-hover: #b96336;
  --dashboard-primary-fg: #fffaf5;
  --dashboard-subtle-bg: rgba(250, 248, 245, 0.06);
  --usage-data-fill: #7f9ba0;
  --usage-data-fill-hover: #9fb5b8;
  --usage-data-fill-strong: #6f8f8a;
  --usage-data-track: color-mix(in srgb, var(--dashboard-border) 76%, var(--usage-data-fill) 10%);
  --dashboard-shadow: 0 2px 8px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.04);
  --dashboard-on-accent: #ffffff;
  --dashboard-on-accent-border: rgba(255, 255, 255, 0.4);

  /* ========== TYPOGRAPHY TOKENS ========== */
  /* Font Sizes: standard scale from 8px to 30px */
  --font-size-xs: 8px;
  --font-size-sm: 12px;
  --font-size-base: 14px;
  --font-size-md: 16px;
  --font-size-lg: 18px;
  --font-size-xl: 20px;
  --font-size-2xl: 24px;
  --font-size-3xl: 30px;

  /* Font Weights: constrained to supported values (400, 500, 600, 700) */
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;

  color-scheme: dark;
}

/* Light theme. Opt-in via <html data-theme="light">, persisted by the
   sidebar toggle (toggleTheme in js/app.js + the head bootstrap snippet
   on each page, which applies it before first paint). */
[data-theme='light'] {
  --dashboard-bg: #faf8f5;
  --dashboard-fg: var(--portal-ink);
  --dashboard-sidebar: #f0ece4;
  --dashboard-border: var(--portal-line);
  --dashboard-muted: var(--portal-ink-muted);
  --dashboard-secondary: #4b433d;
  --dashboard-card: #fffdf8;
  --dashboard-hover: #eee7dc;
  --dashboard-input-bg: #fffdf8;
  --dashboard-overlay: rgba(27, 25, 23, 0.42);

  --dashboard-success-fg: #27724f;
  --dashboard-danger-fg: #a73529;
  --dashboard-warning-fg: #8f5b08;
  --dashboard-info-fg: #40536e;
  --dashboard-accent-fg: #8d4f2f;
  --dashboard-primary: #c96f3d;
  --dashboard-primary-hover: #b96336;
  --dashboard-primary-fg: #ffffff;
  --dashboard-subtle-bg: rgba(27, 25, 23, 0.035);
  --usage-data-fill: #6f8f8a;
  --usage-data-fill-hover: #567b77;
  --usage-data-fill-strong: #4f746f;
  --usage-data-track: color-mix(in srgb, var(--dashboard-border) 82%, var(--usage-data-fill) 12%);
  --dashboard-shadow: var(--portal-shadow-tight);
  --dashboard-on-accent: #ffffff;
  --dashboard-on-accent-border: rgba(255, 255, 255, 0.4);

  color-scheme: light;
}

[data-sidebar='collapsed'] {
  --sidebar-width: var(--sidebar-collapsed);
}

/* ==========================================================================
   BASE / BODY
   ========================================================================== */
/* Paint the root canvas dark too, so any frame before <body> lays out (e.g.
   a hard navigation fallback) is the dashboard background, not white. */
html {
  background: var(--dashboard-bg);
}

body {
  font-family: var(--font-sans);
  background: var(--dashboard-bg);
  color: var(--dashboard-fg);
  min-height: 100vh;
  display: block;
  letter-spacing: 0;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ==========================================================================
   TEXT STYLE PRESETS
   Semantic text styles using typography tokens. Mix and match with
   modifiers to compose any text hierarchy consistently.
   ========================================================================== */

/* Headings */
.text-heading-1 {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  line-height: 1.2;
}

.text-heading-2 {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  line-height: 1.3;
}

.text-heading-3 {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  line-height: 1.4;
}

/* Body text */
.text-body-lg {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-normal);
  line-height: 1.6;
}

.text-body {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-normal);
  line-height: 1.5;
}

.text-body-sm {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-normal);
  line-height: 1.5;
}

.text-caption {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-normal);
  line-height: 1.4;
}

/* Weight modifiers */
.text-medium {
  font-weight: var(--font-weight-medium);
}

.text-semibold {
  font-weight: var(--font-weight-semibold);
}

.text-bold {
  font-weight: var(--font-weight-bold);
}

/* ==========================================================================
   SIDEBAR
   ========================================================================== */
.sidebar {
  width: var(--sidebar-width);
  min-height: 100vh;
  background: var(--dashboard-sidebar);
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  z-index: 50;
  transition: width 0.18s ease;
  /* Persist the sidebar across cross-document View Transitions (see the
     @view-transition rule below): the browser matches old/new frames by
     name so the chrome stays put while only the content cross-fades. */
  view-transition-name: portal-sidebar;
}

/* The logo bar belongs to the sidebar surface; the page topbar owns only the
   content area to its right. */
.sidebar-header {
  height: var(--topbar-h); /* align the logo bar's border with the topbar's */
  padding: 0 16px;
  background: transparent;
  display: flex;
  align-items: center;
}

.sidebar-logo {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  color: inherit;
  text-decoration: none;
}

.sidebar-logo-text {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar-collapse-btn {
  position: absolute;
  right: 12px;
  bottom: 14px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 6px;
  border: 1px solid color-mix(in srgb, var(--dashboard-border) 78%, transparent);
  background: color-mix(in srgb, var(--dashboard-sidebar) 84%, var(--dashboard-card) 16%);
  color: var(--dashboard-muted);
  cursor: pointer;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  transition:
    background-color var(--transition-fast),
    border-color var(--transition-fast),
    color var(--transition-fast);
}
.sidebar-collapse-btn:hover {
  border-color: color-mix(in srgb, var(--dashboard-accent) 28%, var(--dashboard-border));
  background: var(--dashboard-hover);
  color: var(--dashboard-fg);
}
.sidebar-collapse-btn svg {
  width: 16px;
  height: 16px;
}

/* ---- Collapsed rail ---- */
[data-sidebar='collapsed'] .sidebar-logo-text,
[data-sidebar='collapsed'] .nav-item-label,
[data-sidebar='collapsed'] .soon-badge,
[data-sidebar='collapsed'] .nav-group-label,
[data-sidebar='collapsed'] .nav-group-line {
  display: none;
}

[data-sidebar='collapsed'] .sidebar-header {
  justify-content: center;
  padding: 0;
}
[data-sidebar='collapsed'] .nav-item {
  justify-content: center;
  padding: 8px 0;
}
[data-sidebar='collapsed'] .nav-group {
  margin-bottom: 8px;
}

.sidebar-logo img {
  width: 20px;
  height: 20px;
}

.sidebar-logo span {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--dashboard-fg);
}

.sidebar-email {
  font-size: var(--font-size-sm);
  color: var(--dashboard-muted);
  font-family: var(--font-mono);
  padding-left: 28px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ---- Sidebar Navigation ---- */
.sidebar-nav {
  flex: 1;
  overflow-y: auto;
  padding: 16px 8px 68px;
  border-right: 1px solid var(--dashboard-border); /* rail divider, below the unified header */
}

.nav-group {
  margin-bottom: 24px;
}

.nav-group-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--dashboard-muted);
  padding: 0 12px;
  margin-bottom: 4px;
}

.nav-group-line {
  width: 32px;
  height: 1px;
  background: var(--dashboard-border);
  margin-left: 12px;
  margin-bottom: 8px;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 8px 14px;
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  font-family: var(--font-sans);
  color: var(--dashboard-muted);
  background: none;
  border: none;
  cursor: pointer;
  transition: all var(--transition-fast);
  text-decoration: none;
  position: relative;
}

.nav-item:hover {
  background: var(--dashboard-hover);
  color: var(--dashboard-fg);
}

/* Active-page highlight. The sidebar markup is shared/static across pages
   (see _sidebar.html), so the active item is selected by the page's
   `body[data-page]` rather than a baked-in `.active` class. */
.nav-item.active,
body[data-page='home'] .nav-item[data-nav-id='home'],
body[data-page='team'] .nav-item[data-nav-id='team'],
body[data-page='endpoints'] .nav-item[data-nav-id='endpoints'],
body[data-page='keys'] .nav-item[data-nav-id='keys'],
body[data-page='usage'] .nav-item[data-nav-id='usage'],
body[data-page='history'] .nav-item[data-nav-id='history'] {
  background: transparent;
  color: var(--dashboard-accent);
  font-weight: var(--font-weight-medium);
}

.nav-item.active::before,
body[data-page='home'] .nav-item[data-nav-id='home']::before,
body[data-page='team'] .nav-item[data-nav-id='team']::before,
body[data-page='endpoints'] .nav-item[data-nav-id='endpoints']::before,
body[data-page='keys'] .nav-item[data-nav-id='keys']::before,
body[data-page='usage'] .nav-item[data-nav-id='usage']::before,
body[data-page='history'] .nav-item[data-nav-id='history']::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  bottom: 8px;
  width: 3px;
  background: var(--dashboard-accent);
  border-radius: var(--radius-full);
}

.nav-item.disabled {
  cursor: not-allowed;
  opacity: 0.6;
}
.nav-item.disabled:hover {
  background: none;
  color: var(--dashboard-muted);
}

.nav-item svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* Keep the label on one line; the badge stays compact so the longest label
   ("Available Models") fits without wrapping. */
.nav-item-label {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

.nav-item .soon-badge {
  margin-left: auto;
  flex-shrink: 0;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--dashboard-accent);
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

/* ---- Sidebar Footer ---- */
.sidebar-footer {
  padding: 12px;
  border-top: 1px solid var(--dashboard-border);
  display: flex;
  gap: 8px;
}

/* Topbar controls (theme toggle + sign out, rendered by
   renderTopbarControls in js/app.js into .topbar-right) */
.topbar-ctl-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  font-family: var(--font-sans);
  color: var(--dashboard-secondary);
  background: none;
  border: 1px solid var(--dashboard-border);
  cursor: pointer;
  text-decoration: none;
  transition: all var(--transition-fast);
}

.topbar-ctl-btn:hover {
  background: var(--dashboard-hover);
  color: var(--dashboard-fg);
}
.topbar-ctl-btn svg {
  width: 15px;
  height: 15px;
}
.topbar-ctl-btn.icon-only,
[data-theme='light'] .topbar-ctl-btn.icon-only {
  width: 34px;
  height: 34px;
  min-height: 0;
  padding: 0;
  justify-content: center;
  background: transparent;
  border: none;
  box-shadow: none;
}

.topbar-ctl-btn.icon-only:hover,
[data-theme='light'] .topbar-ctl-btn.icon-only:hover {
  background: transparent;
  border: none;
  box-shadow: none;
  transform: none;
  color: var(--dashboard-fg);
}

.topbar-ctl-btn.icon-only svg {
  width: 18px;
  height: 18px;
}

[data-ui-tooltip] {
  position: relative;
}

[data-ui-tooltip]::after {
  content: attr(data-ui-tooltip);
  position: absolute;
  left: 50%;
  bottom: calc(100% + 8px);
  z-index: 1000;
  width: max-content;
  max-width: min(240px, calc(100vw - 24px));
  padding: 5px 8px;
  border: 1px solid var(--dashboard-border);
  border-radius: var(--radius-md);
  background: var(--dashboard-card);
  color: var(--dashboard-fg);
  box-shadow: var(--dashboard-shadow);
  font-family: var(--font-sans);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: 1.2;
  text-align: center;
  white-space: normal;
  overflow-wrap: anywhere;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transform: translate(-50%, 2px);
  transition:
    opacity var(--transition-fast),
    transform var(--transition-fast),
    visibility var(--transition-fast);
}

[data-ui-tooltip]:hover::after,
[data-ui-tooltip]:focus-visible::after {
  opacity: 1;
  visibility: visible;
  transform: translate(-50%, 0);
}

[data-ui-tooltip][data-ui-tooltip-placement='bottom']::after {
  top: calc(100% + 8px);
  bottom: auto;
  transform: translate(-50%, -2px);
}

[data-ui-tooltip][data-ui-tooltip-placement='bottom']:hover::after,
[data-ui-tooltip][data-ui-tooltip-placement='bottom']:focus-visible::after {
  transform: translate(-50%, 0);
}

.signout-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 8px 12px;
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  font-family: var(--font-sans);
  color: var(--dashboard-secondary);
  background: none;
  border: 1px solid var(--dashboard-border);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.signout-btn:hover {
  background: var(--dashboard-hover);
  color: var(--dashboard-fg);
}
.signout-btn svg {
  width: 16px;
  height: 16px;
}

/* ==========================================================================
   MAIN LAYOUT
   ========================================================================== */
.main {
  flex: 1;
  margin-left: var(--sidebar-width);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  transition: margin-left 0.18s ease;
}

.topbar {
  position: relative;
  z-index: 120;
  height: 56px;
  border-bottom: 1px solid var(--dashboard-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 32px;
  view-transition-name: portal-topbar;
}

.topbar-title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
}

.topbar-right {
  display: flex;
  align-items: center;
  gap: 14px;
}

.topbar-right > .user-avatar {
  width: 38px;
  height: 38px;
  font-size: var(--font-size-md);
}

/* The fixed sidebar is reserved via margin. `--sidebar-width` already
   collapses to `--sidebar-collapsed` under [data-sidebar='collapsed']
   (and on narrow screens), so this single rule covers both states. */
body.portal-shell > .topbar,
body.portal-shell > .content,
body.portal-shell > #portal-root > .topbar,
body.portal-shell > #portal-root > .content {
  margin-left: var(--sidebar-width);
  transition: margin-left 0.18s ease;
}

@media (max-width: 760px) {
  :root,
  [data-sidebar='expanded'],
  [data-sidebar='collapsed'] {
    --sidebar-width: var(--sidebar-collapsed);
  }

  .sidebar {
    width: var(--sidebar-collapsed);
  }

  .sidebar-logo-text,
  .nav-item-label,
  .soon-badge,
  .nav-group-label,
  .nav-group-line {
    display: none;
  }

  .sidebar-header {
    justify-content: center;
    padding: 0;
  }

  .nav-item {
    justify-content: center;
    padding: 8px 0;
  }

  .nav-group {
    margin-bottom: 8px;
  }

  body.portal-shell > .topbar,
  body.portal-shell > .content,
  body.portal-shell > #portal-root > .topbar,
  body.portal-shell > #portal-root > .content {
    width: calc(100vw - var(--sidebar-collapsed));
    margin-left: var(--sidebar-collapsed);
  }

  .sidebar-logo-text,
  .nav-item-label,
  .soon-badge,
  .nav-group-label,
  .nav-group-line {
    display: none;
  }

  .sidebar-header {
    justify-content: center;
    padding: 0;
  }

  .nav-item {
    justify-content: center;
    padding: 8px 0;
  }

  .nav-group {
    margin-bottom: 8px;
  }

  .topbar {
    padding: 0 14px;
    gap: 12px;
  }

  .topbar-title {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .topbar-right {
    flex-shrink: 0;
    gap: 8px;
  }

  .content {
    padding: 18px 14px;
  }

  .content-inner {
    max-width: none;
  }

  .form-row > button,
  .form-row > .btn-primary,
  .form-row > .btn-outline,
  .form-row > .btn-danger,
  .form-row > .btn-secondary,
  .form-row > .btn-danger-outline {
    width: 100%;
    flex-basis: 100%;
  }

  .card,
  .ante-card,
  .install-card {
    padding: 16px;
  }

  .cards-grid {
    grid-template-columns: 1fr;
  }

  .update-banner {
    justify-content: flex-start;
    flex-wrap: wrap;
    padding: 10px 12px;
  }
}

/* ==========================================================================
   BADGE & UTILITY
   ========================================================================== */
.badge-public,
.badge-standard,
.badge-admin {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-radius: 4px;
  padding: 2px 8px;
}
.badge-public {
  color: var(--dashboard-muted);
  background: var(--dashboard-hover);
  border: 1px solid var(--dashboard-border);
}
.badge-standard {
  color: var(--dashboard-success-fg);
  background: rgba(34, 197, 94, 0.15);
  border: 1px solid rgba(34, 197, 94, 0.3);
}
.badge-admin {
  color: var(--dashboard-danger-fg);
  background: rgba(239, 68, 68, 0.15);
  border: 1px solid rgba(239, 68, 68, 0.3);
}

.docs-link {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  color: var(--dashboard-secondary);
  text-decoration: none;
  transition: color 0.15s;
}

.docs-link:hover {
  color: var(--dashboard-fg);
}
.docs-link svg {
  width: 16px;
  height: 16px;
}

/* ==========================================================================
   CONTENT AREA
   ========================================================================== */
.content {
  flex: 1;
  padding: 32px;
}
.content-inner {
  width: 100%;
  max-width: none;
  margin: 0;
}

/* ---- Welcome Section ---- */
.welcome-section {
  margin-bottom: 20px;
}
.welcome-title {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-semibold);
  color: var(--dashboard-fg);
}
.welcome-sub {
  font-size: var(--font-size-base);
  color: var(--dashboard-muted);
  margin-top: 2px;
}

/* ==========================================================================
   CTA BUTTONS
   ========================================================================== */
.cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 20px;
}

.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  font-family: var(--font-sans);
  background: var(--dashboard-accent);
  color: #fff;
  border: none;
  cursor: pointer;
  transition: all var(--transition-fast);
  text-decoration: none;
  line-height: 1.35;
  text-align: center;
  white-space: normal;
  max-width: 100%;
}

.btn-primary:hover {
  background: rgba(99, 102, 241, 0.85);
}
.btn-primary svg {
  width: 16px;
  height: 16px;
}

.btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  font-family: var(--font-sans);
  background: none;
  color: var(--dashboard-secondary);
  border: 1px solid var(--dashboard-border);
  cursor: pointer;
  transition: all var(--transition-fast);
  text-decoration: none;
  line-height: 1.35;
  text-align: center;
  white-space: normal;
  max-width: 100%;
}

.btn-outline:hover {
  background: var(--dashboard-hover);
  color: var(--dashboard-fg);
}
.btn-outline svg {
  width: 16px;
  height: 16px;
}

.btn-danger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  font-family: var(--font-sans);
  background: var(--dashboard-danger);
  color: #fff;
  border: none;
  cursor: pointer;
  transition: all var(--transition-fast);
  text-decoration: none;
  line-height: 1.35;
  text-align: center;
  white-space: normal;
  max-width: 100%;
}

.btn-danger:hover {
  background: var(--dashboard-danger-hover);
}

.btn-sm {
  padding: 6px 12px;
  font-size: var(--font-size-sm);
}

/* Secondary action style for buttons used inside tables / form-rows where the
 * button must sit alongside text rather than break onto its own line. */
.btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  font-family: var(--font-sans);
  background: var(--dashboard-card);
  color: var(--dashboard-fg);
  border: 1px solid var(--dashboard-border);
  cursor: pointer;
  transition: all var(--transition-fast);
  text-decoration: none;
  line-height: 1.35;
  text-align: center;
  white-space: normal;
  max-width: 100%;
}
.btn-secondary:hover {
  background: var(--dashboard-hover);
}
.btn-secondary svg {
  width: 16px;
  height: 16px;
}

.table-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}

.btn-danger-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  font-family: var(--font-sans);
  background: none;
  color: var(--dashboard-danger);
  border: 1px solid var(--dashboard-danger);
  cursor: pointer;
  transition: all var(--transition-fast);
  text-decoration: none;
  line-height: 1.35;
  text-align: center;
  white-space: normal;
  max-width: 100%;
}
.btn-danger-outline:hover {
  background: var(--dashboard-danger);
  color: #fff;
}

/* ==========================================================================
   INSTALL CARD
   ========================================================================== */
.install-card {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--dashboard-border);
  border-radius: 0;
  padding: 16px 0;
  margin-bottom: 12px;
}

.install-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}
.install-header svg {
  width: 16px;
  height: 16px;
  color: var(--dashboard-accent);
}
.install-header span {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
}

.install-command {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--dashboard-bg);
  border: 1px solid var(--dashboard-border);
  border-radius: var(--radius-md);
  padding: 12px 16px;
}

.install-command code {
  flex: 1;
  font-size: var(--font-size-base);
  font-family: var(--font-mono);
  color: var(--dashboard-fg);
}

.copy-btn {
  flex-shrink: 0;
  padding: 6px;
  border-radius: 4px;
  background: none;
  border: none;
  color: var(--dashboard-muted);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.copy-btn:hover {
  color: var(--dashboard-fg);
  background: var(--dashboard-hover);
}
.copy-btn svg {
  width: 16px;
  height: 16px;
}
.copy-btn.copy-btn-success {
  color: var(--dashboard-success-fg);
}

.install-hint {
  font-size: var(--font-size-sm);
  color: var(--dashboard-muted);
  margin-top: 8px;
}
.install-hint code {
  font-family: var(--font-mono);
  color: var(--dashboard-secondary);
}

/* Stale-tab update prompt, shown by js/app.js when /api/version changes. */
.update-banner {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 10px 16px;
  background: var(--dashboard-accent);
  color: var(--dashboard-on-accent);
  font-family: var(--font-sans);
  font-size: var(--font-size-base);
  box-shadow: var(--dashboard-shadow);
}

.update-banner-reload,
.update-banner-dismiss {
  border-radius: 6px;
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: var(--font-size-base);
}

.update-banner-reload {
  padding: 4px 14px;
  border: none;
  background: var(--dashboard-on-accent);
  color: var(--dashboard-accent);
  font-weight: var(--font-weight-semibold);
}

.update-banner-dismiss {
  padding: 4px 10px;
  border: 1px solid var(--dashboard-on-accent-border);
  background: transparent;
  color: var(--dashboard-on-accent);
}

/* ==========================================================================
   FEATURE CARDS GRID
   ========================================================================== */
.cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.feature-card {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--dashboard-border);
  border-radius: 0;
  padding: 16px 0;
  text-align: left;
  cursor: pointer;
  transition: border-color var(--transition-fast);
  text-decoration: none;
  display: block;
}

.feature-card:hover {
  border-color: rgba(99, 102, 241, 0.4);
}

.feature-card.disabled {
  opacity: 0.6;
  cursor: default;
}
.feature-card.disabled:hover {
  border-color: var(--dashboard-border);
}

.feature-card-icon {
  width: 20px;
  height: 20px;
  margin-bottom: 10px;
  color: var(--dashboard-accent);
}
.feature-card.disabled .feature-card-icon {
  color: var(--dashboard-muted);
}

.feature-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.feature-card-top svg:last-child {
  width: 12px;
  height: 12px;
  color: var(--dashboard-muted);
  transition: color 0.15s;
}
.feature-card:hover .feature-card-top svg:last-child {
  color: var(--dashboard-secondary);
}

.feature-card h4 {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--dashboard-fg);
  margin-bottom: 4px;
}
.feature-card p {
  font-size: var(--font-size-sm);
  color: var(--dashboard-muted);
  line-height: 1.6;
}

/* ==========================================================================
   ANTE AGENT PAGE
   ========================================================================== */
.ante-card {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--dashboard-border);
  border-radius: 0;
  padding: 20px 0;
}

.ante-card h2 {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--dashboard-fg);
  margin-bottom: 24px;
}

.ante-section {
  margin-bottom: 32px;
}
.ante-section:last-child {
  margin-bottom: 0;
}
.ante-section h3 {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-semibold);
  color: var(--dashboard-accent);
  margin-bottom: 12px;
}
.ante-section p {
  font-size: var(--font-size-base);
  color: var(--dashboard-secondary);
  margin-bottom: 12px;
}

.ante-section .cmd-block {
  background: var(--dashboard-card);
  border: 1px solid var(--dashboard-border);
  border-radius: var(--radius-md);
  padding: 12px 16px;
}

.ante-section .cmd-block code {
  font-size: var(--font-size-base);
  font-family: var(--font-mono);
  color: var(--dashboard-fg);
}

.ante-cmd-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ante-cmd-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  font-size: var(--font-size-base);
}
.ante-cmd-row span {
  color: var(--dashboard-secondary);
}

.ante-cmd-row code,
.ante-cmd-row-code {
  background: var(--dashboard-bg);
  border: 1px solid var(--dashboard-border);
  border-radius: 4px;
  padding: 4px 10px;
  font-size: var(--font-size-base);
  font-family: var(--font-mono);
  color: var(--dashboard-fg);
}

/* ==========================================================================
   LOGIN PAGE
   ========================================================================== */
.login-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  width: 100%;
  background: var(--dashboard-bg);
}

.login-card {
  background: var(--dashboard-card);
  border: 1px solid var(--dashboard-border);
  border-radius: var(--radius-xl);
  padding: 40px;
  width: 100%;
  max-width: 400px;
  text-align: center;
  box-shadow: var(--dashboard-shadow);
}

.login-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 8px;
}
.login-logo img {
  width: 32px;
  height: 32px;
}
.login-logo span {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  color: var(--dashboard-fg);
}

.login-sub {
  font-size: var(--font-size-base);
  color: var(--dashboard-muted);
  margin-bottom: 32px;
}

.oauth-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 12px;
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  font-family: var(--font-sans);
  background: var(--dashboard-hover);
  border: 1px solid var(--dashboard-border);
  color: var(--dashboard-fg);
  cursor: pointer;
  transition: all var(--transition-fast);
  margin-bottom: 12px;
  text-decoration: none;
}

.oauth-btn:hover {
  background: var(--dashboard-border);
}
.oauth-btn svg {
  width: 18px;
  height: 18px;
}

.oauth-icon {
  flex: 0 0 auto;
}

/* ==========================================================================
   GENERIC CARD (reusable — matches .ante-card visual language)
   ========================================================================== */
.card {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--dashboard-border);
  border-radius: 0;
  padding: 20px 0;
}

.card h2 {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--dashboard-fg);
  margin-bottom: 24px;
}

.card h3 {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-semibold);
  color: var(--dashboard-accent);
  margin-bottom: 12px;
}

.card p {
  font-size: var(--font-size-base);
  color: var(--dashboard-secondary);
  margin-bottom: 12px;
}

.card + .card {
  margin-top: 16px;
}

/* ==========================================================================
   TABLE STYLES (keys, team, usage pages)
   ========================================================================== */
.table-wrapper {
  overflow-x: auto;
  border: 1px solid var(--dashboard-border);
  border-radius: var(--radius-lg);
}

table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-base);
}

thead {
  background: var(--dashboard-sidebar);
}

thead th {
  padding: 10px 16px;
  text-align: left;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--dashboard-muted);
  border-bottom: 1px solid var(--dashboard-border);
  white-space: nowrap;
}

tbody tr {
  border-bottom: 1px solid var(--dashboard-border);
  transition: background 0.1s;
}

tbody tr:last-child {
  border-bottom: none;
}

tbody tr:hover {
  background: var(--dashboard-hover);
}

tbody td {
  padding: 12px 16px;
  color: var(--dashboard-fg);
  vertical-align: middle;
}

tbody td code {
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  background: var(--dashboard-bg);
  border: 1px solid var(--dashboard-border);
  border-radius: 4px;
  padding: 2px 8px;
  color: var(--dashboard-fg);
}

.table-empty {
  text-align: center;
  padding: 40px 16px;
  color: var(--dashboard-muted);
  font-size: var(--font-size-base);
}

/* ==========================================================================
   FORM / INPUT STYLES (dark theme)
   ========================================================================== */
label {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--dashboard-secondary);
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

input[type='text'],
input[type='email'],
input[type='password'],
input[type='number'],
input[type='url'],
input[type='search'],
input[type='date'],
input[type='time'],
input[type='datetime-local'],
select,
textarea {
  width: 100%;
  padding: 10px 14px;
  font-size: var(--font-size-base);
  font-family: var(--font-sans);
  color: var(--dashboard-fg);
  background: var(--dashboard-input-bg);
  border: 1px solid var(--dashboard-border);
  border-radius: var(--radius-md);
  outline: none;
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast);
}

input[type='text']:focus,
input[type='email']:focus,
input[type='password']:focus,
input[type='number']:focus,
input[type='url']:focus,
input[type='search']:focus,
input[type='date']:focus,
input[type='time']:focus,
input[type='datetime-local']:focus,
select:focus,
textarea:focus {
  border-color: var(--dashboard-accent);
  box-shadow: 0 0 0 3px var(--dashboard-input-focus);
}

input[type='date'],
input[type='time'],
input[type='datetime-local'] {
  min-height: 40px;
  line-height: 1.2;
}

input[type='date']::-webkit-calendar-picker-indicator,
input[type='time']::-webkit-calendar-picker-indicator,
input[type='datetime-local']::-webkit-calendar-picker-indicator {
  cursor: pointer;
  opacity: 0.75;
}

input::placeholder,
textarea::placeholder {
  color: var(--dashboard-muted);
}

select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b6b80' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
}

textarea {
  min-height: 80px;
  resize: vertical;
}

.form-group {
  margin-bottom: 16px;
}

.form-hint {
  font-size: var(--font-size-sm);
  color: var(--dashboard-muted);
  margin-top: 4px;
}

.form-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: flex-end;
}

.form-row > * {
  flex: 1 1 180px;
  min-width: 0;
}

.form-row > button,
.form-row > .btn-primary,
.form-row > .btn-outline,
.form-row > .btn-danger,
.form-row > .btn-secondary,
.form-row > .btn-danger-outline {
  flex: 0 0 auto;
  min-width: 132px;
}

/* ==========================================================================
   MODAL STYLES
   ========================================================================== */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: var(--dashboard-overlay);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 200;
  backdrop-filter: blur(4px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s;
}

.modal-overlay.active {
  opacity: 1;
  pointer-events: auto;
}

.modal {
  background: var(--dashboard-card);
  border: 1px solid var(--dashboard-border);
  border-radius: var(--radius-xl);
  padding: 32px;
  width: 100%;
  max-width: 480px;
  max-height: 90vh;
  overflow-y: auto;
}

.confirm-modal {
  max-width: 420px;
  padding: 22px;
}

.confirm-modal .modal-header {
  margin-bottom: 10px;
}

.confirm-message {
  color: var(--dashboard-secondary);
  font-size: var(--font-size-base);
  line-height: 1.45;
  margin-bottom: 18px;
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}

.modal-header h2 {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--dashboard-fg);
}

.modal-header h3 {
  margin: 0;
  color: var(--dashboard-fg);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
}

.modal-close {
  flex: 0 0 auto;
  display: inline-grid;
  place-items: center;
  width: 32px;
  height: 32px;
  margin: -4px -6px 0 12px;
  padding: 0;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--dashboard-muted);
  cursor: pointer;
  line-height: 1;
  transition:
    background-color 150ms ease,
    border-color 150ms ease,
    color 150ms ease,
    transform 150ms cubic-bezier(0.22, 1, 0.36, 1);
}

.modal-close:hover,
.modal-close:focus-visible {
  border-color: color-mix(in srgb, var(--dashboard-border) 78%, transparent);
  background: var(--dashboard-hover);
  color: var(--dashboard-fg);
  outline: none;
}

.modal-close:focus-visible {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--dashboard-accent) 18%, transparent);
}

.modal-close:active {
  transform: scale(0.96);
}

.modal-close svg {
  width: 16px;
  height: 16px;
  stroke-width: 2.2;
}

.modal-body {
  margin-bottom: 24px;
}

.modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.confirm-actions {
  justify-content: flex-end;
  margin-top: 0;
}

.key-create-form {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(220px, 1fr) 180px;
  align-items: end;
  gap: 14px;
}

.key-create-form > * {
  min-width: 0;
}

.key-create-form .form-group {
  margin-bottom: 0;
}

.key-create-form .btn-primary {
  width: 100%;
  min-height: 42px;
}

.portal-section-card {
  padding: 24px 28px;
}

.portal-section-heading {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 16px;
}

.portal-section-heading h3 {
  margin: 0;
  color: var(--dashboard-fg);
}

.portal-section-heading h3::after {
  display: none;
}

.portal-section-heading p {
  margin: 6px 0 0;
  color: var(--dashboard-secondary);
  font-size: var(--font-size-base);
}

.section-title-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.section-title-row span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  min-height: 28px;
  border: 1px solid color-mix(in srgb, var(--dashboard-border) 82%, var(--dashboard-accent));
  border-radius: 999px;
  color: var(--dashboard-secondary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  line-height: 1;
  padding: 0 8px;
}

.key-list-card {
  display: grid;
  gap: 26px;
}

.key-group + .key-group {
  border-top: 1px solid var(--dashboard-border);
  padding-top: 26px;
}

.resource-list {
  display: grid;
  border: 1px solid var(--dashboard-border);
  border-radius: 10px;
  overflow: hidden;
}

.resource-row {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(360px, 1.35fr) auto;
  align-items: center;
  gap: 18px;
  min-height: 72px;
  padding: 14px 16px;
  background: color-mix(in srgb, var(--dashboard-card) 92%, var(--dashboard-bg));
  border-bottom: 1px solid var(--dashboard-border);
}

.resource-row:last-child {
  border-bottom: 0;
}

.resource-row:hover {
  background: var(--dashboard-hover);
}

.resource-main,
.resource-meta {
  min-width: 0;
}

.resource-main {
  display: grid;
  gap: 5px;
}

.resource-name {
  overflow: hidden;
  color: var(--dashboard-fg);
  font-weight: var(--font-weight-semibold);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.resource-sub {
  color: var(--dashboard-muted);
  font-size: var(--font-size-sm);
}

.resource-main code {
  width: fit-content;
  max-width: 100%;
  overflow: hidden;
  border: 1px solid var(--dashboard-border);
  border-radius: 5px;
  background: var(--dashboard-bg);
  color: var(--dashboard-fg);
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  padding: 3px 8px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.resource-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--dashboard-secondary);
  font-size: var(--font-size-sm);
}

.resource-meta > span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.resource-meta > span:not(:last-child)::after {
  color: var(--dashboard-muted);
  content: '/';
  margin-left: 10px;
}

.resource-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  white-space: nowrap;
}

.resource-empty {
  border: 1px dashed color-mix(in srgb, var(--dashboard-border) 78%, var(--dashboard-muted));
  border-radius: 10px;
  color: var(--dashboard-muted);
  font-size: var(--font-size-base);
  padding: 28px 16px;
  text-align: center;
}

.key-warning-banner {
  margin-bottom: 14px;
  border: 1px solid rgba(99, 102, 241, 0.22);
  border-radius: var(--radius-md);
  background: rgba(99, 102, 241, 0.08);
  color: var(--dashboard-secondary);
  font-size: var(--font-size-base);
  line-height: 1.45;
  padding: 10px 12px;
}

.secret-key-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: stretch;
  margin-bottom: 12px;
}

.secret-key {
  min-width: 0;
  overflow-x: auto;
  border: 1px solid var(--dashboard-border);
  border-radius: var(--radius-md);
  background: var(--dashboard-bg);
  color: var(--dashboard-fg);
  font-family: var(--font-mono);
  font-size: var(--font-size-base);
  line-height: 1.5;
  padding: 10px 12px;
  white-space: nowrap;
}

.secret-copy-btn {
  min-width: 78px;
  border: 1px solid var(--dashboard-border);
  border-radius: var(--radius-md);
  background: var(--dashboard-card);
  color: var(--dashboard-secondary);
  cursor: pointer;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  padding: 0 14px;
}

.secret-copy-btn:hover {
  border-color: var(--dashboard-accent);
  color: var(--dashboard-accent-fg);
}

.secret-copy-btn.is-success {
  border-color: rgba(34, 197, 94, 0.35);
  color: var(--dashboard-success-fg);
}

.copy-failure-fallback {
  display: flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  margin: 0;
  color: var(--dashboard-secondary);
  cursor: pointer;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.copy-failure-fallback input {
  flex: 0 0 auto;
  width: 16px;
  height: 16px;
  accent-color: var(--dashboard-accent);
}

/* ==========================================================================
   SUMMARY GRID / STAT BOXES (usage page)
   ========================================================================== */
.summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}

.stat-box {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--dashboard-border);
  border-radius: 0;
  padding: 16px 0;
}

.stat-box-label {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--dashboard-muted);
  margin-bottom: 6px;
}

.stat-box-value {
  display: block;
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--dashboard-fg);
  font-variant-numeric: tabular-nums;
}

.stat-box-value.accent {
  color: var(--dashboard-accent);
}

.stat-box-sub {
  font-size: var(--font-size-sm);
  color: var(--dashboard-muted);
  margin-top: 2px;
}

/* ==========================================================================
   STATUS BADGES (for key status, team roles, etc.)
   ========================================================================== */
.badge {
  display: inline-block;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 2px 8px;
  border-radius: 4px;
}

.badge-active {
  color: var(--dashboard-success);
  background: rgba(34, 197, 94, 0.12);
  border: 1px solid rgba(34, 197, 94, 0.25);
}

.badge-revoked {
  color: var(--dashboard-danger);
  background: rgba(239, 68, 68, 0.12);
  border: 1px solid rgba(239, 68, 68, 0.25);
}

.badge-warning {
  color: var(--dashboard-warning);
  background: rgba(245, 158, 11, 0.12);
  border: 1px solid rgba(245, 158, 11, 0.25);
}

.badge-muted {
  color: var(--dashboard-muted);
  background: var(--dashboard-hover);
  border: 1px solid var(--dashboard-border);
}

.badge-oauth {
  background: rgba(34, 197, 94, 0.12);
  border-color: rgba(34, 197, 94, 0.4);
  color: var(--dashboard-success-fg);
}

/* ==========================================================================
   UTILITY CLASSES
   ========================================================================== */
.text-muted {
  color: var(--dashboard-muted);
}
.text-secondary {
  color: var(--dashboard-secondary);
}
.text-accent {
  color: var(--dashboard-accent);
}
.text-danger {
  color: var(--dashboard-danger);
}
.text-success {
  color: var(--dashboard-success);
}
.text-mono {
  font-family: var(--font-mono);
}
.text-sm {
  font-size: var(--font-size-sm);
}

.inline-alert {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  line-height: 1.45;
  margin-bottom: 16px;
  padding: 11px 12px;
}

.error-alert {
  border: 1px solid rgba(239, 68, 68, 0.25);
  background: rgba(239, 68, 68, 0.08);
  color: var(--dashboard-danger-fg);
}

.inline-alert-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: rgba(239, 68, 68, 0.14);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  line-height: 1;
}
.text-xs {
  font-size: var(--font-size-xs);
}

.mt-0 {
  margin-top: 0;
}
.mt-8 {
  margin-top: 8px;
}
.mt-16 {
  margin-top: 16px;
}
.mt-24 {
  margin-top: 24px;
}
.mb-0 {
  margin-bottom: 0;
}
.mb-8 {
  margin-bottom: 8px;
}
.mb-16 {
  margin-bottom: 16px;
}
.mb-24 {
  margin-bottom: 24px;
}

.flex {
  display: flex;
}
.flex-wrap {
  flex-wrap: wrap;
}
.items-center {
  align-items: center;
}
.justify-between {
  justify-content: space-between;
}
.gap-8 {
  gap: 8px;
}
.gap-12 {
  gap: 12px;
}
.gap-16 {
  gap: 16px;
}

.hidden {
  display: none;
}

/* ---------------------------------------------------------------------------
 * Observation drawer (Traces -> request detail).
 *
 * Right-side sheet; full-screen on mobile. Renders the body of a single
 * inference. Lives in portal/ only — the sessions branch's Gantt can
 * import from here once it lands.
 * ------------------------------------------------------------------------ */

.obs-drawer-overlay {
  position: fixed;
  inset: 0;
  background: var(--dashboard-overlay);
  z-index: 998;
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease-out;
}
.obs-drawer-overlay.active {
  opacity: 1;
  pointer-events: auto;
}

.obs-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: 480px;
  max-width: 100vw;
  background: var(--dashboard-card);
  border-left: 1px solid var(--dashboard-border);
  z-index: 999;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 180ms ease-out;
}
.obs-drawer.active {
  transform: translateX(0);
}
.obs-drawer-overlay.active .obs-drawer {
  transform: translateX(0);
}
@media (max-width: 720px) {
  .obs-drawer {
    width: 100vw;
    border-left: 0;
  }
}
@media (prefers-reduced-motion: reduce) {
  .obs-drawer,
  .obs-drawer-overlay {
    transition: none;
  }
}

.obs-drawer-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--dashboard-border);
  position: sticky;
  top: 0;
  background: var(--dashboard-card);
  z-index: 1;
}
.obs-drawer-head h3 {
  margin: 0;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
}
.obs-drawer-close {
  background: none;
  border: 0;
  color: var(--dashboard-secondary);
  font-size: var(--font-size-xl);
  cursor: pointer;
  padding: 4px 8px;
  line-height: 1;
}
.obs-drawer-close:hover {
  color: var(--dashboard-fg);
}

.obs-drawer-body {
  padding: 14px 16px 24px;
}

.obs-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 16px;
  margin: 8px 0 16px;
}
.obs-meta div {
  margin: 0;
}
.obs-meta dt {
  font-size: var(--font-size-sm);
  color: var(--dashboard-secondary);
  text-transform: uppercase;
  letter-spacing: 0.4px;
  margin-bottom: 2px;
}
.obs-meta dd {
  margin: 0;
  font-size: var(--font-size-base);
  font-variant-numeric: tabular-nums;
  word-break: break-word;
}
.obs-meta-id {
  grid-column: 1 / -1;
}
.obs-meta-id code {
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  color: var(--dashboard-secondary);
}

.obs-section {
  border: 1px solid var(--dashboard-border);
  border-radius: 6px;
  margin-top: 10px;
  background: var(--dashboard-bg);
}
.obs-section > summary {
  cursor: pointer;
  padding: 10px 12px;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  user-select: none;
}
.obs-section[open] > summary {
  border-bottom: 1px solid var(--dashboard-border);
}
.obs-section-body {
  padding: 10px 12px;
}
/* Tool definitions / tool calls (Phase 2) */
.obs-tool {
  border: 1px solid var(--dashboard-border);
  border-radius: 4px;
  margin-bottom: 8px;
  overflow: hidden;
}
.obs-tool:last-child {
  margin-bottom: 0;
}
.obs-tool-head {
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding: 6px 10px;
  background: var(--dashboard-bg);
  border-bottom: 1px solid var(--dashboard-border);
}
.obs-tool-name {
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
}
.obs-tool-id {
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  color: var(--dashboard-secondary);
}
.obs-tool-desc {
  font-size: var(--font-size-sm);
  color: var(--dashboard-secondary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.obs-tool-schema > summary {
  font-size: var(--font-size-sm);
  color: var(--dashboard-secondary);
  cursor: pointer;
  padding: 4px 10px;
}
.obs-tool .obs-json {
  border: none;
  border-radius: 0;
}
.obs-section-hint {
  font-size: var(--font-size-sm);
  color: var(--dashboard-secondary);
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.obs-json-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}
.obs-json {
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  background: var(--dashboard-input-bg);
  border: 1px solid var(--dashboard-border);
  border-radius: 4px;
  padding: 8px 10px;
  margin: 0;
  white-space: pre-wrap;
  word-break: break-word;
  max-height: 360px;
  overflow: auto;
}

.redacted-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 1px 8px;
  border-radius: 10px;
  background: var(--dashboard-hover);
  color: var(--dashboard-secondary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.redacted-chip-icon {
  flex: 0 0 auto;
  /* SVG path uses currentColor; the chip's `color:` is the icon tint. */
}
/* Item 4: distinguish POLICY-HIDDEN ("the gateway refuses to serve this")
 * from NOT-RECORDED ("this row simply doesn't have a value"). The two
 * variants land on the same base `.redacted-chip` so legacy callers
 * that don't pass a kind still render reasonably.
 *
 *   .redacted-chip-policy      — solid fill, lock icon, label "redacted"
 *   .redacted-chip-unavailable — outlined, dashed border, em-dash glyph
 */
.redacted-chip-policy {
  background: var(--dashboard-hover);
  color: var(--dashboard-fg);
  border: 1px solid var(--dashboard-border);
}
.redacted-chip-unavailable {
  background: transparent;
  color: var(--dashboard-secondary);
  border: 1px dashed var(--dashboard-border);
}
/* The unavailable variant uses an em-dash *prefix* glyph (the ::before
 * pseudo-element) so the chip reads as "— unavailable" without the
 * label text needing to encode the glyph. */
.redacted-chip-unavailable::before {
  content: '\2014'; /* em-dash */
  margin-right: 2px;
  color: var(--dashboard-muted);
}

.privacy-banner {
  border: 1px solid var(--dashboard-border);
  border-radius: 6px;
  padding: 8px 10px;
  font-size: var(--font-size-sm);
  margin-bottom: 12px;
  line-height: 1.4;
}
.privacy-banner-warn {
  border-color: rgba(245, 158, 11, 0.4);
  background: rgba(245, 158, 11, 0.08);
  color: var(--dashboard-warning);
}
.privacy-banner-muted {
  background: var(--dashboard-hover);
  color: var(--dashboard-secondary);
}

/* Trace row affordances. Whole row is the click target; the trailing
 * glyph is a sighted-user hint. tabindex=0 + role=button on the <tr>
 * gives keyboard + AT users the same affordance. */
.trace-row {
  cursor: pointer;
}
.trace-row:hover {
  background: var(--dashboard-hover);
}
.trace-row:focus {
  outline: 2px solid var(--dashboard-input-focus);
  outline-offset: -2px;
}
.trace-row-glyph {
  color: var(--dashboard-secondary);
  font-size: var(--font-size-sm);
  margin-left: 4px;
}
/* 429 cool-down: dim the table and block pointer events for ~5s so a
 * user who hit the per-user obs budget doesn't keep firing requests. */
.obs-rows-disabled {
  opacity: 0.5;
  pointer-events: none;
}

/* ─── Item 6: shared JSON-highlight palette ──────────────────────────
 * The shared highlighter (ui/web/shared/json_highlight.js) emits two
 * class names per token — the legacy short form (.key, .string, ...)
 * for the admin observations page, and the prefixed form
 * (.json-key, .json-string, ...) we scope under `.obs-json` here so
 * we don't trample on any other page that happens to use one of the
 * short names. */
.obs-json .json-key {
  color: var(--dashboard-accent);
}
.obs-json .json-string {
  color: var(--dashboard-fg);
}
.obs-json .json-number {
  color: var(--dashboard-warning);
}
.obs-json .json-boolean {
  color: var(--dashboard-warning);
}
.obs-json .json-null {
  color: var(--dashboard-secondary);
}

/* ─── Item 7: mobile bottom-sheet (static, no drag-to-dismiss) ──────
 * On narrow viewports the right-side drawer becomes a bottom sheet —
 * the same control surface but anchored to the bottom edge so the
 * thumb-zone reaches the close button. Drag-to-dismiss is
 * intentionally deferred (the static sheet is already a step-up over
 * the v1 fullscreen takeover); backdrop-tap and the close button still
 * dismiss. The 500px breakpoint is narrower than the 720px breakpoint
 * above on purpose: phones get the sheet, small tablets keep the
 * full-screen drawer. */
@media (max-width: 500px) {
  .obs-drawer {
    top: auto;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100vw;
    height: 80vh;
    transform: translateY(100%);
    border-left: 0;
    border-top: 1px solid var(--dashboard-border);
    border-radius: 12px 12px 0 0;
  }
  .obs-drawer.active {
    /* Sheet rests at 20vh from the top → 80vh visible height (matches
     * the `height: 80vh` rule above). */
    transform: translateY(0);
  }
  .obs-drawer-overlay.active .obs-drawer {
    transform: translateY(0);
  }
}

/* (Removed) The previous prefers-reduced-motion @media rule for the
 * bottom-sheet was a no-op: it duplicated the active-state transform
 * already declared above. The earlier global `prefers-reduced-motion`
 * block neutralises `transition` (not `transform`), so the bottom sheet
 * already snaps into place at translateY(20vh) without animation. */

/* ── Trace-list filter strip (Next-2b) ─────────────────────────────── */
#traceFilterStrip {
  margin-bottom: 12px;
  padding: 10px 12px;
}
.trace-filter-toggle {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  background: transparent;
  border: 0;
  color: inherit;
  cursor: pointer;
  padding: 4px 0;
  font: inherit;
  text-align: left;
  min-width: 0;
}
.trace-filter-pill {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1 1 auto;
  font-size: var(--font-size-base);
  color: var(--dashboard-muted);
}
.trace-filter-grid {
  display: none;
  margin-top: 12px;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.trace-filter-grid .form-group {
  margin-bottom: 0;
  min-width: 0;
}
#traceFilterStrip.expanded .trace-filter-grid,
#usageFilterStrip.expanded .trace-filter-grid {
  display: grid;
}
.trace-filter-toggle .toggle-glyph {
  display: inline-block;
  flex: 0 0 auto;
  color: var(--dashboard-muted);
  transition: transform 120ms ease;
}
#traceFilterStrip.expanded .trace-filter-toggle .toggle-glyph,
#usageFilterStrip.expanded .trace-filter-toggle .toggle-glyph {
  transform: rotate(180deg);
}
.trace-filter-search {
  display: flex;
  align-items: center;
  gap: 6px;
}
.trace-filter-search input {
  flex: 1;
}
/* Banner for deep-link rows that fall outside the current filter view. */
.banner {
  padding: 10px 14px;
  border-radius: 6px;
  margin: 8px 0;
  font-size: var(--font-size-base);
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.banner-info {
  background: rgba(96, 165, 250, 0.1);
  border: 1px solid rgba(96, 165, 250, 0.3);
  color: var(--dashboard-info-fg);
}
.banner code {
  font-family: ui-monospace, SFMono-Regular, monospace;
}
@media (max-width: 720px) {
  .trace-filter-grid {
    grid-template-columns: 1fr;
  }
}

/* ==========================================================================
   BRAND REFRESH LAYER
   ========================================================================== */
html {
  background:
    radial-gradient(circle at 10% 0%, rgba(201, 111, 61, 0.12), transparent 30rem),
    var(--dashboard-bg);
}

[data-theme='light'] html,
html[data-theme='light'] {
  background: #e8e5e0;
}

body.portal-shell {
  background:
    linear-gradient(90deg, rgba(16, 16, 16, 0.08), transparent 20rem), var(--dashboard-bg);
}

[data-theme='light'] body.portal-shell {
  background: linear-gradient(90deg, rgba(27, 25, 23, 0.04), transparent 18rem), #e8e5e0;
}

[data-theme='light'] body.portal-shell::before,
.login-wrapper::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  background-image:
    url("data:image/svg+xml,%3Csvg width='48' height='48' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='22.5' y='22.5' width='3' height='3' rx='0.4' transform='rotate(45 24 24)' fill='%23d5cfc8' opacity='0.28'/%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg width='48' height='48' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='22.5' y='22.5' width='3' height='3' rx='0.4' transform='rotate(45 24 24)' fill='%23d5cfc8' opacity='0.22'/%3E%3C/svg%3E");
  background-position:
    0 0,
    24px 24px;
  background-size: 48px 48px;
}

::selection {
  background: rgba(201, 111, 61, 0.22);
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[role='button']:focus-visible {
  outline: 2px solid var(--dashboard-accent);
  outline-offset: 2px;
}

.sidebar {
  background: color-mix(in srgb, var(--dashboard-sidebar) 88%, #000 12%);
  box-shadow: inset -1px 0 0 var(--dashboard-border);
}

[data-theme='light'] .sidebar {
  background: rgba(240, 236, 228, 0.94);
  backdrop-filter: blur(14px);
}

.sidebar-logo img,
.login-logo img {
  filter: drop-shadow(0 4px 10px rgba(201, 111, 61, 0.16));
}

.sidebar-logo span,
.topbar-title,
.welcome-title,
.login-logo span {
  letter-spacing: -0.01em;
}

.sidebar-logo span {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-bold);
}

.sidebar-nav {
  padding: 18px 10px 72px;
  border-right: 0;
}

.nav-group {
  margin-bottom: 22px;
}

.nav-group-label {
  color: var(--dashboard-muted);
  font-family: var(--font-mono);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.12em;
}

.nav-group-line {
  background: color-mix(in srgb, var(--dashboard-border) 70%, transparent);
}

.nav-item {
  min-height: 38px;
  border: 1px solid transparent;
  border-radius: 10px;
  color: var(--dashboard-secondary);
  font-weight: var(--font-weight-medium);
  transition:
    background-color 0.16s ease,
    border-color 0.16s ease,
    color 0.16s ease,
    transform 0.16s ease;
}

.nav-item:hover {
  border-color: var(--dashboard-border);
  transform: translateX(1px);
}

.nav-item.active,
body[data-page='home'] .nav-item[data-nav-id='home'],
body[data-page='team'] .nav-item[data-nav-id='team'],
body[data-page='endpoints'] .nav-item[data-nav-id='endpoints'],
body[data-page='keys'] .nav-item[data-nav-id='keys'],
body[data-page='usage'] .nav-item[data-nav-id='usage'],
body[data-page='history'] .nav-item[data-nav-id='history'] {
  background: rgba(201, 111, 61, 0.14);
  border-color: rgba(201, 111, 61, 0.3);
  color: var(--dashboard-accent-fg);
  box-shadow: inset 3px 0 0 var(--dashboard-accent);
}

.nav-item svg,
.docs-link svg,
.topbar-ctl-btn svg {
  stroke-width: 1.8;
}

.nav-item .soon-badge,
.badge,
.badge-public,
.badge-standard,
.badge-admin,
.stat-box-label,
thead th,
label {
  font-family: var(--font-mono);
}

.topbar {
  height: var(--topbar-h);
  background: color-mix(in srgb, var(--dashboard-bg) 88%, transparent);
  backdrop-filter: blur(16px);
}

[data-theme='light'] .topbar {
  background: rgba(250, 248, 245, 0.82);
}

.topbar-title {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-semibold);
}

.docs-link,
.topbar-ctl-btn,
.user-avatar-btn,
.user-menu-item {
  border-radius: 10px;
}

.docs-link {
  padding: 7px 10px;
}

.docs-link:hover {
  background: var(--dashboard-hover);
}

.content {
  padding: 28px;
}

.content-inner {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.welcome-section {
  margin-bottom: 0;
  padding: 2px 0 4px;
}

.welcome-title {
  font-size: clamp(22px, 2.4vw, 32px);
  font-weight: var(--font-weight-semibold);
  line-height: 1.08;
}

.welcome-sub {
  max-width: 760px;
  margin-top: 8px;
  font-family: var(--font-mono);
  font-size: var(--font-size-base);
  line-height: 1.55;
}

.cta-row {
  margin-bottom: 0;
}

.card,
.ante-card,
.install-card,
.feature-card,
.stat-box,
#traceFilterStrip,
#usageFilterStrip {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--dashboard-border);
  border-radius: 0;
  box-shadow: none;
}

[data-theme='light'] .card,
[data-theme='light'] .ante-card,
[data-theme='light'] .install-card,
[data-theme='light'] .feature-card,
[data-theme='light'] .stat-box,
[data-theme='light'] #traceFilterStrip,
[data-theme='light'] #usageFilterStrip {
  background: transparent;
}

.card,
.ante-card {
  padding: 24px 0;
}

.install-card {
  padding: 18px 0;
  margin-bottom: 0;
}

.card h3,
.ante-section h3 {
  color: var(--dashboard-fg);
  font-size: var(--font-size-md);
}

.card h3::after,
.ante-section h3::after,
.install-header span::after {
  content: '';
  display: block;
  width: 32px;
  height: 2px;
  margin-top: 8px;
  background: var(--dashboard-accent);
}

.install-header {
  align-items: flex-start;
}

.install-header svg,
.feature-card-icon,
.text-accent,
.stat-box-value.accent,
.obs-json .json-key {
  color: var(--dashboard-accent-fg);
}

.install-command,
.ante-section .cmd-block,
.ante-cmd-row code,
.ante-cmd-row-code,
.secret-key,
tbody td code,
.obs-json {
  background: color-mix(in srgb, var(--dashboard-bg) 78%, var(--dashboard-card) 22%);
  border-color: color-mix(in srgb, var(--dashboard-border) 82%, var(--dashboard-accent) 18%);
}

[data-theme='light'] .install-command,
[data-theme='light'] .ante-section .cmd-block,
[data-theme='light'] .ante-cmd-row code,
[data-theme='light'] .ante-cmd-row-code,
[data-theme='light'] .secret-key,
[data-theme='light'] tbody td code,
[data-theme='light'] .obs-json {
  background: #f5f1e9;
}

.btn-primary,
.oauth-btn#magic-login-submit,
.update-banner {
  background: var(--dashboard-accent);
  color: var(--dashboard-primary-fg);
  border: 1px solid color-mix(in srgb, var(--dashboard-accent) 80%, #000 20%);
  box-shadow: 0 8px 18px rgba(128, 68, 35, 0.14);
}

.btn-primary:hover,
.oauth-btn#magic-login-submit:hover {
  background: color-mix(in srgb, var(--dashboard-accent) 84%, white 16%);
  transform: translateY(-1px);
}

.btn-outline,
.btn-secondary,
.topbar-ctl-btn,
.secret-copy-btn,
.oauth-btn,
#continue-btn,
.accountButton,
.portalLink {
  background: color-mix(in srgb, var(--dashboard-card) 86%, var(--dashboard-bg) 14%);
  border-color: var(--dashboard-border);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.03) inset;
}

.btn-outline:hover,
.btn-secondary:hover,
.topbar-ctl-btn:hover,
.secret-copy-btn:hover,
.oauth-btn:hover,
#continue-btn:hover {
  border-color: color-mix(in srgb, var(--dashboard-accent) 42%, var(--dashboard-border));
  color: var(--dashboard-fg);
  transform: translateY(-1px);
}

.oauth-btn:disabled {
  cursor: not-allowed;
  opacity: 0.58;
  transform: none;
}

.feature-card {
  min-height: 144px;
  transition:
    border-color var(--transition-fast),
    background-color var(--transition-fast);
}

.feature-card:hover {
  border-color: rgba(201, 111, 61, 0.34);
  background-color: var(--dashboard-hover);
}

.cards-grid {
  gap: 14px;
}

.table-wrapper {
  border-color: var(--dashboard-border);
  background: var(--dashboard-card);
  box-shadow: var(--portal-shadow-tight);
}

thead {
  background: color-mix(in srgb, var(--dashboard-sidebar) 74%, var(--dashboard-card) 26%);
}

thead th {
  color: var(--dashboard-muted);
  font-size: var(--font-size-xs);
  letter-spacing: 0.09em;
}

tbody tr {
  transition:
    background-color 0.12s ease,
    box-shadow 0.12s ease;
}

tbody tr:hover {
  background: color-mix(in srgb, var(--dashboard-hover) 80%, var(--dashboard-accent) 6%);
}

tbody td {
  line-height: 1.5;
}

input[type='text'],
input[type='email'],
input[type='password'],
input[type='number'],
input[type='url'],
input[type='search'],
input[type='date'],
input[type='time'],
input[type='datetime-local'],
select,
textarea {
  min-height: 42px;
  border-radius: 10px;
}

label {
  font-size: var(--font-size-xs);
  letter-spacing: 0.08em;
}

.summary-grid {
  gap: 14px;
}

.stat-box {
  padding: 18px;
}

.stat-box-value {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-semibold);
  letter-spacing: -0.02em;
}

.modal,
.obs-drawer {
  box-shadow: var(--dashboard-shadow);
}

.login-wrapper {
  position: relative;
  justify-content: center;
  min-height: 100vh;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 8%, rgba(216, 102, 52, 0.1), transparent 34rem),
    linear-gradient(135deg, #faf8f5 0%, #f2eee8 100%);
  padding: 32px clamp(20px, 5vw, 72px);
}

.login-card {
  position: relative;
  z-index: 1;
  max-width: 430px;
  padding: 34px;
  text-align: left;
  border-radius: var(--radius-xl);
  background: rgba(255, 253, 248, 0.96);
  color: #1b1917;
  border-color: #e8e1d9;
  box-shadow:
    0 8px 30px rgba(0, 0, 0, 0.08),
    0 1px 2px rgba(0, 0, 0, 0.04);
}

.login-logo {
  justify-content: flex-start;
}

.login-logo span {
  color: #1b1917;
  font-size: var(--font-size-xl);
}

.login-sub {
  color: #7c706a;
  font-family: var(--font-mono);
  line-height: 1.5;
}

.login-card .oauth-btn,
.login-card #continue-btn,
.login-card input {
  color: #1b1917;
  background: #faf8f5;
  border-color: #eee6dc;
}

.login-card .oauth-btn:hover,
.login-card #continue-btn:hover {
  background: #f0ece4;
  border-color: #ddd2c5;
}

.login-card .error-msg {
  margin: 0 0 16px;
  padding: 10px 12px;
  border: 1px solid rgba(216, 75, 58, 0.24);
  border-radius: 10px;
  border-color: rgba(216, 75, 58, 0.24);
  background: rgba(216, 75, 58, 0.08);
  color: #a73529;
  font-family: var(--font-sans);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  line-height: 1.4;
}

.magic-login-divider,
.continue-divider,
.dev-login-divider {
  color: #7c706a;
  font-family: var(--font-mono);
}

#magic-login-form,
#continue-block,
#dev-login-block {
  margin-top: 14px;
}

.magic-login-divider,
.dev-login-divider {
  margin-bottom: 6px;
  font-size: var(--font-size-base);
}

.continue-divider {
  height: 1px;
  margin: 16px 0 12px;
  background: #e2d9cf;
}

.magic-login-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 14px;
}

#continue-btn {
  display: grid;
  width: 100%;
  gap: 4px;
  padding: 11px 12px;
  border: 1px solid #eee6dc;
  border-radius: 10px;
  text-align: left;
  cursor: pointer;
}

.continue-label,
.continue-hint {
  color: #7c706a;
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  line-height: 1.35;
}

.continue-email {
  min-width: 0;
  overflow: hidden;
  color: #1b1917;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.continue-hint {
  margin-top: 8px;
}

.magic-login-status,
.dev-login-status {
  min-height: 18px;
  color: #7c706a;
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  line-height: 1.5;
}

@media (max-width: 920px) {
  .login-wrapper {
    justify-content: center;
    background: #faf8f5;
  }
}

@media (max-width: 760px) {
  .content {
    padding: 18px 12px 22px;
  }

  .content-inner {
    gap: 14px;
  }

  .topbar {
    padding: 0 12px;
  }

  .docs-link {
    width: 34px;
    height: 34px;
    justify-content: center;
    padding: 0;
    overflow: hidden;
    color: transparent;
  }

  .docs-link svg {
    color: var(--dashboard-secondary);
  }

  .welcome-title {
    font-size: var(--font-size-2xl);
  }

  .card,
  .ante-card,
  .install-card {
    padding: 16px;
    border-radius: var(--radius-lg);
  }

  .cards-grid {
    grid-template-columns: 1fr;
  }

  .feature-card {
    min-height: 0;
  }

  .install-command,
  .secret-key-row {
    grid-template-columns: 1fr;
  }

  .install-command {
    display: grid;
  }

  .install-command code {
    overflow-x: auto;
    white-space: nowrap;
  }

  .copy-btn,
  .secret-copy-btn {
    min-height: 36px;
  }

  .login-wrapper {
    align-items: stretch;
    padding: 18px;
  }

  .login-card {
    align-self: center;
    padding: 24px;
    border-radius: 18px;
  }
}

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

/* --------------------------------------------------------------------------
   Polish pass: restrained brand color, theme-specific buttons, alignment.
   ----------------------------------------------------------------------- */
.nav-item.active,
body[data-page='home'] .nav-item[data-nav-id='home'],
body[data-page='team'] .nav-item[data-nav-id='team'],
body[data-page='endpoints'] .nav-item[data-nav-id='endpoints'],
body[data-page='keys'] .nav-item[data-nav-id='keys'],
body[data-page='usage'] .nav-item[data-nav-id='usage'],
body[data-page='history'] .nav-item[data-nav-id='history'] {
  background: transparent;
  border-color: transparent;
  color: var(--dashboard-accent);
  box-shadow: none;
}

[data-theme='light'] .nav-item.active,
[data-theme='light'] body[data-page='home'] .nav-item[data-nav-id='home'],
[data-theme='light'] body[data-page='team'] .nav-item[data-nav-id='team'],
[data-theme='light'] body[data-page='endpoints'] .nav-item[data-nav-id='endpoints'],
[data-theme='light'] body[data-page='keys'] .nav-item[data-nav-id='keys'],
[data-theme='light'] body[data-page='usage'] .nav-item[data-nav-id='usage'],
[data-theme='light'] body[data-page='history'] .nav-item[data-nav-id='history'] {
  background: transparent;
  border-color: transparent;
  color: var(--dashboard-accent);
}

.btn-primary,
.btn-outline,
.btn-secondary,
.btn-danger,
.btn-danger-outline,
.oauth-btn,
.topbar-ctl-btn,
.docs-link,
.secret-copy-btn,
#continue-btn,
.accountButton,
.portalLink,
.update-banner-reload,
.update-banner-dismiss {
  min-height: 40px;
  border-radius: 10px;
  font-size: var(--font-size-base);
  line-height: 1;
}

.btn-primary,
.oauth-btn#magic-login-submit,
.update-banner {
  background: var(--dashboard-primary);
  border-color: color-mix(in srgb, var(--dashboard-primary) 74%, #000);
  color: var(--dashboard-primary-fg);
  box-shadow: 0 8px 18px rgba(128, 68, 35, 0.14);
}

.btn-primary:hover,
.oauth-btn#magic-login-submit:hover {
  background: var(--dashboard-primary-hover);
  color: var(--dashboard-primary-fg);
  transform: translateY(-1px);
}

.btn-primary:active,
.btn-outline:active,
.btn-secondary:active,
.btn-danger:active,
.btn-danger-outline:active,
.oauth-btn:active,
.secret-copy-btn:active,
#continue-btn:active {
  transform: translateY(0);
}

.btn-outline,
.btn-secondary,
.topbar-ctl-btn,
.secret-copy-btn,
.oauth-btn,
#continue-btn,
.accountButton,
.portalLink {
  background: color-mix(in srgb, var(--dashboard-card) 88%, var(--dashboard-bg));
  border: 1px solid var(--dashboard-border);
  color: var(--dashboard-fg);
  box-shadow: none;
}

[data-theme='light'] .btn-outline,
[data-theme='light'] .btn-secondary,
[data-theme='light'] .topbar-ctl-btn,
[data-theme='light'] .secret-copy-btn,
[data-theme='light'] .oauth-btn,
[data-theme='light'] #continue-btn,
[data-theme='light'] .accountButton,
[data-theme='light'] .portalLink {
  background: #fffdf8;
  border-color: #e8e1d9;
}

[data-theme='light'] .btn-primary,
[data-theme='light'] .oauth-btn#magic-login-submit,
[data-theme='light'] .update-banner {
  border-color: transparent;
}

.btn-outline:hover,
.btn-secondary:hover,
.topbar-ctl-btn:hover,
.secret-copy-btn:hover,
.oauth-btn:hover,
#continue-btn:hover,
.accountButton:hover,
.portalLink:hover {
  background: color-mix(in srgb, var(--dashboard-hover) 64%, var(--dashboard-card));
  border-color: color-mix(in srgb, var(--dashboard-accent) 24%, var(--dashboard-border));
  color: var(--dashboard-fg);
  transform: translateY(-1px);
}

.btn-primary:disabled,
.btn-outline:disabled,
.btn-secondary:disabled,
.btn-danger:disabled,
.btn-danger-outline:disabled,
.topbar-ctl-btn:disabled,
.secret-copy-btn:disabled {
  cursor: not-allowed;
  opacity: 0.54;
  transform: none;
}

.btn-primary:disabled:hover,
.btn-outline:disabled:hover,
.btn-secondary:disabled:hover,
.btn-danger:disabled:hover,
.btn-danger-outline:disabled:hover,
.topbar-ctl-btn:disabled:hover,
.secret-copy-btn:disabled:hover {
  transform: none;
}

[data-theme='light'] .btn-outline:hover,
[data-theme='light'] .btn-secondary:hover,
[data-theme='light'] .topbar-ctl-btn:hover,
[data-theme='light'] .secret-copy-btn:hover,
[data-theme='light'] .oauth-btn:hover,
[data-theme='light'] #continue-btn:hover,
[data-theme='light'] .accountButton:hover,
[data-theme='light'] .portalLink:hover {
  background: #f5f1e9;
  border-color: #d9cec3;
}

.login-card .oauth-provider-btn {
  position: relative;
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr) 14px;
  align-items: center;
  min-height: 54px;
  padding: 0 18px 0 16px;
  margin-bottom: 10px;
  color: #1b1917;
  background: linear-gradient(180deg, #fffdf8 0%, #f7f1e8 100%);
  border: 1px solid #d7cabd;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.95),
    0 1px 2px rgba(20, 17, 12, 0.04);
  font-weight: var(--font-weight-semibold);
  line-height: 1.2;
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    color var(--transition-fast);
}

.login-card .oauth-provider-btn[hidden] {
  display: none;
}

.login-card .passkey-provider-btn {
  background: linear-gradient(180deg, #fff6ed 0%, #f7e5d3 100%);
  border-color: #d7aa84;
  color: #8d4f2f;
}

.login-card .passkey-provider-btn span {
  color: #1b1917;
}

.login-card .passkey-provider-btn:disabled {
  cursor: wait;
  opacity: 0.74;
}

#btn-github.oauth-provider-btn {
  margin-bottom: 20px;
}

.login-card .oauth-provider-btn span {
  min-width: 0;
  text-align: left;
}

.login-card .oauth-provider-btn .oauth-icon {
  width: 20px;
  height: 20px;
}

.login-card .oauth-provider-btn::after {
  content: '';
  width: 7px;
  height: 7px;
  justify-self: end;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  opacity: 0.44;
  transform: rotate(-45deg);
  transition:
    border-color var(--transition-fast),
    opacity var(--transition-fast),
    transform var(--transition-fast);
}

.login-card .oauth-provider-btn:hover,
[data-theme='light'] .login-card .oauth-provider-btn:hover {
  color: #1b1917;
  background: linear-gradient(180deg, #fffaf3 0%, #f6eadc 100%);
  border-color: #c96f3d;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.95),
    0 0 0 3px rgba(201, 111, 61, 0.12),
    0 2px 4px rgba(97, 57, 33, 0.06);
}

.login-card .oauth-provider-btn:hover::after {
  border-color: #8d4f2f;
  opacity: 0.86;
  transform: translateX(2px) rotate(-45deg);
}

.login-card .oauth-provider-btn:active {
  box-shadow:
    inset 0 1px 2px rgba(20, 17, 12, 0.12),
    0 4px 14px rgba(97, 57, 33, 0.1);
  transform: translateY(0);
}

.login-card #magic-email {
  min-height: 52px;
  padding: 0 14px;
}

.login-card #magic-login-submit {
  min-height: 52px;
  margin-bottom: 0;
}

.btn-danger {
  background: #c9473a;
  border: 1px solid #b23d32;
  color: #fff8f5;
}

.btn-danger:hover {
  background: #ad382e;
}

.btn-danger-outline {
  background: color-mix(in srgb, var(--dashboard-card) 88%, var(--dashboard-bg));
  border-color: #d8aaa1;
  color: var(--dashboard-danger-fg);
}

[data-theme='light'] .btn-danger-outline {
  background: #fffdf8;
  color: #a73529;
}

.btn-danger-outline:hover {
  background: #c9473a;
  border-color: #c9473a;
  color: #fff8f5;
}

.btn-sm {
  min-height: 36px;
  padding: 0 12px;
  font-size: var(--font-size-base);
}

.table-actions {
  justify-content: flex-start;
  gap: 8px;
}

.table-actions .btn-secondary,
.table-actions .btn-danger,
.table-actions .btn-danger-outline,
.table-actions .btn-primary {
  min-width: 82px;
  min-height: 40px;
  padding: 0 14px;
}

#createEndpointForm {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(200px, 1fr) minmax(220px, 1fr) 120px;
  align-items: end;
  gap: 16px;
}

#createEndpointForm > * {
  min-width: 0;
}

#createEndpointForm .form-group {
  margin-bottom: 0;
}

#createEndpointForm .btn-primary,
.key-create-form .btn-primary {
  width: 100%;
  min-height: 42px;
  padding: 0 16px;
}

.endpoints-create-card,
.endpoints-list-card {
  padding: 24px 28px;
}

.endpoints-card-heading {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 18px;
}

.endpoints-card-heading h3,
.endpoint-group-heading h3 {
  color: var(--dashboard-fg);
  margin: 0;
}

.endpoints-card-heading h3::after,
.endpoint-group-heading h3::after {
  display: none;
}

.endpoints-card-heading p,
.endpoint-group-heading p {
  margin: 6px 0 0;
}

.endpoints-soft-note,
.endpoint-quota,
.endpoint-title-row span {
  display: inline-flex;
  align-items: center;
  border: 1px solid color-mix(in srgb, var(--dashboard-border) 82%, var(--dashboard-accent));
  border-radius: 999px;
  color: var(--dashboard-secondary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  line-height: 1;
  min-height: 28px;
  padding: 0 10px;
  white-space: nowrap;
}

.endpoints-list-card {
  display: grid;
  gap: 28px;
}

.endpoint-group + .endpoint-group {
  border-top: 1px solid var(--dashboard-border);
  padding-top: 28px;
}

.endpoint-group-heading {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}

.endpoint-title-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.endpoint-title-row span {
  min-width: 28px;
  justify-content: center;
  padding: 0 8px;
}

.endpoint-quota {
  max-width: min(48vw, 560px);
  overflow: hidden;
  text-overflow: ellipsis;
}

.endpoint-list {
  display: grid;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid var(--dashboard-border);
  border-radius: 10px;
  overflow: hidden;
}

.endpoint-row {
  display: grid;
  grid-template-columns: minmax(260px, 1.35fr) minmax(360px, 1fr) auto;
  align-items: center;
  gap: 18px;
  min-height: 74px;
  padding: 14px 16px;
  background: color-mix(in srgb, var(--dashboard-card) 92%, var(--dashboard-bg));
  border-bottom: 1px solid var(--dashboard-border);
}

.endpoint-row:last-child {
  border-bottom: none;
}

.endpoint-row:hover {
  background: var(--dashboard-hover);
}

.endpoint-main,
.endpoint-meta {
  min-width: 0;
}

.endpoint-name {
  color: var(--dashboard-accent);
  font-weight: var(--font-weight-semibold);
  text-decoration: none;
}

.endpoint-name:hover {
  text-decoration: underline;
}

.endpoint-url {
  color: var(--dashboard-muted);
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  line-height: 1.45;
  margin-top: 4px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.endpoint-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--dashboard-secondary);
  font-size: var(--font-size-sm);
  min-width: 0;
}

.endpoint-meta > span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.endpoint-meta > span:not(:last-child)::after {
  color: var(--dashboard-muted);
  content: '/';
  margin-left: 10px;
}

.endpoint-meta code {
  flex: 0 0 auto;
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  background: var(--dashboard-bg);
  border: 1px solid var(--dashboard-border);
  border-radius: 5px;
  color: var(--dashboard-fg);
  padding: 3px 8px;
}

.endpoint-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  white-space: nowrap;
}

.endpoint-actions .btn-secondary,
.endpoint-actions .btn-danger-outline {
  min-width: 76px;
}

.endpoint-empty {
  border: 1px dashed color-mix(in srgb, var(--dashboard-border) 78%, var(--dashboard-muted));
  border-radius: 10px;
  color: var(--dashboard-muted);
  font-size: var(--font-size-base);
  padding: 28px 16px;
  text-align: center;
}

.card h3::after,
.ante-section h3::after,
.install-header span::after {
  background: var(--dashboard-accent);
}

.install-command,
.ante-section .cmd-block,
.ante-cmd-row code,
.ante-cmd-row-code,
.secret-key,
tbody td code,
.obs-json {
  border-color: color-mix(in srgb, var(--dashboard-border) 86%, var(--dashboard-accent));
}

.key-warning-banner {
  border-color: rgba(201, 111, 61, 0.22);
  background: rgba(201, 111, 61, 0.07);
}

@media (max-width: 980px) {
  #createEndpointForm {
    grid-template-columns: 1fr;
  }

  .endpoints-card-heading,
  .endpoint-group-heading {
    display: grid;
  }

  .endpoint-quota {
    max-width: 100%;
  }

  .endpoint-row {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .endpoint-meta {
    flex-wrap: wrap;
  }

  .endpoint-actions {
    justify-content: flex-start;
  }
}

/* --------------------------------------------------------------------------
   Layout refinement: reduce redundant cards, improve org cards and charts.
   ----------------------------------------------------------------------- */
.org-directory {
  max-width: 980px;
}

.org-directory-transition,
.org-detail-transition {
  animation: org-panel-enter 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.org-directory .org-list-header {
  margin-bottom: 18px;
}

.org-directory .org-list {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}

.org-directory .org-list-item {
  position: relative;
  min-height: 146px;
  grid-template-columns: 1fr;
  align-content: space-between;
  gap: 18px;
  padding: 16px;
  border-radius: 14px;
  background: var(--dashboard-card);
  box-shadow: var(--portal-shadow-tight);
  transition:
    background-color 160ms ease,
    border-color 160ms ease,
    box-shadow 180ms ease,
    opacity 160ms ease,
    transform 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

[data-theme='light'] .org-directory .org-list-item {
  background: rgba(255, 253, 248, 0.92);
}

.org-list-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.org-directory .org-list-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--dashboard-accent) 12%, var(--dashboard-card));
  color: var(--dashboard-accent-fg);
}

[data-theme='light'] .org-directory .org-list-icon {
  background: #f2e2d8;
}

.org-directory .org-list-open {
  min-height: 30px;
  min-width: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--dashboard-border);
  border-radius: 999px;
  padding: 0 10px;
  color: var(--dashboard-secondary);
  font-size: var(--font-size-sm);
}

[data-theme='light'] .org-directory .org-list-open {
  border-color: #e8e1d9;
}

.org-directory .org-list-name {
  white-space: normal;
  line-height: 1.3;
}

.org-directory .org-list-meta {
  margin-top: 4px;
}

.org-directory .org-list-item:hover,
.org-directory .org-list-item:focus-visible {
  border-color: color-mix(in srgb, var(--dashboard-accent) 28%, var(--dashboard-border));
  transform: translateY(-1px);
}

.org-directory .org-list-item.is-loading {
  border-color: color-mix(in srgb, var(--dashboard-accent) 38%, var(--dashboard-border));
  cursor: progress;
  opacity: 0.78;
  transform: translateY(-1px) scale(0.99);
}

.org-directory .org-list-item:disabled {
  cursor: wait;
}

.org-list-skeleton {
  cursor: default;
  pointer-events: none;
}

.org-skeleton-avatar {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-lg);
}

.org-skeleton-pill {
  width: 58px;
  height: 30px;
  border-radius: 999px;
}

.org-skeleton-name {
  width: min(68%, 240px);
}

.org-skeleton-meta {
  width: min(46%, 160px);
}

.org-skeleton-label {
  width: 82px;
}

.org-skeleton-title {
  width: min(52vw, 280px);
  height: 22px;
}

.org-skeleton-copy {
  width: min(68vw, 360px);
}

.org-detail-loading {
  min-height: 440px;
}

.org-summary-skeleton .skeleton:first-child {
  width: 72px;
  height: 10px;
}

.org-summary-skeleton .skeleton:last-child {
  width: 46px;
  height: 18px;
}

.org-table-skeleton {
  display: grid;
  gap: 12px;
  border: 1px solid var(--dashboard-border);
  border-radius: 10px;
  padding: 16px;
}

.org-table-skeleton .skeleton:nth-child(1) {
  width: 34%;
}

.org-table-skeleton .skeleton:nth-child(2) {
  width: 82%;
}

.org-table-skeleton .skeleton:nth-child(3) {
  width: 74%;
}

.org-inline-loading {
  position: relative;
  top: auto;
  margin: -2px 0 14px;
}

.org-detail-refreshing {
  opacity: 0.72;
  transition: opacity 160ms ease;
}

@keyframes org-panel-enter {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

.usage-panel {
  position: relative;
  overflow: visible;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  padding: 18px 0 6px;
}

.usage-page {
  position: relative;
}

.usage-page-actions {
  display: flex;
  justify-content: flex-end;
  margin: 0 0 10px;
}

.page-loading-bar {
  position: sticky;
  top: var(--topbar-h);
  z-index: 5;
  height: 2px;
  margin: -2px 0 14px;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in srgb, var(--dashboard-accent) 12%, transparent);
}

.page-loading-bar::after {
  content: '';
  display: block;
  width: 38%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(
    90deg,
    transparent,
    color-mix(in srgb, var(--dashboard-accent) 88%, #ffffff 12%),
    transparent
  );
  animation: loading-bar-slide 1.05s ease-in-out infinite;
}

@keyframes loading-bar-slide {
  from {
    transform: translateX(-110%);
  }
  to {
    transform: translateX(285%);
  }
}

.loading-surface {
  position: relative;
}

.loading-surface::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  border-radius: inherit;
  background: linear-gradient(
    110deg,
    transparent 0%,
    color-mix(in srgb, var(--dashboard-card) 62%, transparent) 42%,
    color-mix(in srgb, var(--dashboard-accent) 10%, transparent) 50%,
    color-mix(in srgb, var(--dashboard-card) 62%, transparent) 58%,
    transparent 100%
  );
  background-size: 220% 100%;
  animation: loading-surface-shimmer 1.3s ease-in-out infinite;
}

@keyframes loading-surface-shimmer {
  from {
    background-position: 130% 0;
  }
  to {
    background-position: -90% 0;
  }
}

.usage-loading-icon {
  --usage-loader-size: 28px;
  position: relative;
  display: inline-grid;
  place-items: center;
  width: var(--usage-loader-size);
  height: var(--usage-loader-size);
  color: var(--dashboard-accent);
  vertical-align: middle;
}

.usage-loading-icon.compact {
  --usage-loader-size: 18px;
}

.usage-loading-icon > span {
  position: absolute;
  border-radius: 999px;
}

.usage-loading-icon > span:nth-child(1) {
  width: 100%;
  height: 100%;
  border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
}

.usage-loading-icon > span:nth-child(2) {
  width: 100%;
  height: 100%;
  border: 2px solid transparent;
  border-top-color: currentColor;
  border-right-color: color-mix(in srgb, currentColor 48%, transparent);
  animation: usage-loader-spin 0.8s linear infinite;
}

@keyframes usage-loader-spin {
  to {
    transform: rotate(360deg);
  }
}

.usage-page-skeleton {
  pointer-events: none;
}

.usage-metric-skeleton {
  width: min(100%, 138px);
  height: 28px;
  border-radius: var(--radius-md);
}

.usage-stat-label-skeleton {
  width: 108px;
  height: 11px;
  margin: 0 0 12px;
}

.usage-stat-sub-skeleton {
  width: 132px;
  height: 10px;
  margin: 10px 0 0;
}

.stat-box.is-refreshing {
  position: relative;
}

.stat-box.is-refreshing::after,
.usage-chart-shell.is-refreshing::after,
.hbar-list.is-refreshing::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  background: linear-gradient(
    110deg,
    transparent 0%,
    color-mix(in srgb, var(--dashboard-card) 24%, transparent) 44%,
    color-mix(in srgb, var(--dashboard-accent) 7%, transparent) 52%,
    transparent 72%
  );
  background-size: 220% 100%;
  animation: loading-surface-shimmer 1.3s ease-in-out infinite;
}

.usage-chart-shell.is-refreshing,
.hbar-list.is-refreshing {
  position: relative;
}

.usage-chart-skeleton {
  display: flex;
  align-items: flex-end;
  gap: 18px;
  width: 100%;
  height: 100%;
}

.usage-chart-skeleton-group {
  flex: 1 1 0;
  display: flex;
  min-width: 48px;
  height: calc(100% - 18px);
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.usage-chart-skeleton-bar {
  width: min(54px, 72%);
  min-height: 22px;
  border-radius: 6px 6px 2px 2px;
}

.usage-chart-skeleton-label {
  width: 42px;
  height: 10px;
  border-radius: 999px;
}

.model-breakdown-skeleton {
  display: grid;
  gap: 8px;
  padding: 8px 0;
}

.model-breakdown-skeleton-row {
  min-height: 26px;
}

.hbar-name-skeleton {
  width: min(100%, 180px);
}

.hbar-track-skeleton {
  width: 100%;
  height: 14px;
  border-radius: 4px;
}

.hbar-cost-skeleton {
  width: 72px;
  justify-self: end;
}

.usage-filter-card {
  margin-top: 22px;
  padding: 10px 0 0;
}

#usageFilterStrip.usage-filter-card {
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

[data-theme='light'] #usageFilterStrip.usage-filter-card {
  background: transparent;
}

.usage-filter-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 38px;
}

.usage-filter-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid color-mix(in srgb, var(--dashboard-border) 88%, transparent);
  border-radius: var(--radius-md);
  background: var(--dashboard-card);
  color: var(--dashboard-fg);
  font: inherit;
  font-weight: var(--font-weight-semibold);
  cursor: pointer;
  box-shadow: 0 1px 2px rgba(20, 17, 12, 0.04);
  transition:
    background-color 0.15s ease,
    border-color 0.15s ease,
    color 0.15s ease,
    transform 0.15s ease;
}

.usage-filter-toggle:hover,
.usage-filter-toggle:focus-visible {
  border-color: color-mix(in srgb, var(--dashboard-accent) 26%, var(--dashboard-border));
  color: var(--dashboard-accent-fg);
  transform: translateY(-1px);
}

.usage-filter-toggle .toggle-glyph {
  display: inline-block;
  color: var(--dashboard-muted);
  transition: transform 120ms ease;
}

#usageFilterStrip.expanded .usage-filter-toggle .toggle-glyph {
  transform: rotate(180deg);
}

.usage-filter-chips {
  display: flex;
  align-items: center;
  gap: 0;
  min-width: 0;
  flex: 1 1 auto;
  min-height: 24px;
  overflow-x: auto;
  scrollbar-width: none;
}

.usage-filter-chips::-webkit-scrollbar {
  display: none;
}

.usage-filter-chip {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  max-width: 190px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  border: 0;
  border-radius: 0;
  padding: 0;
  background: transparent;
  color: var(--dashboard-muted);
  font-size: var(--font-size-sm);
  line-height: 1.35;
}

.usage-filter-chip + .usage-filter-chip::before {
  content: '/';
  margin: 0 8px;
  color: color-mix(in srgb, var(--dashboard-muted) 54%, transparent);
}

.usage-filter-card .trace-filter-grid {
  grid-template-columns: repeat(4, minmax(180px, 1fr));
  align-items: end;
  gap: 16px 14px;
  padding: 18px 0 2px;
}

.usage-filter-card .trace-filter-grid .form-group {
  min-width: 0;
}

.usage-datetime-control {
  display: grid;
  grid-template-columns: minmax(150px, 1fr) 1px minmax(96px, 0.48fr);
  align-items: center;
  min-height: 42px;
  overflow: hidden;
  border: 1px solid var(--dashboard-border);
  border-radius: 10px;
  background: var(--dashboard-input-bg);
  transition:
    border-color 0.15s,
    box-shadow 0.15s;
}

.usage-datetime-control:focus-within {
  border-color: var(--dashboard-accent);
  box-shadow: 0 0 0 3px var(--dashboard-input-focus);
}

.usage-picker-segment {
  position: relative;
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  min-height: 40px;
  padding: 0 12px;
  color: var(--dashboard-muted);
  cursor: pointer;
  font-size: var(--font-size-base);
  line-height: 1;
}

.usage-picker-segment.has-value {
  color: var(--dashboard-fg);
}

.usage-picker-segment.is-disabled {
  cursor: not-allowed;
  opacity: 0.54;
}

.usage-picker-icon {
  display: inline-flex;
  flex: 0 0 auto;
  color: var(--dashboard-muted);
}

.usage-picker-icon svg {
  width: 16px;
  height: 16px;
  stroke-width: 1.8;
}

.usage-picker-value {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.usage-picker-native {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  opacity: 0;
  cursor: pointer;
}

.usage-picker-native:disabled {
  cursor: not-allowed;
}

.usage-datetime-separator {
  width: 1px;
  height: 22px;
  background: color-mix(in srgb, var(--dashboard-border) 82%, transparent);
}

.usage-filter-actions {
  display: flex;
  align-items: center;
  align-self: end;
  gap: 8px;
  min-width: 0;
  min-height: 42px;
}

.usage-filter-actions .btn-sm {
  min-height: 42px;
  padding-inline: 16px;
}

.usage-filter-status {
  min-width: 0;
  color: var(--dashboard-muted);
  font-size: var(--font-size-sm);
  white-space: nowrap;
}

.usage-filter-toggle-skeleton {
  width: 92px;
  height: 34px;
  border-radius: var(--radius-md);
}

.usage-filter-chip-skeleton {
  width: 112px;
  height: 28px;
  border-radius: 7px;
}

.usage-page-size-control {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: 0;
  color: var(--dashboard-muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0;
  text-transform: none;
  white-space: nowrap;
}

.usage-page-size-control span {
  color: var(--dashboard-muted);
}

.usage-page-size-control select {
  width: auto;
  min-width: 42px;
  min-height: 24px;
  padding: 0 16px 0 2px;
  border: 0;
  border-radius: 4px;
  background: transparent;
  box-shadow: none;
  color: var(--dashboard-fg);
  font-size: var(--font-size-sm);
}

.usage-page-size-control select:focus {
  border-color: transparent;
  box-shadow: none;
}

.usage-page-size-control select:focus-visible {
  outline: 2px solid var(--dashboard-accent);
  outline-offset: 2px;
}

.usage-panel + .usage-panel,
.usage-panel + .card,
#usageFilterStrip + .usage-panel {
  margin-top: 18px;
}

.usage-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 12px;
}

.usage-panel h3 {
  color: var(--dashboard-fg);
  font-size: var(--font-size-md);
  margin: 0;
}

.usage-panel h3::after {
  content: '';
  display: block;
  width: 32px;
  height: 2px;
  margin-top: 8px;
  background: var(--dashboard-accent);
}

.usage-panel-sub {
  display: block;
  margin-top: 7px;
  color: var(--dashboard-muted);
  font-size: var(--font-size-sm);
}

.chart-window-controls {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.icon-btn.btn-sm {
  display: inline-grid;
  place-items: center;
  width: 36px;
  min-width: 36px;
  padding: 0;
}

.icon-btn svg {
  width: 16px;
  height: 16px;
  stroke-width: 2.2;
}

.icon-btn:disabled {
  cursor: not-allowed;
  opacity: 0.48;
  transform: none;
}

.usage-chart-shell {
  overflow-x: auto;
  overflow-y: visible;
  padding: 18px 8px 34px;
}

.chart-container {
  min-width: min(760px, 100%);
  height: 300px;
  display: flex;
  gap: 18px;
  align-items: end;
  padding: 10px 24px 30px;
  border: 1px solid var(--dashboard-border);
  border-radius: 14px;
  background: var(--dashboard-card);
  box-shadow: var(--portal-shadow-tight);
  overflow: visible;
}

.usage-visual-loading {
  align-self: stretch;
  display: grid;
  place-items: center;
  width: 100%;
  min-height: 128px;
  color: var(--dashboard-accent);
}

[data-theme='light'] .chart-container {
  background: rgba(255, 253, 248, 0.92);
}

.bar-group {
  flex: 1 1 0;
  min-width: 64px;
  display: flex;
  flex-direction: column;
  align-items: center;
  height: calc(100% - 28px);
  justify-content: flex-end;
  position: relative;
}

.bar {
  width: min(54px, 72%);
  background: var(--usage-data-fill);
  border-radius: 6px 6px 2px 2px;
  min-height: 2px;
  transition:
    background-color 0.16s ease,
    height 0.22s ease,
    transform 0.16s ease;
}

.bar:hover,
.bar:focus-visible {
  background: var(--usage-data-fill-hover);
  outline: none;
  transform: translateY(-2px);
}

.bar-label {
  width: auto;
  margin-top: 8px;
  color: var(--dashboard-muted);
  font-size: var(--font-size-sm);
  text-align: center;
  white-space: nowrap;
  transform: none;
}

.bar-tooltip.visible {
  display: block;
  border-radius: var(--radius-md);
  padding: 6px 9px;
  box-shadow: 0 12px 30px rgba(18, 15, 10, 0.18);
  transform: translate(-50%, -100%);
}

.bar-label {
  width: auto;
  min-height: 18px;
  margin-top: 8px;
  transform: none;
  color: var(--dashboard-muted);
  font-size: var(--font-size-sm);
  text-align: center;
}

.bar-tooltip {
  position: absolute;
  bottom: auto;
  left: 0;
  transform: translate(-50%, -100%);
  max-width: min(280px, calc(100vw - 32px));
  min-height: 28px;
  display: block;
  z-index: 10000;
  padding: 7px 12px;
  border-radius: var(--radius-md);
  box-shadow: var(--dashboard-shadow);
  font-size: var(--font-size-sm);
  line-height: 1.2;
  white-space: nowrap;
}

.bar-tooltip.visible {
  display: block;
}

.bar:hover .bar-tooltip {
  display: none;
}

.hbar-list {
  padding: 14px 0 4px;
}

.hbar-row {
  grid-template-columns: minmax(180px, 240px) minmax(180px, 1fr) 96px;
}

.hbar-bar-track {
  background: var(--usage-data-track);
}

@media (max-width: 760px) {
  .org-directory {
    max-width: none;
  }

  .org-directory .org-list {
    grid-template-columns: 1fr;
  }

  .portal-loading-grid,
  .loading-form-grid {
    grid-template-columns: 1fr;
  }

  .usage-panel {
    padding-top: 12px;
  }

  .chart-container {
    min-width: 640px;
  }
}

/* ==========================================================================
   Activity tab — Gantt session viewer (Next-2.5)
   ========================================================================== */
.activity-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 16px;
  align-items: stretch;
  min-height: 400px;
}
.activity-sessions {
  border: 1px solid var(--dashboard-border);
  border-radius: 6px;
  overflow-y: auto;
  max-height: 600px;
  background: var(--dashboard-card);
}
.activity-session-card {
  padding: 10px 12px;
  border-bottom: 1px solid var(--dashboard-border);
  cursor: pointer;
  outline: none;
}
.activity-session-card:hover,
.activity-session-card:focus-visible {
  background: var(--dashboard-hover);
}
.activity-session-card.active {
  background: rgba(99, 102, 241, 0.1);
  border-left: 3px solid var(--dashboard-accent);
}
.activity-session-id {
  font-family: ui-monospace, SFMono-Regular, monospace;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--dashboard-fg);
  display: flex;
  gap: 6px;
  align-items: center;
}
.activity-session-meta {
  display: flex;
  gap: 10px;
  margin-top: 4px;
  font-size: var(--font-size-sm);
  color: var(--dashboard-secondary);
  flex-wrap: wrap;
}
.activity-gantt {
  border: 1px solid var(--dashboard-border);
  border-radius: 6px;
  background: var(--dashboard-card);
  padding: 12px 14px;
  overflow-x: auto;
}
.activity-gantt-header {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--dashboard-border);
  margin-bottom: 10px;
}
.activity-gantt-title {
  font-family: ui-monospace, SFMono-Regular, monospace;
  font-size: var(--font-size-base);
  color: var(--dashboard-fg);
}
.activity-gantt-axis {
  display: flex;
  justify-content: space-between;
  font-size: var(--font-size-sm);
  color: var(--dashboard-secondary);
  gap: 16px;
}
.activity-gantt-tracks {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.activity-track {
  display: grid;
  grid-template-columns: 28px 1fr 220px;
  align-items: center;
  gap: 8px;
  padding: 4px 0;
  cursor: pointer;
  outline: none;
  border-radius: 4px;
}
.activity-track:hover,
.activity-track:focus-visible {
  background: var(--dashboard-hover);
}
.activity-track-num {
  font-family: ui-monospace, SFMono-Regular, monospace;
  font-size: var(--font-size-sm);
  color: var(--dashboard-muted);
  text-align: right;
}
.activity-track-rail {
  position: relative;
  height: 14px;
  background: var(--dashboard-subtle-bg);
  border-radius: 3px;
}
.activity-track-bar {
  position: absolute;
  top: 1px;
  bottom: 1px;
  border-radius: 2px;
  min-width: 2px;
}
.activity-track-label {
  font-size: var(--font-size-sm);
  color: var(--dashboard-secondary);
  font-family: ui-monospace, SFMono-Regular, monospace;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.activity-empty,
.activity-skeleton,
.activity-error,
.activity-truncated {
  padding: 16px;
  font-size: var(--font-size-sm);
  color: var(--dashboard-secondary);
}
.activity-error {
  color: var(--dashboard-danger);
}
.activity-truncated {
  background: rgba(245, 158, 11, 0.08);
  border-left: 3px solid #f59e0b;
  margin-bottom: 10px;
  border-radius: 0 4px 4px 0;
}
/* Mobile fallback list — hidden on desktop, shown <900px in place of
   the two-column Gantt. The desktop layout is unreadable below 900px
   (Gantt bars become too narrow), and a card list is the ergonomic
   shape for touch. */
.activity-mobile-list {
  display: none;
}
@media (max-width: 899px) {
  .activity-layout {
    display: none;
  }
  .activity-mobile-list {
    display: block;
    border: 1px solid var(--dashboard-border);
    border-radius: 6px;
    background: var(--dashboard-card);
  }
}

/* ==========================================================================
   Group-by-session buckets on Traces tab (Next-2.5)
   ========================================================================== */
.trace-groupby-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-size-base);
  cursor: pointer;
  user-select: none;
}
.trace-bucket-header {
  background: rgba(99, 102, 241, 0.06);
  cursor: pointer;
  outline: none;
}
.trace-bucket-header:hover,
.trace-bucket-header:focus-visible {
  background: rgba(99, 102, 241, 0.12);
}
.trace-bucket-header td {
  padding: 8px 10px;
  font-size: var(--font-size-sm);
  border-top: 1px solid var(--dashboard-border);
}
.trace-bucket-label {
  font-weight: var(--font-weight-medium);
}
.trace-bucket-chev {
  display: inline-block;
  width: 1em;
  text-align: center;
  color: var(--dashboard-secondary);
}

/* ==========================================================================
   TOASTS (showToast in js/app.js)
   ========================================================================== */
#toast-container {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 300;
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: min(420px, calc(100vw - 48px));
}

.toast {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 16px;
  background: var(--dashboard-card);
  border: 1px solid var(--dashboard-border);
  border-radius: 10px;
  box-shadow: var(--dashboard-shadow);
  font-size: var(--font-size-base);
  color: var(--dashboard-fg);
  cursor: pointer;
  animation: toast-enter 0.2s ease-out;
  transition:
    opacity 0.25s,
    transform 0.25s;
}

@keyframes toast-enter {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

.toast-leaving {
  opacity: 0;
  transform: translateY(8px);
}

.toast-icon {
  flex-shrink: 0;
  display: inline-flex;
}
.toast-icon svg {
  width: 16px;
  height: 16px;
  margin-top: 1px;
}
.toast-success .toast-icon {
  color: var(--dashboard-success);
}
.toast-error .toast-icon {
  color: var(--dashboard-danger);
}
.toast-info .toast-icon {
  color: var(--dashboard-accent);
}
.toast-message {
  overflow-wrap: anywhere;
}

/* Confirm dialog (confirmDialog in js/app.js) */
.modal-confirm {
  max-width: 420px;
}
.confirm-dialog-message {
  font-size: var(--font-size-base);
  line-height: 1.6;
  color: var(--dashboard-secondary);
  white-space: pre-line;
}

/* Prompt dialog (promptDialog in js/app.js) */
.modal-prompt {
  max-width: 420px;
}
.prompt-dialog-message {
  font-size: var(--font-size-base);
  line-height: 1.6;
  color: var(--dashboard-secondary);
  margin-bottom: 16px;
  white-space: pre-line;
}

/* ==========================================================================
   SKELETONS & EMPTY/ERROR STATES (helpers in js/app.js)
   ========================================================================== */
.skeleton {
  display: inline-block;
  height: 12px;
  border-radius: 6px;
  background: linear-gradient(
    90deg,
    var(--dashboard-hover) 25%,
    var(--dashboard-border) 50%,
    var(--dashboard-hover) 75%
  );
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.4s ease-in-out infinite;
}

@keyframes skeleton-shimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .skeleton {
    animation: none;
  }
  .org-directory-transition,
  .org-detail-transition {
    animation: none;
  }
  .org-directory .org-list-item,
  .org-detail-refreshing,
  .stat-box.is-refreshing::after,
  .usage-chart-shell.is-refreshing::after,
  .hbar-list.is-refreshing::after,
  .modal-close,
  .back-link-btn,
  .back-link-btn svg {
    transition: none;
    animation: none;
  }
  .sidebar,
  .main {
    transition: none;
  }
}

.skeleton-line {
  display: block;
  margin: 10px 0;
}

.empty-state {
  padding: 28px 16px;
  text-align: center;
  color: var(--dashboard-muted);
}

.empty-state-title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--dashboard-secondary);
  margin-bottom: 4px;
}

.empty-state-title.error-state-title {
  color: var(--dashboard-danger-fg);
}

.empty-state-hint {
  font-size: var(--font-size-sm);
  margin-bottom: 10px;
}

.page-error-state {
  display: grid;
  gap: 12px;
  align-content: center;
  min-height: 280px;
  padding: 32px 24px;
  border: 1px solid var(--dashboard-border);
  border-radius: 6px;
  background: var(--dashboard-card);
  text-align: center;
}

.portal-loading-card {
  position: relative;
  max-width: 980px;
  overflow: hidden;
  padding: 24px 28px;
}

.portal-loading-card .page-loading-bar {
  position: relative;
  top: auto;
  margin: -24px -28px 22px;
}

.portal-loading-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
}

.portal-loading-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.portal-loading-tile {
  display: grid;
  gap: 10px;
  min-height: 92px;
  border: 1px solid var(--dashboard-border);
  border-radius: 10px;
  padding: 16px;
  background: color-mix(in srgb, var(--dashboard-card) 88%, var(--dashboard-bg));
}

.portal-loading-title {
  width: min(46vw, 260px);
  height: 22px;
}

.portal-loading-pill,
.skeleton-pill {
  width: 58px;
  height: 28px;
  border-radius: 999px;
}

.loading-group {
  pointer-events: none;
}

.loading-form-grid {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(200px, 1fr) minmax(220px, 1fr) 120px;
  align-items: end;
  gap: 16px;
}

.loading-form-grid .skeleton {
  height: 42px;
  border-radius: var(--radius-md);
}

.skeleton-heading {
  width: min(44vw, 220px);
  height: 18px;
}

.skeleton-copy {
  width: min(58vw, 320px);
  margin-top: 10px;
}

.skeleton-link {
  width: 84px;
}

.skeleton-name {
  width: min(72%, 260px);
}

.skeleton-code {
  width: min(88%, 360px);
}

.skeleton-meta {
  width: 92px;
}

.skeleton-action {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  justify-self: end;
}

.resource-row-skeleton:hover,
.endpoint-row-skeleton:hover {
  background: color-mix(in srgb, var(--dashboard-card) 92%, var(--dashboard-bg));
}

.resource-row-skeleton .resource-meta > span::after,
.endpoint-row-skeleton .endpoint-meta > span::after {
  content: none;
  margin-left: 0;
}

.endpoint-title-skeleton {
  width: min(50vw, 280px);
  height: 24px;
}

.skeleton-tab {
  width: 76px;
  height: 34px;
  border-radius: 999px;
}

.endpoint-detail-table-skeleton {
  margin-top: 18px;
}

.endpoint-detail-table-skeleton .resource-row {
  grid-template-columns: minmax(120px, 0.7fr) minmax(220px, 1fr) minmax(120px, 0.8fr);
}

.drawer-loading {
  display: grid;
  place-items: center;
  min-height: 180px;
  color: var(--dashboard-accent);
}

.team-table-header,
.trace-strip-head,
.button-row,
.modal-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.team-table-header,
.trace-strip-head {
  justify-content: space-between;
  margin-bottom: 12px;
}

.org-list-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}

.org-list-header h3 {
  margin-bottom: 4px;
}

.org-list-header p {
  margin: 0;
  font-size: var(--font-size-base);
}

.org-list {
  display: grid;
  gap: 8px;
}

.org-list-item {
  width: 100%;
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  border: 1px solid var(--dashboard-border);
  border-radius: var(--radius-md);
  background: var(--dashboard-card);
  color: var(--dashboard-fg);
  padding: 11px 12px;
  text-align: left;
  cursor: pointer;
  transition:
    background 0.12s ease,
    border-color 0.12s ease;
}

.org-list-item:hover,
.org-list-item:focus-visible {
  background: var(--dashboard-hover);
  border-color: rgba(99, 102, 241, 0.42);
  outline: none;
}

.org-list-icon {
  width: 32px;
  height: 32px;
  border-radius: 7px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(99, 102, 241, 0.12);
  color: var(--dashboard-accent-fg);
  font-weight: var(--font-weight-bold);
}

.org-list-main {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.org-list-name {
  overflow: hidden;
  color: var(--dashboard-fg);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.org-list-meta,
.org-list-open {
  color: var(--dashboard-muted);
  font-size: var(--font-size-sm);
}

.back-link-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  width: fit-content;
  min-height: 34px;
  margin-bottom: 18px;
  border: 1px solid color-mix(in srgb, var(--dashboard-border) 82%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--dashboard-card) 88%, transparent);
  color: var(--dashboard-secondary);
  cursor: pointer;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  line-height: 1;
  padding: 0 12px 0 9px;
  box-shadow: 0 1px 2px rgba(20, 17, 12, 0.04);
  transition:
    background-color 150ms ease,
    border-color 150ms ease,
    color 150ms ease,
    transform 150ms cubic-bezier(0.22, 1, 0.36, 1);
}

.back-link-btn svg {
  width: 16px;
  height: 16px;
  color: var(--dashboard-muted);
  stroke-width: 2.2;
  transition:
    color 150ms ease,
    transform 150ms cubic-bezier(0.22, 1, 0.36, 1);
}

.back-link-btn:hover,
.back-link-btn:focus-visible {
  border-color: color-mix(in srgb, var(--dashboard-accent) 26%, var(--dashboard-border));
  background: color-mix(in srgb, var(--dashboard-accent) 7%, var(--dashboard-card));
  color: var(--dashboard-accent-fg);
  transform: translateY(-1px);
}

.back-link-btn:hover svg,
.back-link-btn:focus-visible svg {
  color: var(--dashboard-accent-fg);
  transform: translateX(-2px);
}

.back-link-btn:focus-visible {
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--dashboard-accent) 18%, transparent),
    0 1px 2px rgba(20, 17, 12, 0.04);
  outline: none;
}

.back-link-btn:active {
  transform: translateY(0);
}

.org-detail-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.org-detail-title-block {
  min-width: 0;
}

.org-detail-title-block h3 {
  margin: 0 0 4px;
  color: var(--dashboard-fg);
  font-size: var(--font-size-lg);
}

.org-detail-title-block p {
  margin: 0;
  font-size: var(--font-size-base);
}

.org-detail-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.org-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 20px;
}

.org-summary-item {
  min-width: 0;
  display: grid;
  gap: 3px;
  border: 1px solid var(--dashboard-border);
  border-radius: var(--radius-md);
  background: var(--dashboard-subtle-bg);
  padding: 9px 12px;
}

.org-summary-item span {
  color: var(--dashboard-muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.org-summary-item strong {
  overflow: hidden;
  color: var(--dashboard-fg);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-bold);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.col-check input[type='checkbox'] {
  width: 16px;
  height: 16px;
  accent-color: var(--dashboard-accent);
  cursor: pointer;
}

.team-inline-form {
  display: flex;
  align-items: center;
  gap: 8px;
}

.team-inline-form input {
  width: 220px;
  padding: 6px 10px;
  border-radius: 6px;
  border: 1px solid var(--dashboard-border);
  background: var(--dashboard-bg);
  color: var(--dashboard-fg);
  font-size: var(--font-size-base);
}

.table-section-label {
  margin-top: 28px;
  margin-bottom: 12px;
}

.card h3.table-label,
.table-label {
  color: var(--dashboard-secondary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.06em;
  line-height: 1.2;
  margin: 0;
  text-transform: uppercase;
}

.card h3.table-section-label {
  margin: 28px 0 12px;
}

.inline-warning {
  background: rgba(234, 179, 8, 0.1);
  border: 1px solid rgba(234, 179, 8, 0.3);
  border-radius: 6px;
  padding: 10px 12px;
  color: var(--dashboard-warning-fg);
  font-size: var(--font-size-sm);
  margin-top: 12px;
}

.compact-warning {
  margin-top: 10px;
  margin-bottom: 0;
}

.scope-badge {
  display: inline-block;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  padding: 2px 8px;
  border-radius: 4px;
  letter-spacing: 0.3px;
  margin-left: 10px;
  text-transform: uppercase;
}

.scope-badge.personal {
  background: rgba(59, 130, 246, 0.15);
  color: var(--dashboard-info-fg);
  border: 1px solid rgba(59, 130, 246, 0.3);
}

.scope-badge.org {
  background: rgba(34, 197, 94, 0.15);
  color: var(--dashboard-success-fg);
  border: 1px solid rgba(34, 197, 94, 0.3);
}

.chart-container {
  min-width: min(760px, 100%);
  height: 300px;
  display: flex;
  align-items: flex-end;
  gap: 18px;
  padding: 10px 24px 30px;
  border: 1px solid var(--dashboard-border);
  border-radius: 14px;
  background: var(--dashboard-card);
  box-shadow: var(--portal-shadow-tight);
  position: relative;
  overflow: visible;
}

.chart-empty {
  color: var(--dashboard-muted);
  width: 100%;
  text-align: center;
  align-self: center;
}

.bar-group {
  flex: 1 1 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 64px;
  height: calc(100% - 28px);
  justify-content: flex-end;
  position: relative;
}

.bar {
  width: min(54px, 72%);
  background: var(--usage-data-fill);
  border-radius: 6px 6px 2px 2px;
  min-height: 2px;
  transition:
    background-color 0.16s ease,
    height 0.22s ease,
    transform 0.16s ease;
  position: relative;
}

.bar:hover,
.bar:focus-visible {
  background: var(--usage-data-fill-hover);
  outline: none;
  transform: translateY(-2px);
}

.bar-label {
  width: auto;
  margin-top: 8px;
  color: var(--dashboard-muted);
  font-size: var(--font-size-sm);
  text-align: center;
  white-space: nowrap;
  transform: none;
}

.bar-tooltip {
  position: absolute;
  background: var(--dashboard-sidebar);
  border: 1px solid var(--dashboard-border);
  padding: 6px 9px;
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  color: var(--dashboard-fg);
  white-space: nowrap;
  display: none;
  z-index: 10;
  pointer-events: none;
  box-shadow: 0 12px 30px rgba(18, 15, 10, 0.18);
}

.bar-tooltip.visible {
  display: block;
  transform: translate(-50%, -100%);
}

.usage-chart-shell {
  position: relative;
  overflow-x: auto;
  padding: 12px 20px 52px;
  scrollbar-gutter: stable;
}

.hbar-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 8px 0;
}

.hbar-row {
  display: grid;
  grid-template-columns: 200px 1fr 100px;
  gap: 10px;
  align-items: center;
  font-size: var(--font-size-base);
}

.hbar-row.hbar-other {
  opacity: 0.7;
}

.hbar-name {
  color: var(--dashboard-fg);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.hbar-bar-track {
  background: var(--usage-data-track);
  border-radius: 4px;
  height: 14px;
  position: relative;
  overflow: hidden;
}

.hbar-bar-fill {
  background: var(--usage-data-fill-strong);
  height: 100%;
  border-radius: 4px;
}

.hbar-cost,
.cost-cell {
  color: var(--dashboard-warning);
  font-weight: var(--font-weight-semibold);
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.token-cell,
.ts-cell,
.cache-read,
.cache-write {
  color: var(--dashboard-muted);
  font-variant-numeric: tabular-nums;
}

.cache-read {
  color: var(--dashboard-success);
}

.cache-write {
  color: var(--dashboard-accent);
}

.savings-badge {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
}

.savings-high {
  background: rgba(34, 197, 94, 0.12);
  color: var(--dashboard-success);
}

.savings-mid {
  background: rgba(245, 158, 11, 0.12);
  color: var(--dashboard-warning);
}

.savings-low {
  color: var(--dashboard-muted);
}

.model-pill {
  background: rgba(99, 102, 241, 0.1);
  color: var(--dashboard-accent-fg);
  padding: 2px 8px;
  border-radius: 4px;
  font-size: var(--font-size-sm);
  border: 1px solid rgba(99, 102, 241, 0.25);
  white-space: nowrap;
  max-width: 240px;
  overflow: hidden;
  text-overflow: ellipsis;
  display: inline-block;
  vertical-align: middle;
}

.auth-pill {
  padding: 2px 8px;
  border-radius: 4px;
  font-size: var(--font-size-sm);
  border: 1px solid;
  white-space: nowrap;
}

.auth-vk {
  background: rgba(99, 102, 241, 0.1);
  color: var(--dashboard-accent-fg);
  border-color: rgba(99, 102, 241, 0.25);
}

.auth-oauth {
  background: rgba(34, 197, 94, 0.1);
  color: var(--dashboard-success);
  border-color: rgba(34, 197, 94, 0.25);
}

.auth-byok {
  background: rgba(245, 158, 11, 0.1);
  color: var(--dashboard-warning);
  border-color: rgba(245, 158, 11, 0.25);
}

.auth-unknown {
  color: var(--dashboard-muted);
  border-color: var(--dashboard-border);
}

.usage-history-shell {
  position: relative;
}

.usage-history-scroll {
  max-height: 560px;
  overflow: auto;
  border: 1px solid var(--dashboard-border);
  border-radius: 10px;
}

.usage-history-scroll table {
  border: 0;
  border-collapse: separate;
  border-spacing: 0;
  min-width: 960px;
}

.usage-history-scroll thead th {
  position: sticky;
  top: 0;
  z-index: 4;
  background: color-mix(in srgb, var(--dashboard-sidebar) 94%, var(--dashboard-card));
  box-shadow: 0 1px 0 var(--dashboard-border);
}

.usage-history-scroll tbody td {
  border-bottom: 1px solid var(--dashboard-border);
}

.usage-history-scroll tbody tr:last-child td {
  border-bottom: 0;
}

.usage-history-scroll tbody.is-pending {
  opacity: 0.58;
}

.usage-history-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: max-content;
  max-width: calc(100% - 24px);
  transform: translate(-50%, -50%);
  padding: 8px 12px;
  border: 1px solid color-mix(in srgb, var(--dashboard-border) 74%, var(--dashboard-accent));
  border-radius: 999px;
  background: color-mix(in srgb, var(--dashboard-card) 92%, var(--dashboard-bg));
  box-shadow: 0 14px 34px rgba(18, 15, 10, 0.16);
  color: var(--dashboard-secondary);
  font-size: var(--font-size-sm);
  pointer-events: none;
}

.usage-history-skeleton-row td {
  height: 45px;
}

.usage-history-cell-skeleton {
  display: block;
  height: 14px;
  margin: 0;
  border-radius: 999px;
}

.usage-history-cell-skeleton.wide {
  width: 118px;
}

.usage-history-cell-skeleton.medium {
  width: 96px;
}

.usage-history-cell-skeleton.short {
  width: 62px;
}

.usage-pager,
.pg-bar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  padding-top: 12px;
  color: var(--dashboard-muted);
  font-size: var(--font-size-sm);
}

.usage-pager-label,
.pg-info {
  min-width: 54px;
  text-align: center;
  font-variant-numeric: tabular-nums;
}

.detail-tabs {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--dashboard-border);
  margin-bottom: 16px;
}

.detail-tab {
  padding: 10px 16px;
  color: var(--dashboard-secondary);
  cursor: pointer;
  border: 0;
  border-bottom: 2px solid transparent;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  background: none;
}

.detail-tab.active {
  color: var(--dashboard-primary);
  border-bottom-color: var(--dashboard-primary);
}

.metric-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.metric-tile {
  background: var(--dashboard-bg);
  border: 1px solid var(--dashboard-border);
  border-radius: 6px;
  padding: 12px 14px;
}

.metric-tile-label {
  font-size: var(--font-size-sm);
  color: var(--dashboard-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.metric-tile-value {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  margin-top: 4px;
  font-variant-numeric: tabular-nums;
}

.base-url-row {
  display: flex;
  align-items: stretch;
  gap: 8px;
  margin-top: 8px;
}

.base-url-row input {
  flex: 1;
  font-family: var(--font-mono);
  font-size: var(--font-size-base);
}

.provider-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 8px;
}

.provider-row {
  border: 1px solid var(--dashboard-border);
  border-radius: 6px;
  padding: 12px;
  background: var(--dashboard-bg);
}

.provider-row-head {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 6px;
}

.provider-row-name {
  font-weight: var(--font-weight-semibold);
}

.provider-row-hint {
  font-size: var(--font-size-sm);
  color: var(--dashboard-muted);
}

.activity-mobile-list {
  display: grid;
  gap: 12px;
}

.activity-session-requests {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.trace-export-anchor {
  position: relative;
  display: inline-block;
}

.trace-export-popover {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 260px;
  background: var(--dashboard-bg);
  border: 1px solid var(--dashboard-border);
  border-radius: 6px;
  padding: 12px;
  box-shadow: var(--dashboard-shadow);
  z-index: 50;
  font-size: var(--font-size-base);
}

.trace-groupby-label {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--dashboard-secondary);
  font-size: var(--font-size-base);
}

.trace-row,
.trace-bucket-header {
  cursor: pointer;
}

.trace-row:hover td,
.trace-bucket-header:hover td {
  background: var(--dashboard-hover);
}

.request-id {
  font-family: var(--font-mono);
  font-size: var(--font-size-sm);
  color: var(--dashboard-secondary);
}

.muted-link {
  color: var(--dashboard-secondary);
  text-decoration: none;
}

.breadcrumb-separator {
  color: var(--dashboard-secondary);
  margin: 0 8px;
}

.section-divider {
  margin: 24px 0 18px;
  border: 0;
}

.obs-drawer-overlay {
  position: fixed;
  inset: 0;
  display: none;
  justify-content: flex-end;
  background: rgba(15, 23, 42, 0.35);
  z-index: 400;
}

.obs-drawer-overlay.active {
  display: flex;
}

.obs-drawer {
  width: min(720px, 100vw);
  height: 100%;
  overflow: auto;
  background: var(--dashboard-card);
  border-left: 1px solid var(--dashboard-border);
  box-shadow: var(--dashboard-shadow);
  padding: 18px;
}

.json-pre {
  overflow: auto;
  background: var(--dashboard-bg);
  border: 1px solid var(--dashboard-border);
  border-radius: var(--radius-md);
  padding: 12px;
  color: var(--dashboard-fg);
  font-size: var(--font-size-sm);
}

@media (max-width: 760px) {
  .hbar-row {
    grid-template-columns: minmax(86px, 1fr) minmax(90px, 1.4fr);
  }

  .hbar-cost {
    grid-column: 2;
    text-align: left;
  }

  .metric-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .usage-pager,
  .pg-bar {
    justify-content: center;
    flex-wrap: wrap;
  }

  .team-inline-form,
  .base-url-row {
    align-items: stretch;
    flex-direction: column;
  }

  .team-inline-form input {
    width: 100%;
  }

  .org-list-header,
  .org-detail-header {
    align-items: stretch;
    flex-direction: column;
  }

  .org-detail-actions {
    justify-content: flex-start;
  }

  .org-summary-grid {
    grid-template-columns: 1fr;
  }

  .key-create-form {
    grid-template-columns: 1fr;
  }

  .key-create-form .btn-primary {
    width: 100%;
  }
}

/* ==========================================================================
   USER MENU (avatar dropdown in topbar; built by renderTopbarControls)
   ========================================================================== */
.user-menu {
  position: relative;
  display: inline-flex;
}

.user-avatar-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 1px solid var(--dashboard-border);
  border-radius: 50%;
  background: none;
  cursor: pointer;
  transition: all var(--transition-fast);
}
.user-avatar-btn:hover {
  border-color: var(--dashboard-accent);
}

.user-avatar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--dashboard-accent);
  color: #fff;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
}

.user-menu-panel {
  display: none;
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  width: 280px;
  max-width: calc(100vw - 32px);
  background: var(--dashboard-card);
  border: 1px solid var(--dashboard-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--dashboard-shadow);
  padding: 12px;
  z-index: 1200;
}
.user-menu:hover .user-menu-panel,
.user-menu:focus-within .user-menu-panel,
.user-menu.open .user-menu-panel {
  display: block;
}
.user-menu-panel[hidden] {
  display: none;
}

.user-menu-identity {
  padding: 4px 6px 12px;
}
.user-menu-email {
  font-size: var(--font-size-base);
  line-height: 1.35;
  font-weight: var(--font-weight-semibold);
  color: var(--dashboard-fg);
  word-break: break-all;
  margin-bottom: 10px;
}
.user-menu-badge {
  /* inherits .badge-* classes for color */
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  padding: 3px 9px;
  border-radius: 5px;
}

.user-menu-divider {
  height: 1px;
  background: var(--dashboard-border);
  margin: 0 0 6px;
}

.user-menu-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-height: 36px;
  padding: 8px 8px;
  border: none;
  border-radius: 6px;
  background: none;
  color: var(--dashboard-secondary);
  font-size: var(--font-size-base);
  line-height: 1.35;
  font-family: var(--font-sans);
  font-weight: var(--font-weight-medium);
  text-align: left;
  cursor: pointer;
  transition: all var(--transition-fast);
}
.user-menu-item:hover {
  background: var(--dashboard-hover);
  color: var(--dashboard-fg);
}
.user-menu-item svg {
  width: 16px;
  height: 16px;
  flex: 0 0 auto;
}

/* ==========================================================================
   PAGE-SPECIFIC INFORMATION HIERARCHY REFINEMENTS
   ========================================================================== */
.usage-history-panel {
  margin-top: 16px;
}

.endpoint-detail-card {
  padding-top: 22px;
}

.endpoint-detail-title {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.endpoint-detail-title h3 {
  margin: 4px 0 0;
  color: var(--dashboard-fg);
  font-size: var(--font-size-xl);
}

.endpoint-detail-title h3::after {
  display: none;
}

.org-list-header.portal-section-heading {
  margin-bottom: 18px;
}

.endpoint-detail-card .detail-tabs {
  max-width: 100%;
  overflow-x: auto;
  scrollbar-width: none;
}

.endpoint-detail-card .detail-tab {
  flex: 0 0 auto;
}

@media (max-width: 980px) {
  .portal-section-heading {
    display: grid;
  }

  .resource-row {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .resource-meta {
    flex-wrap: wrap;
  }

  .resource-meta > span::after,
  .endpoint-meta > span::after {
    display: none;
  }

  .resource-actions {
    justify-content: flex-start;
  }

  .endpoint-detail-title {
    display: grid;
  }
}

.portal-section-heading h3::after,
.key-list-card h3::after,
.usage-history-panel h3::after,
.endpoint-detail-card h3::after {
  display: none;
}

/* ==========================================================================
   CROSS-DOCUMENT VIEW TRANSITIONS
   Smooths full-page sidebar navigation into a crossfade instead of a flash.
   Both the old and new document opt in (all portal pages share this sheet);
   unsupported browsers ignore it and navigate normally.
   ========================================================================== */
@view-transition {
  navigation: auto;
}

@media (prefers-reduced-motion: reduce) {
  ::view-transition-group(*),
  ::view-transition-old(*),
  ::view-transition-new(*) {
    animation: none !important;
  }
}

.mobile-more-btn,
.mobile-more-backdrop,
.mobile-more-sheet {
  display: none;
}

.nav-label-mobile {
  display: none;
}

/* ==========================================================================
   MOBILE PORTAL ADAPTATION
   Phones use full-width content with a bottom navigation rail instead of
   reserving a permanent left column.
   ========================================================================== */
@media (max-width: 760px) {
  :root,
  [data-sidebar='expanded'],
  [data-sidebar='collapsed'] {
    --sidebar-width: 0px;
    --mobile-nav-h: 72px;
    --topbar-h: 58px;
  }

  body.portal-shell {
    min-width: 0;
    padding-bottom: calc(var(--mobile-nav-h) + env(safe-area-inset-bottom));
  }

  body.portal-shell > .topbar,
  body.portal-shell > .content,
  body.portal-shell > #portal-root > .topbar,
  body.portal-shell > #portal-root > .content {
    width: auto;
    margin-left: 0;
  }

  .topbar {
    position: sticky;
    top: 0;
    z-index: 45;
    padding: 0 14px;
  }

  .topbar-title {
    min-width: 0;
    font-size: var(--font-size-lg);
  }

  .topbar-right {
    gap: 8px;
  }

  .topbar .docs-link,
  .topbar .topbar-ctl-btn {
    display: none;
  }

  .topbar-right {
    margin-left: auto;
  }

  .user-avatar-btn,
  .user-avatar {
    width: 42px;
    height: 42px;
  }

  .user-menu-panel {
    position: fixed;
    top: calc(var(--topbar-h) + 8px);
    right: 12px;
    left: 12px;
    width: auto;
    max-width: none;
  }

  .sidebar {
    top: auto;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    min-height: 0;
    height: calc(var(--mobile-nav-h) + env(safe-area-inset-bottom));
    border-top: 1px solid var(--dashboard-border);
    border-right: 0;
    box-shadow: 0 -16px 34px rgba(18, 15, 10, 0.12);
  }

  .sidebar-header,
  .sidebar-collapse-btn,
  .nav-group-label,
  .nav-group-line,
  .nav-item-label,
  .soon-badge {
    display: none;
  }

  .sidebar-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
    width: 100%;
    height: var(--mobile-nav-h);
    padding: 8px 14px calc(8px + env(safe-area-inset-bottom));
    overflow-x: hidden;
    overflow-y: hidden;
    scrollbar-width: none;
  }

  .sidebar-nav::-webkit-scrollbar {
    display: none;
  }

  .nav-group {
    display: contents;
  }

  .nav-item.mobile-more,
  .nav-item.mobile-hidden,
  .nav-item[href='#'] {
    display: none;
  }

  .nav-item,
  .mobile-more-btn {
    flex: 1 1 0;
    width: auto;
    min-width: 0;
    max-width: 64px;
    height: 52px;
    min-height: 52px;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 0;
    border-radius: 14px;
  }

  .nav-item svg,
  .mobile-more-btn svg {
    width: 21px;
    height: 21px;
  }

  .nav-item.mobile-primary .nav-item-label,
  .mobile-more-btn-label {
    display: block;
    max-width: 100%;
    overflow: hidden;
    color: inherit;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    line-height: 1;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .nav-item.mobile-primary .nav-label-desktop {
    display: none;
  }

  .nav-item.mobile-primary .nav-label-mobile {
    display: inline;
  }

  .mobile-more-btn {
    display: inline-flex;
    border: 0;
    background: transparent;
    color: var(--dashboard-secondary);
    cursor: pointer;
    font: inherit;
  }

  .nav-item.active,
  .mobile-more-btn.active {
    color: var(--dashboard-accent-fg);
    background: color-mix(in srgb, var(--dashboard-accent) 12%, transparent);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--dashboard-accent) 30%, transparent);
  }

  .mobile-more-backdrop {
    position: fixed;
    inset: 0;
    z-index: 80;
    display: block;
    background: rgba(20, 17, 12, 0.32);
    backdrop-filter: blur(3px);
  }

  .mobile-more-sheet {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 90;
    display: grid;
    gap: 14px;
    max-height: min(76dvh, 620px);
    padding: 10px 18px calc(var(--mobile-nav-h) + 18px + env(safe-area-inset-bottom));
    border: 1px solid var(--dashboard-border);
    border-bottom: 0;
    border-radius: 22px 22px 0 0;
    background: color-mix(in srgb, var(--dashboard-card) 94%, var(--dashboard-bg) 6%);
    box-shadow: 0 -24px 54px rgba(18, 15, 10, 0.2);
    pointer-events: none;
    transform: translateY(110%);
    transition: transform 180ms ease;
    visibility: hidden;
  }

  .mobile-more-sheet.open {
    pointer-events: auto;
    transform: translateY(0);
    visibility: visible;
  }

  .mobile-more-handle {
    justify-self: center;
    width: 40px;
    height: 4px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--dashboard-muted) 44%, transparent);
  }

  .mobile-more-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
  }

  .mobile-more-head h2 {
    margin: 0;
    color: var(--dashboard-fg);
    font-size: var(--font-size-lg);
  }

  .mobile-more-head p {
    max-width: 240px;
    margin: 4px 0 0;
    overflow: hidden;
    color: var(--dashboard-muted);
    font-size: var(--font-size-sm);
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .mobile-more-list {
    display: grid;
    gap: 8px;
    overflow-y: auto;
  }

  .mobile-more-item {
    min-height: 48px;
    display: flex;
    align-items: center;
    gap: 12px;
    border: 1px solid color-mix(in srgb, var(--dashboard-border) 82%, transparent);
    border-radius: 14px;
    background: color-mix(in srgb, var(--dashboard-bg) 42%, transparent);
    color: var(--dashboard-fg);
    cursor: pointer;
    font: inherit;
    font-weight: var(--font-weight-semibold);
    padding: 0 14px;
    text-align: left;
    text-decoration: none;
  }

  .mobile-more-item svg {
    width: 20px;
    height: 20px;
    color: var(--dashboard-secondary);
  }

  .mobile-more-item.active {
    border-color: color-mix(in srgb, var(--dashboard-accent) 34%, var(--dashboard-border));
    color: var(--dashboard-accent-fg);
    background: color-mix(in srgb, var(--dashboard-accent) 9%, var(--dashboard-card));
  }

  .mobile-more-item.disabled {
    color: var(--dashboard-muted);
    opacity: 0.62;
  }

  .mobile-more-item.danger {
    color: var(--dashboard-danger-fg);
  }

  .content {
    padding: 18px 14px 22px;
  }

  .content-inner {
    width: 100%;
    max-width: none;
    gap: 16px;
  }

  .welcome-section {
    padding-top: 4px;
  }

  .welcome-title {
    max-width: 100%;
    font-size: var(--font-size-3xl);
    line-height: 1.08;
    overflow-wrap: anywhere;
  }

  .welcome-sub {
    font-size: var(--font-size-md);
    line-height: 1.35;
  }

  .cta-row,
  .button-row,
  .modal-actions,
  .confirm-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .btn-primary,
  .btn-outline,
  .btn-secondary,
  .btn-danger,
  .btn-danger-outline {
    min-height: 44px;
  }

  .card,
  .ante-card,
  .install-card,
  .portal-section-card,
  .endpoints-create-card,
  .endpoints-list-card,
  .usage-panel {
    padding: 18px;
    border-radius: var(--radius-xl);
  }

  .portal-section-heading,
  .endpoints-card-heading,
  .endpoint-group-heading,
  .usage-panel-head,
  .team-table-header,
  .trace-strip-head {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .install-command,
  .base-url-row,
  .secret-key-row {
    display: grid;
    grid-template-columns: 1fr;
  }

  .install-command code,
  .base-url-row input,
  .secret-key,
  .endpoint-url,
  .request-id {
    white-space: normal;
    overflow-wrap: anywhere;
  }

  .copy-btn,
  .secret-copy-btn {
    width: 100%;
    min-height: 44px;
  }

  .form-row,
  #createEndpointForm,
  .key-create-form,
  .team-inline-form {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .form-row > *,
  .form-row > button,
  .form-row > .btn-primary,
  .form-row > .btn-outline,
  .form-row > .btn-danger,
  .form-row > .btn-secondary,
  .form-row > .btn-danger-outline {
    width: 100%;
    min-width: 0;
  }

  input,
  select,
  textarea {
    min-height: 44px;
    font-size: var(--font-size-md);
  }

  .resource-row,
  .endpoint-row {
    grid-template-columns: 1fr;
    align-items: stretch;
    gap: 12px;
    padding: 16px;
  }

  .resource-meta,
  .endpoint-meta {
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .resource-meta > span,
  .endpoint-meta > span {
    white-space: normal;
  }

  .resource-meta > span::after,
  .endpoint-meta > span::after {
    display: none;
  }

  .resource-actions,
  .endpoint-actions,
  .org-detail-actions {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .org-list-item {
    grid-template-columns: 40px minmax(0, 1fr);
    min-height: 76px;
  }

  .org-list-open {
    grid-column: 2;
  }

  .metric-grid,
  .org-summary-grid {
    grid-template-columns: 1fr;
  }

  .usage-page {
    display: grid;
    grid-template-columns: 1fr;
    align-items: start;
    gap: 12px;
  }

  .usage-page-actions {
    grid-column: 1;
    grid-row: 1;
    z-index: 1;
    margin: 12px 12px 0 0;
    justify-content: end;
  }

  .request-history-page .usage-page-actions {
    grid-row: auto;
    margin: 0 0 2px;
  }

  .usage-page-actions .icon-btn {
    width: 44px;
    min-width: 44px;
    min-height: 44px;
    border-radius: 14px;
  }

  .summary-grid {
    grid-column: 1 / -1;
    grid-row: 1;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin: 0 0 10px;
  }

  .summary-grid .stat-box:first-child {
    grid-column: 1 / -1;
    padding-right: 62px;
  }

  .stat-box {
    min-width: 0;
    padding: 12px 14px;
    border-radius: 14px;
  }

  .stat-box-label {
    margin-bottom: 5px;
    font-size: var(--font-size-xs);
    letter-spacing: 0.08em;
  }

  .stat-box-value {
    font-size: var(--font-size-xl);
    line-height: 1.1;
  }

  .summary-grid .stat-box:not(:first-child) .stat-box-value {
    font-size: var(--font-size-lg);
  }

  .stat-box-sub {
    min-height: 16px;
    margin-top: 4px;
    font-size: var(--font-size-sm);
    line-height: 1.25;
  }

  .usage-page > .inline-alert,
  .usage-page > .page-loading-bar,
  .usage-page > .update-banner,
  .usage-page > .compact-card,
  .usage-page > #usageFilterStrip,
  .usage-page > .usage-panel {
    grid-column: 1 / -1;
  }

  .usage-filter-toolbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 8px;
  }

  .usage-filter-chips {
    grid-column: 1 / -1;
    flex-wrap: wrap;
    overflow: visible;
    min-width: 0;
    max-width: 100%;
  }

  .usage-filter-chip {
    max-width: 156px;
  }

  .usage-filter-toggle {
    justify-content: space-between;
    min-height: 42px;
  }

  .usage-filter-card .trace-filter-grid {
    grid-template-columns: 1fr;
  }

  .usage-datetime-control {
    grid-template-columns: minmax(0, 1fr) 1px minmax(96px, 0.42fr);
  }

  .usage-filter-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .usage-filter-actions .btn-sm {
    width: 100%;
    min-height: 42px;
  }

  .usage-filter-status {
    grid-column: 1 / -1;
  }

  .usage-page-size-control {
    justify-self: start;
  }

  .usage-chart-shell {
    margin-inline: -4px;
    padding: 12px 4px 24px;
    overflow-x: hidden;
  }

  .chart-container {
    width: 100%;
    min-width: 0;
    height: 240px;
    padding-inline: 18px;
    gap: 8px;
  }

  .bar-group {
    min-width: 0;
  }

  .bar {
    width: min(42px, 76%);
  }

  .usage-chart-skeleton {
    gap: 8px;
  }

  .usage-chart-skeleton-group {
    min-width: 0;
  }

  .usage-chart-skeleton-bar {
    width: min(42px, 76%);
  }

  .bar-label {
    font-size: var(--font-size-xs);
  }

  .hbar-row {
    grid-template-columns: 1fr;
    gap: 6px;
    padding: 8px 0;
  }

  .hbar-cost {
    grid-column: auto;
  }

  .usage-history-scroll {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    max-height: min(68dvh, 640px);
    overflow: auto;
    border: 1px solid var(--dashboard-border);
    border-radius: var(--radius-lg);
    scrollbar-gutter: stable;
  }

  .usage-history-panel,
  .usage-panel {
    min-width: 0;
  }

  .usage-history-scroll table {
    width: max-content;
    min-width: 920px;
    table-layout: auto;
    border: 0;
  }

  .usage-history-scroll thead th {
    position: sticky;
    top: 0;
    z-index: 2;
    background: var(--dashboard-sidebar);
    padding: 8px 7px;
    font-size: var(--font-size-xs);
    letter-spacing: 0.04em;
  }

  .usage-history-scroll thead th:nth-child(1) {
    min-width: 132px;
  }

  .usage-history-scroll thead th:nth-child(2) {
    min-width: 92px;
  }

  .usage-history-scroll thead th:nth-child(3) {
    min-width: 142px;
  }

  .usage-history-scroll thead th:nth-child(4),
  .usage-history-scroll thead th:nth-child(5),
  .usage-history-scroll thead th:nth-child(6),
  .usage-history-scroll thead th:nth-child(7),
  .usage-history-scroll thead th:nth-child(8),
  .usage-history-scroll thead th:nth-child(9),
  .usage-history-scroll thead th:nth-child(10),
  .usage-history-scroll thead th:nth-child(11) {
    min-width: 76px;
  }

  .usage-history-scroll thead th:nth-child(10),
  .usage-history-scroll tbody td:nth-child(10) {
    min-width: 92px;
  }

  .usage-history-scroll tbody td {
    max-width: 150px;
    padding: 9px 7px;
    overflow: hidden;
    color: var(--dashboard-secondary);
    font-size: var(--font-size-sm);
    line-height: 1.3;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .usage-history-scroll .ts-cell {
    white-space: nowrap;
  }

  .usage-history-scroll tbody td:nth-child(1),
  .usage-history-scroll tbody td:nth-child(2) {
    font-family: var(--font-mono);
  }

  .usage-history-scroll tbody td:nth-child(3) {
    padding-right: 2px;
  }

  .usage-history-scroll tbody td:nth-child(6),
  .usage-history-scroll tbody td:nth-child(7),
  .usage-history-scroll tbody td:nth-child(8),
  .usage-history-scroll tbody td:nth-child(9) {
    text-align: right;
    font-variant-numeric: tabular-nums;
  }

  .usage-history-scroll .model-pill {
    display: inline-block;
    max-width: 100%;
    overflow: hidden;
    padding: 2px 5px;
    text-overflow: ellipsis;
    vertical-align: middle;
  }

  .usage-history-scroll .cost-cell {
    color: var(--dashboard-accent-fg);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    text-align: right;
  }

  .usage-history-scroll .table-empty {
    display: table-cell;
    padding: 18px 10px;
    text-align: center;
  }

  .usage-history-overlay {
    position: absolute;
    top: 50%;
    left: 50%;
    max-width: calc(100% - 16px);
    transform: translate(-50%, -50%);
    white-space: nowrap;
  }

  .table-wrapper {
    overflow: visible;
  }

  .table-wrapper table {
    min-width: 0;
  }

  .obs-drawer {
    width: 100%;
    max-width: none;
    border-radius: 16px 16px 0 0;
  }

  .modal-overlay {
    align-items: flex-end;
    padding: 12px;
  }

  .modal {
    max-width: none;
    max-height: calc(100dvh - 24px);
    padding: 22px;
    border-radius: var(--radius-xl);
  }
}

/* --------------------------------------------------------------------------
   Focused surface reduction pass.
   Keep the portal work-focused: ordinary content is flat, only overlays float.
   ----------------------------------------------------------------------- */
:root {
  --portal-radius-control: 6px;
  --portal-radius-panel: 8px;
  --portal-shadow-soft: 0 1px 2px rgba(20, 17, 12, 0.05);
  --portal-shadow-tight: none;
}

.card,
.ante-card,
.install-card,
.feature-card,
.portal-section-card,
.endpoints-create-card,
.endpoints-list-card,
.stat-box,
.chart-container,
.table-wrapper,
.usage-history-scroll,
.metric-tile,
.provider-row,
.activity-sessions,
.page-error-state,
.portal-loading-tile,
#traceFilterStrip,
#usageFilterStrip {
  border-radius: var(--portal-radius-panel);
  box-shadow: none;
}

.card,
.ante-card,
.install-card,
.feature-card,
.portal-section-card,
.endpoints-create-card,
.endpoints-list-card,
.stat-box {
  background: color-mix(in srgb, var(--dashboard-card) 58%, transparent);
}

[data-theme='light'] .card,
[data-theme='light'] .ante-card,
[data-theme='light'] .install-card,
[data-theme='light'] .feature-card,
[data-theme='light'] .portal-section-card,
[data-theme='light'] .endpoints-create-card,
[data-theme='light'] .endpoints-list-card,
[data-theme='light'] .stat-box {
  background: rgba(255, 253, 248, 0.66);
}

.install-card,
.feature-card,
.stat-box,
.chart-container {
  border-color: color-mix(in srgb, var(--dashboard-border) 82%, transparent);
}

.card h3::after,
.ante-section h3::after,
.install-header span::after,
.usage-panel h3::after,
.endpoints-card-heading h3::after,
.endpoint-group-heading h3::after,
.key-list-card h3::after,
.usage-history-panel h3::after,
.endpoint-detail-card h3::after {
  display: none;
}

.btn-primary,
.btn-outline,
.btn-secondary,
.btn-danger,
.btn-danger-outline,
.oauth-btn,
.topbar-ctl-btn,
.docs-link,
.secret-copy-btn,
.copy-btn,
.usage-filter-toggle,
.user-menu-item,
.back-link-btn,
.feature-card,
.bar,
tbody tr {
  transition:
    background-color 120ms ease,
    border-color 120ms ease,
    color 120ms ease,
    opacity 120ms ease;
}

.btn-primary,
.oauth-btn#magic-login-submit,
.update-banner,
.btn-outline,
.btn-secondary,
.topbar-ctl-btn,
.secret-copy-btn,
.oauth-btn,
#continue-btn,
.accountButton,
.portalLink,
.usage-filter-toggle,
.back-link-btn {
  box-shadow: none;
}

.btn-primary:hover,
.oauth-btn#magic-login-submit:hover,
.btn-outline:hover,
.btn-secondary:hover,
.topbar-ctl-btn:hover,
.secret-copy-btn:hover,
.oauth-btn:hover,
#continue-btn:hover,
.feature-card:hover,
.usage-filter-toggle:hover,
.usage-filter-toggle:focus-visible,
.back-link-btn:hover,
.back-link-btn:focus-visible,
.bar:hover,
.bar:focus-visible,
.nav-item:hover,
.org-directory .org-list-item:hover,
.org-directory .org-list-item:focus-visible {
  transform: none;
}

.feature-card {
  min-height: 124px;
}

.feature-card:hover {
  background: color-mix(in srgb, var(--dashboard-card) 68%, var(--dashboard-hover) 32%);
  box-shadow: none;
}

[data-theme='light'] .feature-card:hover {
  background: rgba(255, 253, 248, 0.9);
}

.stat-box {
  padding: 16px 18px;
}

.stat-box-label,
thead th,
label,
.metric-tile-label {
  letter-spacing: 0;
}

.stat-box-value {
  letter-spacing: 0;
}

.usage-page-actions {
  margin-bottom: 4px;
}

.usage-filter-card {
  margin-top: 14px;
  padding-top: 0;
}

.usage-filter-toggle {
  min-height: 32px;
  border-radius: var(--portal-radius-control);
  background: transparent;
  padding: 0 10px;
}

.usage-filter-toggle:hover,
.usage-filter-toggle:focus-visible {
  background: color-mix(in srgb, var(--dashboard-hover) 72%, transparent);
}

.usage-filter-card .trace-filter-grid {
  padding-top: 14px;
}

.usage-datetime-control,
input[type='text'],
input[type='email'],
input[type='password'],
input[type='number'],
input[type='url'],
input[type='search'],
input[type='date'],
input[type='time'],
input[type='datetime-local'],
select,
textarea {
  border-radius: var(--portal-radius-control);
}

.usage-panel {
  padding-top: 14px;
}

.usage-panel + .usage-panel,
.usage-panel + .card,
#usageFilterStrip + .usage-panel {
  margin-top: 12px;
}

.usage-chart-shell {
  padding: 8px 0 24px;
}

.chart-container {
  height: 260px;
  padding: 8px 18px 26px;
  background: color-mix(in srgb, var(--dashboard-card) 46%, transparent);
}

[data-theme='light'] .chart-container {
  background: rgba(255, 253, 248, 0.58);
}

.bar:hover,
.bar:focus-visible {
  background: var(--usage-data-fill-hover);
  outline: 2px solid color-mix(in srgb, var(--usage-data-fill-hover) 42%, transparent);
  outline-offset: 2px;
}

.bar-tooltip,
.bar-tooltip.visible,
.trace-export-popover,
.user-menu-panel,
.toast {
  border-radius: var(--portal-radius-panel);
  box-shadow: 0 10px 28px rgba(18, 15, 10, 0.14);
}

.usage-history-scroll {
  border-radius: var(--portal-radius-panel);
}

.usage-history-scroll thead th {
  box-shadow: none;
}

.usage-history-overlay {
  border-radius: var(--portal-radius-panel);
  box-shadow: none;
}

.skeleton,
.loading-surface::after,
.stat-box.is-refreshing::after,
.usage-chart-shell.is-refreshing::after,
.hbar-list.is-refreshing::after {
  animation: none;
}

.skeleton {
  background: color-mix(in srgb, var(--dashboard-border) 76%, var(--dashboard-card));
}

.login-wrapper {
  background: var(--dashboard-bg);
}

.login-card {
  border-radius: var(--radius-lg);
  box-shadow: 0 8px 24px rgba(18, 15, 10, 0.1);
}

.login-card .oauth-provider-btn,
[data-theme='light'] .login-card .oauth-provider-btn,
.login-card .passkey-provider-btn {
  border-radius: var(--portal-radius-panel);
  background: #fffdf8;
  box-shadow: none;
}

.login-card .oauth-provider-btn:hover,
[data-theme='light'] .login-card .oauth-provider-btn:hover {
  background: #f8f3ec;
  box-shadow: none;
  transform: none;
}

.login-card .oauth-provider-btn:hover::after {
  transform: rotate(-45deg);
}

@media (max-width: 760px) {
  .content {
    padding: 16px 14px 18px;
  }

  .content-inner {
    gap: 14px;
  }

  .card,
  .ante-card,
  .install-card,
  .portal-section-card,
  .endpoints-create-card,
  .endpoints-list-card,
  .usage-panel {
    border-radius: var(--portal-radius-panel);
    padding: 16px;
  }

  .usage-panel {
    padding: 10px 0 0;
  }

  .sidebar {
    box-shadow: none;
  }

  .nav-item,
  .mobile-more-btn {
    border-radius: var(--portal-radius-panel);
  }

  .nav-item.active,
  .mobile-more-btn.active {
    box-shadow: none;
  }

  .summary-grid {
    gap: 8px;
  }

  .stat-box {
    border-radius: var(--portal-radius-panel);
    padding: 11px 12px;
  }

  .usage-page-actions {
    margin: 8px 8px 0 0;
  }

  .usage-page-actions .icon-btn {
    border-radius: var(--portal-radius-panel);
  }

  .usage-filter-toggle {
    border-radius: var(--portal-radius-panel);
  }

  .usage-chart-shell {
    margin-inline: 0;
    padding: 6px 0 18px;
  }

  .chart-container {
    height: 220px;
    padding: 8px 14px 22px;
  }

  .usage-history-scroll {
    border-radius: var(--portal-radius-panel);
  }

  .mobile-more-sheet {
    border-radius: 12px 12px 0 0;
    box-shadow: none;
  }

  .mobile-more-item {
    border-radius: var(--portal-radius-panel);
  }

  .login-card {
    border-radius: var(--radius-lg);
    box-shadow: 0 1px 2px rgba(18, 15, 10, 0.06);
  }
}

@media (max-width: 760px) {
  .nav-item,
  .mobile-more-btn {
    position: relative;
    border-radius: 0;
  }

  .nav-item.active,
  body[data-page='home'] .nav-item[data-nav-id='home'],
  body[data-page='team'] .nav-item[data-nav-id='team'],
  body[data-page='endpoints'] .nav-item[data-nav-id='endpoints'],
  body[data-page='keys'] .nav-item[data-nav-id='keys'],
  body[data-page='usage'] .nav-item[data-nav-id='usage'],
  body[data-page='history'] .nav-item[data-nav-id='history'],
  [data-theme='light'] .nav-item.active,
  [data-theme='light'] body[data-page='home'] .nav-item[data-nav-id='home'],
  [data-theme='light'] body[data-page='team'] .nav-item[data-nav-id='team'],
  [data-theme='light'] body[data-page='endpoints'] .nav-item[data-nav-id='endpoints'],
  [data-theme='light'] body[data-page='keys'] .nav-item[data-nav-id='keys'],
  [data-theme='light'] body[data-page='usage'] .nav-item[data-nav-id='usage'],
  [data-theme='light'] body[data-page='history'] .nav-item[data-nav-id='history'],
  .mobile-more-btn.active {
    background: transparent;
    border-color: transparent;
    color: var(--dashboard-accent-fg);
  }

  .nav-item.active::after,
  body[data-page='home'] .nav-item[data-nav-id='home']::after,
  body[data-page='team'] .nav-item[data-nav-id='team']::after,
  body[data-page='endpoints'] .nav-item[data-nav-id='endpoints']::after,
  body[data-page='keys'] .nav-item[data-nav-id='keys']::after,
  body[data-page='usage'] .nav-item[data-nav-id='usage']::after,
  body[data-page='history'] .nav-item[data-nav-id='history']::after,
  .mobile-more-btn.active::after {
    content: '';
    position: absolute;
    right: 18px;
    bottom: 3px;
    left: 18px;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
  }
}

/* ==========================================================================
   BORDERLESS FLAT OVERRIDES (FORCE EXCLUDE CARDS & SHADOWS)
   ========================================================================== */
.card,
.ante-card,
.install-card,
.feature-card,
.stat-box,
.key-list-card,
.portal-section-card {
  background: transparent !important;
  border: none !important;
  border-bottom: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

/* 统一主体内容区顶部间距，清除 padding-top 叠加的后遗症 */
.content {
  padding-top: 0 !important;
}

/* 组织目录列表页宽度撑满 */
.org-directory {
  max-width: none !important;
}

/* 组织网格项去阴影并微调圆角 */
.org-list-item {
  box-shadow: none !important;
  border-radius: var(--radius-lg) !important;
}

.feature-card:hover {
  background: transparent !important;
  border-color: var(--dashboard-accent) !important;
  box-shadow: none !important;
  transform: none !important;
}

/* 彻底清除 nav-item active 圆角与背景 */
.nav-item.active,
body[data-page='home'] .nav-item[data-nav-id='home'],
body[data-page='team'] .nav-item[data-nav-id='team'],
body[data-page='endpoints'] .nav-item[data-nav-id='endpoints'],
body[data-page='keys'] .nav-item[data-nav-id='keys'],
body[data-page='usage'] .nav-item[data-nav-id='usage'],
body[data-page='history'] .nav-item[data-nav-id='history'] {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

/* Daily cost 左右按键去框 */
.chart-window-controls .icon-btn {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  width: 28px !important;
  height: 28px !important;
  color: var(--dashboard-muted) !important;
  cursor: pointer;
  transition: color var(--transition-fast) !important;
}

.chart-window-controls .icon-btn:hover:not(:disabled) {
  color: var(--dashboard-accent) !important;
}

.chart-window-controls .icon-btn:disabled {
  opacity: 0.35 !important;
  cursor: not-allowed !important;
}

/* 页面标题大字体与大边距 */
.topbar-title {
  font-size: var(--font-size-2xl) !important;
  font-weight: var(--font-weight-bold) !important;
  letter-spacing: -0.02em !important;
}

.topbar {
  margin-bottom: 24px !important;
}

/* Custom Refresh Button styling */
.usage-refresh-btn {
  margin-left: auto;
  background: transparent !important;
  border: 1px solid transparent !important;
  color: var(--dashboard-muted) !important;
  cursor: pointer;
  transition: all var(--transition-fast) !important;
}

.usage-refresh-btn:hover:not(:disabled) {
  background: color-mix(in srgb, var(--dashboard-hover) 64%, var(--dashboard-card)) !important;
  border-color: var(--dashboard-border) !important;
  color: var(--dashboard-fg) !important;
  transform: rotate(30deg);
}

/* Dashboard quick-access modules */
body[data-page='home'] .cards-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 4px;
}

body[data-page='home'] .feature-card {
  position: relative;
  display: flex !important;
  min-height: 172px;
  padding: 18px !important;
  flex-direction: column;
  border: 1px solid color-mix(in srgb, var(--dashboard-border) 86%, transparent) !important;
  border-radius: var(--portal-radius-panel) !important;
  background: color-mix(in srgb, var(--dashboard-card) 58%, transparent) !important;
  color: var(--dashboard-fg);
  text-decoration: none;
}

[data-theme='light'] body[data-page='home'] .feature-card {
  background: rgba(255, 253, 248, 0.72) !important;
}

body[data-page='home'] .feature-card:hover,
body[data-page='home'] .feature-card:focus-visible {
  border-color: color-mix(in srgb, var(--dashboard-accent) 48%, var(--dashboard-border)) !important;
  background: color-mix(in srgb, var(--dashboard-card) 76%, var(--dashboard-hover) 24%) !important;
  outline: none;
}

[data-theme='light'] body[data-page='home'] .feature-card:hover,
[data-theme='light'] body[data-page='home'] .feature-card:focus-visible {
  background: rgba(255, 253, 248, 0.96) !important;
}

body[data-page='home'] .feature-card.disabled,
body[data-page='home'] .feature-card.disabled:hover {
  border-color: color-mix(in srgb, var(--dashboard-border) 76%, transparent) !important;
  background: color-mix(in srgb, var(--dashboard-card) 38%, transparent) !important;
  cursor: not-allowed;
  opacity: 1;
}

body[data-page='home'] .feature-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}

body[data-page='home'] .feature-card-icon {
  width: 22px;
  height: 22px;
  margin: 0;
  color: var(--dashboard-accent-fg);
}

body[data-page='home'] .feature-card.disabled .feature-card-icon {
  color: var(--dashboard-muted);
}

body[data-page='home'] .feature-card-kicker {
  display: inline-flex;
  min-height: 24px;
  align-items: center;
  gap: 6px;
  padding: 3px 8px;
  border: 1px solid color-mix(in srgb, var(--dashboard-border) 86%, transparent);
  border-radius: var(--portal-radius-control);
  color: var(--dashboard-muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: 1.2;
}

body[data-page='home'] .feature-card-kicker svg {
  width: 13px;
  height: 13px;
}

body[data-page='home'] .feature-card h4 {
  margin-bottom: 6px;
  color: var(--dashboard-fg);
  font-size: var(--font-size-md);
  line-height: 1.3;
}

body[data-page='home'] .feature-card p {
  max-width: 34rem;
  color: var(--dashboard-muted);
  font-size: var(--font-size-base);
  line-height: 1.5;
}

body[data-page='home'] .feature-card-action {
  display: inline-flex;
  align-items: center;
  margin-top: auto;
  padding-top: 18px;
  color: var(--dashboard-secondary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
}

body[data-page='home'] .feature-card:not(.disabled):hover .feature-card-action,
body[data-page='home'] .feature-card:not(.disabled):focus-visible .feature-card-action {
  color: var(--dashboard-accent-fg);
}

body[data-page='home'] .feature-card.disabled .feature-card-kicker,
body[data-page='home'] .feature-card.disabled .feature-card-action,
body[data-page='home'] .feature-card.disabled h4,
body[data-page='home'] .feature-card.disabled p {
  color: var(--dashboard-muted);
}

@media (max-width: 980px) {
  body[data-page='home'] .cards-grid {
    grid-template-columns: 1fr;
  }

  body[data-page='home'] .feature-card {
    min-height: 0;
  }
}

.usage-refresh-btn:active:not(:disabled) {
  transform: scale(0.95) rotate(30deg);
}

.usage-refresh-btn:disabled {
  opacity: 0.48 !important;
  cursor: not-allowed !important;
}

/* Zebra striping for history table */
.usage-history-scroll tbody tr:nth-child(even) {
  background: var(--dashboard-subtle-bg);
}

.usage-history-scroll tbody tr:hover {
  background: var(--dashboard-hover) !important;
}

/* Page size select styling in pager */
.usage-pager-select {
  appearance: none;
  width: auto !important;
  height: 32px !important;
  min-height: 32px !important;
  padding: 0 24px 0 8px !important;
  border: 1px solid transparent !important;
  border-radius: 6px !important;
  background-color: transparent !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%236b6b80' stroke-width='2.2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 8px center !important;
  color: var(--dashboard-fg) !important;
  font-size: var(--font-size-sm) !important;
  font-weight: var(--font-weight-medium) !important;
  cursor: pointer;
  outline: none;
  box-sizing: border-box !important;
  transition: all var(--transition-fast) !important;
}

.usage-pager-select:hover:not(:disabled) {
  background-color: var(--dashboard-hover) !important;
  border-color: transparent !important;
}

.usage-pager-select:focus-visible {
  outline: 2px solid var(--dashboard-accent) !important;
  outline-offset: 1px;
}

/* Custom ghost pager buttons and gap alignment */
.usage-pager {
  gap: 8px !important;
}

.usage-pager .icon-btn {
  background: transparent !important;
  border: 1px solid transparent !important;
  box-shadow: none !important;
  width: 32px !important;
  height: 32px !important;
  min-width: 32px !important;
  min-height: 32px !important;
  border-radius: 6px !important;
  padding: 0 !important;
  color: var(--dashboard-fg) !important;
  cursor: pointer;
  transition: all var(--transition-fast) !important;
}

.usage-pager .icon-btn:hover:not(:disabled) {
  background: var(--dashboard-hover) !important;
  color: var(--dashboard-fg) !important;
}

.usage-pager .icon-btn:disabled {
  opacity: 0.35 !important;
  cursor: not-allowed !important;
}
