/**
 * 本应报告 × PhosphorUI 主题桥接
 * 在保留现有 class（panel / card / primary）的前提下套用复古未来主义视觉。
 */

@font-face {
  font-family: "DingTalk JinBuTi";
  src: url("/static/fonts/DingTalk-JinBuTi.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

:root {
  --benying-font: "DingTalk JinBuTi", "PingFang SC", "Microsoft YaHei", "Noto Sans SC", sans-serif;
  --ph-font-mono: var(--benying-font);
  --ph-font-display: var(--benying-font);
  --benying-sidebar-width: 248px;
}

body.benying-phosphor {
  font-family: var(--benying-font) !important;
  color: var(--ph-white);
  background-color: var(--ph-bg);
}

body.benying-phosphor button,
body.benying-phosphor input,
body.benying-phosphor textarea,
body.benying-phosphor select,
body.benying-phosphor .ph-heading,
body.benying-phosphor .ph-logo {
  font-family: var(--benying-font) !important;
}

/* 侧栏导航 */
.ph-sidebar.sidebar {
  width: var(--benying-sidebar-width);
  background: var(--ph-surface-2);
  border-right: 2px solid var(--ph-surface-3);
  padding: 0.75rem 0 1rem;
}

.brand {
  padding: 0 1rem 1rem;
  border-bottom: 1px solid var(--ph-surface-3);
  margin-bottom: 0.75rem;
}

.brand strong {
  font-family: var(--benying-font);
  font-size: 0.95rem;
  letter-spacing: 0.06em;
  color: var(--ph-amber);
  text-transform: uppercase;
}

.brand-sub {
  color: var(--ph-white);
  opacity: 0.65;
  font-size: 0.72rem;
}

.sidebar-chat-btn {
  margin: 0 0.75rem 0.65rem;
  width: calc(100% - 1.5rem);
  border: 2px solid var(--ph-cyan);
  border-radius: 0;
  background: transparent;
  color: var(--ph-cyan);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
}

.sidebar-chat-btn:hover {
  background: var(--ph-cyan);
  color: var(--ph-bg);
}

.nav-group-label {
  display: block;
  padding: 0.35rem 0 0.15rem;
  color: var(--ph-cyan);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  opacity: 0.9;
}

/* 侧栏：> 与链接同一行（覆盖 ph-list 默认换行） */
.benying-nav ul.ph-list {
  line-height: 1.45;
  padding-left: 0;
}

.benying-nav ul.ph-list > li {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0.2rem;
}

.benying-nav ul.ph-list > li::before {
  flex-shrink: 0;
  line-height: 1;
  margin-right: 0;
  font-weight: 700;
}

.benying-nav ul.ph-list.nav-stage-group {
  margin-left: 0.65rem;
  padding-left: 0;
  border-left: 2px solid var(--ph-surface-3);
}

.benying-nav ul.ph-list.nav-stage-group > li::before {
  content: ">>";
  color: var(--ph-cyan);
}

.benying-nav .nav-item.ph-link {
  display: inline;
  flex: 1;
  min-width: 0;
  padding: 0;
  border: 0;
  border-bottom: 1px dashed var(--ph-cyan);
  color: var(--ph-cyan);
  font-size: 0.9rem;
  line-height: 1.35;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.benying-nav .nav-item.ph-link:hover {
  background: transparent;
  color: var(--ph-amber);
  border-bottom-color: var(--ph-amber);
}

.benying-nav .nav-item.ph-link.active {
  background: transparent;
  color: var(--ph-amber);
  border-bottom: 1px solid var(--ph-amber);
  font-weight: 700;
}

.benying-nav .nav-item.nav-stage-muted {
  opacity: 0.45;
  font-style: italic;
}

.sidebar-foot {
  border-top: 1px solid var(--ph-surface-3);
}

.sidebar-foot .badge.ok {
  background: rgba(0, 255, 65, 0.15);
  color: var(--ph-green);
  border: 1px solid var(--ph-green);
}

.sidebar-foot .badge:not(.ok) {
  background: rgba(255, 176, 0, 0.12);
  color: var(--ph-amber);
  border: 1px solid var(--ph-amber);
}

/* 主区 */
.ph-main.main {
  background: var(--ph-bg);
}

.main-header {
  background: var(--ph-surface-1);
  border-bottom: 2px solid var(--ph-surface-3);
  padding: 0.85rem 1.25rem;
}

.main-header h1,
#page-title-text {
  font-family: var(--ph-font-display);
  color: var(--ph-amber);
  font-size: 1.05rem;
  letter-spacing: 0.05em;
}

.page-title-sub {
  color: var(--ph-white) !important;
  opacity: 0.7;
  font-family: var(--ph-font-mono);
}

.page-content {
  padding: 1rem 1.25rem 2rem;
}

.system-status-bar {
  background: var(--ph-surface-2);
  border-color: var(--ph-surface-3);
  color: var(--ph-white);
}

.system-status-label,
.system-status-bar .form-hint {
  color: var(--ph-white);
  opacity: 0.75;
}

.system-status-help-btn {
  border-color: var(--ph-cyan);
  background: transparent;
  color: var(--ph-cyan);
}

.system-status-help-tip {
  background: var(--ph-surface-1);
  border: 2px solid var(--ph-surface-3);
  color: var(--ph-white);
  box-shadow: 4px 4px 0 var(--ph-surface-3);
}

.system-status-help-table th,
.system-status-help-table td {
  border-color: var(--ph-surface-3);
}

.system-status-help-table th {
  background: var(--ph-surface-2);
}

.system-status-active {
  background: rgba(0, 243, 243, 0.15);
  color: var(--ph-cyan);
}

/* 面板与卡片 */
.panel,
.card,
.feature-panel,
.gen-progress-card,
.chat-drawer-panel {
  background: var(--ph-surface-1);
  border: 2px solid var(--ph-surface-3);
  border-radius: 0;
  color: var(--ph-white);
  box-shadow: 4px 4px 0 rgba(0, 0, 0, 0.35);
}

.panel h2,
.feature-panel h2,
.card h3 {
  font-family: var(--ph-font-display);
  color: var(--ph-amber);
  letter-spacing: 0.04em;
}

.feature-panel {
  border-color: var(--ph-cyan);
  background: rgba(0, 243, 243, 0.05);
}

.feature-panel h2 {
  color: var(--ph-cyan);
}

.form-hint {
  color: var(--ph-white);
  opacity: 0.72;
}

.board-intro code,
.system-status-help-meta code {
  background: var(--ph-surface-2);
  color: var(--ph-cyan);
  border: 1px solid var(--ph-surface-3);
}

.board-intro ul.board-links {
  color: var(--ph-white);
  opacity: 0.85;
}

/* 表单控件 */
input,
textarea,
select {
  background: var(--ph-surface-2);
  border: 2px solid var(--ph-surface-3);
  border-radius: 0;
  color: var(--ph-white);
}

input:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: var(--ph-amber);
}

input::placeholder,
textarea::placeholder {
  color: var(--ph-white);
  opacity: 0.4;
}

/* 按钮 */
button {
  border-radius: 0;
  font-family: var(--ph-font-display);
  letter-spacing: 0.03em;
  border: 2px solid var(--ph-white);
  background: var(--ph-bg);
  color: var(--ph-white);
}

button:hover {
  background: var(--ph-surface-3);
  color: var(--ph-amber);
}

button.primary {
  border-color: var(--ph-amber);
  color: var(--ph-amber);
  background: transparent;
}

button.primary:hover {
  background: var(--ph-amber);
  color: var(--ph-bg);
}

button.secondary {
  border-color: var(--ph-cyan);
  color: var(--ph-cyan);
  background: transparent;
}

button.secondary:hover {
  background: var(--ph-cyan);
  color: var(--ph-bg);
}

/* 状态与标签 */
.badge {
  border-radius: 0;
  background: rgba(255, 176, 0, 0.15);
  color: var(--ph-amber);
  border: 1px solid var(--ph-amber);
}

.badge.ok {
  background: rgba(0, 255, 65, 0.12);
  color: var(--ph-green);
  border-color: var(--ph-green);
}

.state-pill {
  font-family: var(--ph-font-display);
  color: var(--ph-cyan);
}

.state,
.agent-meta {
  color: var(--ph-white);
  opacity: 0.7;
}

/* 链接 */
a.dl,
.primary-link,
.board-links a {
  color: var(--ph-cyan);
}

a.dl:hover,
.primary-link:hover {
  color: var(--ph-amber);
}

/* 分析/日志区块 */
.analysis-box,
.topic-item,
.agent-block-header,
.agent-section {
  background: var(--ph-surface-2);
  border: 1px solid var(--ph-surface-3);
  color: var(--ph-white);
}

.topic-item:hover {
  border-color: var(--ph-amber);
  background: rgba(255, 176, 0, 0.08);
}

.analysis-box pre,
.panel pre,
.research-log-box,
.app-log-pre {
  color: var(--ph-white);
}

.app-log-pre,
.research-log-box {
  background: var(--ph-surface-2);
  border: 1px solid var(--ph-surface-3);
}

/* Agent 页 tabs */
.agent-tabs {
  border-bottom-color: var(--ph-surface-3);
}

.agent-tab.active {
  background: var(--ph-surface-1);
  border-bottom-color: var(--ph-amber);
}

.agent-tab-title {
  color: var(--ph-white);
}

.agent-tab.active .agent-tab-title {
  color: var(--ph-amber);
}

/* 进度弹层 */
.gen-progress-overlay {
  background: rgba(0, 0, 0, 0.82);
}

.gen-progress-bar {
  background: var(--ph-surface-3);
}

.gen-progress-bar-fill {
  background: linear-gradient(90deg, var(--ph-amber), var(--ph-orange));
}

.gen-step-active {
  color: var(--ph-cyan);
}

.gen-step-done {
  color: var(--ph-green);
}

/* Haisnap 可视化 */
.haisnap-viz-step {
  border-color: var(--ph-surface-3);
  background: var(--ph-surface-2);
}

.haisnap-viz-step.is-active {
  border-color: var(--ph-amber);
}

.haisnap-viz-step.is-done {
  border-color: var(--ph-green);
}

/* 对话抽屉 */
.chat-drawer-panel {
  border-left: 2px solid var(--ph-amber);
}

.chat-drawer-header h2 {
  font-family: var(--ph-font-display);
  color: var(--ph-amber);
}

.chat-messages {
  background: var(--ph-surface-2);
}

.chat-msg-user {
  background: rgba(0, 243, 243, 0.12);
  border: 1px solid var(--ph-cyan);
}

.chat-msg-assistant {
  background: rgba(255, 176, 0, 0.08);
  border: 1px solid var(--ph-amber);
}

/* Toast */
.app-toast {
  background: var(--ph-surface-1);
  border: 2px solid var(--ph-amber);
  color: var(--ph-amber);
  box-shadow: 4px 4px 0 var(--ph-surface-3);
}

.app-toast-error {
  border-color: var(--ph-red);
  color: var(--ph-red);
}

/* Mermaid 图表在深色底上的可读性 */
.board-diagram .mermaid svg {
  filter: invert(0.92) hue-rotate(180deg) brightness(0.95) contrast(0.9);
}

/* 顶栏（Phosphor 移动菜单） */
.benying-header .ph-logo {
  font-size: 1rem;
  letter-spacing: 0.08em;
}

.benying-header-sub {
  margin-left: 0.75rem;
  font-size: 0.72rem;
  color: var(--ph-white);
  opacity: 0.55;
  font-family: var(--ph-font-mono);
}

.ph-pageheader .ph-mobile-toggle {
  color: var(--ph-amber);
}

.ph-splitpagelayout.app {
  min-height: 100vh;
}

@media (max-width: 800px) {
  .ph-sidebar.sidebar {
    width: var(--benying-sidebar-width);
  }
  .ph-sidebar.sidebar .brand-sub {
    display: block;
  }
}

/* 表格（若页面使用原生 table） */
table {
  border-collapse: collapse;
  width: 100%;
}

th,
td {
  border: 1px solid var(--ph-surface-3);
  padding: 0.45rem 0.6rem;
}

th {
  font-family: var(--ph-font-display);
  color: var(--ph-amber);
  background: var(--ph-surface-2);
}
