:root {
  --bg: #ffffff;
  --bg-subtle: #fafafa;
  --bg-muted: #f4f4f5;
  --bg-hover: #f4f4f5;
  --border: #e8e8e8;
  --border-strong: #d4d4d8;
  --fg: #09090b;
  --fg-muted: #71717a;
  --fg-subtle: #a1a1aa;
  --accent: #2b59ff;
  --accent-fg: #ffffff;
  --accent-soft: #eef2ff;
  --success: #16a34a;
  --success-soft: #dcfce7;
  --warn: #d97706;
  --warn-soft: #fef3c7;
  --danger: #dc2626;
  --danger-soft: #fee2e2;
  --info: #0284c7;
  --info-soft: #e0f2fe;
  --radius: 6px;
  --radius-lg: 10px;
  --shadow-xs: 0 1px 0 rgba(0, 0, 0, 0.04);
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.04), 0 0 0 1px rgba(0, 0, 0, 0.04);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.06), 0 0 0 1px rgba(0, 0, 0, 0.05);
  --shadow-lg: 0 12px 32px rgba(0, 0, 0, 0.08), 0 0 0 1px rgba(0, 0, 0, 0.05);
  --font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  --row-h: 36px;
  --sidebar-w: 232px;
}

* {
  box-sizing: border-box;
}

html,
body {
  height: 100%;
  margin: 0;
}

body {
  font-family: var(--font-sans);
  font-size: 13px;
  line-height: 1.5;
  color: var(--fg);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

#app {
  height: 100%;
}

button {
  font: inherit;
  color: inherit;
  cursor: pointer;
}

input,
select,
textarea {
  font: inherit;
  color: inherit;
}

a {
  color: inherit;
  text-decoration: none;
}

[data-density=compact] {
  --row-h: 30px;
  font-size: 12px;
}

[data-density=comfortable] {
  --row-h: 40px;
  font-size: 13px;
}

::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: var(--bg-muted);
  border-radius: 999px;
  border: 2px solid var(--bg);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--border-strong);
}

.row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.col {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.muted {
  color: var(--fg-muted);
}

.subtle {
  color: var(--fg-subtle);
}

.mono {
  font-family: var(--font-mono);
}

.tnum {
  font-variant-numeric: tabular-nums;
}

.divider {
  height: 1px;
  background: var(--border);
  margin: 12px 0;
}

.kv {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 6px 16px;
  font-size: 12.5px;
  margin: 0;
}

.kv dt {
  color: var(--fg-muted);
  font-weight: 400;
}

.kv dd {
  margin: 0;
}

.grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

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

.empty {
  padding: 60px 20px;
  text-align: center;
  color: var(--fg-muted);
  font-size: 13px;
}

.live-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--success);
  animation: dot-pulse 2s ease-in-out infinite;
  display: inline-block;
}

@keyframes dot-pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.3;
  }
}
.spacer {
  flex: 1;
}

.dot-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.dot-grid-2 + .dot-grid-2 {
  margin-top: 16px;
}
@media (max-width: 900px) {
  .dot-grid-2 {
    grid-template-columns: 1fr;
  }
}

.dot-section-label {
  font-size: 11px;
  font-weight: 500;
  color: var(--fg-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 8px;
}

.dot-btn {
  height: 30px;
  padding: 0 12px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: var(--bg);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--fg);
  white-space: nowrap;
  transition: background 0.12s ease;
}

.dot-btn:hover {
  background: var(--bg-hover);
}

.dot-btn.is-primary {
  background: var(--fg);
  color: var(--bg);
  border-color: var(--fg);
}

.dot-btn.is-primary:hover {
  background: #1f1f23;
}

.dot-btn.is-accent {
  background: var(--accent);
  color: var(--accent-fg);
  border-color: var(--accent);
}

.dot-btn.is-accent:hover {
  filter: brightness(0.95);
}

.dot-btn.is-ghost {
  border-color: transparent;
  background: transparent;
  color: var(--fg-muted);
}

