/* Ops Maturity Scanner - Process, Systems, People */

:root {
  --oms-glow: 0 0 24px rgba(0, 82, 204, 0.15);
  --oms-shadow-card: 0 2px 8px rgba(0, 0, 0, 0.06);
  --oms-gradient-primary: linear-gradient(135deg, #0052CC 0%, #003D99 100%);
  --oms-gradient-success: linear-gradient(135deg, #22C55E 0%, #16A34A 100%);
  --oms-gradient-warning: linear-gradient(135deg, #F59E0B 0%, #D97706 100%);
  --oms-gradient-critical: linear-gradient(135deg, #EF4444 0%, #DC2626 100%);
}

.oms-page {
  background: var(--color-bg);
  color: var(--color-text-primary);
}

.oms-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 2rem 1.5rem 4rem;
}

.oms-main {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Input section - SSE design */
.oms-input-section {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: 1.5rem 2rem 2rem;
  margin-bottom: 1rem;
  position: relative;
  overflow: hidden;
}

.oms-input-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--oms-gradient-primary);
}

.oms-section-header-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1.5rem;
  flex-wrap: wrap;
}

.oms-section-header-actions {
  display: flex;
  gap: 0.5rem;
  flex-shrink: 0;
}

.btn-oms-input-guide,
.btn-oms-methodology {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-size: 0.8125rem;
  font-weight: 600;
  background: var(--color-bg-gray);
  border: 1px solid var(--color-border);
  border-radius: 6px;
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s;
}

.btn-oms-input-guide:hover,
.btn-oms-methodology:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.oms-presets-section { margin-bottom: 1.25rem; }
.oms-presets-label { font-size: 0.8125rem; font-weight: 500; color: var(--color-text-secondary); margin-bottom: 0.5rem; }
.oms-presets-row { display: flex; flex-wrap: wrap; gap: 0.5rem; }

.btn-oms-preset {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 0.5rem 0.875rem;
  font-size: 0.8125rem;
  background: var(--color-bg-gray);
  border: 1px solid var(--color-border);
  border-radius: 6px;
  color: var(--color-text-primary);
  cursor: pointer;
  text-align: left;
  transition: border-color 0.15s, background 0.15s;
}

.btn-oms-preset:hover {
  border-color: var(--color-primary);
  background: rgba(0, 82, 204, 0.06);
}

.oms-preset-label { font-weight: 600; color: var(--color-primary); }
.oms-preset-desc { font-size: 0.75rem; color: var(--color-text-secondary); margin-top: 0.125rem; }

.oms-cross-links { display: flex; align-items: center; gap: 0.5rem; margin-top: 1.25rem; flex-wrap: wrap; }
.oms-cross-links-label { font-size: 0.8125rem; color: var(--color-text-muted); }
.oms-cross-link { font-size: 0.875rem; font-weight: 500; color: var(--color-primary); text-decoration: none; }
.oms-cross-link:hover { text-decoration: underline; }
.oms-cross-links-sep { color: var(--color-border); font-size: 0.75rem; }

.oms-section-title { font-size: 1.25rem; font-weight: 700; color: var(--color-text-primary); margin-bottom: 0.5rem; }
.oms-section-description { font-size: 0.9375rem; color: var(--color-text-secondary); line-height: 1.5; margin-bottom: 0.75rem; }
.oms-scale-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  font-size: 0.75rem;
  color: var(--color-text-muted);
}
.oms-legend-item em {
  font-style: normal;
  font-weight: 600;
  color: var(--color-text-secondary);
  margin-right: 0.2rem;
}

.oms-quick-actions { display: flex; gap: 0.75rem; margin-bottom: 1rem; flex-wrap: wrap; }
.btn-quick-action {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  background: var(--color-bg-gray);
  border: 1px solid var(--color-border);
  border-radius: 6px;
  color: var(--color-text-secondary);
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}
.btn-quick-action:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

