/* flowchart.css — 流程图 & 重型UI专用样式 */
/* v1.0.0 — 2026-06-18 */

/* ════════════════════════════════════════════
   火力全开弹窗
   ════════════════════════════════════════════ */

.fire-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, .7);
  z-index: 9999;
  backdrop-filter: blur(4px);
}

.fire-dialog {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 10000;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 28px 32px;
  min-width: 380px;
  max-width: 460px;
  box-shadow: 0 16px 48px rgba(0, 0, 0, .5);
  animation: fireIn .25s ease-out;
}

@keyframes fireIn {
  from { opacity: 0; transform: translate(-50%, -48%); }
  to   { opacity: 1; transform: translate(-50%, -50%); }
}

.fire-dialog h2 {
  font-size: 20px;
  color: var(--text);
  margin: 0 0 12px;
  text-align: center;
}

.fire-dialog .fire-icon {
  font-size: 48px;
  text-align: center;
  margin-bottom: 8px;
}

.fire-body {
  color: var(--t2);
  font-size: 13px;
  line-height: 1.8;
}

.fire-body ul {
  margin: 8px 0 8px 20px;
  padding: 0;
}

.fire-body ul li {
  margin-bottom: 4px;
}

.fire-body strong {
  color: var(--amber);
}

.fire-divider {
  height: 1px;
  background: var(--border);
  margin: 16px 0;
}

.fire-consequence {
  text-align: center;
  color: var(--rose);
  font-size: 15px;
  font-weight: 700;
  margin: 8px 0;
}

.fire-btns {
  display: flex;
  gap: 10px;
  margin-top: 20px;
  justify-content: center;
}

/* 按钮基础 */
.btn {
  padding: 8px 18px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  font-size: 13px;
  cursor: pointer;
  transition: all .2s;
  font-family: inherit;
}

.btn:hover { border-color: var(--b-hover); }

.btn-s { padding: 4px 10px; font-size: 11px; }

.btn-p {
  background: var(--indigo);
  border-color: var(--indigo);
  color: #fff;
}

.btn-o {
  background: transparent;
  color: var(--t2);
}

.btn-fire {
  background: linear-gradient(135deg, #f59e0b, #ef4444);
  border-color: #f59e0b;
  color: #fff;
  font-weight: 700;
  font-size: 14px;
  padding: 10px 24px;
  animation: firePulse 2s infinite;
}

@keyframes firePulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(245, 158, 11, .4); }
  50%      { box-shadow: 0 0 0 8px rgba(245, 158, 11, 0); }
}

.btn-fire.running {
  background: linear-gradient(135deg, #ef4444, #dc2626);
  animation: fireRun .6s infinite;
}

@keyframes fireRun {
  0%, 100% { box-shadow: 0 0 4px rgba(239, 68, 68, .6); }
  50%      { box-shadow: 0 0 16px rgba(239, 68, 68, .9); }
}

.btn-fire:disabled {
  opacity: .8;
  cursor: not-allowed;
}

/* 成本确认弹窗 */
.fire-cost-body table {
  width: 100%;
  border-collapse: collapse;
  margin: 12px 0;
}

.fire-cost-body td {
  padding: 6px 10px;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
  color: var(--t2);
}

.fire-cost-body td:first-child {
  color: var(--t3);
  width: 120px;
}

.fire-cost-total td {
  border-bottom: none;
  color: var(--amber) !important;
  font-size: 15px;
  padding-top: 10px;
}

/* ════════════════════════════════════════════
   进度条
   ════════════════════════════════════════════ */

.fire-progress {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px;
  margin: 0 16px 12px;
}

.fire-progress-header {
  font-size: 14px;
  font-weight: 700;
  color: var(--amber);
  margin-bottom: 12px;
}

.fire-bar-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  font-size: 11px;
}

.fire-bar-row span:first-child {
  color: var(--t3);
  width: 28px;
  text-align: left;
  font-weight: 600;
}

