/* OpenAlex 风格 - 白底、简洁、现代 */
* { box-sizing: border-box; }

body.openalex-style {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  margin: 0;
  padding: 0;
  background: #fff;
  color: #000;
  min-height: 100vh;
}

/* 主内容区 */
.page-wrap {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* 顶部导航：左产品区 | 右用户区 */
.top-nav {
  border-bottom: 1px solid #e0e0e0;
  padding: 0.75rem 2rem;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
}
.nav-main {
  display: flex;
  align-items: center;
  gap: 1.25rem;
}
.nav-brand {
  font-weight: 700;
  font-size: 1.1rem;
  color: #000;
  text-decoration: none;
}
.nav-brand:hover { color: #1565c0; }
.nav-sep {
  color: #ddd;
  font-weight: 300;
  user-select: none;
}
.nav-main > a {
  color: #333;
  text-decoration: none;
  font-size: 0.95rem;
}
.nav-main > a:hover { color: #000; text-decoration: underline; }
.nav-dropdown {
  position: relative;
}
.nav-dropdown-btn {
  background: none;
  border: none;
  color: #333;
  font-size: 0.95rem;
  cursor: pointer;
  padding: 0;
  font-family: inherit;
  display: flex;
  align-items: center;
  gap: 0.2rem;
}
.nav-dropdown-btn:hover { color: #000; text-decoration: underline; }
.nav-dropdown-chevron { font-size: 0.6rem; }
.nav-dropdown-menu {
  position: absolute;
  top: 100%;
  left: 0;
  margin: 0.25rem 0 0;
  padding: 0.5rem 0;
  list-style: none;
  background: #fff;
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  min-width: 160px;
  z-index: 100;
}
.nav-dropdown-menu a {
  display: block;
  padding: 0.4rem 1rem;
  color: #333;
  text-decoration: none;
  font-size: 0.9rem;
}
.nav-dropdown-menu a:hover {
  background: #f5f5f5;
  color: #1565c0;
}
.nav-user-area {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding-left: 1.25rem;
  border-left: 1px solid #eee;
}
.nav-btn-sm {
  padding: 0.3rem 0.65rem;
  font-size: 0.85rem;
}
.nav-user-role {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.6rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: #0d47a1;
  background: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%);
  border-radius: 999px;
  letter-spacing: 0.02em;
  border: 1px solid rgba(13, 71, 161, 0.2);
}
.nav-vip-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.55rem;
  font-size: 0.72rem;
  font-weight: 600;
  color: #b8860b;
  background: linear-gradient(135deg, #fffde7 0%, #fff9c4 100%);
  border-radius: 999px;
  letter-spacing: 0.03em;
  border: 1px solid rgba(184, 134, 11, 0.35);
  box-shadow: 0 1px 2px rgba(184, 134, 11, 0.08);
}
.nav-user-email {
  font-size: 0.9rem;
  color: #555;
  max-width: 12rem;
  overflow: hidden;
  text-overflow: ellipsis;
}
.nav-btn {
  display: inline-block;
  padding: 0.4rem 0.9rem;
  font-size: 0.9rem;
  font-weight: 500;
  border-radius: 6px;
  text-decoration: none;
  cursor: pointer;
  border: 1px solid transparent;
  font-family: inherit;
}
.nav-btn-ghost {
  background: transparent;
  color: #333;
  border-color: #ddd;
}
.nav-btn-ghost:hover {
  background: #f5f5f5;
  border-color: #ccc;
}
.nav-btn-primary {
  background: #1565c0;
  color: #fff;
  border-color: #1565c0;
}
.nav-btn-primary:hover {
  background: #0d47a1;
  border-color: #0d47a1;
}
.nav-logout-form { margin: 0; }

/* Flash 消息 */
.flash-messages {
  margin-bottom: 1.25rem;
}
.flash {
  margin: 0 0 0.75rem;
  padding: 0.75rem 1rem 0.75rem 2.75rem;
  border-radius: 8px;
  font-size: 0.9rem;
  line-height: 1.5;
  position: relative;
  border: 1px solid transparent;
  box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
.flash::before {
  content: "";
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1rem;
  height: 1rem;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.flash-error {
  background: #ffebee;
  color: #c62828;
  border-color: #ffcdd2;
}
.flash-error::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23c62828'%3E%3Cpath d='M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z'/%3E%3C/svg%3E");
}
.flash-success {
  background: #e8f5e9;
  color: #2e7d32;
  border-color: #c8e6c9;
}
.flash-success::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%232e7d32'%3E%3Cpath d='M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 15l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z'/%3E%3C/svg%3E");
}
.flash-warning {
  background: #fff8e1;
  color: #e65100;
  border-color: #ffecb3;
}
.flash-warning::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23e65100'%3E%3Cpath d='M1 21h22L12 2 1 21zm12-3h-2v-2h2v2zm0-4h-2v-4h2v4z'/%3E%3C/svg%3E");
}
.flash-info {
  background: #e3f2fd;
  color: #1565c0;
  border-color: #bbdefb;
}
.flash-info::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%231565c0'%3E%3Cpath d='M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-6h2v6zm0-8h-2V7h2v2z'/%3E%3C/svg%3E");
}

/* 主内容 */
.main {
  flex: 1;
  max-width: 1400px;
  margin: 0 auto;
  padding: 2rem;
  width: 100%;
}

/* 首页 Hero */
.home-hero {
  text-align: center;
  padding: 5rem 0 4rem;
  max-width: 720px;
  margin: 0 auto;
}
.hero-title {
  font-size: 2.25rem;
  font-weight: 700;
  line-height: 1.2;
  margin: 0 0 1rem;
  color: #000;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
}
.hero-title-icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  color: #000;
}
.hero-title-icon svg {
  display: block;
}
.hero-title-com {
  font-size: 0.65em;
  font-weight: 400;
  color: #1565c0;
  margin-left: 0.05em;
  display: inline-block;
  transform: translateY(0.25em);
}
.hero-desc {
  font-size: 1.05rem;
  line-height: 1.6;
  color: #333;
  margin: 0 0 2.5rem;
}

