/* Protocol Intelligence Agent — dashboard styles */

/* ---------- Protocol synopsis block ---------- */
.pt-synopsis-block {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.pt-synopsis-area {
  width: 100%;
  max-width: 760px;
  height: 110px;
  padding: 14px 16px;
  border: 1px solid var(--rule);
  border-radius: 6px;
  background: var(--bg-2);
  font-family: var(--mono);
  font-size: 12px;
  line-height: 1.6;
  color: var(--ink-2);
  resize: none;
  outline: none;
  cursor: default;
}

/* ---------- Risk score stat card colors ---------- */
#stat-risk-card.risk-high .at-stat-val  { color: var(--status-confirmed); }
#stat-risk-card.risk-med  .at-stat-val  { color: var(--status-suspected); }
#stat-risk-card.risk-low  .at-stat-val  { color: var(--status-monitored); }

/* ---------- Amendment callout ---------- */
.pt-callout {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 24px 28px;
  border: 1px solid var(--rule);
  border-left: 4px solid var(--status-confirmed);
  border-radius: 6px;
  background: color-mix(in oklch, var(--status-confirmed) 5%, var(--bg));
  margin-bottom: 32px;
  flex-wrap: wrap;
}
.pt-callout.callout-med {
  border-left-color: var(--status-suspected);
  background: color-mix(in oklch, var(--status-suspected) 5%, var(--bg));
}
.pt-callout.callout-low {
  border-left-color: var(--status-monitored);
  background: color-mix(in oklch, var(--status-monitored) 5%, var(--bg));
}
.pt-callout-amount {
  font-family: var(--serif);
  font-size: clamp(28px, 4vw, 40px);
  color: var(--ink);
  letter-spacing: -0.03em;
  line-height: 1;
  white-space: nowrap;
}
.pt-callout-desc {
  font-size: 14px;
  color: var(--ink-2);
  line-height: 1.55;
  max-width: 480px;
}
.pt-callout-desc strong {
  color: var(--ink);
  font-weight: 600;
}

/* ---------- Severity badges ---------- */
.pt-sev-badge {
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 10px;
  border-radius: 999px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  white-space: nowrap;
}
.pt-sev-badge.critical {
  background: color-mix(in oklch, var(--status-confirmed) 12%, transparent);
  color: var(--status-confirmed);
  border: 1px solid color-mix(in oklch, var(--status-confirmed) 30%, transparent);
}
.pt-sev-badge.high {
  background: color-mix(in oklch, var(--status-suspected) 14%, transparent);
  color: var(--status-suspected);
  border: 1px solid color-mix(in oklch, var(--status-suspected) 30%, transparent);
}
.pt-sev-badge.medium {
  background: color-mix(in oklch, var(--status-monitored) 12%, transparent);
  color: var(--status-monitored);
  border: 1px solid color-mix(in oklch, var(--status-monitored) 30%, transparent);
}
.pt-sev-badge.low {
  background: color-mix(in oklch, var(--ink) 6%, transparent);
  color: var(--muted);
  border: 1px solid var(--rule);
}

/* ---------- Likelihood bar cell ---------- */
.pt-likelihood-cell {
  display: flex;
  align-items: center;
  gap: 8px;
}
.pt-likelihood-track {
  flex: 1;
  min-width: 60px;
  height: 4px;
  background: var(--rule);
  border-radius: 2px;
}
.pt-likelihood-fill {
  height: 100%;
  border-radius: 2px;
  background: var(--status-suspected);
}
.pt-likelihood-fill.hi { background: var(--status-confirmed); }
.pt-likelihood-fill.lo { background: var(--status-monitored); }
.pt-likelihood-label {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--muted);
  white-space: nowrap;
}

/* ---------- Amendment detail row ---------- */
.pt-amendment-detail {
  padding: 16px 24px 20px;
  background: var(--bg-2);
  border-bottom: 1px solid var(--rule);
}
.pt-amendment-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px 32px;
  max-width: 800px;
}
@media (max-width: 600px) {
  .pt-amendment-detail-grid { grid-template-columns: 1fr; }
}
.pt-amendment-detail-label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 6px;
}
.pt-amendment-detail-text {
  font-size: 13px;
  color: var(--ink-2);
  line-height: 1.65;
  margin: 0;
}