.dot-btn.is-ghost:hover {
  background: var(--bg-hover);
  color: var(--fg);
}

.dot-btn.is-danger {
  color: var(--danger);
}

.dot-btn.is-danger:hover {
  background: var(--danger-soft);
}

.dot-btn.is-sm {
  height: 26px;
  padding: 0 9px;
  font-size: 12px;
}

.dot-btn[disabled],
.dot-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.dot-btn svg {
  width: 14px;
  height: 14px;
}

.dot-icon-btn {
  width: 30px;
  height: 30px;
  border-radius: var(--radius);
  border: 1px solid transparent;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--fg-muted);
  position: relative;
}

.dot-icon-btn:hover {
  background: var(--bg-hover);
  color: var(--fg);
}

.dot-icon-btn .dot-indicator {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  border: 2px solid var(--bg);
  box-sizing: content-box;
}

.dot-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 500;
  background: var(--bg-muted);
  color: var(--fg-muted);
  font-variant-numeric: tabular-nums;
}

.dot-pill .dot-pill-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}

.dot-pill.is-success {
  background: var(--success-soft);
  color: var(--success);
}

.dot-pill.is-warn {
  background: var(--warn-soft);
  color: var(--warn);
}

.dot-pill.is-danger {
  background: var(--danger-soft);
  color: var(--danger);
}

.dot-pill.is-info {
  background: var(--info-soft);
  color: var(--info);
}

.dot-pill.is-accent {
  background: var(--accent-soft);
  color: var(--accent);
}

.dot-pill.is-outline {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--fg-muted);
}

.dot-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--bg);
}

.dot-card-header {
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 10px;
}

.dot-card-header h3 {
  margin: 0;
  font-size: 13px;
  font-weight: 600;
}

.dot-card-header .dot-card-sub {
  color: var(--fg-muted);
  font-size: 12px;
}

.dot-card-body {
  padding: 16px;
}

.dot-chart-card .dot-card-body {
  padding: 4px 8px 8px;
}

.dot-input {
  height: 30px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0 10px;
  background: var(--bg);
  font-size: 12.5px;
  outline: none;
  color: var(--fg);
  width: auto;
}

.dot-input:focus {
  border-color: var(--fg);
}

.dot-input::placeholder {
  color: var(--fg-subtle);
}

.dot-input.is-search {
  padding-left: 30px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2371717a' stroke-width='2'><circle cx='11' cy='11' r='7'/><path d='m20 20-3.5-3.5'/></svg>");
  background-repeat: no-repeat;
  background-position: 9px center;
  background-size: 14px;
}

.dot-input.is-mono {
  font-family: var(--font-mono);
  font-size: 12px;
}

.dot-textarea {
  width: 100%;
  height: 80px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg);
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg);
  outline: none;
  resize: vertical;
}

.dot-textarea:focus {
  border-color: var(--fg);
}

.dot-select {
  height: 30px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0 26px 0 10px;
  background: var(--bg) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2371717a' stroke-width='2'><path d='m6 9 6 6 6-6'/></svg>") no-repeat right 8px center/12px;
  font-size: 12.5px;
  appearance: none;
  outline: none;
  color: var(--fg);
}

.dot-select:focus {
  border-color: var(--fg);
}

.dot-form-label {
  font-size: 12px;
  font-weight: 500;
  margin-bottom: 4px;
  display: block;
  color: var(--fg);
}

.dot-checkbox {
  width: 14px;
  height: 14px;
  border: 1.5px solid var(--border-strong);
  border-radius: 3px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  background: var(--bg);
  flex-shrink: 0;
}

.dot-checkbox[data-checked=true] {
  background: var(--fg);
  border-color: var(--fg);
  color: var(--bg);
}

.dot-checkbox[data-checked=true]::after {
  content: "";
  width: 7px;
  height: 4px;
  border-left: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(-45deg) translate(1px, -1px);
  display: block;
}

.dot-toggle {
  width: 28px;
  height: 16px;
  background: var(--bg-muted);
  border-radius: 999px;
  border: 1px solid var(--border);
  position: relative;
  cursor: pointer;
  flex-shrink: 0;
  display: inline-block;
}

