/* ==========================================================================
   SmartVantage — AI Readiness Diagnostic mockup
   Scoped styles for the topology viewer and readiness panel that sit inside
   the shared .demo-page > .mockup-container > .app-body scaffold.
   Class prefix: .svd- for SmartVantage page layout bits,
                 .topology- for the graph pane.
   ========================================================================== */


/* ==========================================================================
   SmartVantage-scoped page tokens
   ========================================================================== */

.svd-eyebrow {
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-4);
}

/* Use case metrics need a narrower, tighter feel for SmartVantage where two
   of the values are long strings ("5 days", "48 hrs/wk"). */
.content-section .use-case-metrics .metric-value {
  font-size: clamp(var(--text-2xl), 2.4vw, 38px);
}


/* ==========================================================================
   WHAT WE CAPTURE / PRIVACY — two-column card layout
   ========================================================================== */

.svd-capture-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
  margin-top: var(--space-10);
}

.svd-capture-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-6) var(--space-4);
}

.svd-capture-heading {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-body);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-ink);
  margin: 0 0 var(--space-4);
}

.svd-capture-icon {
  width: 22px;
  height: 22px;
  color: var(--color-success, #22c55e);
  flex-shrink: 0;
}

.svd-capture-icon--no { color: var(--color-text-muted); }

.svd-capture-list {
  margin: 0;
  padding: 0;
  list-style: none;
  color: var(--color-text-muted);
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
}

.svd-capture-list li {
  position: relative;
  padding-left: var(--space-5);
  margin-bottom: var(--space-3);
}

.svd-capture-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-accent);
  opacity: 0.5;
}

.svd-capture-card:last-child .svd-capture-list li::before { background: var(--color-text-subtle); }


/* ==========================================================================
   WHAT YOU WALK AWAY WITH — numbered deliverable list
   ========================================================================== */

.svd-deliverable-list {
  margin: var(--space-10) 0 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.svd-deliverable-list li {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-5);
  align-items: start;
  padding: var(--space-5) var(--space-6);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}

.svd-deliverable-step {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--color-accent-soft);
  color: var(--color-accent);
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: var(--text-base);
  font-weight: 600;
  flex-shrink: 0;
}

.svd-deliverable-title {
  margin: 0 0 var(--space-2);
  font-family: var(--font-body);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-ink);
  line-height: var(--leading-snug);
}

.svd-deliverable-body {
  margin: 0;
  color: var(--color-text-muted);
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
}


/* ==========================================================================
   MOCKUP — sidebar context chip
   ========================================================================== */

.demo-page .svd-context-chip {
  padding: 10px 12px;
  background: var(--demo-bg-card);
  border: 1px solid var(--demo-border);
  border-radius: var(--demo-radius-sm);
  margin-bottom: 8px;
}

.demo-page .svd-context-label {
  display: block;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--demo-text-muted);
  margin-bottom: 3px;
}

.demo-page .svd-context-value {
  display: block;
  font-size: 11px;
  font-weight: 500;
  color: var(--demo-text-primary);
  line-height: 1.3;
}


/* ==========================================================================
   TOPOLOGY VIEWER — replaces .document-viewer for the graph pane
   ========================================================================== */

.demo-page .topology-viewer {
  display: flex;
  flex-direction: column;
  background: var(--demo-bg-dark);
  min-width: 0;
  overflow: hidden;
}

.demo-page .topology-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--demo-radius-md);
  padding: 12px 16px;
  background: var(--demo-bg-panel);
  border-bottom: 1px solid var(--demo-border);
}

.demo-page .topology-level-tabs {
  display: inline-flex;
  gap: 2px;
  padding: 3px;
  background: var(--demo-bg-card);
  border-radius: var(--demo-radius-md);
}

.demo-page .topology-level-tab {
  border: none;
  background: transparent;
  color: var(--demo-text-secondary);
  font-family: inherit;
  font-size: 13px;
  font-weight: 500;
  padding: 6px 14px;
  border-radius: calc(var(--demo-radius-md) - 2px);
  cursor: pointer;
  transition: all 0.2s;
}

.demo-page .topology-level-tab:hover {
  color: var(--demo-text-primary);
  background: var(--demo-bg-hover);
}

.demo-page .topology-level-tab.active {
  background: var(--demo-accent-blue);
  color: white;
}

.demo-page .topology-scope {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  font-size: 11px;
}

.demo-page .topology-scope-label {
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--demo-text-muted);
  margin-bottom: 2px;
}

