/* Interactive demo panel — matches Jam Marker CEP UI (web scale) */

.demo-shell {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
  width: 100%;
  max-width: 440px;
  animation: float-in 0.6s var(--ease-out) both;
}

@keyframes float-in {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

.demo-hint {
  font-size: 0.75rem;
  color: var(--text-muted);
  text-align: center;
}

.demo-panel.ad-panel {
  display: flex;
  flex-direction: column;
  height: 460px;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-modal);
  overflow: hidden;
  background: var(--surface-app);
  font: var(--text-label);
}

.demo-panel .ad-panel-header {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  height: 36px;
  padding: 0 var(--sp-6);
  background: var(--surface-raised);
  border-bottom: 1px solid var(--border-strong);
  box-shadow: var(--bevel-top);
}

.demo-panel .ad-logo { flex: none; }

.demo-panel .ad-panel-titleblock {
  flex: 1;
  min-width: 0;
}

.demo-panel .ad-panel-title {
  font: var(--fw-semibold) var(--fs-md)/1.1 var(--font-ui);
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.demo-panel .ad-panel-sub {
  font: var(--fw-regular) var(--fs-tiny)/1.2 var(--font-ui);
  color: var(--text-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.demo-panel .ad-version {
  font: var(--fw-regular) var(--fs-micro)/1 var(--font-ui);
  color: var(--text-muted);
}

.demo-panel .ad-tabs {
  display: flex;
  gap: 2px;
  padding: 0 var(--sp-6);
  border-bottom: 1px solid var(--border-strong);
}

.demo-panel .ad-tab {
  display: inline-flex;
  align-items: center;
  height: 28px;
  padding: 0 12px;
  margin-bottom: -1px;
  border: none;
  background: transparent;
  cursor: pointer;
  color: var(--text-secondary);
  border-bottom: 2px solid transparent;
  font: var(--fw-regular) var(--fs-sm)/1 var(--font-ui);
  transition: color var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out);
}

.demo-panel .ad-tab:hover { color: var(--text-primary); }

.demo-panel .ad-tab--on {
  color: var(--text-primary);
  font-weight: var(--fw-semibold);
  border-bottom-color: var(--blue-500);
}

.demo-panel .ad-tab:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}

.demo-panel .ad-tab-panel {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  gap: var(--sp-4);
  padding: var(--sp-4) var(--sp-6);
}

.demo-panel .ad-tab-panel[hidden] { display: none; }

.demo-panel .ad-flow--mini {
  padding: var(--sp-3) var(--sp-4);
  background: var(--gray-50);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  font: var(--fw-regular) var(--fs-tiny)/1.4 var(--font-ui);
  color: var(--status-success);
}

.demo-panel .ad-toolbar {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex: none;
}

.demo-panel .ad-toolbar--top { padding: 0; }

.demo-panel .ad-toolbar--foot {
  margin-top: auto;
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border-strong);
}

.demo-panel .ad-toolbar-spacer { flex: 1; }

.demo-panel .ad-btn {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: var(--control-h-sm);
  padding: 0 var(--sp-6);
  border: none;
  border-radius: var(--radius-xs);
  cursor: pointer;
  font: var(--fw-semibold) var(--fs-base)/1 var(--font-ui);
  white-space: nowrap;
  transition: background var(--dur-base) var(--ease-out);
}

.demo-panel .ad-btn:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}

.demo-panel .ad-btn--sm { height: var(--control-h-sm); padding: 0 var(--sp-4); }

.demo-panel .ad-btn--default {
  color: var(--text-primary);
  background: var(--gray-400);
  box-shadow: var(--bevel-top);
}

.demo-panel .ad-btn--default:hover:not(:disabled) { background: #4b4b4b; }

.demo-panel .ad-btn--cta {
  color: var(--text-on-amber);
  background: var(--cta);
  box-shadow: var(--bevel-top);
}

.demo-panel .ad-btn--cta:hover:not(:disabled) { background: var(--cta-hover); }

.demo-panel .ad-btn--primary {
  color: var(--white);
  background: var(--blue-500);
  box-shadow: var(--bevel-top);
}

.demo-panel .ad-btn--primary:hover:not(:disabled) { background: var(--blue-600, #1f7ad4); }

.demo-panel .ad-btn--ghost {
  color: var(--text-primary);
  background: transparent;
}

.demo-panel .ad-btn--ghost:hover:not(:disabled) { background: rgba(255, 255, 255, 0.06); }

.demo-panel .ad-btn:disabled {
  opacity: 0.55;
  cursor: default;
}

.demo-panel .ad-iconbtn {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border: none;
  border-radius: var(--radius-xs);
  background: transparent;
  color: var(--text-secondary);
  font-size: 16px;
  cursor: pointer;
}

.demo-panel .ad-iconbtn:hover { background: rgba(255, 255, 255, 0.06); color: var(--text-primary); }

.demo-panel .ad-iconbtn:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}

.demo-panel .ad-field-row {
  display: flex;
  gap: var(--sp-3);
}

.demo-panel .ad-select {
  flex: 1;
  height: var(--control-h-sm);
  padding: 0 var(--sp-4);
  background: var(--gray-75);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-xs);
  color: var(--text-primary);
  font: var(--fw-regular) var(--fs-base)/1 var(--font-ui);
  box-shadow: var(--inset-well);
}

.demo-panel .ad-search-wrap {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  height: var(--control-h-sm);
  padding: 0 var(--sp-4);
  background: var(--gray-75);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-xs);
  box-shadow: var(--inset-well);
}

.demo-panel .ad-search-wrap:focus-within {
  border-color: var(--blue-500);
  box-shadow: var(--focus-ring);
}