/* ---------- Eligibility criteria grid ---------- */
.pt-criteria-grid {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.pt-criteria-pair {
  border: 1px solid var(--rule);
  border-radius: 6px;
  overflow: hidden;
}
.pt-criteria-pair-header {
  padding: 12px 20px;
  background: var(--bg-2);
  border-bottom: 1px solid var(--rule);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.pt-criteria-pair-title {
  font-family: var(--serif);
  font-size: 15px;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.pt-impact-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 26px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid color-mix(in oklch, var(--status-recovered) 40%, transparent);
  background: color-mix(in oklch, var(--status-recovered) 10%, transparent);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--status-recovered);
  white-space: nowrap;
}
.pt-criteria-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
@media (max-width: 640px) {
  .pt-criteria-cards { grid-template-columns: 1fr; }
}
.pt-criteria-card {
  padding: 20px 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.pt-criteria-card.before {
  background: color-mix(in oklch, var(--status-confirmed) 4%, var(--bg));
  border-right: 1px solid var(--rule);
}
.pt-criteria-card.after {
  background: color-mix(in oklch, var(--status-recovered) 4%, var(--bg));
}
@media (max-width: 640px) {
  .pt-criteria-card.before { border-right: none; border-bottom: 1px solid var(--rule); }
}
.pt-criteria-card-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.pt-criteria-card-label.before { color: var(--status-confirmed); }
.pt-criteria-card-label.after  { color: var(--status-recovered); }
.pt-criteria-card-icon {
  font-size: 13px;
  line-height: 1;
}
.pt-criteria-text {
  font-size: 13px;
  color: var(--ink-2);
  line-height: 1.65;
  margin: 0;
  font-style: italic;
}

/* ---------- Population funnel ---------- */
.pt-funnel-section {
  display: flex;
  flex-direction: column;
  gap: 18px;
  max-width: 600px;
}
.pt-funnel-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.pt-funnel-label-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.pt-funnel-label {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}
.pt-funnel-val {
  font-family: var(--serif);
  font-size: 18px;
  color: var(--ink);
  letter-spacing: -0.02em;
}
.pt-funnel-track {
  height: 8px;
  background: var(--rule);
  border-radius: 4px;
  overflow: hidden;
}
.pt-funnel-fill {
  height: 100%;
  border-radius: 4px;
  transition: width .6s ease;
}
.pt-funnel-fill.before { background: var(--status-confirmed); opacity: .6; }
.pt-funnel-fill.after  { background: var(--status-recovered); }
.pt-funnel-delta {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--status-recovered);
  letter-spacing: 0.06em;
}

/* ---------- Enrollment chart wrapper ---------- */
.pt-enrollment-chart-wrap {
  max-width: 820px;
  margin-bottom: 0;
}

/* ---------- Comparable trials ---------- */
.pt-comparable-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid var(--rule);
  border-radius: 6px;
  overflow: hidden;
}
.pt-comparable-loading {
  padding: 24px;
  font-family: var(--mono);
  font-size: 12px;
  color: var(--muted);
  letter-spacing: 0.06em;
}
.pt-comparable-item {
  padding: 18px 22px;
  border-bottom: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.pt-comparable-item:last-child { border-bottom: none; }
.pt-comparable-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.pt-comparable-nct {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--muted);
  text-decoration: none;
  border-bottom: 1px solid var(--rule);
  transition: color .15s;
}
.pt-comparable-nct:hover { color: var(--ink-2); }
.pt-comparable-status {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 1px 8px;
  border-radius: 999px;
}
.pt-comparable-status.recruiting {
  background: color-mix(in oklch, var(--status-recovered) 12%, transparent);
  color: var(--status-recovered);
  border: 1px solid color-mix(in oklch, var(--status-recovered) 30%, transparent);
}
.pt-comparable-status.active {
  background: color-mix(in oklch, var(--status-monitored) 12%, transparent);
  color: var(--status-monitored);
  border: 1px solid color-mix(in oklch, var(--status-monitored) 30%, transparent);
}
.pt-comparable-status.completed {
  background: color-mix(in oklch, var(--ink) 8%, transparent);
  color: var(--muted);
  border: 1px solid var(--rule);
}
.pt-comparable-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--ink);
  line-height: 1.4;
}
.pt-comparable-detail {
  font-size: 12px;
  color: var(--muted);
  font-family: var(--mono);
  letter-spacing: 0.04em;
}
.pt-comparable-live {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--status-recovered);
  padding: 1px 7px;
  border: 1px solid color-mix(in oklch, var(--status-recovered) 30%, transparent);
  border-radius: 999px;
  background: color-mix(in oklch, var(--status-recovered) 8%, transparent);
}
.pt-comparable-error {
  padding: 20px 22px;
  font-size: 13px;
  color: var(--muted);
}

/* ---------- Pipeline navigation link ---------- */
.pt-pipeline-link {
  margin-top: 48px;
  margin-bottom: 48px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.pt-pipeline-label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}
.pt-pipeline-a {
  font-size: 14px;
  color: var(--ink-2);
  text-decoration: none;
  border-bottom: 1px solid var(--rule);
  padding-bottom: 1px;
  width: fit-content;
  transition: color .15s, border-color .15s;
}
.pt-pipeline-a:hover {
  color: var(--ink);
  border-color: var(--ink-2);
}
