/* Components · cards, buttons, badges, forms, tables, charts */

/* ============ BUTTONS ============ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  height: 36px;
  padding: 0 var(--s-4);
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  font-size: var(--fs-13);
  font-weight: var(--fw-medium);
  color: var(--text-primary);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease);
  text-decoration: none;
  white-space: nowrap;
}
.btn:hover { background: var(--panel-muted); border-color: var(--border-strong); text-decoration: none; }
.btn:active { transform: translateY(1px); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

.btn-primary {
  background: var(--accent);
  color: var(--text-on-accent);
  border-color: var(--accent);
}
.btn-primary:hover {
  background: var(--accent-strong);
  border-color: var(--accent-strong);
  color: #fff;
}

.btn-ghost { background: transparent; border-color: transparent; color: var(--text-secondary); }
.btn-ghost:hover { background: var(--panel-muted); color: var(--text-primary); }

.btn-sm { height: 28px; padding: 0 var(--s-3); font-size: var(--fs-12); }
.btn-lg { height: 42px; padding: 0 var(--s-5); font-size: var(--fs-14); }

.btn .kbd {
  font-family: var(--font-mono);
  font-size: 10px;
  background: rgba(255, 255, 255, 0.18);
  padding: 1px 4px;
  border-radius: var(--r-sm);
}

/* ============ BADGES / CHIPS ============ */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px var(--s-2);
  border-radius: var(--r-pill);
  font-size: 11px;
  font-weight: var(--fw-medium);
  letter-spacing: 0.02em;
  background: var(--panel-muted);
  color: var(--text-secondary);
  border: 1px solid transparent;
  white-space: nowrap;
}
.badge-success { background: var(--success-soft); color: #047857; }
.badge-warning { background: var(--warning-soft); color: #C2410C; }
.badge-danger { background: var(--danger-soft); color: #B91C1C; }
.badge-accent { background: var(--accent-soft); color: var(--accent-strong); }
.badge-info { background: var(--info-soft); color: #0369A1; }
.badge-burgundy { background: var(--burgundy-soft); color: var(--burgundy-strong); }
.badge-bronze   { background: var(--bronze-soft);   color: var(--bronze-strong); }
.badge-teal     { background: var(--teal-deep-soft); color: var(--teal-deep-strong); }
.badge-forest   { background: var(--forest-soft);   color: var(--forest-strong); }

.badge .pulse {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
  animation: pulse 1.6s var(--ease) infinite;
}
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.35; } }

.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 4px 10px;
  background: var(--panel-muted);
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  font-size: var(--fs-12);
  color: var(--text-secondary);
}
.chip .mono { font-size: 11px; color: var(--text-tertiary); }

/* Provenance chip · special treatment */
.provenance {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 4px 10px;
  background: var(--panel-muted);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  font-size: 11px;
  color: var(--text-tertiary);
  font-family: var(--font-mono);
}
.provenance svg { width: 11px; height: 11px; color: var(--text-tertiary); }

/* ============ CARDS ============ */
.card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.card-header {
  padding: var(--s-4) var(--s-5);
  border-bottom: 1px solid var(--divider);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
}
.card-header h3 {
  margin: 0;
  font-size: var(--fs-15);
  font-weight: var(--fw-semibold);
  color: var(--text-primary);
}
.card-body { padding: var(--s-5); }
.card-footer {
  padding: var(--s-3) var(--s-5);
  border-top: 1px solid var(--divider);
  background: var(--panel-muted);
  font-size: var(--fs-12);
  color: var(--text-tertiary);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
}

/* ============ STATS ============ */
.stat-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--s-4);
}
.stat {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--s-4) var(--s-5);
}
.stat .label {
  font-size: var(--fs-12);
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: var(--fw-semibold);
}
.stat .value {
  font-family: var(--font-mono);
  font-size: var(--fs-24);
  font-weight: var(--fw-medium);
  color: var(--text-primary);
  margin-top: var(--s-1);
  letter-spacing: -0.02em;
}
.stat .delta {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  font-size: var(--fs-12);
  font-family: var(--font-mono);
  margin-top: var(--s-1);
}
.stat .delta.up { color: var(--accent); }
.stat .delta.down { color: var(--warning); }

