/**
 * AI 合同风险评估 + 报告页
 */

/* 全页背景：assets/images/bg_risk.png（与案例共享 / 法律地图 / 短视频等页一致：仅铺图，不叠渐变蒙版） */
.page-bg--contract-risk {
  background: url("../assets/images/bg_risk.png") center / cover no-repeat;
}

/* 报告页 + bg_risk：空态/加载为浅色毛玻璃衬板（与上传页视觉一致），正文深色易读 */
body:has(.page-bg--contract-risk) #report-empty.contract-risk-report,
body:has(.page-bg--contract-risk) #report-loading.contract-risk-report {
  max-width: min(640px, 94vw);
  margin-left: auto;
  margin-right: auto;
  padding: 36px 28px 40px;
  background: rgba(252, 253, 255, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: var(--radius-lg, 22px);
  border: 1px solid rgba(255, 255, 255, 0.45);
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.16);
  color: var(--color-text);
  text-shadow: none;
}

body:has(.page-bg--contract-risk) #report-empty .contract-risk-report--empty-hint {
  color: var(--color-text-muted);
}

body:has(.page-bg--contract-risk) #report-empty a {
  color: var(--color-consult, #5b8cff);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
}

body:has(.page-bg--contract-risk) #report-empty a:hover {
  color: #3d6fd8;
}

body:has(.page-bg--contract-risk) #report-main.contract-risk-report {
  background: rgba(252, 253, 255, 0.92);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid rgba(255, 255, 255, 0.45);
  border-radius: var(--radius-lg, 22px);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.18);
  padding: 22px 22px 32px;
}

body:has(.page-bg--contract-risk) #report-main.contract-risk-report .contract-risk-report__head {
  background: transparent;
  padding: 0 0 20px;
  margin-bottom: 24px;
  border-radius: 0;
  border: none;
  border-bottom: 1px solid var(--color-border);
  box-shadow: none;
}

body:has(.page-bg--contract-risk) #report-main.contract-risk-report h2,
body:has(.page-bg--contract-risk) #report-main.contract-risk-report .contract-risk-report__h2 {
  color: var(--color-text);
  text-shadow: none;
}

body:has(.page-bg--contract-risk) #report-main .contract-risk-contract-wrap {
  background: #fff;
  border-color: var(--color-border);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

body:has(.page-bg--contract-risk) #report-main .contract-risk-report__disclaimer {
  background: rgba(255, 255, 255, 0.65);
  border-radius: var(--radius-md, 14px);
  border: 1px dashed var(--color-border);
  border-top: 1px dashed var(--color-border);
}

body:has(.page-bg--contract-risk) #report-render-err {
  background: rgba(255, 255, 255, 0.96);
  border-radius: var(--radius-sm, 8px);
  padding: 12px 14px;
}

.contract-risk-page {
  width: 100%;
  max-width: 920px;
  margin: 0 auto;
  padding: 20px var(--page-gutter, 24px) 48px;
  box-sizing: border-box;
}

/* 与案例共享页一致：沿用 legal-consult 默认 .consult-page-intro max-width:640px */

.contract-risk-page .consult-page-intro p.contract-risk-intro-lines {
  max-width: 100%;
}

/* 标题下说明固定为两行（每行单独成块，避免单字落单） */
.contract-risk-page .consult-page-intro .contract-risk-intro-lines .contract-risk-line {
  display: block;
}

.contract-risk-page .consult-page-intro .contract-risk-intro-lines .contract-risk-line + .contract-risk-line {
  margin-top: 0.4em;
}

/* 毛玻璃下方：使用说明（宽度与标题区对齐；原「温暖的话」已换入毛玻璃内） */
.contract-risk-warm {
  margin: 0 auto 16px;
  max-width: min(640px, 94vw);
  padding: 0;
  box-sizing: border-box;
  font-size: 0.9375rem;
  line-height: 1.65;
  font-weight: 500;
  /* 与法律文书页 .legal-documents-warm 一致的浅蓝字 */
  color: rgba(200, 230, 255, 0.9);
  text-align: center;
  text-shadow: 0 1px 14px rgba(0, 0, 0, 0.28);
}

.contract-risk-warm .contract-risk-line {
  display: block;
}

.contract-risk-warm .contract-risk-line + .contract-risk-line {
  margin-top: 0.35em;
}

/* 页面底部：压缩免责声明 */
.contract-risk-footnote {
  margin: 20px auto 0;
  max-width: 560px;
  padding: 0 var(--page-gutter, 24px);
  box-sizing: border-box;
  font-size: 0.7rem;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.45);
  text-align: center;
}

.contract-risk-panel {
  padding: 22px 22px 24px;
  border-radius: var(--radius-lg, 20px);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  margin-bottom: 20px;
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.22);
}

