/* Hub 补充样式 (主题用 DaisyUI 内置 data-theme, 见顶栏切换) */
body.hub-app {
  min-height: 100dvh;
  font-family: Inter, system-ui, sans-serif;
}

/* 桌面端侧栏常开 (与 _head 内联关键 CSS 一致; 侧栏 HTMX boost 不卸载, 仅整页直开时兜底) */
@media (min-width: 1024px) {
  body.hub-app .drawer.lg\:drawer-open > .drawer-toggle {
    display: none;
  }
  body.hub-app .drawer.lg\:drawer-open > .drawer-toggle ~ .drawer-side {
    pointer-events: auto;
    visibility: visible;
    position: sticky;
    display: block;
    width: auto;
  }
  body.hub-app .drawer.lg\:drawer-open > .drawer-toggle ~ .drawer-side > :not(.drawer-overlay) {
    transform: translateX(0);
  }
  body.hub-app .drawer.lg\:drawer-open > .drawer-side > .drawer-overlay {
    pointer-events: none;
    cursor: default;
  }
}

/* 数字输入框去掉浏览器自带上下箭头, 避免误点改值 */
body.hub-app input[type="number"] {
  -moz-appearance: textfield;
  appearance: textfield;
}
body.hub-app input[type="number"]::-webkit-outer-spin-button,
body.hub-app input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* 作战台右上角 Toast: 不挡点击下层, 单条 alert 可关 */
#cmd-toast-host .alert {
  max-width: min(24rem, calc(100vw - 2rem));
}

.hub-notify-bar {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1rem;
  padding: 0.5rem 0.75rem;
  border-radius: var(--rounded-box, 0.75rem);
  border: 1px solid color-mix(in oklch, var(--color-primary) 25%, transparent);
  background: var(--color-base-200);
  font-size: 0.875rem;
  opacity: 0.92;
}

.hub-risk-html table {
  width: 100%;
  font-size: 0.75rem;
  border-collapse: collapse;
}

.hub-risk-html td,
.hub-risk-html th {
  padding: 0.25rem 0.5rem;
  border-bottom: 1px solid color-mix(in oklch, var(--color-base-content) 8%, transparent);
}

/* 作战台账号卡: 按内容高度排列, 避免邻卡持仓表把无持仓卡撑高后「持仓」错位 */
#cmd-cards-grid {
  align-items: start;
}
#cmd-cards-grid > .card {
  height: auto;
  align-self: start;
}
#cmd-cards-grid > .card > .card-body {
  flex: none;
  justify-content: flex-start;
}
.hub-risk-html {
  flex: none;
}
/* risk_line 内联 HTML 不依赖 Tailwind, 与 NiceGUI 作战台行布局一致 */
.hub-risk-html .risk-stats {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  font-size: 0.75rem;
  line-height: 1.625;
}
.hub-risk-html .risk-stats-row {
  display: flex;
  flex-wrap: nowrap;
  align-items: baseline;
  width: 100%;
  column-gap: 0.375rem;
}
.hub-risk-html .risk-stats-spacer {
  flex: 1 1 0.75rem;
  min-width: 0.75rem;
}
/* 持仓区最小高度: 表头+一行 / 「无持仓」, 同排卡片标题对齐 */
.cmd-card-positions {
  min-height: 4.5rem;
}

.htmx-request .htmx-indicator {
  display: inline-flex;
}

.htmx-indicator {
  display: none;
}

.material-symbols-outlined {
  font-size: 1.25rem;
  vertical-align: middle;
}

/* 管理页旧 class 兼容 */
.hub-glass-card {
  margin-bottom: 1rem;
  padding: 1.25rem;
  border-radius: var(--rounded-box, 1rem);
  background: var(--color-base-200);
  box-shadow: 0 4px 24px color-mix(in oklch, black 35%, transparent);
}

.hub-table {
  width: 100%;
  font-size: 0.875rem;
}

.hub-table th,
.hub-table td {
  padding: 0.5rem 0.75rem;
  border-bottom: 1px solid color-mix(in oklch, var(--color-base-content) 8%, transparent);
}

.hub-table-wrap {
  overflow-x: auto;
}

.hub-muted {
  opacity: 0.65;
}

.hub-form-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

.hub-form-grid {
  display: grid;
  gap: 0.75rem;
  grid-template-columns: repeat(auto-fill, minmax(11rem, 1fr));
}

/* 作战台分组 Tab 多时横向滚动, 避免换行挤占与误点 */
.cmd-tabs-scroll {
  display: flex;
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}
.cmd-tabs-scroll .tab {
  white-space: nowrap;
}