/* ============ SPARKLINE / OUTPUT CARDS ============ */
.output-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--s-4);
}
.output-card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: all var(--dur-fast) var(--ease);
  cursor: pointer;
  display: flex;
  flex-direction: column;
}
.output-card:hover {
  border-color: var(--accent);
  box-shadow: var(--shadow-2);
  transform: translateY(-1px);
}
.output-card .preview {
  height: 130px;
  background: linear-gradient(180deg, #FAFCFB 0%, #F4F7F5 100%);
  border-bottom: 1px solid var(--divider);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
.output-card .preview svg { width: 100%; height: 100%; }
.output-card .meta {
  padding: var(--s-3) var(--s-4);
}
.output-card .meta .name {
  font-size: var(--fs-13);
  font-weight: var(--fw-semibold);
  color: var(--text-primary);
  margin: 0 0 2px 0;
}
.output-card .meta .sub {
  font-size: var(--fs-12);
  color: var(--text-tertiary);
  font-family: var(--font-mono);
}

/* ============ TABLES ============ */
.table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-13);
}
.table th {
  text-align: left;
  padding: var(--s-2) var(--s-4);
  background: var(--panel-muted);
  border-bottom: 1px solid var(--border);
  color: var(--text-tertiary);
  font-weight: var(--fw-semibold);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  white-space: nowrap;
}
.table td {
  padding: var(--s-3) var(--s-4);
  border-bottom: 1px solid var(--divider);
  vertical-align: middle;
}
.table tr:last-child td { border-bottom: none; }
.table tr:hover td { background: var(--panel-muted); }
.table .mono { color: var(--text-secondary); font-size: var(--fs-12); }

.table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* ============ FORMS ============ */
.form-group { margin-bottom: var(--s-4); }
.form-group label {
  display: block;
  font-size: var(--fs-12);
  font-weight: var(--fw-semibold);
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--s-1);
}
.input, .select {
  display: block;
  width: 100%;
  height: 38px;
  padding: 0 var(--s-3);
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  font-size: var(--fs-14);
  color: var(--text-primary);
  font-family: var(--font-mono);
  transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.input:focus, .select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.input.error {
  border-color: var(--danger);
}
.field-hint {
  font-size: var(--fs-12);
  color: var(--text-tertiary);
  margin-top: var(--s-1);
}
.field-error {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: var(--fs-12);
  color: var(--danger);
  margin-top: var(--s-1);
}
.unit-toggle {
  display: inline-flex;
  background: var(--panel-muted);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 2px;
  gap: 0;
}
.unit-toggle button {
  padding: 4px 10px;
  background: transparent;
  border: none;
  font-size: 11px;
  font-family: var(--font-mono);
  color: var(--text-tertiary);
  border-radius: var(--r-sm);
  cursor: pointer;
}
.unit-toggle button.active { background: var(--panel); color: var(--text-primary); box-shadow: var(--shadow-1); }

.form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--s-4) var(--s-5);
}

/* ============ TABS ============ */
.tabs {
  display: flex;
  gap: var(--s-1);
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--s-5);
}
.tab {
  padding: var(--s-3) var(--s-4);
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  font-size: var(--fs-13);
  font-weight: var(--fw-medium);
  color: var(--text-tertiary);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease);
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
}
.tab:hover { color: var(--text-primary); }
.tab.active {
  color: var(--accent-strong);
  border-bottom-color: var(--accent);
}