.demo-page .topology-scope-value {
  color: var(--demo-text-secondary);
  font-variant-numeric: tabular-nums;
}


/* ==========================================================================
   TOPOLOGY CANVAS — SVG container
   ========================================================================== */

.demo-page .topology-canvas {
  position: relative;
  flex: 1;
  min-height: 0;
  background:
    radial-gradient(ellipse 60% 50% at 50% 50%, oklch(16% 0.006 268) 0%, transparent 70%),
    var(--demo-bg-darkest);
  overflow: hidden;
}

.demo-page .topology-svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* Node groups */
.demo-page .topology-node {
  cursor: pointer;
  transition: opacity 200ms ease, transform 200ms ease;
  transform-box: fill-box;
  transform-origin: center;
}

.demo-page .topology-node:focus { outline: none; }

.demo-page .topology-node:focus-visible .topology-node-shape {
  stroke: #7d96ff;
  stroke-width: 2.5;
}

.demo-page .topology-node-shape {
  transition: stroke 200ms ease, stroke-width 200ms ease, fill 200ms ease;
}

.demo-page .topology-node-label {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  fill: var(--demo-text-primary);
  text-anchor: middle;
  pointer-events: none;
  user-select: none;
}

.demo-page .topology-node-sublabel {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 10px;
  font-weight: 500;
  fill: var(--demo-text-muted);
  text-anchor: middle;
  pointer-events: none;
  user-select: none;
  letter-spacing: 0.3px;
}

