@layer features {

.progress-toolbar { display: flex; align-items: center; gap: 12px; flex: 1; min-width: 200px; max-width: 400px }
.progress-toolbar.hidden { display: none }
.progress-toolbar-bar { flex: 1; height: 6px; background: var(--color-border-default); border-radius: 5px; overflow: hidden }
.progress-toolbar-fill { height: 100%; background: var(--color-accent); border-radius: 5px; width: 0%; transition: width 0.3s ease-out }
.progress-toolbar-text { font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold); color: var(--color-text-primary); min-width: 40px; text-align: right }
.token-display { display: flex; align-items: center; gap: 16px; margin-left: auto; padding: 8px 16px; background: var(--color-bg-surface-alt); border-radius: 5px; border: 1px solid var(--color-border-default); font-size: 13px }
.token-display-item { display: flex; align-items: center; gap: 6px }
.token-label { color: var(--color-text-secondary); font-weight: var(--font-weight-medium) }
.token-value { color: var(--color-text-primary); font-weight: var(--font-weight-semibold) }
.token-value.cost-value { color: var(--color-text-primary); font-weight: var(--font-weight-bold) }
.insights { border: 1px solid var(--color-border-default); padding: 20px; border-radius: 5px; margin-top: 20px; background: var(--color-bg-surface); box-shadow: 0 1px 2px rgba(0,0,0,0.05); position: relative }
.ins-title { font-weight: var(--font-weight-semibold); margin-bottom: 16px; color: var(--color-text-primary); font-size: var(--font-size-base) }
.ins-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 16px }
.ins-actions button { padding: 8px 16px; font-size: 13px; font-weight: var(--font-weight-medium) }
.cases-container { 
  display: grid; 
  grid-template-columns: 1fr; 
  gap: 12px; 
  padding-right: 8px;
}
.cases-container::-webkit-scrollbar {
  width: 6px;
}
.cases-container::-webkit-scrollbar-track {
  background: var(--color-bg-surface-alt);
  border-radius: 5px;
}
.cases-container::-webkit-scrollbar-thumb {
  background: var(--color-border-default);
  border-radius: 5px;
}
.cases-container::-webkit-scrollbar-thumb:hover {
  background: var(--color-border-strong);
}
#cases { display: grid; grid-template-columns: 1fr; gap: 12px }
.case { border: 1px solid var(--color-border-default); border-radius: 5px; padding: 20px; background: var(--color-bg-surface); transition: all 0.2s ease; box-shadow: 0 1px 2px rgba(0,0,0,0.05); position: relative }
.case:hover { border-color: var(--color-border-default); box-shadow: 0 2px 4px rgba(0,0,0,0.1) }
.case-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; padding-bottom: 16px; border-bottom: 1px solid var(--color-border-default) }
.case-header > div:first-child { font-weight: var(--font-weight-semibold); font-size: var(--font-size-base); color: var(--color-text-primary) }
.case-meta { display: flex; gap: 12px; margin-bottom: 16px; font-size: 13px; color: var(--color-text-secondary) }
.case-id, .case-type { padding: 4px 10px; background: var(--color-bg-surface-alt); border-radius: 5px; border: 1px solid var(--color-border-default); font-weight: var(--font-weight-medium); font-size: var(--font-size-xs); color: var(--color-text-primary) }
.case-section { margin-bottom: 16px }
.case-section-title { font-weight: var(--font-weight-semibold); font-size: var(--font-size-xs); color: var(--color-text-secondary); margin-bottom: 8px; text-transform: uppercase; letter-spacing: 0.5px }
.case-steps { margin: 0; padding-left: 20px; color: var(--color-text-primary); line-height: 1.6; font-size: var(--font-size-sm) }
.case-steps li { margin-bottom: 8px }
.case-expected { color: var(--color-text-primary); line-height: 1.5; padding: 16px; background: var(--color-bg-surface-alt); border-radius: 5px; border-left: 3px solid var(--color-accent); font-size: var(--font-size-sm) }
.case-actions { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--color-border-default) }
.case-editing { border: 2px solid var(--color-text-primary); background: var(--color-bg-surface); box-shadow: 0 0 0 2px rgba(44,44,44,0.1) }
/* ── "From Manual Input" page (Test Generator) sections ──
 * Flat MODEC layout: a section title (h6), a content area, optional
 * inline notice. Replaces the old border-left card / .panel-title /
 * .insights / .acceptance-label pattern. */