/* 首页搜索框 - 图1 风格：单框黑边、分隔线、选项栏 */
.hero-search { margin-bottom: 3rem; }
.hero-search-box {
  max-width: 640px;
  margin: 0 auto;
  border: 1px solid #000;
  border-radius: 8px;
  background: #fff;
  overflow: visible;
}
.hero-search-input-wrap {
  padding: 0.75rem 1rem;
}
.hero-search-input {
  width: 100%;
  border: none;
  padding: 0.5rem 0;
  font-size: 1rem;
  outline: none;
  background: transparent;
  box-sizing: border-box;
}
.hero-search-input::placeholder { color: #999; }
.hero-search-divider {
  margin: 0;
  border: none;
  border-top: 1px solid #e0e0e0;
}
.hero-search-options {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.5rem 1rem;
  flex-wrap: wrap;
}
.hero-type-dropdown { position: relative; }
.hero-type-btn {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.25rem 0;
  background: none;
  border: none;
  color: #555;
  cursor: pointer;
  font-size: 0.9rem;
}
.hero-type-btn:hover { color: #000; }
.hero-type-chevron { font-size: 0.55rem; color: #666; }
.hero-type-panel {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 0.35rem;
  min-width: 180px;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.12);
  z-index: 100;
  overflow: hidden;
}
.hero-type-panel[hidden] { display: none !important; }
.hero-type-option {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.6rem 1rem;
  cursor: pointer;
  font-size: 0.95rem;
  color: #333;
}
.hero-type-option:hover { background: #f5f5f5; }
.hero-type-option.selected { font-weight: 600; }
.hero-type-check { color: #1565c0; font-size: 0.9rem; }
.search-container {
  display: flex;
  border: 1px solid #ccc;
  border-radius: 8px;
  overflow: hidden;
  max-width: 560px;
  margin: 0 auto;
  background: #fff;
}
.search-input {
  flex: 1;
  border: none;
  padding: 0.9rem 1.25rem;
  font-size: 1rem;
  outline: none;
  color: #000;
}
.search-input::placeholder { color: #999; }
.search-btn {
  background: #000;
  color: #fff;
  border: none;
  padding: 0.9rem 1.5rem;
  font-size: 0.95rem;
  cursor: pointer;
  font-weight: 500;
}
.search-btn:hover { background: #333; }
.search-options {
  display: flex;
  gap: 0.75rem;
  justify-content: center;
  margin-top: 0.75rem;
}
.search-type, .search-tag {
  font-size: 0.85rem;
  color: #666;
  padding: 0.25rem 0.5rem;
}

/* 数据状态说明 */
.data-notice {
  margin-top: 2rem;
  padding: 1rem 1.25rem;
  background: #f5f9ff;
  border: 1px solid #e3f2fd;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  text-align: center;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  overflow-x: auto;
}
.data-notice-icon {
  flex-shrink: 0;
  padding: 0.2rem 0.5rem;
  background: #1565c0;
  color: #fff;
  border-radius: 4px;
  font-size: 0.85rem;
  font-weight: 600;
}
.data-notice-text {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.5;
  color: #333;
}
.data-notice-text strong { color: #0d47a1; }

/* Chat 区域 */
.chat-section {
  border-top: 1px solid #e0e0e0;
  padding-top: 2rem;
  background: #fafafa;
  margin: 0 -2rem;
  padding: 2rem;
}
.chat-area {
  min-height: 120px;
  max-height: 400px;
  overflow-y: auto;
  margin-bottom: 1rem;
}
.chat-area .welcome {
  text-align: center;
  padding: 1rem 0;
}
.chat-area .greeting {
  font-size: 1rem;
  color: #666;
  margin: 0;
}
.chat-form {
  display: flex;
  gap: 0.5rem;
  max-width: 720px;
  margin: 0 auto 1.5rem;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 8px;
  padding: 0.5rem;
}
.chat-form input {
  flex: 1;
  background: transparent;
  border: none;
  color: #000;
  font-size: 1rem;
  padding: 0.75rem 1rem;
  outline: none;
}
.chat-form input::placeholder { color: #999; }
.chat-form .send-btn {
  background: #000;
  color: #fff;
  border: none;
  padding: 0.5rem 1.25rem;
  border-radius: 6px;
  cursor: pointer;
  font-weight: 600;
}
.chat-form .send-btn:hover { background: #333; }
.preset-cards {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: center;
  max-width: 900px;
  margin: 0 auto;
}
.preset-card {
  background: #fff;
  border: 1px solid #ddd;
  color: #333;
  padding: 0.75rem 1.25rem;
  border-radius: 8px;
  cursor: pointer;
  font-size: 0.9rem;
  transition: background 0.2s, border-color 0.2s;
}
.preset-card:hover {
  background: #f5f5f5;
  border-color: #000;
}
.quick-tags {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}
.quick-tags .tag-label { font-size: 0.85rem; color: #666; }
.quick-tag {
  background: transparent;
  border: 1px dashed #999;
  color: #666;
  padding: 0.35rem 0.75rem;
  border-radius: 6px;
  cursor: pointer;
  font-size: 0.85rem;
}
.quick-tag:hover {
  border-color: #000;
  color: #000;
}

/* 消息样式 */
.msg {
  max-width: 800px;
  margin: 1rem auto;
  padding: 1rem 1.25rem;
  border-radius: 8px;
}
.msg.user {
  background: #f0f0f0;
  margin-left: auto;
  margin-right: 2rem;
}
.msg.assistant {
  background: #fff;
  margin-right: auto;
  margin-left: 2rem;
  border: 1px solid #e0e0e0;
}
.msg-content { margin-bottom: 0.5rem; color: #333; line-height: 1.5; }
.msg-content strong { color: #000; }
.msg-table-wrap {
  overflow-x: auto;
  max-height: 320px;
  overflow-y: auto;
  margin-top: 0.75rem;
}
.msg-table-wrap table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}
.msg-table-wrap th,
.msg-table-wrap td {
  padding: 0.4rem 0.6rem;
  text-align: left;
  border-bottom: 1px solid #e0e0e0;
  color: #333;
}
.msg-table-wrap th { background: #f5f5f5; color: #000; font-weight: 600; }
.msg-table-wrap .scholar-link { color: #1565c0; text-decoration: none; }
.msg-table-wrap .scholar-link:hover { text-decoration: underline; }
.table-more { color: #666; font-size: 0.8rem; margin-top: 0.5rem; }

/* 学者列表页 */
.scholar-list-page { max-width: 1200px; margin: 0 auto; }
.list-search-form { margin-bottom: 2rem; }

/* OpenAlex 风格搜索栏 */
.search-bar-wrap { margin-bottom: 0.75rem; }
.search-main-bar {
  border: 1px solid #ccc;
  border-radius: 24px;
  overflow: hidden;
  max-width: 100%;
  background: #fff;
}
.search-main-input {
  width: 100%;
  border: none;
  padding: 0.85rem 1.25rem;
  font-size: 1rem;
  outline: none;
  border-radius: 24px;
  box-sizing: border-box;
}
.search-main-input::placeholder { color: #999; }
.search-main-input[readonly] {
  background: #f9f9f9;
  cursor: default;
  color: #666;
}
.search-main-bar-with-btn {
  display: flex;
  align-items: stretch;
}
.search-main-bar-with-btn .search-main-input { flex: 1; min-width: 0; border-radius: 24px 0 0 24px; }
.search-main-btn {
  padding: 0 1.25rem;
  background: #000;
  color: #fff;
  border: none;
  font-size: 0.95rem;
  font-weight: 500;
  cursor: pointer;
  border-radius: 0 24px 24px 0;
}
.search-main-btn:hover { background: #333; }
.search-entry-hint {
  margin: 0.35rem 0 0;
  font-size: 0.85rem;
  color: #999;
}
.search-entry-hint a { color: #1565c0; text-decoration: none; }
.search-entry-hint a:hover { text-decoration: underline; }

.talent-quota-hint {
  margin: 0.5rem 0 0;
  font-size: 0.9rem;
  color: #666;
}
.talent-quota-hint a { color: #1565c0; text-decoration: none; }
.talent-quota-hint a:hover { text-decoration: underline; }
.talent-quota-vip { color: #2e7d32; }

.rank-mode-tabs {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.rank-country-combo,
.rank-sort-combo {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.35rem 0.75rem;
  border: 1px solid #ccc;
  border-radius: 8px;
  background: #fafafa;
}
.rank-sort-combo { font-size: 0.9rem; }
.rank-sort-combo .sort-label { color: #666; }
.rank-sort-combo .sort-link { color: #1565c0; text-decoration: none; }
.rank-sort-combo .sort-link:hover { text-decoration: underline; }
.rank-sort-combo .sort-active { font-weight: 600; color: #000; }
.rank-sort-combo .sort-sep { color: #ccc; margin: 0 0.25rem; }
.rank-tab {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.9rem;
  color: #333;
  cursor: pointer;
}
.rank-tab input { margin: 0; }
.rank-tab:hover { color: #1565c0; }
.rank-table-wrap { overflow-x: auto; margin-top: 1rem; }
.rank-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}
.rank-table th,
.rank-table td {
  padding: 0.6rem 0.75rem;
  text-align: left;
  border-bottom: 1px solid #e8e8e8;
}
.rank-table th {
  background: #f5f5f5;
  font-weight: 600;
  color: #333;
}
.rank-table tbody tr:hover { background: #fafafa; }
.rank-table .rank-num { width: 4rem; color: #666; font-weight: 500; }
.rank-table .rank-name { font-weight: 500; color: #1565c0; }
.rank-table .meta-num { font-variant-numeric: tabular-nums; }

.search-filters-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.filter-dropdown { position: relative; }
.filter-btn {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.75rem;
  border: 1px solid #ccc;
  border-radius: 20px;
  background: #fff;
  cursor: pointer;
  font-size: 0.9rem;
  color: #333;
}
.filter-btn:hover:not(:disabled) { border-color: #999; background: #f9f9f9; }
.filter-btn:disabled { cursor: default; opacity: 0.9; }
.filter-btn-chevron { font-size: 0.65rem; color: #666; }
.filter-type .filter-btn-static { cursor: default; background: #f0f0f0; }
.filter-more { font-size: 0.9rem; color: #666; margin-left: 0.25rem; }

.filter-panel {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 0.35rem;
  min-width: 280px;
  max-width: 400px;
  max-height: 360px;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.12);
  z-index: 100;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.filter-panel[hidden] { display: none !important; }
.filter-search {
  padding: 0.6rem 1rem 0.6rem 2.25rem;
  border: none;
  border-bottom: 1px solid #eee;
  font-size: 0.9rem;
  outline: none;
  background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E") no-repeat 0.75rem center;
}
.filter-list-panel {
  list-style: none;
  margin: 0;
  padding: 0.5rem 0;
  overflow-y: auto;
  max-height: 280px;
}
.filter-option {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.5rem 1rem;
  cursor: pointer;
  font-size: 0.9rem;
  color: #333;
}
.filter-option:hover { background: #f5f5f5; }
.filter-option-label { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.filter-option-count { color: #999; font-size: 0.85rem; margin-left: 0.5rem; flex-shrink: 0; }
.filter-option-empty { padding: 1rem; color: #999; font-size: 0.9rem; cursor: default; }
.filter-option-clear { color: #1565c0; font-weight: 500; border-bottom: 1px solid #eee; }
.filter-option-clear:hover { background: #e3f2fd; }

/* 兼容旧表单 */
.list-search-container {
  display: flex;
  border: 1px solid #ccc;
  border-radius: 8px;
  overflow: hidden;
  max-width: 560px;
}
.list-search-input {
  flex: 1;
  border: none;
  padding: 0.75rem 1rem;
  font-size: 1rem;
  outline: none;
}
.list-search-btn {
  background: #000;
  color: #fff;
  border: none;
  padding: 0.75rem 1.25rem;
  cursor: pointer;
  font-weight: 500;
}
.list-search-btn:hover { background: #333; }

/* 两栏布局 */
.list-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 2rem;
}
.list-main { min-width: 0; }
.search-result-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1rem;
}
.result-count {
  font-size: 0.95rem;
  color: #666;
}
.result-sort { font-size: 0.9rem; }
.result-sort .sort-label { color: #666; }
.result-sort .sort-link {
  color: #1565c0;
  text-decoration: none;
  margin: 0 0.25rem;
}
.result-sort .sort-link:hover { text-decoration: underline; }
.result-sort .sort-active { font-weight: 600; color: #000; }
.result-sort .sort-sep { color: #ccc; margin: 0 0.25rem; }

/* 学者结果列表 */
.scholar-results {
  list-style: none;
  padding: 0;
  margin: 0;
}
.scholar-item {
  padding: 1rem 0;
  border-bottom: 1px solid #e0e0e0;
}
.scholar-item:last-child { border-bottom: none; }
.scholar-title {
  font-size: 1.5rem;
  color: #1565c0;
  text-decoration: none;
  display: block;
  margin-bottom: 0.5rem;
}
.scholar-title:hover { text-decoration: underline; }
.scholar-meta {
  font-size: 0.9rem;
  color: #666;
}
.scholar-meta .meta-institution { margin-right: 1rem; }
.scholar-meta .meta-country,
.scholar-meta .meta-cited,
.scholar-meta .meta-h,
.scholar-meta .meta-works { margin-right: 0.75rem; }
.scholar-meta .meta-growth { margin-right: 0.6rem; font-size: 0.88em; color: #2e7d32; }
.scholar-meta .meta-burst { margin-right: 0.6rem; font-size: 0.88em; color: #1565c0; }
.future-star-hint { margin: 0.5rem 0; padding-left: 1.2rem; font-size: 0.9rem; color: #555; line-height: 1.6; }
.corp-intel-summary { margin: 0.75rem 0 1rem; }
.corp-concentration { font-size: 0.95rem; color: #333; }
.corp-section-title { font-size: 1.1rem; margin: 1rem 0 0.5rem; color: #333; }

/* 企业技术情报：左右对比布局，每边占一半空间 */
.corp-compare-layout { max-width: 1400px; margin: 0 auto; background: #fff; }
.corp-compare-summary-row { display: flex; border: 1px solid #e0e0e0; border-bottom: none; border-radius: 8px 8px 0 0; overflow: hidden; }
.corp-summary-half { flex: 1; display: flex; align-items: center; justify-content: center; padding: 0.85rem 1rem; font-size: 1rem; gap: 0.25rem; }
.corp-summary-left { background: #e3f2fd; color: #333; border-right: 1px solid #e0e0e0; }
.corp-summary-right { background: #fff8e1; color: #333; }
.corp-summary-empty { background: #f5f5f5; color: #999; }
.corp-summary-hint { font-size: 0.9rem; }
.corp-summary-name { font-weight: 600; }
.corp-summary-count .meta-num { font-weight: 700; color: #1565c0; }
.corp-compare-columns { display: flex; min-height: 400px; border: 1px solid #e0e0e0; border-radius: 0 0 8px 8px; overflow: hidden; background: #fff; }
.corp-compare-col { flex: 1 1 50%; width: 50%; min-width: 0; padding: 1rem 1.25rem; background: #fff; }
.corp-col-left { border-right: 1px solid #e8e8e8; }
.corp-col-right { background: #fff; }
.corp-compare-col-header { margin-bottom: 1rem; padding: 0.5rem 0.75rem; margin-left: -0.75rem; margin-right: -0.75rem; padding-left: 0.75rem; padding-right: 0.75rem; border-radius: 6px; }
.corp-header-left { background: #e3f2fd; }
.corp-header-right { background: #fff8e1; }
.corp-col-title { margin: 0 0 0.25rem; font-size: 1.1rem; color: #333; }
.corp-col-count { font-size: 0.9rem; color: #555; }
.corp-col-count .meta-num { font-weight: 600; color: #1565c0; }
.corp-compare-col .filter-card { margin-bottom: 1rem; }
.corp-compare-col .filter-card h4 { margin: 0 0 0.5rem; font-size: 0.95rem; color: #555; }
.corp-compare-col .scholar-results { margin-top: 0.5rem; }
.corp-scholar-pagination { margin-top: 0.75rem; }
.corp-col-empty { display: flex; align-items: center; justify-content: center; color: #999; background: #fafafa; }
.scholar-meta .meta-domain { margin-right: 0.5rem; font-size: 0.85em; color: #555; max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.scholar-meta .meta-type { margin-right: 0.5rem; font-size: 0.85em; color: #666; }
.institution-tag {
  display: inline-block;
  padding: 0.15rem 0.5rem;
  font-size: 0.8rem;
  border-radius: 4px;
  margin-right: 0.5rem;
  font-weight: 500;
}
.institution-tag-education { background: #e3f2fd; color: #1565c0; }
.institution-tag-company { background: #fff3e0; color: #e65100; }
.institution-tag-healthcare { background: #f3e5f5; color: #7b1fa2; }
.institution-tag-government { background: #e8f5e9; color: #2e7d32; }
.institution-tag-facility,
.institution-tag-funder { background: #f5f5f5; color: #616161; }
.scholar-meta .meta-num { font-weight: 600; color: #1565c0; }

/* 分页 */
.pagination {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 2rem;
  flex-wrap: wrap;
  list-style: none;
  padding-left: 0;
  margin-left: 0;
}
.pagination .page-link {
  color: #1565c0;
  text-decoration: none;
  padding: 0.35rem 0.6rem;
  border-radius: 4px;
}
.pagination .page-link:hover {
  background: #e3f2fd;
  text-decoration: none;
}
.pagination .page-current {
  padding: 0.35rem 0.6rem;
  font-weight: 600;
  color: #000;
}
.list-empty-state {
  padding: 3rem 0;
  text-align: center;
}
.empty-desc { color: #666; }

.scholar-meta .meta-country { margin-right: 0.75rem; }

/* 筛选侧边栏 */
.list-sidebar {
  position: sticky;
  top: 2rem;
  height: fit-content;
}
.filter-card {
  background: #fff;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  padding: 1rem;
  margin-bottom: 1rem;
}
.filter-card h3 {
  font-size: 0.9rem;
  margin: 0 0 0.75rem;
  color: #000;
}
.filter-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.filter-list li {
  padding: 0.35rem 0;
  font-size: 0.9rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.filter-item { color: #333; text-decoration: none; }
.filter-item:hover { color: #1565c0; text-decoration: underline; }
.filter-count { color: #999; font-size: 0.85rem; }
.filter-hint { font-size: 0.85rem; color: #999; margin: 0; }

/* 人才流动洞察（与 talent/discovery 搜索栏一致：左侧白底输入 + 右侧黑底查询按钮） */
.mobility-query-bar {
  display: flex;
  align-items: stretch;
}
.mobility-filters-inner {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  padding: 0.5rem 1rem 0.5rem 1.25rem;
  background: #fff;
  border-radius: 24px 0 0 24px;
}
.mobility-inner-input,
.mobility-inner-select {
  border: none;
  background: transparent;
  padding: 0.35rem 0.5rem;
  font-size: 0.9rem;
  font-family: inherit;
  outline: none;
  min-width: 80px;
}
.mobility-inner-input::placeholder { color: #999; }
.mobility-inner-input-short { min-width: 55px; }
.mobility-inner-input-wide { min-width: 200px; }
.mobility-inner-input-tiny { min-width: 58px; max-width: 72px; }
.mobility-inner-select { cursor: pointer; min-width: 90px; }
.mobility-inner-select-field { min-width: 180px; }
.doctor-check-wrap { display: inline-flex; align-items: center; gap: 0.35rem; margin-right: 0.5rem; font-size: 0.9rem; color: #333; white-space: nowrap; }
.doctor-check-wrap input { margin: 0; }
.scholar-meta .meta-phd { margin-right: 0.5rem; font-size: 0.88em; color: #673ab7; max-width: 180px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.result-tags { margin-left: 0.5rem; font-size: 0.9rem; color: #666; }
.result-tag { margin-right: 0.5rem; padding: 0.1rem 0.4rem; background: #e8eaf6; border-radius: 4px; }

/* 博士院校搜索联想下拉 - 使用 fixed 避免被父级 overflow 裁剪 */
.phd-combobox-wrap, .country-combobox-wrap, .keyword-combobox-wrap { position: relative; display: inline-block; }
.talent-discovery-query-bar .keyword-combobox-wrap { flex: 1; min-width: 0; }
.talent-discovery-query-bar .keyword-combobox-wrap .mobility-inner-input { flex: 1; width: 100%; min-width: 0; box-sizing: border-box; }
.phd-dropdown-item .keyword-zh { font-weight: 500; color: #222; margin-right: 0.35rem; }
.phd-dropdown-item .keyword-en { font-size: 0.85em; color: #666; }
/* 企业技术情报：两个输入框各占一半 */
.corp-intel-query-bar .country-combobox-wrap { flex: 1; min-width: 0; display: flex; }
.corp-intel-query-bar .country-combobox-wrap .mobility-inner-input { flex: 1; width: 100%; min-width: 0; box-sizing: border-box; }
.doctor-query-bar .mobility-filters-inner,
.future-star-query-bar .mobility-filters-inner,
.corp-intel-query-bar .mobility-filters-inner,
.talent-discovery-query-bar .mobility-filters-inner,
.mobility-query-bar .mobility-filters-inner { overflow: visible; }
.phd-dropdown {
  display: none;
  position: fixed;
  min-width: 280px;
  max-width: 420px;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 8px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.18);
  z-index: 9999;
  overflow: hidden;
}
.phd-dropdown-open { display: block !important; }
.phd-dropdown-search {
  width: 100%;
  box-sizing: border-box;
  padding: 0.5rem 0.75rem;
  border: none;
  border-bottom: 1px solid #eee;
  font-size: 0.9rem;
  outline: none;
}
.phd-dropdown-search { display: block; }
.phd-dropdown-search::placeholder { color: #999; }
.phd-dropdown-list {
  max-height: 260px;
  overflow-y: auto;
  list-style: none;
  margin: 0;
  padding: 0.25rem 0;
}
.phd-dropdown-item {
  padding: 0.5rem 0.75rem 0.5rem 2rem;
  font-size: 0.9rem;
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.phd-dropdown-item:hover { background: #f0f4ff; }
.phd-dropdown-item.phd-dropdown-empty { color: #999; cursor: default; padding-left: 0.75rem; }
.phd-dropdown-header {
  padding: 0.5rem 0.75rem 0.25rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: #7c4dff;
  cursor: default;
  background: #f5f0ff;
  border-bottom: 1px solid #e8e0f5;
  list-style: none;
}
.phd-dropdown-header:hover { background: #f5f0ff; }
.mobility-arrow { color: #999; font-weight: 600; margin: 0 0.1rem; }
.mobility-query-bar .filter-btn.filter-btn-static {
  border: none;
  background: #f0f0f0;
  padding: 0.35rem 0.6rem;
}
.scholar-path {
  font-size: 0.85rem;
  color: #555;
  margin-top: 0.35rem;
  line-height: 1.4;
}

/* 学者论文列表页（与学者列表页样式一致） */
.scholar-works-page { max-width: 1200px; margin: 0 auto; }
.works-header { margin-bottom: 1.5rem; }
.works-header h1 { font-size: 1.5rem; color: #000; margin: 0 0 0.5rem; }
.works-back { margin: 0; font-size: 0.9rem; }
.works-back a { color: #1565c0; text-decoration: none; }
.works-back a:hover { text-decoration: underline; }
.works-result-header { margin-bottom: 1rem; }
.works-result-header .result-count { font-size: 0.95rem; color: #666; }
.works-results { list-style: none; padding: 0; margin: 0; }
.work-item { padding: 1rem 0; border-bottom: 1px solid #e0e0e0; }
.work-item:last-child { border-bottom: none; }
.work-title { font-size: 1.1rem; color: #1565c0; text-decoration: none; display: block; margin-bottom: 0.4rem; }
.work-title:hover { text-decoration: underline; }
.work-meta { font-size: 0.9rem; color: #666; }
.work-meta .meta-year,
.work-meta .meta-authors,
.work-meta .meta-venue,
.work-meta .meta-cited { margin-right: 1rem; }
.work-meta .meta-pdf { color: #1565c0; text-decoration: none; margin-left: 0.5rem; }
.work-meta .meta-pdf:hover { text-decoration: underline; }
.works-source { font-size: 0.85rem; color: #999; margin-top: 2rem; }
.works-source a { color: #1565c0; text-decoration: none; }
.works-source a:hover { text-decoration: underline; }
.scholar-works-page .empty { color: #999; padding: 2rem 0; }

/* 学者论文列表 - 与动态详情页统一的卡片边框与按钮样式 */
.works-article { margin-bottom: 1.5rem; }
.works-article-body.works-article-body { white-space: normal; }
.works-article .works-results { list-style: none; padding: 0; margin: 0; }
.works-article .work-item {
  padding: 1rem 0;
  border-bottom: 1px solid #e8e8e8;
}
.works-article .work-item:last-child { border-bottom: none; }
.works-article .work-title { font-size: 1.05rem; color: #1565c0; text-decoration: none; display: block; margin-bottom: 0.35rem; }
.works-article .work-title:hover { text-decoration: underline; }
.works-article .work-meta { font-size: 0.9rem; color: #666; }
.works-article .work-meta .meta-year,
.works-article .work-meta .meta-authors,
.works-article .work-meta .meta-venue,
.works-article .work-meta .meta-cited { margin-right: 1rem; }
.works-article .work-meta .meta-pdf { color: #1565c0; text-decoration: none; margin-left: 0.5rem; }
.works-article .work-meta .meta-pdf:hover { text-decoration: underline; }
.works-pagination {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid #e8e8e8;
}
.works-pagination .page-current { font-size: 0.95rem; color: #666; font-weight: 500; }
.works-page-btn { padding: 0.35rem 0.9rem; font-size: 0.9rem; }

/* 学者详情页（与学者列表页宽度一致） */
.scholar-detail { max-width: 1200px; margin: 0 auto; width: 100%; }
.scholar-header { margin-bottom: 2rem; }
.scholar-name { margin: 0 0 0.25rem; font-size: 1.75rem; color: #000; font-weight: 700; }
.scholar-id-line { margin: 0; font-size: 0.9rem; display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.scholar-id-link { color: #1565c0; text-decoration: none; }
.scholar-id-link:hover { text-decoration: underline; }
.download-btn {
  display: inline-block;
  padding: 0.35rem 0.75rem;
  background: #1565c0;
  color: #fff !important;
  text-decoration: none;
  border: 1px solid #1565c0;
  border-radius: 6px;
  font-size: 0.9rem;
}
.download-btn:hover { background: #0d47a1; color: #fff !important; text-decoration: none; }
.follow-btn {
  display: inline-block;
  padding: 0.35rem 0.75rem;
  background: #f5f5f5;
  color: #9e9e9e;
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  font-size: 0.9rem;
  cursor: not-allowed;
}
.follow-btn:hover { background: #f5f5f5; color: #9e9e9e; }
/* 关注按钮：可点击，蓝色主色 */
.follow-scholar-btn {
  cursor: pointer !important;
  background: #1976d2 !important;
  color: #fff !important;
  border-color: #1976d2 !important;
}
.follow-scholar-btn:hover { background: #1565c0 !important; color: #fff !important; border-color: #1565c0 !important; }
/* 已关注状态：灰色 */
.follow-scholar-btn-active {
  background: #e0e0e0 !important;
  color: #616161 !important;
  border-color: #d0d0d0 !important;
}
.follow-scholar-btn-active:hover { background: #d5d5d5 !important; color: #424242 !important; }
.download-btn + .follow-btn,
.download-btn + .claim-btn,
.download-btn + .claim-badge,
.claim-btn + .follow-btn,
.claim-badge + .follow-btn,
.follow-btn + .follow-btn { margin-left: 0.5rem; }
.claim-btn {
  display: inline-block;
  padding: 0.35rem 0.75rem;
  background: #2e7d32;
  color: #fff !important;
  border: none;
  border-radius: 4px;
  font-size: 0.9rem;
  text-decoration: none;
  cursor: pointer;
}
.claim-btn:hover { background: #1b5e20; color: #fff !important; }
.claim-badge {
  display: inline-block;
  padding: 0.35rem 0.75rem;
  border-radius: 4px;
  font-size: 0.9rem;
  font-weight: 500;
}
.claim-badge-approved {
  background: #e8f5e9;
  color: #2e7d32;
  border: 1px solid #a5d6a7;
}
.claim-badge-pending {
  background: #fff3e0;
  color: #e65100;
  border: 1px solid #ffcc80;
}
.works-back .download-btn { margin-left: 0.5rem; }
.works-back .follow-btn { margin-left: 0.5rem; }
.scholar-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1.25rem;
}
.scholar-card {
  background: #fff;
  border-radius: 8px;
  padding: 1.25rem;
  border: 1px solid #e0e0e0;
}
.scholar-card h2 {
  font-size: 1rem;
  color: #000;
  margin: 0 0 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid #e0e0e0;
  font-weight: 600;
}
.scholar-card .desc { font-size: 0.85rem; color: #666; margin: 0.75rem 0 0; }
.scholar-card dl { margin: 0; }
.scholar-card dt { font-size: 0.8rem; color: #666; margin-top: 0.5rem; }
.scholar-card dd { margin: 0.15rem 0 0; }
.scholar-card .empty { color: #999; margin: 0; font-size: 0.9rem; }
.scholar-card .email-link { color: #1565c0; text-decoration: none; }
.scholar-card .email-link:hover { text-decoration: underline; }
.dynamics-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.dynamics-item {
  padding: 0.5rem 0;
  border-bottom: 1px solid #eee;
}
.dynamics-item:last-child { border-bottom: none; }
.dynamics-title-link {
  color: #1565c0;
  text-decoration: none;
  font-size: 0.95rem;
}
.dynamics-title-link:hover { text-decoration: underline; }

/* 学者动态详情 - 文章式布局，与学者详情页卡片统一边框 */
.dynamics-article {
  width: 100%;
  padding: 1.25rem;
  font-family: inherit;
  background: #fff;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  box-sizing: border-box;
}
.dynamics-article-header {
  margin-bottom: 1.75rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid #e8e8e8;
}
.dynamics-article-title {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.35;
  color: #1a1a1a;
  margin: 0 0 0.75rem;
  letter-spacing: -0.01em;
}
.dynamics-article-meta {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.dynamic-category {
  display: inline-block;
  padding: 0.25rem 0.65rem;
  background: #e8f4fd;
  color: #0d47a1;
  border-radius: 6px;
  font-size: 0.85rem;
  font-weight: 500;
}
.dynamic-time {
  font-size: 0.9rem;
  color: #6b6b6b;
}
.dynamics-article-body {
  font-size: 1.0625rem;
  line-height: 1.8;
  color: #333;
  white-space: pre-wrap;
  word-wrap: break-word;
  letter-spacing: 0.01em;
}
.dynamics-article-body p {
  margin: 0 0 1em;
}
.dynamics-article-body p:last-child {
  margin-bottom: 0;
}
@media (max-width: 768px) {
  .dynamics-article {
    padding: 1.25rem 0;
  }
  .dynamics-article-title {
    font-size: 1.25rem;
  }
}
.metrics-row {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}
.metric {
  display: flex;
  flex-direction: column;
  min-width: 70px;
}
.metric .val { font-size: 1.4rem; font-weight: 700; color: #1565c0; }
.metric .label { font-size: 0.8rem; color: #666; }
.tag-list { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.tag {
  background: #e3f2fd;
  color: #1565c0;
  padding: 0.25rem 0.6rem;
  border-radius: 6px;
  font-size: 0.85rem;
}
.scholar-card .table-wrap { overflow-x: auto; max-height: 280px; overflow-y: auto; }
.scholar-card table { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
.scholar-card th, .scholar-card td { padding: 0.4rem 0.6rem; text-align: left; border-bottom: 1px solid #eee; }
.scholar-card th { background: #f8f9fa; font-weight: 600; }
.card-topic-share, .card-yearly { grid-column: 1 / -1; }

/* 学者详情 - 资料区、科研能力、深度洞察（统一卡片布局） */
/* Scholar Score 综合评分卡 - 浅蓝与页面统一，白色字体 */
.scholar-score-card {
  background: linear-gradient(135deg, #42a5f5 0%, #64b5f6 50%, #90caf9 100%);
  border: 1px solid #64b5f6;
  border-radius: 12px;
  padding: 1.5rem 1.75rem;
  margin-bottom: 2rem;
  color: #fff;
  box-shadow: 0 2px 12px rgba(33, 150, 243, 0.2);
}
.scholar-score-card .score-card-title {
  font-size: 0.95rem;
  font-weight: 600;
  margin: 0 0 1rem;
  color: #fff;
  letter-spacing: 0.02em;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
}
.scholar-score-card .score-card-title-left {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}
.scholar-score-card .score-card-works-link {
  color: #fff;
  text-decoration: none;
  padding: 0.35rem 0.75rem;
  background: rgba(255, 255, 255, 0.25);
  border-radius: 6px;
  font-size: 0.9rem;
  font-weight: 600;
  white-space: nowrap;
  transition: background 0.2s, color 0.2s;
}
.scholar-score-card .score-card-works-link:hover {
  background: rgba(255, 255, 255, 0.95);
  color: #1565c0;
}
.scholar-score-card .score-help-btn {
  background: rgba(255, 255, 255, 0.9);
  color: #1565c0;
  border-color: rgba(255, 255, 255, 0.8);
}
.scholar-score-card .score-help-btn:hover {
  background: #fff;
  color: #0d47a1;
  border-color: #fff;
}
.scholar-score-card .score-total-wrap {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
}
.scholar-score-card .score-total-value {
  font-size: 3rem;
  font-weight: 700;
  line-height: 1;
  color: #fff;
}
.scholar-score-card .score-total-label {
  font-size: 1rem;
  color: #fff;
}
.scholar-score-card .score-breakdown {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 1.5rem;
}
.scholar-score-card .score-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-width: 80px;
}
.scholar-score-card .score-item-value {
  font-size: 1.35rem;
  font-weight: 700;
  color: #fff;
}
.scholar-score-card .score-item-label {
  font-size: 0.8rem;
  color: rgba(255, 255, 255, 0.95);
  margin-top: 0.2rem;
}
@media (max-width: 600px) {
  .scholar-score-card .score-breakdown { gap: 0.75rem 1rem; }
  .scholar-score-card .score-item { min-width: 70px; }
  .scholar-score-card .score-item-value { font-size: 1.15rem; }
  .scholar-score-card .score-card-works-link {
    padding: 0.5rem 1rem;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
}

.scholar-profile-section,
.scholar-research-section,
.scholar-extras-section {
  margin-bottom: 2rem;
}
.scholar-profile-section .section-label {
  font-size: 1.1rem;
  font-weight: 700;
  color: #1565c0;
  letter-spacing: 0.03em;
  margin: 0 0 1rem;
  padding: 0.5rem 0.75rem;
  border-bottom: 2px solid #1565c0;
  background: #e3f2fd;
  border-radius: 4px 4px 0 0;
}
.scholar-meta-times {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem 1rem;
  margin-top: 1.25rem;
  padding: 0.6rem 1rem;
  font-size: 0.9rem;
  color: #666;
  background: #f8f9fa;
  border-radius: 6px;
}
.scholar-meta-times .meta-time-item {
  font-weight: 500;
}
.scholar-meta-times .meta-time-value {
  font-weight: 600;
  color: #1565c0;
}
.scholar-meta-times .meta-time-sep {
  color: #999;
  font-weight: 400;
}
@media (max-width: 480px) {
  .scholar-meta-times { flex-wrap: wrap; justify-content: center; }
}
.scholar-research-section .section-label {
  font-size: 1.1rem;
  font-weight: 700;
  color: #2e7d32;
  letter-spacing: 0.03em;
  margin: 0 0 1rem;
  padding: 0.5rem 0.75rem;
  border-bottom: 2px solid #2e7d32;
  background: #e8f5e9;
  border-radius: 4px 4px 0 0;
}
.career-stage-badge {
  display: inline-block;
  padding: 0.25rem 0.6rem;
  border-radius: 6px;
  font-size: 0.9rem;
  font-weight: 600;
}
.career-stage-badge.career-stage-early { background: #e3f2fd; color: #1565c0; }
.career-stage-badge.career-stage-rising { background: #e8f5e9; color: #2e7d32; }
.career-stage-badge.career-stage-established { background: #fff3e0; color: #e65100; }
.career-stage-badge.career-stage-declining { background: #fce4ec; color: #c2185b; }
.career-stage-badge.career-stage-one_hit { background: #f3e5f5; color: #7b1fa2; }

/* 研究方向演化图 */
.topic-evolution-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.topic-evolution-list li {
  padding: 0.5rem 0;
  border-bottom: 1px solid #eee;
  font-size: 0.9rem;
}
.topic-evolution-list li:last-child { border-bottom: none; }
.topic-evolution-period {
  display: inline-block;
  min-width: 7rem;
  font-weight: 600;
  color: #1565c0;
}

/* 学术迁移路径图 */
.migration-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.migration-list li {
  padding: 0.35rem 0;
  font-size: 0.9rem;
}
.country-path {
  font-size: 0.9rem;
  color: #1565c0;
}

/* 领域影响力排名 */
.influence-badge {
  display: inline-block;
  padding: 0.25rem 0.6rem;
  border-radius: 6px;
  font-size: 0.9rem;
  font-weight: 600;
  background: #e8f5e9;
  color: #2e7d32;
}
.influence-badge.influence-highlight {
  background: #e3f2fd;
  color: #1565c0;
}

.scholar-extras-section .section-label {
  font-size: 1.1rem;
  font-weight: 700;
  color: #7b1fa2;
  letter-spacing: 0.03em;
  margin: 0 0 1rem;
  padding: 0.5rem 0.75rem;
  border-bottom: 2px solid #7b1fa2;
  background: #f3e5f5;
  border-radius: 4px 4px 0 0;
}
.similar-scholars-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.similar-scholars-list li {
  padding: 0.5rem 0;
  border-bottom: 1px solid #eee;
  font-size: 0.9rem;
}
.similar-scholars-list li:last-child { border-bottom: none; }
.similar-scholars-list a {
  color: #1565c0;
  text-decoration: none;
  font-weight: 500;
}
.similar-scholars-list a:hover { text-decoration: underline; }
.similar-scholars-list .similar-inst {
  color: #666;
  font-size: 0.85rem;
  margin-left: 0.35rem;
}
.similar-scholars-list .similar-meta {
  display: block;
  font-size: 0.8rem;
  color: #868e96;
  margin-top: 0.2rem;
}

/* 增长指数卡片（与 scholar-card dl 一致） */
.growth-indices-dl {
  margin: 0;
}
.growth-indices-dl dt {
  font-size: 0.8rem;
  color: #666;
  margin-top: 0.5rem;
}
.growth-indices-dl dt:first-child { margin-top: 0; }
.growth-indices-dl dd {
  margin: 0.15rem 0 0;
  font-size: 0.9rem;
}
.growth-indices-dl .growth-value {
  font-weight: 600;
  font-size: 1rem;
}
.growth-indices-dl .growth-value.growth-up { color: #2e7d32; }
.growth-indices-dl .growth-value.growth-down { color: #c62828; }
.growth-indices-dl .growth-detail {
  font-size: 0.8rem;
  color: #868e96;
  margin-left: 0.35rem;
}

/* 增长指数 - 说明按钮与弹窗 */
.scholar-card h2.help-title-row {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}
.growth-help-btn {
  width: 1.2rem;
  height: 1.2rem;
  padding: 0;
  border: 1px solid #adb5bd;
  border-radius: 50%;
  background: #fff;
  color: #495057;
  font-size: 0.75rem;
  font-weight: 600;
  cursor: pointer;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.growth-help-btn:hover {
  background: #e9ecef;
  border-color: #868e96;
}
.growth-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.2s, visibility 0.2s;
}
.growth-modal.growth-modal-open {
  visibility: visible;
  opacity: 1;
}
.growth-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
}
.growth-modal-content {
  position: relative;
  background: #fff;
  border-radius: 8px;
  max-width: 420px;
  width: 100%;
  max-height: 85vh;
  overflow-y: auto;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
  padding: 1.5rem;
}
.growth-modal-content h4 {
  margin: 0 0 1rem;
  font-size: 1.1rem;
}
.growth-modal-body h5 {
  margin: 1rem 0 0.35rem;
  font-size: 0.95rem;
  color: #212529;
}
.growth-modal-body h5:first-child { margin-top: 0; }
.growth-modal-body p {
  margin: 0 0 0.5rem;
  font-size: 0.9rem;
  color: #495057;
  line-height: 1.5;
}
.growth-modal-close {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  width: 1.75rem;
  height: 1.75rem;
  padding: 0;
  border: none;
  background: #f1f3f5;
  color: #495057;
  font-size: 1.25rem;
  line-height: 1;
  cursor: pointer;
  border-radius: 4px;
}
.growth-modal-close:hover {
  background: #e9ecef;
}

/* 统计页 */
.stats-section { margin-bottom: 2.5rem; }
.stats-section h2 { font-size: 1.2rem; color: #000; margin-bottom: 1rem; }
.stats-section h3 { font-size: 0.95rem; color: #555; margin: 0 0 0.5rem; }
.table-wide { min-width: 400px; }
h1 { margin-top: 0; color: #000; }
h2 { font-size: 1rem; color: #555; margin: 1.5rem 0 0.5rem; }

.stats-cards {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 2rem;
}
.card {
  background: #fff;
  border-radius: 8px;
  padding: 1.5rem;
  min-width: 160px;
  border: 1px solid #e0e0e0;
}
.card-value {
  font-size: 1.8rem;
  font-weight: 700;
  color: #1565c0;
}
.card-label {
  font-size: 0.9rem;
  color: #666;
}

.tables { display: flex; gap: 2rem; flex-wrap: wrap; }
.table-block {
  flex: 1;
  min-width: 360px;
  background: #fff;
  border-radius: 8px;
  padding: 1rem;
  border: 1px solid #e0e0e0;
  overflow-x: auto;
}
.table-block table {
  width: 100%;
  min-width: 340px;
  border-collapse: collapse;
  table-layout: auto;
}
.table-block th,
.table-block td {
  padding: 0.5rem 0.75rem;
  text-align: left;
  border-bottom: 1px solid #eee;
}
.table-block th {
  background: #f8f9fa;
  font-weight: 600;
  white-space: nowrap;
}
.table-block tr:hover td { background: #f8f9fa; }

/* 研究领域全景页 */
.panorama-page { max-width: 1200px; margin: 0 auto; }
.panorama-header { margin-bottom: 2rem; }
.panorama-header h1 { font-size: 1.75rem; color: #000; margin: 0 0 0.5rem; }
.panorama-lead { font-size: 1rem; color: #666; margin: 0; }
.panorama-hero {
  margin-bottom: 2.5rem;
  text-align: center;
}
.panorama-hero-card {
  display: inline-block;
  padding: 1.5rem 2.5rem;
  background: linear-gradient(135deg, #f5f9ff 0%, #e3f2fd 100%);
  border: 1px solid #bbdefb;
  border-radius: 12px;
}
.panorama-hero-value {
  display: block;
  font-size: 2.5rem;
  font-weight: 700;
  color: #1565c0;
  line-height: 1.2;
}
.panorama-hero-label { font-size: 0.95rem; color: #555; }
.panorama-section { margin-bottom: 2.5rem; }
.panorama-section .section-label {
  font-size: 1.15rem;
  color: #000;
  margin-bottom: 1rem;
  font-weight: 600;
}
.panorama-charts-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
.panorama-chart-card {
  min-height: 280px;
}
.panorama-chart-card h3 { font-size: 0.95rem; margin: 0 0 0.75rem; color: #333; }
.panorama-empty-chart { color: #999; font-size: 0.9rem; margin: 2rem 0; text-align: center; }
.chart-wrap { height: 220px; position: relative; }
.panorama-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
.panorama-list-card h3 { font-size: 0.95rem; margin: 0 0 0.5rem; color: #333; }
.panorama-list-wrap {
  overflow-x: auto;
  max-height: 340px;
  overflow-y: auto;
}
.panorama-list-wrap table { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
.panorama-list-wrap th, .panorama-list-wrap td { padding: 0.4rem 0.6rem; text-align: left; border-bottom: 1px solid #eee; }
.panorama-list-wrap th { background: #f8f9fa; font-weight: 600; }
.panorama-list-wrap tr:hover td { background: #f8f9fa; }
.panorama-scholars-card { max-width: 100%; }
.panorama-scholars-wrap { overflow-x: auto; max-height: 400px; overflow-y: auto; }
.panorama-scholars-wrap table { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
.panorama-scholars-wrap th, .panorama-scholars-wrap td { padding: 0.5rem 0.75rem; text-align: left; border-bottom: 1px solid #eee; }
.panorama-scholars-wrap th { background: #f8f9fa; font-weight: 600; }
.panorama-scholars-wrap .scholar-link { color: #1565c0; text-decoration: none; }
.panorama-scholars-wrap .scholar-link:hover { text-decoration: underline; }
.panorama-scholars-wrap tr:hover td { background: #f8f9fa; }
.panorama-tags-card h3 { font-size: 0.95rem; margin: 0 0 0.25rem; color: #333; }
.panorama-tags-card .desc { font-size: 0.8rem; color: #666; margin: 0 0 0.75rem; }
.panorama-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.panorama-tag {
  display: inline-block;
  padding: 0.35rem 0.75rem;
  background: #f0f4f8;
  border: 1px solid #e0e6ed;
  border-radius: 6px;
  font-size: 0.85rem;
  color: #333;
}
.panorama-tag small { color: #666; margin-left: 0.15rem; }

/* 机构增长趋势 */
.section-desc { font-size: 0.9rem; color: #666; margin: -0.5rem 0 1rem; }
.growth-metrics-card { text-align: center; }
.growth-metrics-card h3 { font-size: 0.95rem; margin: 0 0 0.5rem; color: #333; }
.growth-metric-value { font-size: 1.75rem; font-weight: 700; color: #1565c0; margin: 0 0 0.25rem; }
.growth-metric-desc { font-size: 0.8rem; color: #666; margin: 0; }
.growth-rank-table { font-size: 0.9rem; }
.growth-rank-table .burst-cell { font-variant-numeric: tabular-nums; }
.burst-value.burst-up { color: #2e7d32; font-weight: 600; }
.burst-value.burst-down { color: #c62828; font-weight: 600; }
.burst-value:not(.burst-up):not(.burst-down) { color: #666; }

/* 机构领域结构 */
.domain-list-card h3 { font-size: 0.95rem; margin: 0 0 0.75rem; color: #333; }
.domain-proportion-list {
  list-style: none; margin: 0; padding: 0; max-height: 260px; overflow-y: auto;
}
.domain-proportion-list li {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0.4rem 0; border-bottom: 1px solid #eee; font-size: 0.9rem;
}
.domain-proportion-list li:last-child { border-bottom: none; }
.domain-proportion-list .domain-name { font-weight: 500; color: #333; }
.domain-proportion-list .domain-pct { font-variant-numeric: tabular-nums; color: #1565c0; font-weight: 600; }
.inst-type-badge {
  display: inline-block; padding: 0.2rem 0.5rem; border-radius: 4px; font-size: 0.8rem; font-weight: 600;
}
.inst-type-badge.inst-type-focused { background: #e8f5e9; color: #2e7d32; }
.inst-type-badge.inst-type-comprehensive { background: #e3f2fd; color: #1565c0; }
.leading-domains-cell { max-width: 280px; }
.domain-tag {
  display: inline-block; margin: 0.15rem 0.2rem 0.15rem 0;
  padding: 0.2rem 0.5rem; background: #f0f4f8; border-radius: 4px;
  font-size: 0.8rem; color: #333;
}

/* 国家/地区科技结构 */
.national-tech-header { margin-bottom: 1rem; }
.national-tech-title {
  display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap;
  font-size: 1.75rem; margin: 0 0 0.5rem;
}
.national-country-tag {
  position: relative;
  display: inline-flex; align-items: center;
  padding: 0.35rem 0.85rem;
  background: #e3f2fd;
  border: 1px solid #1565c0;
  border-radius: 20px;
  font-size: 0.95rem; font-weight: 600; color: #1565c0;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}
.national-country-tag:hover {
  background: #1565c0;
  color: #fff;
}
.national-country-tag-label::after {
  content: ' ▼';
  font-size: 0.75em; opacity: 0.8;
}
.scope-tag {
  display: inline-block;
  padding: 0.2rem 0.5rem;
  background: #f0f4f8;
  border-radius: 4px;
  font-size: 0.85em; font-weight: 600; color: #1565c0;
}
.scope-note { font-size: 0.85em; font-weight: 400; color: #666; }
.city-map-wrap { height: 360px; min-height: 280px; }

/* 合作与需求页 */
.contact-page { max-width: 720px; margin: 0 auto; }
.contact-header { margin-bottom: 2rem; }
.contact-header h1 { font-size: 1.75rem; color: #000; margin: 0 0 0.5rem; }
.contact-lead { font-size: 1.1rem; color: #1565c0; margin: 0; font-weight: 500; }
.contact-content { line-height: 1.7; }
.contact-desc { margin: 0 0 1rem; color: #333; font-size: 1rem; }
.contact-desc strong { color: #000; }
.contact-email { margin-top: 2rem; }
.contact-email .email-link { color: #1565c0; text-decoration: none; font-size: 1.1rem; }

/* 功能与订阅说明 */
.features-page { max-width: 720px; margin: 0 auto; }
.features-header { margin-bottom: 2rem; }
.features-header h1 { font-size: 1.75rem; color: #000; margin: 0 0 0.5rem; }
.features-lead { font-size: 1.1rem; color: #666; margin: 0; }
.features-content { line-height: 1.75; }
.features-section {
  margin-bottom: 2.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid #eee;
}
.features-section:last-child { border-bottom: none; }
.features-section h2 { font-size: 1.15rem; color: #333; margin: 0 0 1rem; }
.features-section h3.features-sub {
  font-size: 1rem;
  color: #1565c0;
  margin: 1.25rem 0 0.5rem;
  font-weight: 600;
}
.features-section h3.features-sub:first-of-type { margin-top: 0.5rem; }
.features-section p { margin: 0 0 0.75rem; color: #444; font-size: 0.95rem; }
.features-section ul { margin: 0 0 0.75rem; padding-left: 1.5rem; }
.features-section li { margin-bottom: 0.4rem; color: #444; font-size: 0.95rem; }
.features-section li strong { color: #000; }
.features-section li a.features-highlight,
.features-section li a.features-highlight strong {
  color: #1565c0;
  text-decoration: none;
}
.features-section li a.features-highlight:hover { text-decoration: underline; }
.features-section li strong.features-price { color: #c62828; }
.contact-email .email-link:hover { text-decoration: underline; }

/* 查询页登录 */
.query-login { max-width: 400px; margin: 3rem auto; text-align: center; }
.query-login .login-desc { color: #666; margin-bottom: 1.5rem; }
.login-form { display: flex; gap: 0.5rem; justify-content: center; margin-bottom: 1rem; }
.login-input {
  padding: 0.6rem 1rem;
  border: 1px solid #ccc;
  border-radius: 6px;
  font-size: 1rem;
  min-width: 180px;
}
.login-btn {
  background: #000;
  color: #fff;
  border: none;
  padding: 0.6rem 1.25rem;
  border-radius: 6px;
  cursor: pointer;
  font-weight: 500;
}
.login-btn:hover { background: #333; }
.login-error { color: #c62828; font-size: 0.9rem; }
.logout-link { font-size: 0.85rem; font-weight: normal; color: #666; margin-left: 1rem; }
.logout-link:hover { color: #1565c0; }

/* 错误与通用 */
.error { color: #c62828; padding: 1rem; background: #ffebee; border-radius: 6px; }
.placeholder { color: #999; }
.meta { color: #666; font-size: 0.9rem; margin-bottom: 0.5rem; }

/* 查询页 */
.query-form textarea {
  width: 100%;
  font-family: "SF Mono", Monaco, monospace;
  font-size: 0.9rem;
  padding: 0.75rem;
  border: 1px solid #ddd;
  border-radius: 6px;
  resize: vertical;
}
.query-form button,
.preset-btn {
  background: #000;
  color: #fff;
  border: none;
  padding: 0.5rem 1rem;
  border-radius: 6px;
  cursor: pointer;
  font-size: 0.9rem;
  margin-top: 0.5rem;
}
.query-form button:hover,
.preset-btn:hover { background: #333; }
.preset-btn { margin-right: 0.5rem; margin-bottom: 0.5rem; font-size: 0.85rem; }
.presets { margin-bottom: 1rem; }
.hint { font-size: 0.85rem; color: #888; margin-top: 0.25rem; }

.query-result {
  margin-top: 2rem;
  background: #fff;
  border-radius: 8px;
  padding: 1rem;
  border: 1px solid #e0e0e0;
}
.table-scroll {
  overflow-x: auto;
  max-height: 400px;
  overflow-y: auto;
}
.query-result table { width: 100%; border-collapse: collapse; }
.query-result th,
.query-result td {
  padding: 0.5rem 0.75rem;
  text-align: left;
  border-bottom: 1px solid #eee;
  white-space: nowrap;
}
.query-result th {
  background: #f8f9fa;
  font-weight: 600;
  position: sticky;
  top: 0;
  z-index: 1;
}

/* 页脚 */
.footer {
  border-top: 1px solid #e0e0e0;
  padding: 1rem 2rem;
  text-align: center;
  font-size: 0.85rem;
  color: #666;
  background: #fff;
}
.footer-text {
  margin: 0;
  font-size: 0.85rem;
  color: #666;
}
.footer-links { display: flex; gap: 1.5rem; }
.footer-links a { color: #1565c0; text-decoration: none; }
.footer-links a:hover { text-decoration: underline; }
.footer-notice { font-size: 0.8rem; color: #999; }

/* ========== 响应式 - 平板/手机 ========== */

@media (max-width: 900px) {
  .list-layout {
    grid-template-columns: 1fr;
  }
  .list-sidebar { position: static; }
}

@media (max-width: 768px) {
  /* 顶部导航：缩小间距，支持换行 */
  .top-nav {
    padding: 0.6rem 1rem;
    flex-wrap: wrap;
  }
  .nav-main {
    gap: 0.75rem;
  }
  .nav-main > a,
  .nav-brand {
    font-size: 0.9rem;
  }
  .nav-user-area {
    gap: 0.5rem;
  }
  .nav-btn {
    padding: 0.35rem 0.7rem;
    font-size: 0.85rem;
  }

  /* 主内容区 */
  .main {
    padding: 1rem;
  }
  .chat-section {
    margin: 0 -1rem;
    padding: 1.5rem 1rem;
  }

  /* 首页 Hero */
  .home-hero {
    padding: 3.5rem 0 2.5rem;
  }
  .hero-title {
    font-size: 1.5rem;
  }
  .hero-title-icon svg {
    width: 32px;
    height: 32px;
  }
  .hero-desc {
    font-size: 0.95rem;
    margin-bottom: 1.5rem;
  }
  .data-notice {
    margin-top: 1.5rem;
    padding: 0.9rem 1rem;
  }
  .data-notice-text { font-size: 0.85rem; }
  .search-container {
    max-width: 100%;
  }
  .search-main-bar, .search-main-input { border-radius: 16px; }
  .filter-panel { min-width: 260px; max-width: 100%; }
  .search-input {
    padding: 0.75rem 1rem;
    font-size: 0.95rem;
  }
  .search-btn {
    padding: 0.75rem 1rem;
    font-size: 0.9rem;
  }

  /* 学者列表页 */
  .list-search-container {
    max-width: 100%;
  }
  .list-search-input {
    min-width: 0;
  }
  .scholar-title {
    font-size: 1.25rem;
  }
  .scholar-meta {
    font-size: 0.85rem;
  }

  /* 学者详情页 */
  .scholar-header {
    margin-bottom: 1.5rem;
  }
  .scholar-name {
    font-size: 1.4rem;
  }
  .scholar-id-line {
    word-break: break-all;
  }
  .scholar-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
    width: 100%;
  }
  .scholar-card {
    padding: 1rem;
    min-width: 0;
    width: 100%;
    box-sizing: border-box;
  }
  .card-topic-share,
  .card-yearly {
    grid-column: 1;
  }
  .metrics-row {
    gap: 0.75rem;
  }
  .metric {
    min-width: 60px;
  }
  .metric .val {
    font-size: 1.2rem;
  }

  /* 统计页 */
  .stats-cards {
    gap: 0.75rem;
  }
  .card {
    min-width: 140px;
    padding: 1rem;
  }
  .card-value {
    font-size: 1.5rem;
  }
  .tables {
    gap: 1rem;
  }
  .table-block {
    min-width: 0;
    width: 100%;
  }
  .table-block table {
    min-width: 280px;
  }

  /* 全景页 */
  .panorama-charts-grid,
  .panorama-grid {
    grid-template-columns: 1fr;
  }
  .panorama-hero-value {
    font-size: 2rem;
  }
  .panorama-hero-card {
    padding: 1rem 1.5rem;
  }

  /* 查询页 */
  .query-login {
    margin: 2rem 1rem;
    padding: 0 1rem;
  }
  .login-form {
    flex-direction: column;
  }
  .login-input {
    min-width: 0;
    width: 100%;
  }
  .presets {
    display: flex;
    flex-wrap: wrap;
  }
  .preset-btn {
    font-size: 0.8rem;
    padding: 0.4rem 0.75rem;
  }
  .query-form textarea {
    font-size: 0.85rem;
    padding: 0.6rem;
  }

  /* 页脚 */
  .footer {
    padding: 1rem;
  }
  .footer-links {
    flex-wrap: wrap;
    justify-content: center;
  }

  /* 消息 */
  .msg.user,
  .msg.assistant {
    margin-left: 0.5rem;
    margin-right: 0.5rem;
  }
}

@media (max-width: 480px) {
  .main {
    padding: 0.75rem;
  }
  .hero-title {
    font-size: 1.3rem;
  }
  .hero-title-icon svg {
    width: 26px;
    height: 26px;
  }
  .hero-desc {
    font-size: 0.9rem;
  }
  .nav-main {
    gap: 0.5rem;
  }
  .nav-main > a,
  .nav-brand {
    font-size: 0.85rem;
  }
  .nav-user-email {
    max-width: 8rem;
  }
  .scholar-name {
    font-size: 1.25rem;
  }
  .scholar-grid {
    gap: 0.75rem;
    width: 100%;
  }
  .scholar-card {
    padding: 0.875rem;
    min-width: 0;
    width: 100%;
    box-sizing: border-box;
  }
  .stats-cards .card {
    min-width: 100%;
  }
  .table-block {
    padding: 0.75rem;
  }
  .table-block th,
  .table-block td {
    padding: 0.4rem 0.5rem;
    font-size: 0.85rem;
  }
  .pagination {
    gap: 0.35rem;
  }
  .pagination .page-link,
  .pagination .page-current {
    padding: 0.3rem 0.5rem;
    font-size: 0.85rem;
  }
}

/* 认证页面 */
.auth-page {
  min-height: 60vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}
.auth-card {
  width: 100%;
  max-width: 400px;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  padding: 2rem;
  background: #fff;
}
.auth-card-wide { max-width: 480px; }
.auth-title {
  margin: 0 0 1.5rem;
  font-size: 1.5rem;
  font-weight: 600;
}
.auth-error {
  color: #c62828;
  background: #ffebee;
  padding: 0.5rem 0.75rem;
  border-radius: 4px;
  margin-bottom: 1rem;
  font-size: 0.9rem;
}
.auth-form { }
.auth-field {
  margin-bottom: 1rem;
}
.auth-field label {
  display: block;
  margin-bottom: 0.35rem;
  font-size: 0.9rem;
  color: #333;
}
.auth-field input,
.auth-field select {
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 1rem;
  box-sizing: border-box;
}
.auth-field-row .auth-code-row {
  display: flex;
  gap: 0.5rem;
}
.auth-field-row .auth-code-row input { flex: 1; }
.auth-code-btn {
  padding: 0.5rem 1rem;
  border: 1px solid #1565c0;
  background: #fff;
  color: #1565c0;
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.9rem;
  white-space: nowrap;
}
.auth-code-btn:hover:not(:disabled) { background: #e3f2fd; }
.auth-code-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.auth-btn {
  width: 100%;
  padding: 0.65rem;
  border: none;
  background: #1565c0;
  color: #fff;
  border-radius: 4px;
  font-size: 1rem;
  cursor: pointer;
  margin-top: 0.5rem;
}
.auth-btn:hover { background: #0d47a1; }
.auth-footer {
  margin-top: 1.5rem;
  text-align: center;
  font-size: 0.9rem;
  color: #666;
}
.auth-footer a { color: #1565c0; text-decoration: none; }
.auth-footer a:hover { text-decoration: underline; }

/* 个人中心 - 用户后台布局 */
.profile-backend {
  display: flex;
  gap: 2rem;
  max-width: 1000px;
  margin: 0 auto;
  padding: 2rem 0;
  min-height: 400px;
}
.profile-sidebar {
  flex-shrink: 0;
  width: 200px;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  padding: 1rem 0;
  background: #fafafa;
}
.profile-sidebar-title {
  margin: 0 0 0.75rem;
  padding: 0 1.25rem;
  font-size: 1rem;
  font-weight: 600;
  color: #333;
}
.profile-nav {
  display: flex;
  flex-direction: column;
}
.profile-nav-item {
  display: block;
  padding: 0.5rem 1.25rem;
  font-size: 0.95rem;
  color: #555;
  text-decoration: none;
  border-left: 3px solid transparent;
}
.profile-nav-item:hover {
  color: #000;
  background: #f0f0f0;
}
.profile-nav-item-active {
  color: #1565c0;
  font-weight: 600;
  background: #e3f2fd;
  border-left-color: #1565c0;
}
.profile-nav-vip-tag {
  margin-left: 0.35rem;
  padding: 0.1rem 0.4rem;
  font-size: 0.7rem;
  font-weight: 600;
  color: #1b5e20;
  background: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);
  border-radius: 4px;
  border: 1px solid rgba(27, 94, 32, 0.25);
}
.profile-main {
  flex: 1;
  min-width: 0;
}
.profile-panel {
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  padding: 1.5rem;
  background: #fff;
}
.profile-panel-title {
  margin: 0 0 1rem;
  font-size: 1.1rem;
  font-weight: 600;
  color: #333;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid #eee;
}
.profile-dl {
  margin: 0;
  padding: 0;
  list-style: none;
}
.profile-row {
  display: flex;
  align-items: center;
  padding: 0.75rem 0;
  border-bottom: 1px solid #f0f0f0;
}
.profile-row:last-of-type { border-bottom: none; }
.profile-dt {
  width: 6rem;
  flex-shrink: 0;
  margin: 0;
  font-size: 0.9rem;
  color: #666;
}
.profile-dd {
  margin: 0;
  font-size: 0.95rem;
  color: #333;
}
.profile-tz-hint {
  font-size: 0.8rem;
  color: #999;
  font-weight: 400;
}
.profile-role-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.6rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: #0d47a1;
  background: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%);
  border-radius: 999px;
  letter-spacing: 0.02em;
  border: 1px solid rgba(13, 71, 161, 0.2);
}
.profile-vip-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.6rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: #1b5e20;
  background: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);
  border-radius: 999px;
  border: 1px solid rgba(27, 94, 32, 0.2);
}
.profile-free-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.6rem;
  font-size: 0.8rem;
  font-weight: 500;
  color: #616161;
  background: #f5f5f5;
  border-radius: 999px;
  border: 1px solid #e0e0e0;
}
.profile-subscription-link {
  margin-left: 0.75rem;
  color: #1565c0;
  text-decoration: none;
  font-size: 0.9rem;
}
.profile-subscription-link:hover { text-decoration: underline; }
.profile-placeholder {
  padding: 2.5rem 0;
  text-align: center;
  color: #999;
}
.profile-placeholder-text {
  margin: 0;
  font-size: 0.95rem;
}
.profile-placeholder-hint { margin-top: 0.5rem; font-size: 0.9rem; }
.profile-placeholder-hint a { color: #1565c0; text-decoration: none; }
.profile-placeholder-hint a:hover { text-decoration: underline; }

/* 认领记录 */
.claims-table-wrap { overflow-x: auto; }
.claims-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}
.claims-table th,
.claims-table td {
  padding: 0.6rem 0.75rem;
  text-align: left;
  border-bottom: 1px solid #eee;
}
.claims-table th {
  background: #f8f9fa;
  font-weight: 600;
  color: #555;
}
.claims-table td.claim-reason { max-width: 200px; overflow: hidden; text-overflow: ellipsis; }
.claims-table a { color: #1565c0; text-decoration: none; }
.claims-table a:hover { text-decoration: underline; }
.claim-status {
  padding: 0.2rem 0.5rem;
  border-radius: 4px;
  font-size: 0.8rem;
}
.claim-status-pending { background: #fff3e0; color: #e65100; }
.claim-status-approved { background: #e8f5e9; color: #2e7d32; }
.claim-status-rejected { background: #ffebee; color: #c62828; }
.claim-action-link { color: #1565c0; text-decoration: none; margin-right: 0.5rem; }
.claim-action-link:hover { text-decoration: underline; }

/* 订阅管理 */
.subscription-panel .subscription-section-title {
  font-size: 0.95rem;
  color: #555;
  margin: 0 0 0.75rem;
}
.subscription-current {
  margin-bottom: 2rem;
}
.subscription-active p,
.subscription-free p { margin: 0; }
.subscription-table-wrap { overflow-x: auto; }
.subscription-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}
.subscription-table th,
.subscription-table td {
  padding: 0.6rem 0.75rem;
  text-align: left;
  border-bottom: 1px solid #eee;
}
.subscription-table th {
  background: #f8f9fa;
  font-weight: 600;
  color: #555;
}
.subscription-table a { color: #1565c0; text-decoration: none; }
.subscription-row-expired td { color: #999; }
.subscription-status-active { color: #2e7d32; font-size: 0.85rem; }
.subscription-status-expired { color: #999; font-size: 0.85rem; }

.profile-pagination {
  margin-top: 1.5rem;
  padding: 1rem 1.25rem;
  background: #fafafa;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
}
.profile-pagination-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}
.profile-page-info {
  font-size: 0.9rem;
  color: #666;
}
.profile-page-nav {
  display: flex;
  gap: 0.5rem;
}
.profile-page-btn {
  display: inline-block;
  padding: 0.4rem 1rem;
  font-size: 0.9rem;
  color: #666;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 6px;
  text-decoration: none;
  transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.profile-page-btn:hover {
  background: #f5f5f5;
  border-color: #ccc;
  color: #333;
  text-decoration: none;
}
.profile-page-btn-primary {
  color: #1565c0;
  border-color: #1565c0;
  background: #fff;
}
.profile-page-btn-primary:hover {
  background: #e3f2fd;
  border-color: #0d47a1;
  color: #0d47a1;
}
@media (max-width: 480px) {
  .profile-pagination-inner {
    flex-direction: column;
    align-items: stretch;
    text-align: center;
  }
  .profile-page-nav { justify-content: center; }
}

.profile-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}
.profile-breadcrumb {
  margin: 0 0 1.25rem;
  font-size: 0.9rem;
  color: #666;
}
.profile-breadcrumb a { color: #1565c0; text-decoration: none; }
.profile-breadcrumb a:hover { text-decoration: underline; }
.btn-add {
  display: inline-block;
  padding: 0.35rem 0.75rem;
  background: #1976d2;
  color: #fff !important;
  text-decoration: none;
  border-radius: 6px;
  font-size: 0.9rem;
}
.btn-add:hover { background: #1565c0; color: #fff !important; }

.inline-form { display: inline; margin-left: 0.5rem; }
.btn-link-delete {
  background: none;
  border: none;
  color: #c62828;
  cursor: pointer;
  font-size: 0.9rem;
  padding: 0;
  text-decoration: underline;
}
.btn-link-delete:hover { color: #b71c1c; }

.dynamics-form { max-width: 480px; }
.dynamics-form .form-group {
  margin-bottom: 1rem;
}
.dynamics-form label {
  display: block;
  margin-bottom: 0.35rem;
  font-weight: 500;
  color: #333;
}
.dynamics-form .required { color: #c62828; }
.dynamics-form select,
.dynamics-form input[type="text"],
.dynamics-form textarea {
  width: 100%;
  padding: 0.5rem 0.6rem;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 0.95rem;
}
.dynamics-form .form-actions {
  margin-top: 1.5rem;
  display: flex;
  gap: 0.75rem;
}
.btn-submit {
  padding: 0.5rem 1.25rem;
  background: #1976d2;
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 0.95rem;
  cursor: pointer;
}
.btn-submit:hover { background: #1565c0; }
.btn-cancel {
  padding: 0.5rem 1rem;
  color: #666;
  text-decoration: none;
  font-size: 0.95rem;
}
.btn-cancel:hover { color: #333; }

/* 认领页面 */
.claim-page {
  max-width: 560px;
  margin: 0 auto;
  padding: 2rem 0;
}
.claim-card {
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  padding: 1.5rem;
  background: #fff;
}
.claim-title {
  margin: 0 0 1.5rem;
  font-size: 1.35rem;
  font-weight: 600;
}
.claim-error {
  color: #c62828;
  background: #ffebee;
  padding: 0.5rem 0.75rem;
  border-radius: 4px;
  margin-bottom: 1rem;
  font-size: 0.9rem;
}
.claim-info-section {
  margin-bottom: 1.25rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid #eee;
}
.claim-section-title {
  margin: 0 0 0.5rem;
  font-size: 0.9rem;
  color: #666;
}
.claim-user, .claim-scholar-name {
  margin: 0;
  font-size: 1rem;
  color: #333;
}
.claim-scholar-meta { margin: 0.25rem 0 0; font-size: 0.9rem; color: #666; }
.claim-scholar-id { margin: 0.25rem 0 0; font-size: 0.85rem; }
.claim-scholar-id a { color: #1565c0; text-decoration: none; }
.claim-scholar-id a:hover { text-decoration: underline; }
.claim-form { margin-top: 1rem; }
.claim-field { margin-bottom: 1rem; }
.claim-field label {
  display: block;
  margin-bottom: 0.35rem;
  font-size: 0.9rem;
  color: #333;
}
.claim-field .required { color: #c62828; }
.claim-field textarea {
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 0.95rem;
  font-family: inherit;
  box-sizing: border-box;
}
.claim-field textarea:focus { outline: none; border-color: #1565c0; }
.claim-actions {
  display: flex;
  gap: 0.75rem;
  margin-top: 1.25rem;
}
.claim-submit-btn {
  padding: 0.5rem 1.25rem;
  background: #2e7d32;
  color: #fff;
  border: none;
  border-radius: 4px;
  font-size: 0.95rem;
  cursor: pointer;
}
.claim-submit-btn:hover { background: #1b5e20; }
.claim-cancel-btn {
  padding: 0.5rem 1rem;
  color: #666;
  text-decoration: none;
  font-size: 0.95rem;
}
.claim-cancel-btn:hover { color: #000; }

@media (max-width: 768px) {
  .profile-backend {
    flex-direction: column;
    padding: 1rem 0;
  }
  .profile-sidebar {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
  }
  .profile-sidebar-title {
    width: 100%;
    margin-bottom: 0.5rem;
    padding: 0;
  }
  .profile-nav {
    flex-direction: row;
    flex-wrap: wrap;
  }
  .profile-nav-item {
    padding: 0.4rem 0.75rem;
    border-left: none;
    border-bottom: 2px solid transparent;
  }
  .profile-nav-item-active {
    border-left: none;
    border-bottom-color: #1565c0;
  }
}

/* ========== 学术对标 / 机构对标 ========== */
.benchmark-panel { max-width: 100%; }
.inst-benchmark-panel .inst-search-row {
  display: flex;
  gap: 0.75rem;
  align-items: center;
}
.inst-benchmark-panel .inst-search-input {
  flex: 1;
  min-width: 200px;
  padding: 0.5rem 0.75rem;
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  font-size: 0.95rem;
}
.inst-benchmark-panel .inst-search-input:focus {
  outline: none;
  border-color: #1565c0;
  box-shadow: 0 0 0 2px rgba(21, 101, 192, 0.15);
}
.inst-benchmark-panel .inst-result-list .inst-meta {
  font-size: 0.8rem;
  color: #888;
  margin-left: 0.35rem;
}
.inst-benchmark-panel .inst-combobox-wrap {
  position: relative;
  width: 100%;
  max-width: 400px;
}
.inst-benchmark-panel .inst-combobox-wrap .mobility-inner-input {
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  font-size: 0.95rem;
}
.inst-benchmark-panel .inst-combobox-wrap .mobility-inner-input:focus {
  outline: none;
  border-color: #1565c0;
}
.inst-benchmark-panel .inst-selected-box {
  margin-top: 1rem;
  padding: 0.75rem 1rem;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  background: #fafafa;
  min-height: 48px;
}
.inst-benchmark-panel .inst-selected-label {
  font-size: 0.85rem;
  color: #666;
  margin-bottom: 0.5rem;
}
.inst-benchmark-panel .inst-selected-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}
.inst-benchmark-panel .inst-tag {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.3rem 0.5rem;
  background: #e3f2fd;
  color: #1565c0;
  border-radius: 6px;
  font-size: 0.9rem;
}
.inst-benchmark-panel .inst-tag-remove {
  background: none;
  border: none;
  color: #1565c0;
  cursor: pointer;
  font-size: 1.1rem;
  line-height: 1;
  padding: 0 0.15rem;
  opacity: 0.8;
}
.inst-benchmark-panel .inst-tag-remove:hover {
  opacity: 1;
  color: #0d47a1;
}
.inst-benchmark-panel .inst-tag-placeholder {
  font-size: 0.9rem;
  color: #999;
}
.inst-benchmark-panel .inst-selected-count {
  font-size: 0.9rem;
  color: #666;
}
.benchmark-desc {
  font-size: 0.95rem;
  color: #555;
  margin: 0 0 1rem;
}
.benchmark-form { margin-bottom: 1.5rem; }
.benchmark-select-wrap {
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  padding: 1rem;
  background: #fafafa;
}
.benchmark-select-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.75rem;
}
.benchmark-check-all {
  font-size: 0.9rem;
  cursor: pointer;
}
.benchmark-check-all input { margin-right: 0.35rem; }
.benchmark-submit-btn {
  background: #1565c0;
  color: #fff;
  border: none;
  padding: 0.5rem 1.25rem;
  border-radius: 6px;
  font-size: 0.95rem;
  cursor: pointer;
}
.benchmark-submit-btn:hover { background: #0d47a1; }
.benchmark-scholar-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.5rem;
}
.benchmark-scholar-item label {
  cursor: pointer;
  font-size: 0.9rem;
  display: flex;
  align-items: center;
  gap: 0.35rem;
}
.benchmark-scholar-item input { margin-right: 0.25rem; }
.benchmark-scholar-item a { color: #1565c0; text-decoration: none; }
.benchmark-scholar-item a:hover { text-decoration: underline; }
.benchmark-hint { color: #666; font-size: 0.95rem; margin-top: 0.5rem; }
.benchmark-results { margin-top: 2rem; }
.benchmark-section {
  margin-bottom: 2.5rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid #eee;
}
.benchmark-section:last-child { border-bottom: none; }
.benchmark-section-title {
  font-size: 1.1rem;
  font-weight: 600;
  color: #333;
  margin: 0 0 1rem;
}
.benchmark-table-wrap { overflow-x: auto; margin-bottom: 1.5rem; }
.benchmark-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}
.benchmark-table th,
.benchmark-table td {
  padding: 0.6rem 0.75rem;
  text-align: left;
  border-bottom: 1px solid #eee;
}
.benchmark-table th {
  background: #f5f5f5;
  font-weight: 600;
  color: #555;
}
.benchmark-table td a { color: #1565c0; text-decoration: none; }
.benchmark-table td a:hover { text-decoration: underline; }
.benchmark-orgs { font-size: 0.85rem; color: #666; max-width: 300px; }
.benchmark-charts-row {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 1.5rem;
}
.benchmark-chart-card {
  flex: 1;
  min-width: 280px;
  border: 1px solid #e8e8e8;
  border-radius: 8px;
  padding: 1rem;
  background: #fff;
}
.benchmark-chart-card h4 {
  margin: 0 0 0.75rem;
  font-size: 0.95rem;
  color: #333;
}
.benchmark-chart-card .chart-hint {
  font-size: 0.8rem;
  font-weight: normal;
  color: #888;
}
.benchmark-chart-wide { min-width: 100%; }
.benchmark-ranking .momentum-bar-item { margin-bottom: 0.5rem; }
.benchmark-momentum-wrap {
  margin-bottom: 1.5rem;
  padding: 1rem;
  border: 1px solid #e8e8e8;
  border-radius: 8px;
  background: linear-gradient(135deg, #f8f9ff 0%, #fff 100%);
}
.benchmark-momentum-wrap h4 { margin: 0 0 0.35rem; font-size: 1rem; }
.benchmark-momentum-desc {
  font-size: 0.85rem;
  color: #666;
  margin: 0 0 0.75rem;
}
.benchmark-momentum-bars { margin-top: 0.5rem; }
.momentum-bar-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.6rem;
}
.momentum-name {
  flex-shrink: 0;
  width: 140px;
  font-size: 0.9rem;
  overflow: hidden;
  text-overflow: ellipsis;
}
.momentum-name a { color: #333; text-decoration: none; }
.momentum-name a:hover { color: #1565c0; text-decoration: underline; }
.momentum-bar-bg {
  flex: 1;
  height: 20px;
  background: #e8e8e8;
  border-radius: 4px;
  overflow: hidden;
}
.momentum-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, #1565c0, #42a5f5);
  border-radius: 4px;
  transition: width 0.3s ease;
}
.momentum-value {
  flex-shrink: 0;
  width: 2.5rem;
  font-weight: 600;
  color: #1565c0;
  text-align: right;
}
.benchmark-layer3-hint { font-size: 0.85rem; color: #999; margin: 0 0 0.75rem; }
.benchmark-no-data {
  margin-top: 1.5rem;
  padding: 1.5rem;
  border: 1px solid #ffcc80;
  border-radius: 8px;
  background: #fff8e1;
}
.benchmark-no-data .benchmark-hint { margin: 0; }

/* ========== 管理后台 ========== */
.admin-wrap { max-width: 1100px; margin: 0 auto; padding: 1rem; }
.admin-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 0;
  border-bottom: 1px solid #e0e0e0;
  margin-bottom: 1.5rem;
}
.admin-brand {
  font-size: 1.25rem;
  font-weight: 600;
  color: #333;
  text-decoration: none;
}
.admin-brand:hover { color: #1565c0; }
.admin-nav {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.admin-nav-item {
  color: #1565c0;
  text-decoration: none;
  font-size: 0.95rem;
}
.admin-nav-item:hover { text-decoration: underline; }
.admin-logout-form { margin: 0; }
.admin-logout-btn {
  padding: 0.35rem 0.75rem;
  font-size: 0.9rem;
  color: #666;
  background: #f5f5f5;
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  cursor: pointer;
}
.admin-logout-btn:hover { background: #eeeeee; color: #333; }
.admin-main { padding: 0; }
.admin-flash { margin-bottom: 1rem; }
.admin-panel { }
.admin-panel-title { margin: 0 0 1rem; font-size: 1.1rem; color: #333; }
.admin-search-form {
  margin-bottom: 1rem;
  display: flex;
  gap: 0.5rem;
}
.admin-search-form input {
  padding: 0.4rem 0.6rem;
  border: 1px solid #ddd;
  border-radius: 4px;
  width: 220px;
}
.admin-table-wrap { overflow-x: auto; }
.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}
.admin-table th,
.admin-table td {
  padding: 0.6rem 0.75rem;
  text-align: left;
  border-bottom: 1px solid #eee;
}
.admin-table th {
  background: #f8f9fa;
  font-weight: 600;
  color: #555;
}
.admin-table a { color: #1565c0; text-decoration: none; }
.admin-table a:hover { text-decoration: underline; }
.admin-pagination {
  margin-top: 1rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  font-size: 0.9rem;
  color: #666;
}
.admin-pagination a { color: #1565c0; text-decoration: none; }
.admin-pagination a:hover { text-decoration: underline; }
.admin-dl {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.5rem 1.5rem;
  margin: 0 0 1.5rem;
  font-size: 0.95rem;
}
.admin-dl dt { color: #666; }
.admin-dl dd { margin: 0; }
.admin-section {
  margin-bottom: 2rem;
  padding: 1rem;
  border: 1px solid #eee;
  border-radius: 8px;
  background: #fafafa;
}
.admin-section h3 { margin: 0 0 0.75rem; font-size: 1rem; color: #555; }
.admin-grant-form { margin-top: 0.75rem; }
.admin-form-row {
  margin-bottom: 0.5rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.admin-form-row label { width: 4rem; font-size: 0.9rem; color: #666; }
.admin-form-row input,
.admin-form-row select {
  padding: 0.35rem 0.5rem;
  border: 1px solid #ddd;
  border-radius: 4px;
}
.admin-grant-form .auth-btn { margin-top: 0.5rem; }
.admin-clear-form { margin-bottom: 0.75rem; }
.admin-clear-btn {
  padding: 0.35rem 0.75rem;
  font-size: 0.85rem;
  color: #c62828;
  background: #ffebee;
  border: 1px solid rgba(198, 40, 40, 0.3);
  border-radius: 6px;
  cursor: pointer;
}
.admin-clear-btn:hover { background: #ffcdd2; }
.admin-delete-form { margin: 0; }
.admin-delete-btn {
  padding: 0.4rem 0.9rem;
  background: #c62828;
  color: #fff;
  border: 1px solid #b71c1c;
  border-radius: 6px;
  font-size: 0.9rem;
  cursor: pointer;
}
.admin-delete-btn:hover { background: #b71c1c; }
.admin-delete-inline {
  padding: 0.2rem 0.5rem;
  background: transparent;
  color: #c62828;
  border: 1px solid #c62828;
  border-radius: 4px;
  font-size: 0.85rem;
  cursor: pointer;
}
.admin-delete-inline:hover { background: #ffebee; }
.admin-empty { margin: 0; color: #999; font-size: 0.9rem; }
.admin-login-wrap {
  min-height: 60vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}
.admin-login-card {
  width: 100%;
  max-width: 360px;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  padding: 2rem;
  background: #fff;
}
.admin-login-title {
  margin: 0 0 1.5rem;
  font-size: 1.25rem;
  font-weight: 600;
  text-align: center;
}