.demo-panel .ad-search-icon { color: var(--text-muted); font-size: 13px; }

.demo-panel .ad-search {
  flex: 1;
  min-width: 0;
  border: none;
  background: transparent;
  color: var(--text-primary);
  font: var(--fw-regular) var(--fs-base)/1 var(--font-ui);
  outline: none;
}

.demo-panel .ad-search-clear {
  border: none;
  background: transparent;
  color: var(--text-link);
  font: var(--fw-regular) var(--fs-tiny)/1 var(--font-ui);
  cursor: pointer;
  padding: 0 var(--sp-2);
}

.demo-panel .ad-list-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font: var(--fw-regular) var(--fs-tiny)/1 var(--font-ui);
  color: var(--text-muted);
}

.demo-panel .ad-list {
  list-style: none;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  background: var(--surface-sunken);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-xs);
  box-shadow: var(--inset-well);
}

.demo-panel .ad-list li {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-4);
  min-height: var(--row-h-loose);
  padding: var(--sp-3) var(--sp-5);
  border-bottom: 1px solid var(--border-strong);
  cursor: pointer;
  font: var(--text-body);
  color: var(--text-secondary);
}

.demo-panel .ad-list li:last-child { border-bottom: none; }

.demo-panel .ad-list li:hover { background: rgba(255, 255, 255, 0.03); }

.demo-panel .ad-list li.active {
  background: var(--blue-100);
  box-shadow: inset 2px 0 0 var(--blue-500);
  color: var(--text-primary);
}

.demo-panel .ad-row-time {
  flex: none;
  font: var(--fw-regular) var(--fs-tiny)/1.35 var(--font-mono);
  color: var(--text-muted);
  padding-top: 2px;
}

.demo-panel .ad-row-text { flex: 1; min-width: 0; }

.demo-panel .ad-empty {
  flex: none;
  padding: var(--sp-8);
  text-align: center;
  font: var(--fw-regular) var(--fs-sm)/1.45 var(--font-ui);
  color: var(--text-muted);
  border: 1px dashed var(--border-subtle);
  border-radius: var(--radius-xs);
}

.demo-panel .ad-preview {
  flex: none;
  font: var(--fw-regular) var(--fs-tiny)/1.4 var(--font-ui);
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-height: 16px;
}

.demo-panel .ad-status {
  flex: none;
  padding: var(--sp-3) var(--sp-4);
  margin: 0 calc(-1 * var(--sp-6)) calc(-1 * var(--sp-4));
  border-top: 1px solid var(--border-strong);
  font: var(--fw-regular) var(--fs-tiny)/1.4 var(--font-ui);
  color: var(--text-muted);
  background: var(--gray-50);
}

.demo-panel .ad-status.ok { color: var(--status-success); }

.demo-panel .demo-settings-preview {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  font: var(--text-body);
  color: var(--text-secondary);
}

.demo-panel .demo-settings-preview h3 {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--text-primary);
}

.demo-panel .demo-setting-pill {
  display: inline-flex;
  padding: 4px 8px;
  border-radius: var(--radius-xs);
  background: var(--gray-400);
  font-size: var(--fs-tiny);
  color: var(--text-primary);
}

.demo-panel .demo-settings-note {
  font-size: var(--fs-tiny);
  color: var(--text-muted);
  margin: 0;
}
  display: inline-flex;
  padding: 4px 8px;
  border-radius: var(--radius-xs);
  background: var(--gray-400);
  font-size: var(--fs-tiny);
  color: var(--text-primary);
}

/* Mini timeline */
.demo-timeline {
  padding: var(--sp-6);
  background: var(--gray-50);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-md);
  box-shadow: var(--inset-well);
}

.demo-timeline-ruler {
  display: flex;
  justify-content: space-between;
  margin-bottom: var(--sp-3);
  font: var(--fw-regular) var(--fs-micro)/1 var(--font-mono);
  color: var(--text-muted);
}

.demo-timeline-track {
  position: relative;
  height: 36px;
  background: var(--gray-75);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-xs);
  overflow: visible;
}

#demoMarkerTrack {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.demo-timeline-track::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    90deg,
    transparent,
    transparent 9.09%,
    rgba(255, 255, 255, 0.04) 9.09%,
    rgba(255, 255, 255, 0.04) calc(9.09% + 1px)
  );
  pointer-events: none;
}

.demo-playhead {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--cta);
  box-shadow: 0 0 6px rgba(232, 168, 74, 0.6);
  transform: translateX(-1px);
  transition: left 0.35s var(--ease-out);
  z-index: 2;
  pointer-events: none;
}

.demo-playhead::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-top-color: var(--cta);
}

.demo-marker {
  position: absolute;
  top: 4px;
  width: 2px;
  bottom: 4px;
  background: var(--blue-500);
  transform: translateX(-1px);
  z-index: 1;
}

.demo-marker::after {
  content: attr(data-label);
  position: absolute;
  top: -2px;
  left: 4px;
  max-width: 72px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font: var(--fw-semibold) 9px/1 var(--font-ui);
  color: var(--blue-500);
}

.demo-timeline-cta {
  font: var(--fw-regular) var(--fs-tiny)/1.4 var(--font-ui);
  color: var(--text-muted);
  margin-top: var(--sp-4);
}

.demo-timeline-cta strong { color: var(--text-secondary); font-weight: var(--fw-semibold); }

.demo-transcribing .ad-list {
  opacity: 0.5;
  pointer-events: none;
}

.demo-transcribing .ad-btn--cta#demoTranscribe {
  animation: pulse-cta 1s ease-in-out infinite;
}

@keyframes pulse-cta {
  50% { opacity: 0.7; }
}