.contract-risk-panel label {
  display: block;
  margin-bottom: 8px;
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--color-text);
}

.contract-risk-file {
  width: 100%;
  padding: 10px;
  border-radius: var(--radius-sm, 8px);
  border: 1px dashed rgba(91, 140, 255, 0.45);
  background: rgba(0, 0, 0, 0.02);
  font-size: 0.9rem;
}

.contract-risk-or {
  margin: 16px 0;
  text-align: center;
  font-size: 0.8rem;
  color: var(--color-text-muted);
}

.contract-risk-textarea {
  width: 100%;
  min-height: 140px;
  padding: 12px 14px;
  border-radius: var(--radius-sm, 8px);
  border: 1px solid var(--color-border);
  font-family: var(--font-sans);
  font-size: 0.9rem;
  line-height: 1.55;
  resize: vertical;
  box-sizing: border-box;
}

.contract-risk-actions {
  margin-top: 18px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.contract-risk-btn {
  padding: 10px 22px;
  border: none;
  border-radius: 999px;
  font-size: 0.9375rem;
  font-weight: 600;
  cursor: pointer;
  color: #1a1308;
  background: linear-gradient(145deg, var(--color-accent) 0%, #a8863a 100%);
  transition: opacity 0.2s ease;
}

.contract-risk-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.contract-risk-hint {
  margin: 12px 0 0;
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  line-height: 1.6;
}

.contract-risk-err {
  margin-top: 12px;
  padding: 10px 14px;
  border-radius: var(--radius-sm, 8px);
  background: rgba(180, 40, 40, 0.08);
  border: 1px solid rgba(180, 40, 40, 0.25);
  color: #8b2020;
  font-size: 0.875rem;
}

/* —— 分析进度台 —— */
.contract-risk-progress {
  margin-top: 22px;
  padding: 18px 18px 16px;
  border-radius: var(--radius-md, 16px);
  border: 1px solid rgba(91, 140, 255, 0.28);
  background: linear-gradient(165deg, rgba(91, 140, 255, 0.09) 0%, rgba(255, 255, 255, 0.04) 100%);
  box-shadow: 0 8px 28px rgba(15, 22, 40, 0.08);
}

.contract-risk-progress[hidden] {
  display: none !important;
}

.contract-risk-progress__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.contract-risk-progress__title {
  margin: 0;
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: 0.06em;
}

.contract-risk-progress__pct {
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  font-size: 1.125rem;
  color: var(--color-consult, #5b8cff);
}

.contract-risk-progress__track {
  height: 10px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.08);
  overflow: hidden;
  margin-bottom: 16px;
}

.contract-risk-progress__fill {
  height: 100%;
  width: 0%;
  border-radius: 999px;
  background: linear-gradient(90deg, #5b8cff 0%, #c9a227 100%);
  transition: width 0.55s ease;
}

.contract-risk-progress__steps {
  margin: 0 0 12px;
  padding: 0;
  list-style: none;
}

.contract-risk-progress__steps li {
  position: relative;
  margin: 0 0 8px;
  padding-left: 1.45em;
  font-size: 0.875rem;
  line-height: 1.45;
  color: var(--color-text-muted);
}

.contract-risk-progress__steps li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.42em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.2);
}

.contract-risk-progress__dot {
  display: none;
}

.contract-risk-progress__steps li.is-active {
  color: var(--color-text);
  font-weight: 600;
}

.contract-risk-progress__steps li.is-active::before {
  background: var(--color-consult, #5b8cff);
  box-shadow: 0 0 0 3px rgba(91, 140, 255, 0.22);
}

.contract-risk-progress__steps li.is-done {
  color: rgba(21, 24, 32, 0.55);
}

.contract-risk-progress__steps li.is-done::before {
  content: "✓";
  width: auto;
  height: auto;
  top: 0;
  background: transparent;
  color: #2d7a4e;
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.45;
  box-shadow: none;
}

.contract-risk-progress__status {
  margin: 0 0 8px;
  font-size: 0.9rem;
  line-height: 1.55;
  color: var(--color-text);
  min-height: 1.55em;
}

.contract-risk-progress__note {
  margin: 0;
  font-size: 0.75rem;
  line-height: 1.5;
  color: var(--color-text-muted);
  opacity: 0.92;
}

.contract-risk-page--analyzing .contract-risk-file,
.contract-risk-page--analyzing .contract-risk-textarea {
  pointer-events: none;
  opacity: 0.65;
}

/* —— 报告页 —— */
.contract-risk-report {
  max-width: 960px;
  margin: 0 auto;
  margin-top: clamp(76px, 12vh, 108px);
  padding: 0 var(--page-gutter, 24px) 56px;
  box-sizing: border-box;
}

.contract-risk-report__head {
  text-align: center;
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--color-border);
}

.contract-risk-report__brand {
  font-size: 0.75rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-bottom: 8px;
}

.contract-risk-report__title {
  margin: 0;
  font-family: var(--font-serif);
  font-size: clamp(1.5rem, 4vw, 1.95rem);
  font-weight: 700;
}

.contract-risk-report__meta {
  margin-top: 10px;
  font-size: 0.85rem;
  color: var(--color-text-muted);
}

.contract-risk-summary {
  padding: 16px 18px;
  border-radius: var(--radius-md, 14px);
  background: rgba(91, 140, 255, 0.08);
  border: 1px solid rgba(91, 140, 255, 0.22);
  margin-bottom: 20px;
  font-size: 0.95rem;
  line-height: 1.65;
  text-align: left;
}

.contract-risk-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 24px;
  justify-content: center;
}