.generation-section {
  background: var(--color-bg-surface);
  margin-bottom: 32px;
}
.generation-section__title {
  margin: 0 0 16px;
  font-family: "Noto Sans", sans-serif;
  font-size: 20px;          /* MODEC h6 */
  font-weight: 500;
  line-height: 1.33;
  letter-spacing: 0.15px;
  color: rgba(0, 0, 0, 0.87);
}
.generation-section__count {
  color: var(--color-accent);
  font-weight: 500;
  margin-left: 4px;
}
.generation-section__notice {
  margin: 12px 0 0;
  font-family: "Noto Sans", sans-serif;
  font-size: 13px;
  font-weight: 400;
  line-height: 1.5;
  color: var(--c-danger-700);
}
.generation-section__row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 16px;
  margin: 16px 0;
}
/* Context Insights — a sub-section inside step 2. Light card surface
 * grouping the related controls (clear/regen, Figma, Acceptance). */
.generation-context {
  margin-top: 24px;
  padding: 20px;
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-subtle);
  border-radius: 8px;
}
.generation-context__title {
  margin: 0 0 12px;
  font-family: "Noto Sans", sans-serif;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.15px;
  color: rgba(0, 0, 0, 0.87);
}
.generation-context__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 20px;
}
/* Inside the Context Insights card, stack fields vertically and let them
 * take the full container width. `.ds-field` defaults to inline-flex with
 * min-width: 180px, which makes two siblings sit side-by-side and shrink
 * their controls (the Acceptance textarea was getting squeezed to ~280px). */
.generation-context .ds-field {
  display: flex;
  width: 100%;
  min-width: 0;
  margin-top: 16px;
}
.generation-context .ds-field > .ds-input,
.generation-context .ds-field > .ds-upload {
  width: 100%;
  box-sizing: border-box;
}

.preview-section {
  background: var(--color-bg-surface);
  transition: all 0.3s ease;
}

.preview-section.section-active {
  background: var(--color-bg-surface-alt);
  box-shadow: 0 4px 16px rgba(168, 216, 234, 0.2);
  animation: previewActivate 0.3s ease-out;
}

.preview-section.section-in-view {
  box-shadow: 0 2px 10px rgba(168, 216, 234, 0.15);
}

@keyframes previewActivate {
  0% {
    border-left-width: 4px;
    box-shadow: 0 1px 2px rgba(0,0,0,0.05);
  }
  50% {
    border-left-width: 7px;
    box-shadow: 0 6px 20px rgba(168, 216, 234, 0.25);
  }
  100% {
    border-left-width: 6px;
    box-shadow: 0 4px 16px rgba(168, 216, 234, 0.2);
  }
}

.preview-section.highlight-section {
  animation: highlightPulse 3s ease-in-out;
  box-shadow: 0 4px 16px rgba(168, 216, 234, 0.2);
}

@keyframes highlightPulse {
  0%   { box-shadow: 0 0 0 0 rgba(168, 216, 234, 0.4); }
  50%  { box-shadow: 0 0 0 8px rgba(168, 216, 234, 0.1); }
  100% { box-shadow: 0 4px 16px rgba(168, 216, 234, 0.2); }
}

/* Improve visual hierarchy for key sections */
.generation-section .panel-title {
  color: var(--color-text-primary);
  font-size: 19px;
  margin-bottom: 24px;
}

.preview-section .panel-title {
  color: var(--color-text-primary);
  font-size: 19px;
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 8px;
}

#testCaseCount {
  font-weight: var(--font-weight-bold);
  color: var(--color-accent);
  font-size: 18px;
}

} /* end @layer features */