/* Form progress */
.form-progress { margin-bottom: 1.5rem; }
.form-progress-bar {
  height: 8px;
  background: var(--color-bg-gray);
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: 0.5rem;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.06);
}
.form-progress .form-progress-bar::before {
  content: '';
  display: block;
  height: 100%;
  background: var(--oms-gradient-primary);
  border-radius: 4px;
  width: var(--progress-pct, 0%);
  transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.form-progress-text { font-size: 0.8125rem; color: var(--color-text-muted); }

/* Form groups */
.form-group {
  margin-bottom: 1rem;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  overflow: hidden;
  background: var(--color-white);
}
.form-group.collapsible .form-group-header {
  cursor: pointer;
  padding: 1rem 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  user-select: none;
  background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
  transition: background 0.2s ease;
}
.form-group.collapsible .form-group-header:hover {
  background: linear-gradient(180deg, #f1f5f9 0%, #e2e8f0 100%);
}
.form-group.collapsible.expanded .form-group-header { border-bottom: 1px solid var(--color-border); }
.form-group.collapsible:not(.expanded) .form-group-body { display: none; }
.form-group-toggle { font-size: 1.125rem; font-weight: 600; color: var(--color-text-muted); width: 24px; text-align: center; }
.form-group-body { padding: 1rem 1.25rem; border-top: 1px solid var(--color-border); }
.form-group-header h3 { font-size: 1rem; font-weight: 600; color: var(--color-text-primary); margin: 0; }
.form-group-subtitle { font-size: 0.8125rem; color: var(--color-text-muted); flex: 1; }

.oms-context-row { display: flex; gap: 1.5rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.oms-context-field { flex: 1; min-width: 140px; }
.oms-context-field label { display: block; font-size: 0.8125rem; font-weight: 500; color: var(--color-text-secondary); margin-bottom: 0.375rem; }
.oms-context-field select {
  width: 100%;
  padding: 0.5rem 0.75rem;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: 6px;
  color: var(--color-text-primary);
  font-size: 0.9375rem;
}

.oms-form { display: flex; flex-direction: column; gap: 0; }

/* Compact question layout - label + scale on one row (like Strategy Health) */
.oms-question {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 0.5rem 1rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--color-border-light);
}
.oms-question:last-child { border-bottom: none; }

.oms-question-label-wrap {
  grid-column: 1;
  grid-row: 1;
  display: flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-text-primary);
  min-width: 0;
}
.oms-question-label-wrap label {
  margin: 0;
  flex: 0 1 auto;
  min-width: 0;
}

.oms-question-hint-btn {
  flex-shrink: 0;
  width: 1.35rem;
  height: 1.35rem;
  border: 1px solid var(--color-border);
  border-radius: 50%;
  background: var(--color-white);
  color: var(--color-text-muted);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s ease;
}
.oms-question-hint-btn:hover,
.oms-question-hint-btn.active {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: rgba(0, 82, 204, 0.08);
}

.oms-question-hint-panel {
  grid-column: 1 / -1;
  grid-row: 3;
  padding: 0.5rem 0.75rem;
  margin: 0;
  background: rgba(0, 82, 204, 0.05);
  border-left: 3px solid var(--color-primary);
  border-radius: 0 4px 4px 0;
  font-size: 0.8125rem;
  color: var(--color-text-secondary);
  line-height: 1.4;
}

.oms-scale {
  grid-column: 2;
  grid-row: 1;
  display: flex;
  gap: 0.25rem;
  flex-shrink: 0;
}

.oms-scale-option {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  width: 1.75rem;
  height: 1.75rem;
  border: 1px solid var(--color-border);
  border-radius: 4px;
  background: var(--color-white);
  transition: all 0.15s ease;
}
.oms-scale-option:hover {
  border-color: var(--color-primary);
  background: rgba(0, 82, 204, 0.06);
}
.oms-scale-option input { position: absolute; opacity: 0; pointer-events: none; }
.oms-scale-option:has(input:checked) {
  border-color: var(--color-primary);
  background: rgba(0, 82, 204, 0.12);
}
.oms-scale-num {
  font-size: 0.8125rem;
  font-family: 'IBM Plex Mono', monospace;
  font-weight: 600;
  color: var(--color-text-secondary);
}
.oms-scale-text {
  display: none;
}

.oms-scale-option:has(input:checked) .oms-scale-num {
  color: var(--color-primary);
}

.oms-hint-icon {
  margin-right: 0.25rem;
}

.oms-validation-msg {
  padding: 0.75rem 1rem;
  margin-bottom: 0.75rem;
  background: rgba(220, 53, 69, 0.12);
  border: 1px solid rgba(220, 53, 69, 0.3);
  border-radius: 6px;
  color: var(--color-text);
  font-size: 0.9rem;
}

.oms-analyze-row {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.75rem;
}
.oms-analyze-controls { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.oms-analyze-controls .btn-primary { display: inline-flex; align-items: center; gap: 0.5rem; }
.btn-oms-expand-all {
  padding: 0.5rem 1rem;
  font-size: 0.8125rem;
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: 6px;
  color: var(--color-text-secondary);
  cursor: pointer;
}
.btn-oms-expand-all:hover { border-color: var(--color-primary); color: var(--color-primary); }
.oms-loading-container { width: 100%; }
.oms-loading {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  background: var(--color-bg-gray);
  border-radius: 6px;
  font-size: 0.875rem;
  color: var(--color-text-secondary);
}
.oms-loading-spinner {
  width: 20px;
  height: 20px;
  border: 2px solid var(--color-border);
  border-top-color: var(--color-primary);
  border-radius: 50%;
  animation: oms-spin 0.8s linear infinite;
}
@keyframes oms-spin { to { transform: rotate(360deg); } }
.oms-analyze-hint { font-size: 0.8125rem; color: var(--color-text-muted); }

/* Output */
.oms-output-section {
  margin-top: 1rem;
  border-top: 1px solid var(--color-border);
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: 1.5rem 2rem;
  position: relative;
  overflow: hidden;
}
.oms-output-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--oms-gradient-primary);
}