.contract-risk-stat {
  padding: 10px 18px;
  border-radius: 999px;
  font-size: 0.875rem;
  font-weight: 600;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
}

.contract-risk-stat--high {
  border-color: rgba(200, 80, 80, 0.45);
  background: rgba(200, 80, 80, 0.08);
  color: #8b2c2c;
}

.contract-risk-stat--medium {
  border-color: rgba(200, 150, 60, 0.45);
  background: rgba(200, 150, 60, 0.1);
  color: #7a5a12;
}

.contract-risk-stat--low {
  border-color: rgba(80, 140, 200, 0.35);
  background: rgba(80, 140, 200, 0.08);
  color: #1e4a6e;
}

.contract-risk-report h2,
.contract-risk-report__h2 {
  font-family: var(--font-serif);
  font-size: 1.15rem;
  margin: 32px 0 14px;
  letter-spacing: 0.06em;
}

.contract-risk-report__lead {
  margin: -6px 0 8px;
  font-size: 0.92rem;
  line-height: 1.6;
  font-weight: 500;
  color: var(--color-text);
  text-align: left;
}

.contract-risk-report__caption {
  margin: 0 0 14px;
  font-size: 0.85rem;
  line-height: 1.55;
  color: var(--color-text-muted);
  text-align: left;
}

.contract-risk-contract-wrap {
  border-radius: var(--radius-md, 14px);
  border: 1px solid var(--color-border);
  background: rgba(0, 0, 0, 0.02);
  overflow: auto;
  max-height: min(70vh, 560px);
  margin-bottom: 28px;
  text-align: left;
}

.contract-risk__pre {
  margin: 0;
  padding: 18px 20px;
  white-space: pre-wrap;
  word-break: break-word;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  line-height: 1.75;
  color: var(--color-text);
}

.contract-risk__mark {
  padding: 0 2px;
  border-radius: 3px;
}

.contract-risk__mark--high {
  background: rgba(255, 200, 120, 0.95);
  box-shadow: 0 0 0 1px rgba(200, 100, 60, 0.35);
}

.contract-risk__mark--medium {
  background: rgba(255, 235, 150, 0.95);
  box-shadow: 0 0 0 1px rgba(180, 140, 40, 0.3);
}

.contract-risk__mark--low {
  background: rgba(220, 235, 255, 0.9);
  box-shadow: 0 0 0 1px rgba(80, 120, 180, 0.25);
}

.contract-risk-table-wrap {
  overflow-x: auto;
  margin-bottom: 24px;
}

.contract-risk-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
  line-height: 1.55;
}

.contract-risk-table th,
.contract-risk-table td {
  border: 1px solid var(--color-border);
  padding: 10px 12px;
  text-align: left;
  vertical-align: top;
}

.contract-risk-table th {
  background: rgba(0, 0, 0, 0.03);
  font-weight: 600;
}

.contract-risk-report-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 28px 0;
  justify-content: center;
}

.contract-risk-report__disclaimer {
  margin-top: 32px;
  padding: 14px 16px;
  font-size: 0.8rem;
  line-height: 1.65;
  color: var(--color-text-muted);
  border-top: 1px dashed var(--color-border);
}

.contract-risk-report--empty {
  text-align: center;
  padding: 48px 24px;
  color: var(--color-text-muted);
}

.contract-risk-report--empty-hint {
  max-width: 520px;
  margin: 12px auto 0;
  font-size: 0.8125rem;
  line-height: 1.55;
  color: rgba(21, 24, 32, 0.55);
}

.contract-risk-report--empty-hint code {
  font-size: 0.9em;
  padding: 0 4px;
  border-radius: 4px;
  background: rgba(0, 0, 0, 0.05);
}

@media (max-width: 640px) {
  .contract-risk-table {
    font-size: 0.8125rem;
  }
}