.dot-toggle[data-on=true] {
  background: var(--fg);
  border-color: var(--fg);
}

.dot-toggle::after {
  content: "";
  position: absolute;
  top: 1px;
  left: 1px;
  width: 12px;
  height: 12px;
  background: var(--bg);
  border-radius: 50%;
  transition: transform 0.15s;
}

.dot-toggle[data-on=true]::after {
  transform: translateX(12px);
}

.dot-bar {
  width: 100%;
  height: 6px;
  background: var(--bg-muted);
  border-radius: 999px;
  overflow: hidden;
}

.dot-bar > span {
  display: block;
  height: 100%;
  background: var(--accent);
  border-radius: 999px;
}

.dot-bar.is-warn > span {
  background: var(--warn);
}

.dot-bar.is-danger > span {
  background: var(--danger);
}

.dot-bar.is-success > span {
  background: var(--success);
}

.dot-spark {
  margin-top: 8px;
  height: 32px;
  width: 100%;
}

.dot-kpis {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}

.dot-kpi {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 14px 16px;
  background: var(--bg);
}

.dot-kpi .dot-kpi-label {
  font-size: 11.5px;
  color: var(--fg-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 500;
}

.dot-kpi .dot-kpi-value {
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -0.02em;
  margin-top: 4px;
  font-variant-numeric: tabular-nums;
}

.dot-kpi .dot-kpi-delta {
  font-size: 11.5px;
  margin-top: 4px;
  color: var(--fg-muted);
  display: flex;
  align-items: center;
  gap: 4px;
}

.dot-kpi .dot-kpi-delta.is-up {
  color: var(--success);
}

.dot-kpi .dot-kpi-delta.is-down {
  color: var(--danger);
}

.dot-kpi .dot-kpi-hint {
  font-size: 11.5px;
  margin-top: 4px;
  color: var(--fg-muted);
}

.dot-tabs {
  display: flex;
  gap: 2px;
  border-bottom: 1px solid var(--border);
  padding: 0 24px;
  margin-top: -1px;
}

.dot-tab {
  padding: 10px 12px;
  font-size: 12.5px;
  color: var(--fg-muted);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  cursor: pointer;
  font-weight: 500;
  background: transparent;
  border-top: 0;
  border-left: 0;
  border-right: 0;
}

.dot-tab:hover {
  color: var(--fg);
}

.dot-tab[data-active=true] {
  color: var(--fg);
  border-bottom-color: var(--fg);
}

.dot-tab .dot-tab-count {
  color: var(--fg-muted);
  margin-left: 6px;
}

.dot-grid {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--bg);
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}

.dot-card > .dot-grid,
.dot-card .dot-grid.is-embedded {
  border: 0;
  border-radius: 0;
}

.dot-grid-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  flex-wrap: wrap;
}

.dot-grid-toolbar .spacer {
  flex: 1;
}

.dot-grid-container {
  display: grid;
  overflow: auto;
  align-content: start;
  min-height: 0;
}

.dot-grid-header {
  text-align: left;
  padding: 8px 12px;
  font-weight: 500;
  color: var(--fg-muted);
  border-bottom: 1px solid var(--border);
  font-size: 11.5px;
  background: var(--bg-subtle);
  white-space: nowrap;
  position: sticky;
  top: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 6px;
  min-height: 36px;
  user-select: none;
}

.dot-grid-header.is-sortable {
  cursor: pointer;
}

.dot-grid-header.is-sortable:hover {
  color: var(--fg);
  background: var(--bg);
}

.dot-grid-header.is-num {
  justify-content: flex-end;
}

.dot-grid-header.is-asc,
.dot-grid-header.is-desc {
  color: var(--fg);
}