.oms-output-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; flex-wrap: wrap; margin-bottom: 1rem; }
.oms-output-actions-top { display: flex; gap: 0.5rem; }
.btn-oms-action {
  padding: 0.5rem 1rem;
  font-size: 0.8125rem;
  font-weight: 600;
  background: var(--color-bg-gray);
  border: 1px solid var(--color-border);
  border-radius: 6px;
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s;
}
.btn-oms-action:hover { border-color: var(--color-primary); color: var(--color-primary); }

.oms-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  margin-bottom: 1rem;
  font-size: 0.8125rem;
  color: var(--color-text-muted);
}
.oms-meta-item { display: flex; align-items: center; gap: 0.25rem; }

.oms-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 1.25rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--color-border);
}
.oms-tab {
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  background: transparent;
  border: none;
  border-radius: 6px;
  color: var(--color-text-secondary);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  transition: color 0.2s, background 0.2s;
}
.oms-tab:hover {
  color: var(--color-primary);
  background: #e8f4fd;
}
.oms-tab.active {
  color: var(--color-primary);
  background: #e8f4fd;
}
.oms-tab-badge {
  font-size: 0.6875rem;
  padding: 0.125rem 0.375rem;
  background: var(--color-primary);
  color: white;
  border-radius: 10px;
  font-weight: 700;
}

.oms-tab-panel { display: none; }
.oms-tab-panel.active { display: block; }

.oms-executive-summary { margin-bottom: 1.5rem; }
.oms-exec-summary-text { font-size: 1rem; line-height: 1.6; color: var(--color-text-primary); }