/* ============ PROGRESS ============ */
.progress {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.progress-bar {
  height: 8px;
  background: var(--panel-muted);
  border-radius: var(--r-pill);
  overflow: hidden;
  border: 1px solid var(--border);
}
.progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent), var(--accent-strong));
  border-radius: var(--r-pill);
  transition: width var(--dur-slow) var(--ease);
}
.progress-meta {
  display: flex;
  justify-content: space-between;
  font-size: var(--fs-12);
  color: var(--text-tertiary);
  font-family: var(--font-mono);
}

.phase-list {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.phase-item {
  display: grid;
  grid-template-columns: 24px 1fr auto;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: var(--panel-muted);
  border-radius: var(--r-md);
  font-size: var(--fs-13);
}
.phase-item.done { background: var(--success-soft); color: #065F46; }
.phase-item.active { background: var(--accent-soft); color: var(--accent-strong); font-weight: var(--fw-semibold); }
.phase-item .pct { font-family: var(--font-mono); font-size: var(--fs-12); }
.phase-item .check {
  width: 18px; height: 18px;
  display: inline-flex; align-items: center; justify-content: center;
}

/* ============ EMPTY STATE ============ */
.empty {
  text-align: center;
  padding: var(--s-12) var(--s-5);
  color: var(--text-tertiary);
}
.empty-icon {
  width: 48px; height: 48px;
  margin: 0 auto var(--s-3);
  color: var(--border-strong);
}
.empty h3 { font-size: var(--fs-16); color: var(--text-primary); margin: 0 0 var(--s-2) 0; }
.empty p { font-size: var(--fs-14); margin: 0 0 var(--s-4) 0; }

/* ============ SKELETON ============ */
.skeleton {
  background: linear-gradient(90deg, var(--panel-muted) 0%, #EEF1F4 50%, var(--panel-muted) 100%);
  background-size: 200% 100%;
  animation: shimmer 1.4s linear infinite;
  border-radius: var(--r-md);
}
@keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* ============ COMPARE TOGGLE (Before/After) ============ */
.compare-toggle {
  display: inline-flex;
  background: var(--panel-muted);
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  padding: 3px;
  gap: 0;
}
.compare-toggle button {
  padding: 6px 14px;
  background: transparent;
  border: none;
  font-size: var(--fs-12);
  font-weight: var(--fw-medium);
  color: var(--text-tertiary);
  border-radius: var(--r-pill);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
}
.compare-toggle button.active {
  background: var(--panel);
  color: var(--text-primary);
  box-shadow: var(--shadow-1);
}
.compare-toggle button.active.legacy { color: var(--warning); }
.compare-toggle button.active.modern { color: var(--accent-strong); }

/* ============ V832 LEGACY VIEW (for Before/After demo) ============ */
.legacy-view {
  background: #C0C0C0;
  border: 2px inset #DDD;
  padding: 8px;
  font-family: 'Tahoma', 'MS Sans Serif', sans-serif;
  font-size: 11px;
  color: #000;
}
.legacy-view .panel {
  background: linear-gradient(180deg, #B7D4E8 0%, #95B8D2 100%);
  padding: 4px 8px;
  font-weight: bold;
  border: 1px solid #5C7E9A;
  margin-bottom: 4px;
}
.legacy-view .button-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background: #ECECEC;
  padding: 6px;
  border: 1px solid #888;
}
.legacy-view .legacy-btn {
  padding: 4px 8px;
  background: linear-gradient(180deg, #FFF 0%, #DDD 100%);
  border: 1px solid #888;
  text-align: center;
  font-size: 11px;
  cursor: default;
}

/* Mobile: tighten cards */
@media (max-width: 768px) {
  .stat-row { grid-template-columns: repeat(2, 1fr); gap: var(--s-3); }
  .stat .value { font-size: var(--fs-20); }
  .output-grid { grid-template-columns: 1fr 1fr; gap: var(--s-3); }
  .form-grid { grid-template-columns: 1fr; }
}
@media (max-width: 414px) {
  .stat-row { grid-template-columns: 1fr 1fr; }
  .output-grid { grid-template-columns: 1fr; }
  .table th, .table td { padding: var(--s-2) var(--s-3); }
}