.dot-grid-header-text {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

.dot-grid-sort {
  font-size: 10px;
  color: var(--accent);
  flex-shrink: 0;
}

.dot-grid-row {
  display: grid;
  grid-column: 1/-1;
  grid-template-columns: subgrid;
  transition: background-color 80ms ease;
}

.dot-grid-row.is-clickable {
  cursor: pointer;
}

.dot-grid-row:hover {
  background: var(--bg-subtle);
}

.dot-grid-row.is-selected {
  background: var(--accent-soft);
}

.dot-grid-cell {
  padding: 0 12px;
  border-bottom: 1px solid var(--border);
  height: var(--row-h);
  display: flex;
  align-items: center;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12.5px;
}

.dot-grid-cell.is-num {
  justify-content: flex-end;
  font-variant-numeric: tabular-nums;
}

.dot-grid-cell .row,
.dot-grid-cell > * {
  min-width: 0;
}

.dot-grid-empty {
  grid-column: 1/-1;
  padding: 28px 16px;
  text-align: center;
  color: var(--fg-muted);
  font-size: 12.5px;
}

.dot-grid-footer {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-top: 1px solid var(--border);
  background: var(--bg);
  font-size: 12px;
  flex-wrap: wrap;
}

.dot-grid-footer .spacer {
  flex: 1;
}

@media (max-width: 768px) {
  .dot-grid {
    overflow-x: auto;
  }
  .dot-grid-container {
    min-width: max-content;
  }
}
.dot-grid-row.is-folder .dot-grid-cell:first-child {
  box-shadow: inset 2px 0 0 var(--accent);
}

.dot-grid-row.is-folder:hover {
  background: var(--accent-soft);
}

.dot-drawer-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15, 15, 20, 0.18);
  backdrop-filter: blur(2px);
  z-index: 2000;
  animation: dot-drawer-fade 0.15s ease;
}

.dot-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: 540px;
  max-width: 100vw;
  background: var(--bg);
  border-left: 1px solid var(--border);
  z-index: 2001;
  display: flex;
  flex-direction: column;
  box-shadow: -8px 0 32px rgba(0, 0, 0, 0.06);
  animation: dot-drawer-slide 0.2s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.dot-drawer-header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 12px;
}

.dot-drawer-header h2 {
  margin: 0;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.dot-drawer-header .dot-drawer-sub {
  font-size: 12px;
  color: var(--fg-muted);
  margin-top: 2px;
  font-family: var(--font-mono);
}

.dot-drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
}

.dot-drawer-footer {
  border-top: 1px solid var(--border);
  padding: 12px 20px;
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}