.oms-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.oms-kpi-card {
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  border: 1px solid var(--color-border);
  border-radius: 10px;
  padding: 1rem 1.25rem;
  text-align: center;
  box-shadow: var(--oms-shadow-card);
}
.oms-kpi-label { font-size: 0.75rem; font-weight: 600; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 0.25rem; }
.oms-kpi-value { font-size: 1.5rem; font-weight: 800; font-family: 'IBM Plex Mono', monospace; color: var(--color-text-primary); }
.oms-kpi-score { border-left: 4px solid var(--color-primary); }
.oms-kpi-level { border-left: 4px solid #22C55E; }
.oms-kpi-benchmark { border-left: 4px solid #F59E0B; }
.oms-kpi-gaps { border-left: 4px solid #EF4444; }

.oms-score-gauge-row { display: flex; align-items: flex-start; gap: 2rem; flex-wrap: wrap; margin: 1.5rem 0; }
.oms-gauge-wrap { flex-shrink: 0; filter: drop-shadow(var(--oms-glow)); }
.oms-gauge {
  width: 160px;
  height: 160px;
  border-radius: 50%;
  background: conic-gradient(
    #0052CC 0deg,
    #003D99 calc(var(--oms-gauge-pct, 0) * 3.6deg),
    #E5E7EB calc(var(--oms-gauge-pct, 0) * 3.6deg),
    #E5E7EB 360deg
  );
  border: 4px solid rgba(255, 255, 255, 0.9);
  box-shadow: 0 4px 16px rgba(0, 82, 204, 0.2), inset 0 0 0 2px rgba(0, 82, 204, 0.1);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.oms-gauge-inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  width: 128px;
  height: 128px;
  border-radius: 50%;
  justify-content: center;
  border: 4px solid rgba(255, 255, 255, 0.95);
}
.oms-gauge-value { font-size: 2rem; font-weight: 800; font-family: 'IBM Plex Mono', monospace; color: var(--color-text-primary); }
.oms-gauge-label { font-size: 0.625rem; font-weight: 700; letter-spacing: 0.2em; color: var(--color-text-muted); }

.oms-score-card {
  flex: 1;
  min-width: 200px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: 1.5rem 2rem;
  text-align: center;
  box-shadow: var(--oms-shadow-card);
}
.oms-score-main { display: flex; align-items: baseline; justify-content: center; gap: 0.5rem; }
.oms-score-value { font-size: 2rem; font-weight: 800; font-family: 'IBM Plex Mono', monospace; color: var(--color-text-primary); }
.oms-score-level { font-size: 1rem; font-weight: 600; color: var(--color-primary); }
.oms-benchmark { font-size: 0.875rem; color: var(--color-text-secondary); margin-top: 0.5rem; }
.oms-severity-badges { display: flex; flex-wrap: wrap; gap: 0.5rem; justify-content: center; margin-top: 0.75rem; }

.oms-sev-badge {
  font-size: 0.6875rem;
  font-weight: 700;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  text-transform: uppercase;
}
.oms-sev-critical { background: var(--oms-gradient-critical); color: white; }
.oms-sev-high { background: var(--oms-gradient-warning); color: white; }
.oms-sev-medium { background: rgba(245, 158, 11, 0.6); color: white; }
.oms-sev-ok { background: rgba(34, 197, 94, 0.2); color: #16A34A; }

.oms-breakpoint { margin: 1.5rem 0; padding: 1rem 1.25rem; background: rgba(239, 68, 68, 0.06); border-left: 4px solid #EF4444; border-radius: 0 8px 8px 0; }
.oms-breakpoint-label { font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: var(--color-text-muted); margin-bottom: 0.25rem; }
.oms-breakpoint-text { font-size: 0.9375rem; font-weight: 500; color: var(--color-text-primary); }

.oms-insights { margin: 1.5rem 0; }
.oms-insights-label { font-size: 0.8125rem; font-weight: 600; color: var(--color-text-secondary); margin-bottom: 0.5rem; }
.oms-insights-list { margin: 0; padding-left: 1.25rem; }
.oms-insights-list li { margin-bottom: 0.375rem; font-size: 0.9375rem; line-height: 1.5; color: var(--color-text-primary); }
.oms-insights-sub { color: var(--color-text-secondary); }

.oms-radar-section {
  display: grid;
  grid-template-columns: minmax(200px, 1fr) minmax(200px, 1fr);
  gap: 1.5rem;
  align-items: start;
  margin: 1.5rem 0;
}

.oms-radar-wrap,
.oms-radar-side {
  padding: 1.25rem;
  background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
  border-radius: 12px;
  border: 1px solid var(--color-border);
  box-shadow: var(--oms-shadow-card);
}

.oms-radar-wrap .oms-dimensions-title,
.oms-radar-side .oms-dimensions-title {
  margin-bottom: 1rem;
}

.oms-dimensions-title { font-size: 1rem; font-weight: 600; color: var(--color-text-primary); margin-bottom: 0.75rem; }
.oms-radar { max-width: 280px; margin: 0 auto; overflow: visible; }
.oms-radar-svg { width: 100%; height: auto; overflow: visible; }
.oms-radar-grid { fill: none; stroke: var(--color-border); stroke-width: 0.5; }
.oms-radar-axis { stroke: var(--color-border); stroke-width: 1; }
.oms-radar-fill { fill: rgba(0, 82, 204, 0.25); stroke: var(--color-primary); stroke-width: 2; }
.oms-radar-dot { fill: var(--color-primary); }
.oms-radar-label { font-size: 0.8125rem; font-weight: 600; fill: var(--color-text-secondary); }

.oms-dimension-row {
  display: grid;
  grid-template-columns: 1fr 2fr 50px;
  gap: 1rem;
  align-items: center;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--color-border-light);
}
.oms-dimension-row:last-child { border-bottom: none; }
.oms-dimension-label { font-size: 0.9375rem; font-weight: 500; color: var(--color-text-primary); }
.oms-dimension-track { height: 8px; background: var(--color-bg-gray); border-radius: 4px; overflow: hidden; }
.oms-dimension-fill { height: 100%; border-radius: 4px; transition: width 0.5s ease; }
.oms-dim-strong { background: var(--oms-gradient-success); }
.oms-dim-mid { background: linear-gradient(90deg, #3B82F6, #60A5FA); }
.oms-dim-weak { background: var(--oms-gradient-warning); }
.oms-dimension-pct { font-size: 0.875rem; font-weight: 600; font-family: 'IBM Plex Mono', monospace; color: var(--color-text-secondary); }

/* Gaps table */
.oms-gaps-table-wrap { overflow-x: auto; margin-top: 1rem; }
.oms-gaps-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.oms-gaps-table th, .oms-gaps-table td { padding: 0.75rem 1rem; text-align: left; border-bottom: 1px solid var(--color-border); }
.oms-gaps-table th { font-weight: 600; color: var(--color-text-secondary); background: var(--color-bg-gray); }
.oms-gaps-sort { cursor: pointer; user-select: none; }
.oms-gaps-sort:hover { background: rgba(255, 255, 255, 0.05); }
.oms-gap-row.oms-gap-critical td { background: rgba(239, 68, 68, 0.06); }
.oms-gap-meta { font-size: 0.75rem; color: var(--color-text-secondary); font-weight: 400; }
.oms-no-gaps { font-style: italic; color: var(--color-text-muted); padding: 1.5rem !important; }
.oms-bench-diff.positive { color: #16A34A; font-weight: 600; }
.oms-bench-diff.negative { color: #EF4444; font-weight: 600; }

/* Roadmap */
.oms-roadmap-timeline { display: flex; flex-direction: column; gap: 1.5rem; margin: 1.5rem 0; }
.oms-roadmap-quarter { border: 1px solid var(--color-border); border-radius: 8px; overflow: hidden; }
.oms-roadmap-quarter-label { font-weight: 700; padding: 0.75rem 1rem; background: var(--color-bg-gray); border-bottom: 1px solid var(--color-border); }
.oms-roadmap-quarter-items { padding: 1rem; }
.oms-roadmap-item { padding: 0.75rem 0; border-bottom: 1px solid var(--color-border-light); }
.oms-roadmap-item:last-child { border-bottom: none; }
.oms-roadmap-phase { font-size: 0.75rem; font-weight: 700; color: var(--color-text-muted); margin-right: 0.5rem; }
.oms-roadmap-focus { font-size: 0.9375rem; }
.oms-roadmap-meta { font-size: 0.75rem; color: var(--color-text-muted); display: block; margin-top: 0.25rem; }
.oms-roadmap-action { font-size: 0.8125rem; color: var(--color-primary); display: block; margin-top: 0.375rem; }
.oms-roadmap-list { padding-left: 1.25rem; }
.oms-roadmap-list li { margin-bottom: 0.5rem; font-size: 0.9375rem; }

/* Benchmarks */
.oms-benchmarks-legend { display: flex; gap: 1rem; margin-bottom: 1rem; font-size: 0.8125rem; color: var(--color-text-muted); }
.oms-bench-legend-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; margin-right: 0.375rem; vertical-align: middle; }
.oms-bench-legend-dot.positive { background: #16A34A; }
.oms-bench-legend-dot.negative { background: #EF4444; }
.oms-benchmarks-tbl { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.oms-benchmarks-tbl th, .oms-benchmarks-tbl td { padding: 0.75rem 1rem; text-align: left; border-bottom: 1px solid var(--color-border); }
.oms-benchmarks-target { margin-top: 1.5rem; padding: 1rem; background: rgba(0, 82, 204, 0.06); border-radius: 8px; border-left: 4px solid var(--color-primary); }
.oms-benchmarks-target-title { font-size: 0.875rem; font-weight: 600; margin-bottom: 0.5rem; }

/* Drilldown */
.oms-drilldown { margin: 1.5rem 0; }
.oms-drilldown-header { margin-bottom: 1.25rem; }
.oms-drilldown-desc { font-size: 0.875rem; color: var(--color-text-secondary); margin: 0.25rem 0 0; }

.oms-drilldown-dimensions { display: flex; flex-direction: column; gap: 1.5rem; }

.oms-drilldown-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: var(--oms-shadow-card);
}

.oms-drilldown-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 1.25rem;
  background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
  border-bottom: 1px solid var(--color-border);
}

.oms-drilldown-dim-title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-primary);
  margin: 0;
}

.oms-drilldown-dim-score {
  font-size: 1rem;
  font-weight: 700;
  font-family: 'IBM Plex Mono', monospace;
  color: var(--color-text-primary);
}

.oms-drilldown-rows { padding: 0.5rem 1.25rem 1rem; }

.oms-drilldown-row {
  display: grid;
  grid-template-columns: 1fr 120px 44px;
  align-items: center;
  gap: 1rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--color-border-light);
  font-size: 0.875rem;
}

.oms-drilldown-row:last-child { border-bottom: none; }

.oms-drilldown-q-label {
  font-weight: 500;
  color: var(--color-text-primary);
  min-width: 0;
}

.oms-drilldown-q-track {
  height: 8px;
  background: var(--color-bg-gray);
  border-radius: 4px;
  overflow: hidden;
}

.oms-drilldown-q-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.4s ease;
}

.oms-drilldown-row.oms-drill-low .oms-drilldown-q-fill { background: var(--oms-gradient-critical); }
.oms-drilldown-row.oms-drill-mid .oms-drilldown-q-fill { background: var(--oms-gradient-warning); }
.oms-drilldown-row.oms-drill-strong .oms-drilldown-q-fill { background: var(--oms-gradient-primary); }

.oms-drilldown-q-score {
  font-weight: 600;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.8125rem;
  color: var(--color-text-secondary);
  text-align: right;
}

.oms-drilldown-row.oms-drill-low .oms-drilldown-q-score { color: #DC2626; }
.oms-drilldown-row.oms-drill-mid .oms-drilldown-q-score { color: #D97706; }

/* Recommendations */
.oms-recs-list { list-style: none; padding: 0; margin: 0; }
.oms-rec-item { padding: 0.75rem 1rem; margin-bottom: 0.5rem; border-radius: 6px; font-size: 0.9375rem; border-left: 4px solid var(--color-border); }
.oms-rec-item.oms-rec-critical { border-left-color: #EF4444; background: rgba(239, 68, 68, 0.06); }
.oms-rec-item.oms-rec-high { border-left-color: #F59E0B; background: rgba(245, 158, 11, 0.06); }
.oms-rec-priority { font-size: 0.6875rem; font-weight: 700; text-transform: uppercase; margin-right: 0.5rem; }

/* Insights tab */
.oms-insights-tab-section { margin-bottom: 1.5rem; }
.oms-insights-tab-title { font-size: 1rem; font-weight: 600; color: var(--color-text-primary); margin-bottom: 0.5rem; }
.oms-insights-tab-list { margin: 0; padding-left: 1.25rem; }
.oms-insights-tab-list li { margin-bottom: 0.375rem; font-size: 0.9375rem; }
.oms-insights-tab-desc { font-size: 0.875rem; color: var(--color-text-secondary); line-height: 1.5; }

/* Tabs bottom */
.oms-tabs-wrap-bottom {
  margin-top: 2rem;
  padding-top: 1rem;
  margin-bottom: 1.5rem;
  border-top: 1px solid var(--color-border);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
}
.oms-tabs-hint {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-secondary);
}
.oms-tabs-bottom {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  padding-bottom: 0;
  border-bottom: none;
}
.oms-tab-bottom { display: inline-flex; }

.oms-output-actions {
  margin-top: 1.5rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
}
/* Knowledge Base (SSE reference design) */
.oms-kb-link {
  display: inline-block;
  margin-top: 0.75rem;
  font-size: 0.875rem;
  color: var(--color-text-secondary);
  text-decoration: none;
}
.oms-kb-link:hover { color: var(--color-primary); }

.oms-knowledge-base { margin-top: 3rem; padding: 2rem 0 3rem; border-top: 1px solid var(--color-border); }
.oms-kb-title { font-size: 1.5rem; font-weight: 700; margin-bottom: 0.75rem; color: var(--color-text-primary); }
.oms-kb-intro { font-size: 1rem; color: var(--color-text-secondary); line-height: 1.6; margin-bottom: 2rem; max-width: 720px; }
.oms-kb-article { margin-bottom: 1rem; }
.oms-kb-article:last-child { margin-bottom: 0; }
.oms-kb-details {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: 0 1.25rem 1.25rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.oms-kb-details:hover { border-color: rgba(0, 82, 204, 0.3); }
.oms-kb-details[open] { border-color: var(--color-primary); box-shadow: 0 0 0 1px rgba(0, 82, 204, 0.1); }
.oms-kb-summary {
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--color-primary);
  cursor: pointer;
  padding: 1rem 0;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.oms-kb-summary::-webkit-details-marker { display: none; }
.oms-kb-summary::before {
  content: '';
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 6px solid var(--color-primary);
  transition: transform 0.2s;
}
.oms-kb-details[open] .oms-kb-summary::before { transform: rotate(180deg); }
.oms-kb-takeaway {
  background: rgba(0, 82, 204, 0.06);
  border-left: 3px solid var(--color-primary);
  padding: 0.75rem 1rem;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--color-text-primary);
  margin-bottom: 1rem;
  border-radius: 0 4px 4px 0;
}
.oms-kb-details p,
.oms-kb-article p { font-size: 0.9375rem; line-height: 1.65; color: var(--color-text-primary); margin-bottom: 0.75rem; }
.oms-kb-details p:last-of-type,
.oms-kb-article p:last-of-type { margin-bottom: 0; }
.oms-kb-details ul,
.oms-kb-article ul { margin: 0.75rem 0 1rem 1.25rem; padding: 0; }
.oms-kb-details li,
.oms-kb-article li { font-size: 0.9375rem; line-height: 1.6; color: var(--color-text-primary); margin-bottom: 0.5rem; }
.oms-kb-details a,
.oms-kb-article a { color: var(--color-primary); text-decoration: none; }
.oms-kb-details a:hover,
.oms-kb-article a:hover { text-decoration: underline; }

/* Modal */
.oms-modal { position: fixed; inset: 0; z-index: 1000; display: flex; align-items: center; justify-content: center; padding: 1rem; }
.oms-modal[hidden] { display: none !important; pointer-events: none; }
.oms-modal-backdrop { position: absolute; inset: 0; background: rgba(0, 0, 0, 0.5); cursor: pointer; }
.oms-modal-content { position: relative; background: var(--color-white); border-radius: 12px; max-width: 560px; width: 100%; max-height: 90vh; overflow-y: auto; box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2); }
.oms-modal-header { display: flex; justify-content: space-between; align-items: flex-start; padding: 1.5rem 1.5rem 0; }
.oms-modal-header h2 { font-size: 1.25rem; font-weight: 700; margin: 0; }
.oms-modal-close { font-size: 1.5rem; background: none; border: none; cursor: pointer; color: var(--color-text-muted); line-height: 1; padding: 0.5rem; margin: -0.5rem; min-width: 2.5rem; min-height: 2.5rem; display: inline-flex; align-items: center; justify-content: center; }
.oms-modal-close:hover { color: var(--color-text-primary); }
.oms-modal-body { padding: 1rem 1.5rem 1.5rem; }
.oms-modal-section { margin: 1rem 0; }
.oms-modal-section h3 { font-size: 0.9375rem; font-weight: 600; margin-bottom: 0.5rem; }
.oms-modal-section ul { margin: 0.5rem 0 0 1.25rem; }
.oms-modal-section li { margin-bottom: 0.375rem; font-size: 0.875rem; }

@media (max-width: 768px) {
  .oms-radar-section {
    grid-template-columns: 1fr;
  }
  .oms-drilldown-row {
    grid-template-columns: 1fr 44px;
    grid-template-rows: auto auto;
    gap: 0.35rem 0.75rem;
  }
  .oms-drilldown-q-label { grid-column: 1; grid-row: 1; }
  .oms-drilldown-q-score { grid-column: 2; grid-row: 1; align-self: start; }
  .oms-drilldown-q-track { grid-column: 1 / -1; grid-row: 2; }

  .oms-tabs {
    overflow-x: auto;
    overflow-y: hidden;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    margin-left: -1.5rem;
    margin-right: -1.5rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
  .oms-tab {
    flex-shrink: 0;
    white-space: nowrap;
  }
  .oms-tabs-bottom {
    overflow-x: auto;
    overflow-y: hidden;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    margin-left: -1.5rem;
    margin-right: -1.5rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
  .oms-tabs-bottom .oms-tab {
    flex-shrink: 0;
    white-space: nowrap;
  }
}

@media (max-width: 600px) {
  .oms-question {
    grid-template-columns: 1fr;
    gap: 0.5rem;
  }
  .oms-scale {
    grid-column: 1;
    grid-row: 2;
    justify-self: start;
  }
  .oms-question-hint-panel {
    grid-row: 3;
  }
  .oms-dimension-row { grid-template-columns: 1fr 50px; gap: 0.5rem; }
  .oms-dimension-label { grid-column: 1 / -1; }
}

@media print {
  .main-nav, .hero-institutional, .oms-input-section, .oms-quick-actions, .oms-presets-section,
  .form-progress, .oms-output-actions-top, .oms-meta-row, .oms-tabs, .oms-tabs-wrap-bottom,
  .oms-output-actions, .btn-oms-input-guide, .btn-oms-methodology { display: none !important; }
  .oms-output-section { display: block !important; }
  .oms-tab-panel { display: block !important; }
  body { background: white; color: #1a1a1a; }
}