/* Node type styles */
.demo-page .topology-node[data-type="function"] .topology-node-shape {
  fill: url(#node-function-grad);
  stroke: #5b7cff;
  stroke-width: 1.5;
}

.demo-page .topology-node[data-type="person"] .topology-node-shape {
  fill: url(#node-person-grad);
  stroke: #7d96ff;
  stroke-width: 1.5;
}

.demo-page .topology-node[data-type="tool"] .topology-node-shape {
  fill: url(#node-tool-grad);
  stroke: #22c55e;
  stroke-width: 1.5;
}

.demo-page .topology-node[data-type="document"] .topology-node-shape {
  fill: rgba(249, 115, 22, 0.15);
  stroke: #f97316;
  stroke-width: 1.5;
}

.demo-page .topology-node[data-type="project"] .topology-node-shape {
  fill: rgba(125, 150, 255, 0.12);
  stroke: #7d96ff;
  stroke-width: 1.5;
  stroke-dasharray: 4 3;
}

/* Edge styles */
.demo-page .topology-edge-line {
  stroke: oklch(38% 0.008 268);
  stroke-linecap: round;
  transition: stroke 200ms ease, stroke-width 200ms ease, opacity 200ms ease;
}

.demo-page .topology-edge-label {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 10px;
  font-weight: 500;
  fill: var(--demo-text-muted);
  text-anchor: middle;
  pointer-events: none;
  user-select: none;
}

.demo-page .topology-edge[data-highlight="true"] .topology-edge-line {
  stroke: var(--demo-accent-blue);
  stroke-width: 2.5;
  opacity: 1;
}

/* Hover / pinned states */
.demo-page .topology-canvas.has-focus .topology-node:not(.focused):not(.neighbor) { opacity: 0.35; }
.demo-page .topology-canvas.has-focus .topology-edge:not(.touches-focus) { opacity: 0.2; }

.demo-page .topology-node.focused .topology-node-shape {
  stroke: #7d96ff;
  stroke-width: 3;
  filter: drop-shadow(0 0 12px rgba(125, 150, 255, 0.5));
}

.demo-page .topology-node.neighbor .topology-node-shape {
  stroke-width: 2;
}

.demo-page .topology-edge.touches-focus .topology-edge-line {
  stroke: #93c5fd;
  stroke-width: 2;
}

.demo-page .topology-edge.touches-focus .topology-edge-label {
  fill: var(--demo-text-primary);
}

/* Pulse when an opportunity card is hovered */
.demo-page .topology-node.pulse .topology-node-shape {
  animation: svd-node-pulse 1.6s ease-in-out infinite;
}

@keyframes svd-node-pulse {
  0%, 100% { stroke-width: 2; filter: none; }
  50% { stroke-width: 3.5; filter: drop-shadow(0 0 14px rgba(125, 150, 255, 0.7)); }
}

/* Tooltip */
.demo-page .topology-tooltip {
  position: absolute;
  z-index: 10;
  padding: 8px 12px;
  background: var(--demo-bg-card);
  border: 1px solid var(--demo-border-light);
  border-radius: var(--demo-radius-md);
  font-size: 12px;
  color: var(--demo-text-primary);
  pointer-events: none;
  opacity: 0;
  transform: translate(-50%, calc(-100% - 12px));
  transition: opacity 150ms ease;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
  max-width: 260px;
  line-height: 1.4;
}

.demo-page .topology-tooltip.visible { opacity: 1; }

.demo-page .topology-tooltip-label {
  font-weight: 600;
  margin-bottom: 2px;
}

.demo-page .topology-tooltip-detail {
  color: var(--demo-text-secondary);
  font-size: 11px;
}


/* ==========================================================================
   READINESS PANEL — adaptations on top of .compliance-panel
   ========================================================================== */

.demo-page .svd-readiness-panel .compliance-title svg { color: var(--demo-accent-green); }

.demo-page .svd-readiness-panel .score-ring .progress {
  stroke: var(--demo-accent-green);
}

.demo-page .svd-readiness-panel .score-value .number {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 30px;
}

.demo-page .svd-readiness-panel .score-value .label {
  font-size: 9px;
  max-width: 72px;
  margin: 3px auto 0;
  line-height: 1.3;
}


/* ==========================================================================
   OPPORTUNITY CARD — adapted discrepancy-item for a richer content block
   ========================================================================== */

.demo-page .svd-opportunity-card {
  flex-direction: column;
  gap: 8px;
  padding: 14px;
}

.demo-page .svd-opportunity-card .discrepancy-item-icon {
  align-self: flex-start;
}

.demo-page .svd-opportunity-card.pinned {
  background: var(--demo-accent-blue-dim);
  border-left: 3px solid var(--demo-accent-blue);
}

.demo-page .svd-opp-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin: 2px 0 6px;
}

.demo-page .svd-opp-badge {
  display: inline-block;
  padding: 2px 8px;
  background: var(--demo-bg-panel);
  border: 1px solid var(--demo-border);
  border-radius: 10px;
  font-size: 10px;
  font-weight: 500;
  color: var(--demo-text-secondary);
  letter-spacing: 0.2px;
}

.demo-page .svd-opp-badge--priority {
  background: rgba(34, 197, 94, 0.12);
  border-color: rgba(34, 197, 94, 0.3);
  color: var(--demo-accent-green);
}

.demo-page .svd-opp-badge--hours {
  background: rgba(65, 102, 245, 0.12);
  border-color: rgba(65, 102, 245, 0.3);
  color: #7d96ff;
}

.demo-page .svd-opp-badge--pattern {
  background: transparent;
  color: var(--demo-text-muted);
}

.demo-page .svd-opp-current,
.demo-page .svd-opp-proposed {
  margin: 0 0 6px;
  font-size: 11px;
  line-height: 1.5;
  color: var(--demo-text-secondary);
}

.demo-page .svd-opp-current strong,
.demo-page .svd-opp-proposed strong {
  color: var(--demo-text-primary);
  font-weight: 600;
}

.demo-page .svd-opp-evidence {
  display: inline-block;
  font-size: 11px;
  color: var(--demo-text-muted);
  margin-top: 2px;
  opacity: 0.7;
}

.demo-page .svd-opp-evidence[aria-disabled="true"] { cursor: default; }


/* Findings group items — plain text blocks */
.demo-page .svd-finding {
  padding: 10px 12px;
  background: var(--demo-bg-card);
  border-bottom: 1px solid var(--demo-border);
  font-size: 12px;
  line-height: 1.5;
  color: var(--demo-text-secondary);
}

.demo-page .svd-finding:first-child { border-top: 1px solid var(--demo-border); }
.demo-page .svd-finding:last-child { border-bottom: none; }


/* ==========================================================================
   UTILITIES
   ========================================================================== */

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}


/* ==========================================================================
   REDUCED MOTION
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
  .demo-page .topology-node,
  .demo-page .topology-edge-line,
  .demo-page .topology-node-shape,
  .demo-page .topology-tooltip {
    transition: none !important;
    animation: none !important;
  }
  .demo-page .topology-node.pulse .topology-node-shape {
    animation: none !important;
    stroke-width: 2.5;
  }
}


/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (max-width: 1200px) {
  .demo-page .topology-toolbar { padding: 10px 12px; }
  .demo-page .topology-scope { display: none; }
}

@media (max-width: 1024px) {
  .svd-capture-grid { grid-template-columns: 1fr; }
  .demo-page .topology-canvas { min-height: 420px; }
}

@media (max-width: 768px) {
  .svd-deliverable-list li { grid-template-columns: 1fr; gap: var(--space-3); }
}