.fire-bar-row span:last-child {
  color: var(--t2);
  width: 100px;
  text-align: right;
  font-size: 11px;
}

.fire-bar {
  flex: 1;
  height: 6px;
  background: var(--border);
  border-radius: 3px;
  overflow: hidden;
}

.fire-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--cyan), var(--emerald));
  border-radius: 3px;
  transition: width .5s ease;
  width: 0;
}

#fireM1 + .fire-bar .fire-fill { background: var(--emerald); }
#fireM3 + .fire-bar .fire-fill { background: var(--amber); }
#fireM4 + .fire-bar .fire-fill { background: var(--indigo); }

/* ════════════════════════════════════════════
   成品输出卡片
   ════════════════════════════════════════════ */

.fire-result {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--cyan);
  border-radius: 0 12px 12px 0;
  margin: 8px 16px;
  overflow: hidden;
}

.fire-result-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 16px;
  background: rgba(56, 189, 248, .05);
  border-bottom: 1px solid var(--border);
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}

.fire-result-meta {
  display: flex;
  gap: 16px;
  padding: 8px 16px;
  font-size: 11px;
  color: var(--t3);
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}

.fire-result-body {
  padding: 16px;
  font-size: 13px;
  line-height: 1.7;
  color: var(--text);
  white-space: pre-wrap;
  max-height: 400px;
  overflow-y: auto;
}

.fire-suggestions {
  padding: 12px 16px;
  border-top: 1px solid var(--border);
  background: rgba(245, 158, 11, .03);
}

.fire-suggestions h4 {
  font-size: 12px;
  color: var(--amber);
  margin: 0 0 8px;
}

.fire-suggestions ul {
  margin: 0;
  padding-left: 18px;
}

.fire-suggestions li {
  font-size: 12px;
  color: var(--t2);
  margin-bottom: 4px;
}

.fire-result-actions {
  display: flex;
  gap: 8px;
  padding: 10px 16px;
  border-top: 1px solid var(--border);
}

/* ════════════════════════════════════════════
   实例选择器 & 组合器
   ════════════════════════════════════════════ */

.instance-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}

.instance-label {
  flex: 1;
  font-size: 13px;
  color: var(--text);
}

.instance-count {
  width: 50px;
  padding: 4px 8px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text);
  font-size: 13px;
  text-align: center;
  font-family: inherit;
  outline: none;
}

.instance-count:focus {
  border-color: var(--cyan);
}

.combo-row {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 0;
  font-size: 12px;
  color: var(--t2);
}

.combo-row input {
  width: 44px;
  padding: 3px 6px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text);
  font-size: 13px;
  text-align: center;
  font-family: inherit;
  outline: none;
}

.combo-row input:focus {
  border-color: var(--cyan);
}

.combo-total {
  margin-left: 8px;
  color: var(--t3);
  font-size: 11px;
}

/* ════════════════════════════════════════════
   Toast
   ════════════════════════════════════════════ */

.toast {
  position: fixed;
  bottom: 80px;
  left: 50%;
  transform: translateX(-50%);
  padding: 8px 20px;
  border-radius: 8px;
  font-size: 13px;
  z-index: 9999;
  animation: toastIn .3s ease-out;
  pointer-events: none;
}

@keyframes toastIn {
  from { opacity: 0; transform: translateX(-50%) translateY(10px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}

.toast.info  { background: rgba(56, 189, 248, .15); border: 1px solid rgba(56, 189, 248, .3); color: var(--cyan); }
.toast.ok    { background: rgba(16, 185, 129, .15); border: 1px solid rgba(16, 185, 129, .3); color: var(--emerald); }
.toast.warn  { background: rgba(245, 158, 11, .15); border: 1px solid rgba(245, 158, 11, .3); color: var(--amber); }
.toast.err   { background: rgba(239, 68, 68, .15); border: 1px solid rgba(239, 68, 68, .3); color: var(--rose); }
