/* Monte Carlo Simulator — page styles */

.page-wrap.page-full { grid-template-columns: 1fr; gap: 0; }
.page-wrap.page-full > main { padding-right: 0; }

.mc-grid {
  display: grid; grid-template-columns: minmax(280px, 0.85fr) minmax(0, 1.2fr);
  gap: 14px; margin-top: 14px;
}
@media (max-width: 1024px) { .mc-grid { grid-template-columns: 1fr; } }
.mc-col { display: flex; flex-direction: column; gap: 12px; }

.mc-card {
  background: #fff; border: 1px solid var(--line); border-radius: var(--r-md);
  padding: 14px 16px;
}
.mc-card h3 {
  font-size: 12px; text-transform: uppercase; letter-spacing: .06em;
  color: var(--brand); font-weight: 700; margin: 0 0 10px;
}
.mc-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 12px; }
.mc-field label { display: block; font-size: 12px; font-weight: 600; color: var(--ink-2); margin-bottom: 4px; }
.mc-field input, .mc-field select {
  width: 100%; padding: 9px 12px; border: 1px solid var(--line); border-radius: 6px;
  font: inherit; font-size: 14px; background: #fff; color: var(--ink); box-sizing: border-box;
}
.mc-field input:focus, .mc-field select:focus { outline: none; border-color: var(--brand); box-shadow: 0 0 0 3px rgba(31,78,121,.12); }

.mc-btn {
  padding: 10px 18px; border: 1px solid var(--line); background: #fff;
  border-radius: 6px; cursor: pointer; font: inherit; font-size: 14px; color: var(--ink); width: 100%; font-weight: 600;
}
.mc-btn.primary { background: var(--brand); color: #fff; border-color: var(--brand); }
.mc-btn.primary:hover { background: #16385A; }
.mc-btn:disabled { opacity: 0.6; cursor: not-allowed; }

.mc-progress {
  margin-top: 10px; display: flex; flex-direction: column; gap: 6px;
}
.mc-progress-bar {
  height: 6px; background: #E5EAF0; border-radius: 999px; overflow: hidden;
}
.mc-progress-bar i {
  display: block; height: 100%; width: 0; background: var(--brand); transition: width 0.1s linear;
}
.mc-progress span { font-size: 11.5px; color: var(--ink-3); font-family: 'JetBrains Mono', ui-monospace, monospace; }

.mc-edge {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px 12px;
  font-size: 12.5px; color: var(--ink-2);
}
.mc-edge b { color: var(--ink); font-family: 'JetBrains Mono', ui-monospace, monospace; }
.mc-edge .full {
  grid-column: span 2; padding-top: 8px; border-top: 1px solid var(--line);
}
.mc-edge .verdict { color: var(--ink-2); font-style: italic; }
.mc-edge .verdict.good { color: #0B7A2C; font-style: normal; font-weight: 600; }
.mc-edge .verdict.bad  { color: #B91C1C; font-style: normal; font-weight: 600; }

/* KPIs */
.mc-kpis {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
}
@media (max-width: 800px) { .mc-kpis { grid-template-columns: repeat(2, 1fr); } }

.mc-kpi {
  background: #fff; border: 1px solid var(--line); border-radius: var(--r-md);
  padding: 12px 14px;
}
.mc-kpi .lbl { font-size: 10.5px; text-transform: uppercase; letter-spacing: .05em; font-weight: 600; color: var(--ink-3); }
.mc-kpi .val { font-size: 20px; font-weight: 700; color: var(--ink); margin-top: 2px; font-family: 'JetBrains Mono', ui-monospace, monospace; }
.mc-kpi .val.pos { color: #0B7A2C; }
.mc-kpi .val.neg { color: #B91C1C; }
.mc-kpi .sub { font-size: 11.5px; color: var(--ink-3); margin-top: 2px; line-height: 1.4; font-family: 'JetBrains Mono', ui-monospace, monospace; }

.mc-chart-card { padding: 14px 16px; }
.mc-chart-wrap { position: relative; width: 100%; min-height: 280px; }
.mc-chart-wrap canvas { width: 100% !important; }

/* Percentile table */
.mc-table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.mc-table th, .mc-table td { padding: 8px 12px; text-align: left; border-bottom: 1px solid var(--line); }
.mc-table th { background: #F4F6F8; font-size: 11px; text-transform: uppercase; letter-spacing: .04em; color: var(--ink-2); font-weight: 700; }
.mc-table td.num { font-family: 'JetBrains Mono', ui-monospace, monospace; text-align: right; }
.mc-table tr.median { background: var(--brand-light, #E8F1FA); font-weight: 700; }
.mc-table td.pos { color: #0B7A2C; }
.mc-table td.neg { color: #B91C1C; }

.mc-empty {
  text-align: center; padding: 60px 20px;
  background: #fff; border: 1px dashed var(--line); border-radius: var(--r-md);
  color: var(--ink-3); font-size: 14px;
}