@keyframes dot-drawer-fade {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes dot-drawer-slide {
  from {
    transform: translateX(20px);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}
.dot-app {
  display: grid;
  grid-template-columns: var(--sidebar-w, 232px) 1fr;
  height: 100vh;
  overflow: hidden;
}

.dot-app[data-sidebar=collapsed] {
  --sidebar-w: 56px;
}

.dot-main {
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow: hidden;
  position: relative;
}

.dot-content {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  background: var(--bg);
  min-width: 0;
}

.dot-mobile-backdrop {
  display: none;
}

.dot-page-header {
  padding: 24px 24px 16px;
  border-bottom: 1px solid var(--border);
}

.dot-page-header h1 {
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0 0 4px;
}

.dot-page-header p {
  color: var(--fg-muted);
  margin: 0;
  font-size: 13px;
}

.dot-page-header .dot-page-header-row {
  display: flex;
  align-items: flex-end;
  gap: 16px;
}

.dot-page-header .dot-page-header-actions {
  display: flex;
  gap: 8px;
  margin-left: auto;
}

.dot-page-body {
  padding: 20px 24px 80px;
}

@media (max-width: 768px) {
  .dot-app {
    grid-template-columns: 1fr;
  }
  .dot-app .dot-sidebar {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    width: 264px;
    max-width: 85vw;
    z-index: 60;
    transform: translateX(-100%);
    transition: transform 0.2s ease;
    will-change: transform;
  }
  .dot-app[data-mobile-nav=open] .dot-sidebar {
    transform: translateX(0);
    box-shadow: 4px 0 24px rgba(0, 0, 0, 0.18);
  }
  .dot-mobile-backdrop {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(15, 15, 20, 0.45);
    z-index: 55;
    animation: dot-backdrop-fade 0.15s ease;
  }
  .dot-page-header {
    padding: 16px 16px 12px;
  }
  .dot-page-body {
    padding: 16px 16px 80px;
  }
}
@keyframes dot-backdrop-fade {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.dot-sidebar {
  background: var(--bg-subtle);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.dot-sidebar-brand {
  height: 52px;
  display: flex;
  align-items: center;
  padding: 0 16px;
  gap: 10px;
  color: var(--fg);
  text-decoration: none;
}

.dot-sidebar-brand-icon {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
  display: block;
}

.dot-sidebar-brand-text {
  font-weight: 600;
  font-size: 14px;
  letter-spacing: -0.01em;
  color: var(--fg-muted);
}

.dot-sidebar-brand-accent {
  color: #f39200;
}

.dot-sidebar-nav {
  flex: 1;
  overflow-y: auto;
  padding: 4px 8px;
}

.dot-sidebar-section {
  margin-top: 14px;
}

.dot-sidebar-section-label {
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-subtle);
  padding: 4px 10px;
  font-weight: 500;
}

.dot-sidebar-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 10px;
  border-radius: var(--radius);
  color: var(--fg-muted);
  font-size: 13px;
  font-weight: 450;
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
  margin: 1px 0;
  text-decoration: none;
}

.dot-sidebar-link:hover {
  background: var(--bg-hover);
  color: var(--fg);
}

.dot-sidebar-link.active,
.dot-sidebar-link[data-active=true] {
  background: var(--bg-muted);
  color: var(--fg);
  font-weight: 500;
}

.dot-sidebar-link svg {
  width: 15px;
  height: 15px;
  flex-shrink: 0;
}

.dot-sidebar-link .dot-sidebar-badge {
  margin-left: auto;
  background: var(--bg-muted);
  color: var(--fg-muted);
  font-size: 10.5px;
  padding: 1px 6px;
  border-radius: 999px;
  font-weight: 500;
}

.dot-sidebar-link.active .dot-sidebar-badge,
.dot-sidebar-link[data-active=true] .dot-sidebar-badge {
  background: var(--bg);
}

.dot-sidebar-version {
  border-top: 1px solid var(--border);
  height: 33px;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 16px;
  font-size: 10.5px;
  color: var(--fg-subtle);
  font-family: var(--font-mono);
  letter-spacing: 0.02em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (min-width: 769px) {
  .dot-app[data-sidebar=collapsed] .dot-sidebar-brand-text,
  .dot-app[data-sidebar=collapsed] .dot-sidebar-section-label,
  .dot-app[data-sidebar=collapsed] .dot-sidebar-link span,
  .dot-app[data-sidebar=collapsed] .dot-sidebar-link .dot-sidebar-badge,
  .dot-app[data-sidebar=collapsed] .dot-sidebar-version {
    display: none;
  }
}
.dot-topbar {
  height: 52px;
  border-bottom: 1px solid var(--border);
  padding: 0 20px;
  display: flex;
  align-items: center;
  gap: 16px;
  background: var(--bg);
  flex-shrink: 0;
  min-width: 0;
}

.dot-topbar .dot-crumbs {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.dot-topbar .dot-crumbs > * {
  flex-shrink: 0;
}

.dot-topbar .dot-crumbs .dot-crumb-cur {
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

.dot-topbar .dot-crumbs .dot-crumb-sep {
  color: var(--fg-subtle);
  display: inline-flex;
}

.dot-topbar .dot-crumbs a {
  color: var(--fg-muted);
  cursor: pointer;
}

.dot-topbar .dot-crumbs a:hover {
  color: var(--fg);
}

.dot-topbar .dot-crumbs .dot-crumb-cur {
  font-weight: 500;
}

@media (max-width: 768px) {
  .dot-topbar {
    padding: 0 12px;
    gap: 8px;
  }
}
.dot-path-bar {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: 12px;
  background: var(--bg-subtle);
  flex-wrap: wrap;
}

.dot-path-bar .seg {
  color: var(--fg-muted);
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 4px;
}

.dot-path-bar .seg:hover {
  background: var(--bg-muted);
  color: var(--fg);
}

.dot-path-bar .seg.cur {
  color: var(--fg);
  font-weight: 500;
}

.dot-path-bar .sep {
  color: var(--fg-subtle);
}

.dot-log-stream {
  font-family: var(--font-mono);
  font-size: 12px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.dot-log-row {
  display: grid;
  grid-template-columns: 80px 64px 100px 1fr;
  gap: 12px;
  padding: 6px 14px;
  border-bottom: 1px solid var(--border);
  align-items: baseline;
  height: 30px;
  box-sizing: border-box;
  overflow: hidden;
}

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

.dot-log-row .t {
  color: var(--fg-subtle);
}

.dot-log-row .lvl {
  font-size: 10.5px;
  font-weight: 600;
  text-transform: uppercase;
}

.dot-log-row .src {
  color: var(--fg-muted);
}

.dot-log-row .msg {
  color: var(--fg);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dot-log-row.is-info .lvl {
  color: var(--info);
}

.dot-log-row.is-warn .lvl {
  color: var(--warn);
}

.dot-log-row.is-error .lvl,
.dot-log-row.is-err .lvl,
.dot-log-row.is-crt .lvl {
  color: var(--danger);
}

.dot-log-row.is-debug .lvl,
.dot-log-row.is-dbg .lvl {
  color: var(--fg-subtle);
}

.dot-log-row.is-success .lvl {
  color: var(--success);
}

.dot-log-row:hover {
  background: var(--bg-subtle);
}

.dot-log-row.is-error,
.dot-log-row.is-err,
.dot-log-row.is-crt {
  background: rgba(220, 38, 38, 0.04);
}

.dot-log-console {
  flex-shrink: 0;
  background: var(--bg-subtle);
  border-top: 1px solid var(--border);
  box-shadow: 0 -2px 8px rgba(0, 0, 0, 0.04);
  transition: height 0.2s ease;
}

.dot-log-console.is-expanded {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 40;
  height: 320px;
  display: flex;
  flex-direction: column;
}

.dot-log-console-header {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 33px;
  box-sizing: border-box;
  padding: 0 16px;
  cursor: pointer;
  user-select: none;
  font-size: 12px;
  font-weight: 600;
  color: var(--fg-muted);
}

.dot-log-console-header:hover {
  background: var(--bg-muted);
}

.dot-log-console-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 16px;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}

.dot-log-console-toolbar .dot-input,
.dot-log-console-toolbar .dot-select {
  height: 26px;
  font-size: 11.5px;
}

.dot-multi-select {
  position: relative;
  display: inline-block;
}

.dot-multi-select-trigger {
  height: 26px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--bg);
  color: var(--fg);
  padding: 0 8px;
  font-size: 11.5px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  min-width: 130px;
  max-width: 240px;
}

.dot-multi-select-trigger > span {
  flex: 1;
  text-align: left;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dot-multi-select-trigger:hover {
  border-color: var(--border-strong);
}

.dot-multi-select-menu {
  position: absolute;
  bottom: calc(100% + 4px);
  left: 0;
  z-index: 50;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  padding: 4px;
  min-width: 100%;
  display: flex;
  flex-direction: column;
}

.dot-multi-select-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-radius: var(--radius);
  cursor: pointer;
  font-size: 12px;
  color: var(--fg);
  user-select: none;
}

.dot-multi-select-item:hover {
  background: var(--bg-hover);
}

.dot-log-console-body {
  flex: 1;
  overflow-y: auto;
  font-family: var(--font-mono);
  font-size: 11.5px;
  line-height: 1.5;
  padding: 4px 16px;
  background: var(--bg);
}

.dot-log-entry {
  white-space: nowrap;
  padding: 1px 0;
  display: flex;
  gap: 10px;
}

.dot-log-entry-time {
  color: var(--fg-subtle);
  flex-shrink: 0;
}

.dot-log-entry-level {
  font-weight: 700;
  width: 28px;
  flex-shrink: 0;
}

.dot-log-entry-category {
  color: var(--fg-muted);
  flex-shrink: 0;
}

.dot-log-entry-msg {
  color: var(--fg);
  overflow: hidden;
  text-overflow: ellipsis;
}

.dot-log-entry.is-inf .dot-log-entry-level {
  color: var(--info);
}

.dot-log-entry.is-wrn .dot-log-entry-level {
  color: var(--warn);
}

.dot-log-entry.is-err .dot-log-entry-level,
.dot-log-entry.is-crt .dot-log-entry-level {
  color: var(--danger);
}

.dot-log-entry.is-err,
.dot-log-entry.is-crt {
  background: rgba(220, 38, 38, 0.05);
}

.dot-auth-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-subtle);
  padding: 20px;
}

.dot-auth-card {
  width: 360px;
  max-width: 100%;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  box-shadow: var(--shadow-md);
}

.dot-auth-logo {
  display: flex;
  justify-content: center;
  margin-bottom: 8px;
}

.dot-auth-logo img {
  height: 36px;
  width: auto;
}

.dot-auth-title {
  text-align: center;
  font-size: 18px;
  font-weight: 600;
  margin: 16px 0 4px;
}

.dot-auth-sub {
  text-align: center;
  color: var(--fg-muted);
  font-size: 13px;
  margin-bottom: 20px;
}

.dot-auth-error {
  background: var(--danger-soft);
  color: var(--danger);
  border: 1px solid var(--danger);
  border-radius: var(--radius);
  padding: 8px 12px;
  font-size: 12.5px;
  margin-bottom: 16px;
}

.dot-auth-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.dot-auth-form label {
  font-size: 12px;
  font-weight: 500;
  margin-bottom: -6px;
  color: var(--fg);
}

.dot-auth-form input {
  height: 36px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0 12px;
  background: var(--bg);
  font-size: 13px;
  outline: none;
  color: var(--fg);
}

.dot-auth-form input:focus {
  border-color: var(--fg);
}

.dot-auth-form button {
  margin-top: 8px;
  height: 38px;
  background: var(--fg);
  color: var(--bg);
  border: 0;
  border-radius: var(--radius);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
}

.dot-auth-form button:hover {
  background: #1f1f23;
}

.dot-fi {
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--fg-muted);
  flex-shrink: 0;
}

.dot-message {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px 14px;
  font-size: 12.5px;
  margin: 12px 0;
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.dot-message-title {
  font-weight: 600;
}

.dot-message.is-error {
  background: var(--danger-soft);
  border-color: var(--danger);
  color: var(--danger);
}

.dot-message.is-warning {
  background: var(--warn-soft);
  border-color: var(--warn);
  color: var(--warn);
}

.dot-message.is-success {
  background: var(--success-soft);
  border-color: var(--success);
  color: var(--success);
}

.dot-message.is-info {
  background: var(--info-soft);
  border-color: var(--info);
  color: var(--info);
}

.dot-spinner {
  width: 28px;
  height: 28px;
  border: 2.5px solid var(--bg-muted);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: dot-spin 0.8s linear infinite;
  display: inline-block;
}

@keyframes dot-spin {
  to {
    transform: rotate(360deg);
  }
}
.dot-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px;
}

.dot-disk-cell {
  width: 14px;
  height: 14px;
  border: 1px solid var(--border);
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  color: var(--success);
  background: var(--success-soft);
}

.dot-disk-cell.is-warn {
  color: var(--warn);
  background: var(--warn-soft);
}

.dot-setting-row {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 24px;
  padding: 18px 0;
  border-bottom: 1px solid var(--border);
  align-items: flex-start;
}

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

.dot-setting-row .dot-setting-label {
  font-size: 13px;
  font-weight: 500;
}

.dot-setting-row .dot-setting-hint {
  color: var(--fg-muted);
  font-size: 12px;
  margin-top: 4px;
}

/*# sourceMappingURL=app.css.map */
