:root {
  --bg-deep: #02050f;
  --bg-mid: #070f23;
  --panel-line: rgba(34, 240, 255, 0.35);
  --grid-cell-size: 44;
  --grid-line-alpha: 0.13;
  --grid-opacity: 0.94;
  --grid-blur: 0px;
  --grid-transition-ms: 2200ms;
  --grid-ease: cubic-bezier(0.22, 0.61, 0.36, 1);
  --text-main: #ddf7ff;
  --text-dim: #8fa9c8;
  --accent-cyan: #18f0ff;
  --accent-pink: #ff3fc9;
  --accent-blue: #57a8ff;
  --ok-bg: rgba(31, 108, 79, 0.35);
  --ok-text: #7dffc7;
  --error-bg: rgba(118, 32, 56, 0.35);
  --error-text: #ff91a8;
  --warning-text: #ffcd76;
  --btn-cyan: #1ff3ff;
  --btn-pink: #ff42cb;
  --btn-blue: #4a8dff;
  --btn-text: #ebfbff;
  font-family: "Rajdhani", "Segoe UI", "Noto Sans", sans-serif;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  color: var(--text-main);
  background:
    radial-gradient(circle at 85% 12%, rgba(91, 69, 219, 0.24), transparent 38%),
    radial-gradient(circle at 12% 88%, rgba(255, 60, 187, 0.2), transparent 40%),
    linear-gradient(140deg, var(--bg-deep) 0%, var(--bg-mid) 60%, #030614 100%);
}

body.fullscreen-open {
  overflow: hidden;
}

h1,
h2,
h3,
p {
  margin: 0;
}

button,
select,
textarea,
input {
  font: inherit;
}

.hidden {
  display: none !important;
}

.cyber-grid {
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgb(108 223 255 / 0.06) 2px, transparent 2px),
    linear-gradient(90deg, rgb(108 223 255 / 0.06) 2px, transparent 2px),
    linear-gradient(rgb(51 180 255 / var(--grid-line-alpha)) 1px, transparent 1px),
    linear-gradient(90deg, rgb(51 180 255 / var(--grid-line-alpha)) 1px, transparent 1px);
  background-size:
    calc(var(--grid-cell-size) * 1px)
    calc(var(--grid-cell-size) * 1px);
  mask-image: radial-gradient(circle at center, rgba(0, 0, 0, 0.92) 44%, transparent 97%);
  opacity: var(--grid-opacity);
  filter: blur(var(--grid-blur));
  transition:
    background-size var(--grid-transition-ms) var(--grid-ease),
    opacity var(--grid-transition-ms) ease-out,
    filter var(--grid-transition-ms) ease-out;
  z-index: -3;
}

.cyber-glow {
  position: fixed;
  width: 36vw;
  height: 36vw;
  border-radius: 999px;
  filter: blur(42px);
  opacity: 0.3;
  pointer-events: none;
  z-index: -2;
}

.cyber-glow-a {
  top: -12vw;
  left: -7vw;
  background: rgba(28, 233, 255, 0.5);
}

.cyber-glow-b {
  right: -10vw;
  bottom: -14vw;
  background: rgba(255, 69, 198, 0.45);
}

.page {
  max-width: 1240px;
  margin: 0 auto;
  padding: 28px 18px 56px;
}

.panel {
  background: linear-gradient(
    160deg,
    rgba(8, 18, 40, 0.44),
    rgba(12, 22, 48, 0.36) 42%,
    rgba(7, 16, 38, 0.46)
  );
  border: none;
  border-radius: 18px;
  padding: 20px;
  box-shadow:
    0 16px 42px rgba(1, 6, 18, 0.62),
    inset 0 1px 0 rgba(216, 242, 255, 0.22);
  margin-top: 18px;
  backdrop-filter: blur(18px) saturate(142%);
  -webkit-backdrop-filter: blur(18px) saturate(142%);
}

.home-panel {
  margin-top: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.home-title {
  font-size: clamp(3.2rem, 8vw, 5.2rem);
  line-height: 0.92;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-align: center;
  background:
    linear-gradient(135deg, #f7fcff 0%, #8cefff 28%, #44a8ff 58%, #ff54ca 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow:
    0 0 26px rgba(24, 240, 255, 0.18),
    0 0 42px rgba(255, 63, 201, 0.1);
}

.workspace-sections {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.eyebrow {
  display: inline-block;
  font-family: "Orbitron", "Rajdhani", sans-serif;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--accent-blue);
}

h1,
h2,
h3 {
  font-family: "Orbitron", "Rajdhani", sans-serif;
}

h1 {
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  color: #effbff;
  text-shadow: 0 0 20px rgba(21, 237, 255, 0.24);
}

h2 {
  font-size: 1.16rem;
  color: #c8e9ff;
}

h3 {
  font-size: 1rem;
  color: #d7f2ff;
}

.lead {
  line-height: 1.55;
  font-size: 1.05rem;
  color: #d5f2ff;
}

.meta {
  color: var(--text-dim);
  font-size: 0.88rem;
}

.agent-card-grid {
  margin-top: 8px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.archimeta-entry {
  margin-top: 2px;
  display: flex;
  gap: 12px;
  align-items: stretch;
}

.archimeta-state-preview {
  margin-top: 12px;
  border-radius: 16px;
  padding: 14px 16px;
  background:
    linear-gradient(145deg, rgba(10, 23, 54, 0.54), rgba(6, 16, 38, 0.64)),
    radial-gradient(circle at top right, rgba(103, 222, 255, 0.08), transparent 42%);
  box-shadow:
    0 12px 28px rgba(4, 11, 28, 0.44),
    inset 0 1px 0 rgba(210, 236, 255, 0.12);
}

.archimeta-state-preview h2 {
  margin: 0;
  font-size: 1rem;
}

.archimeta-open {
  flex: 1 1 auto;
  border-radius: 16px;
  border: none;
  background: linear-gradient(
    120deg,
    rgba(34, 16, 58, 0.5),
    rgba(16, 22, 54, 0.44),
    rgba(10, 24, 56, 0.5)
  );
  color: #f6e9ff;
  text-align: left;
  padding: 14px 16px;
  cursor: pointer;
  box-shadow:
    0 10px 28px rgba(5, 10, 30, 0.5),
    inset 0 1px 0 rgba(255, 223, 247, 0.18);
  backdrop-filter: blur(12px) saturate(135%);
  -webkit-backdrop-filter: blur(12px) saturate(135%);
  transition:
    transform 140ms ease,
    box-shadow 170ms ease;
}

.archimeta-open:hover,
.archimeta-open:focus-visible {
  transform: translateY(-2px);
  box-shadow:
    0 0 20px rgba(255, 84, 205, 0.18),
    0 14px 34px rgba(4, 10, 32, 0.66),
    inset 0 1px 0 rgba(255, 223, 247, 0.24);
  outline: none;
}

.archimeta-title {
  display: block;
  font-family: "Orbitron", "Rajdhani", sans-serif;
  font-size: 1.06rem;
  letter-spacing: 0.05em;
}

.archimeta-subtitle {
  display: block;
  margin-top: 6px;
  color: #cfc2f8;
  font-size: 0.93rem;
  line-height: 1.45;
}

.soundtrack-toggle-button {
  flex: 0 0 auto;
  min-width: 220px;
  align-self: center;
}

.agent-card {
  appearance: none;
  width: 100%;
  border-radius: 16px;
  border: none;
  background: linear-gradient(
    145deg,
    rgba(10, 24, 52, 0.5),
    rgba(8, 19, 44, 0.42) 54%,
    rgba(7, 16, 37, 0.54)
  );
  padding: 12px;
  color: var(--text-main);
  text-align: left;
  cursor: pointer;
  box-shadow:
    0 12px 32px rgba(4, 11, 28, 0.55),
    inset 0 1px 0 rgba(210, 236, 255, 0.16);
  backdrop-filter: blur(10px) saturate(132%);
  -webkit-backdrop-filter: blur(10px) saturate(132%);
  transition:
    transform 140ms ease,
    box-shadow 180ms ease,
    background-color 180ms ease;
}

.agent-card:hover,
.agent-card:focus-visible,
.agent-card.playing {
  transform: translateY(-2px);
  box-shadow:
    0 0 20px rgba(24, 170, 255, 0.2),
    0 16px 38px rgba(2, 8, 24, 0.68),
    inset 0 1px 0 rgba(215, 241, 255, 0.2);
  outline: none;
}

.agent-card-media {
  display: block;
  position: relative;
  width: 100%;
  height: clamp(360px, 58vh, 680px);
  border-radius: 12px;
  overflow: hidden;
  border: none;
  background:
    linear-gradient(145deg, rgba(10, 23, 54, 0.7), rgba(6, 15, 36, 0.78)),
    radial-gradient(circle at 22% 30%, rgba(44, 188, 255, 0.2), transparent 52%),
    radial-gradient(circle at 78% 70%, rgba(255, 63, 201, 0.14), transparent 58%);
  box-shadow:
    inset 0 1px 0 rgba(215, 239, 255, 0.24),
    inset 0 -14px 26px rgba(2, 6, 20, 0.55);
  isolation: isolate;
}

.agent-card-media::after {
  content: "";
  position: absolute;
  left: -4%;
  top: -14%;
  width: 108%;
  height: 11%;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    rgba(24, 240, 255, 0) 0%,
    rgba(24, 240, 255, 0.15) 14%,
    rgba(24, 240, 255, 0.82) 38%,
    rgba(255, 63, 201, 0.84) 50%,
    rgba(24, 240, 255, 0.82) 62%,
    rgba(24, 240, 255, 0.15) 86%,
    rgba(24, 240, 255, 0) 100%
  );
  box-shadow:
    0 0 16px rgba(24, 240, 255, 0.62),
    0 0 28px rgba(255, 63, 201, 0.34);
  opacity: 0;
  transform: translateY(-130%);
  pointer-events: none;
  z-index: 4;
}

.agent-card-image,
.agent-card-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center top;
}

.agent-card-image.image-missing {
  opacity: 0;
}

.agent-card-video {
  opacity: 0;
  transition: opacity 220ms ease;
  pointer-events: none;
}

.agent-card:hover .agent-card-video,
.agent-card:focus-visible .agent-card-video,
.agent-card.playing .agent-card-video {
  opacity: 1;
}

.agent-card:hover .agent-card-media::after,
.agent-card:focus-visible .agent-card-media::after,
.agent-card.playing .agent-card-media::after {
  opacity: 1;
  animation: agent-scan-sweep 1.6s linear 1;
}

.agent-card-body {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.agent-card-title {
  font-family: "Orbitron", "Rajdhani", sans-serif;
  font-size: 1.05rem;
  letter-spacing: 0.03em;
}

.agent-card-subtitle {
  color: #c7def7;
  font-size: 0.92rem;
  line-height: 1.45;
}

@keyframes agent-scan-sweep {
  0% {
    transform: translateY(-130%);
    opacity: 0;
  }
  12% {
    opacity: 1;
  }
  88% {
    opacity: 1;
  }
  100% {
    transform: translateY(1060%);
    opacity: 0;
  }
}

.detail-panel {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.detail-card {
  border: none;
  border-radius: 16px;
  background: linear-gradient(
    145deg,
    rgba(10, 24, 52, 0.5),
    rgba(8, 19, 44, 0.42) 54%,
    rgba(7, 16, 37, 0.54)
  );
  padding: 12px;
  box-shadow:
    0 12px 32px rgba(4, 11, 28, 0.55),
    inset 0 1px 0 rgba(210, 236, 255, 0.16);
  backdrop-filter: blur(10px) saturate(132%);
  -webkit-backdrop-filter: blur(10px) saturate(132%);
}

.detail-card h3 {
  margin-bottom: 8px;
}

.archimeta-panel {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.zone-map {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.zone-card {
  border: 1px solid rgba(86, 156, 249, 0.46);
  border-radius: 12px;
  background: rgba(8, 22, 49, 0.74);
  padding: 12px;
}

.zone-card h3 {
  margin-bottom: 8px;
}

.zone-card p {
  color: #c3ddf5;
  line-height: 1.45;
  font-size: 0.93rem;
}

.archimeta-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.archimeta-mermaid-head {
  margin-top: 8px;
}

.archimeta-mermaid-head h3 {
  margin-bottom: 6px;
}

.archimeta-drilldown {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(300px, 0.9fr);
  gap: 12px;
}

.archimeta-overview-card {
  min-height: 560px;
}

.archimeta-method-index-card {
  min-height: 560px;
}

.archimeta-method-index {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  align-content: start;
  overflow: auto;
}

.archimeta-method-link {
  width: 100%;
  text-align: left;
  border: 1px solid rgba(90, 152, 245, 0.44);
  border-radius: 12px;
  background: rgba(8, 22, 49, 0.68);
  color: #dff3ff;
  padding: 10px 12px;
  cursor: pointer;
  transition:
    border-color 160ms ease,
    transform 140ms ease,
    box-shadow 180ms ease;
}

.archimeta-method-link:hover,
.archimeta-method-link:focus-visible,
.archimeta-method-link.active {
  transform: translateY(-1px);
  border-color: rgba(111, 190, 255, 0.7);
  box-shadow:
    0 0 18px rgba(24, 240, 255, 0.14),
    inset 0 1px 0 rgba(216, 242, 255, 0.2);
  outline: none;
}

.archimeta-method-link-title {
  display: block;
  font-family: "Orbitron", "Rajdhani", sans-serif;
  font-size: 0.94rem;
}

.archimeta-method-link-meta {
  display: block;
  margin-top: 4px;
  color: #9fc9eb;
  font-size: 0.82rem;
}

.archimeta-method-detail-wrap {
  display: block;
}

.diagram-card {
  border: 1px solid rgba(90, 152, 245, 0.44);
  border-radius: 14px;
  background: rgba(4, 16, 38, 0.72);
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  cursor: zoom-in;
  transition:
    transform 140ms ease,
    box-shadow 180ms ease,
    border-color 180ms ease;
}

.diagram-card:hover,
.diagram-card:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(111, 190, 255, 0.62);
  box-shadow:
    0 0 22px rgba(24, 240, 255, 0.2),
    0 14px 28px rgba(2, 9, 26, 0.52),
    inset 0 1px 0 rgba(216, 242, 255, 0.2);
  outline: none;
}

.diagram-meta {
  margin-top: 2px;
  line-height: 1.35;
}

.uml-diagram {
  width: 100%;
  border-radius: 10px;
  border: 1px solid rgba(76, 137, 235, 0.42);
  background:
    radial-gradient(circle at 80% 18%, rgba(102, 76, 238, 0.2), transparent 42%),
    radial-gradient(circle at 18% 82%, rgba(51, 180, 255, 0.16), transparent 45%),
    rgba(3, 11, 28, 0.95);
}

.mermaid-card {
  cursor: zoom-in;
}

.mermaid-host {
  min-height: 280px;
  border-radius: 10px;
  border: 1px solid rgba(76, 137, 235, 0.42);
  background:
    radial-gradient(circle at 80% 18%, rgba(48, 166, 212, 0.16), transparent 38%),
    radial-gradient(circle at 12% 80%, rgba(38, 104, 226, 0.15), transparent 44%),
    rgba(3, 11, 28, 0.95);
  padding: 8px;
  overflow: auto;
}

.mermaid-host svg {
  width: 100%;
  height: auto;
  min-width: 720px;
}

.mermaid-source {
  margin: 0;
}

.mermaid-source summary {
  cursor: pointer;
  color: #8fd7f7;
}

.mermaid-source pre {
  margin: 8px 0 0;
  border-radius: 10px;
  border: 1px solid rgba(89, 141, 216, 0.36);
  background: rgba(2, 8, 22, 0.82);
  padding: 10px;
  color: #bedef2;
  font-size: 0.8rem;
  line-height: 1.35;
  overflow: auto;
}

.diagram-fullscreen {
  position: fixed;
  inset: 0;
  z-index: 90;
  padding: 20px;
  display: grid;
  place-items: center;
}

.diagram-fullscreen-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(2, 8, 24, 0.86);
  backdrop-filter: blur(8px) saturate(122%);
  -webkit-backdrop-filter: blur(8px) saturate(122%);
}

.diagram-fullscreen-panel {
  position: relative;
  z-index: 1;
  width: min(98vw, 1700px);
  height: min(94vh, 980px);
  border-radius: 18px;
  border: 1px solid rgba(92, 168, 255, 0.5);
  background: linear-gradient(
    160deg,
    rgba(7, 19, 44, 0.86),
    rgba(9, 23, 52, 0.8) 48%,
    rgba(7, 18, 45, 0.86)
  );
  box-shadow:
    0 18px 48px rgba(1, 6, 18, 0.68),
    inset 0 1px 0 rgba(216, 242, 255, 0.22);
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.diagram-fullscreen-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.diagram-fullscreen-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.diagram-fullscreen-actions button {
  min-width: 42px;
}

.diagram-fullscreen-content {
  flex: 1;
  min-height: 0;
  border-radius: 12px;
  border: 1px solid rgba(86, 160, 248, 0.42);
  background: rgba(3, 11, 28, 0.84);
  padding: 10px;
  overflow: auto;
  cursor: grab;
}

.diagram-fullscreen-content.dragging {
  cursor: grabbing;
  user-select: none;
}

.diagram-fullscreen-stage {
  position: relative;
  min-width: 100%;
}

.diagram-fullscreen-visual {
  display: block;
  transform-origin: top left;
  will-change: transform;
}

.diagram-fullscreen-content .uml-diagram {
  width: 100%;
  min-height: min(72vh, 860px);
  height: auto;
}

.diagram-fullscreen-content .mermaid-host {
  min-height: min(72vh, 860px);
}

.diagram-fullscreen-content .mermaid-host svg {
  min-width: 1080px;
}

.uml-node {
  fill: rgba(11, 34, 70, 0.87);
  stroke: rgba(94, 182, 255, 0.75);
  stroke-width: 2;
}

.uml-core {
  fill: rgba(24, 61, 106, 0.9);
  stroke: rgba(95, 227, 255, 0.85);
}

.uml-diamond {
  fill: rgba(44, 32, 84, 0.88);
  stroke: rgba(174, 145, 255, 0.84);
  stroke-width: 2;
}

.uml-boundary {
  fill: rgba(5, 12, 31, 0.45);
  stroke: rgba(92, 168, 255, 0.6);
  stroke-width: 2;
  stroke-dasharray: 8 5;
}

.uml-line {
  stroke: rgba(103, 222, 255, 0.88);
  stroke-width: 2.4;
  fill: none;
}

.uml-text-title {
  fill: #ddf6ff;
  font-size: 16px;
  font-weight: 700;
  font-family: "Orbitron", "Rajdhani", sans-serif;
}

.uml-text-sub {
  fill: #9fc9eb;
  font-size: 13px;
  font-family: "Rajdhani", "Segoe UI", sans-serif;
}

.detail-head {
  align-items: center;
}

.detail-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(360px, 0.95fr);
  gap: 16px;
}

.detail-video-wrap {
  border: none;
  border-radius: 16px;
  padding: 12px;
  background: linear-gradient(
    145deg,
    rgba(10, 24, 52, 0.5),
    rgba(8, 19, 44, 0.42) 54%,
    rgba(7, 16, 37, 0.54)
  );
  box-shadow:
    0 12px 32px rgba(4, 11, 28, 0.55),
    inset 0 1px 0 rgba(210, 236, 255, 0.16);
  contain: layout paint;
}

.detail-video {
  width: 100%;
  border-radius: 12px;
  display: block;
  border: none;
  background: rgba(2, 9, 24, 0.8);
  contain: layout paint;
}

.detail-prompt-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 100%;
}

.detail-prompt-tabs {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.detail-prompt-card .editor {
  min-height: 600px;
}

.detail-tabs-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.detail-tabs-nav {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.detail-tab-button {
  border: 1px solid rgba(84, 154, 245, 0.28);
  border-radius: 999px;
  background: rgba(8, 21, 47, 0.6);
  color: #caecff;
  padding: 9px 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: 0.78rem;
}

.detail-tab-button.active {
  border-color: rgba(24, 240, 255, 0.5);
  background: linear-gradient(145deg, rgba(10, 50, 92, 0.76), rgba(7, 22, 47, 0.84));
  color: #f2fdff;
  box-shadow: 0 0 18px rgba(24, 240, 255, 0.14);
}

.detail-tab-panel {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.detail-section {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.detail-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.detail-section-head h3 {
  margin: 0;
}

.detail-agent-info {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.editor-section {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.editor-section h3 {
  margin: 0;
}

.detail-schedule-panel {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px 14px;
  border-radius: 14px;
  background: linear-gradient(145deg, rgba(9, 24, 52, 0.74), rgba(6, 18, 39, 0.9));
  border: 1px solid rgba(89, 163, 255, 0.22);
  box-shadow: inset 0 1px 0 rgba(195, 232, 255, 0.08);
}

.detail-schedule-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.detail-schedule-label {
  color: #e9f8ff;
  letter-spacing: 0.03em;
  font-size: 0.98rem;
}

.detail-schedule-value {
  min-width: 48px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(104, 235, 255, 0.32);
  background: rgba(11, 41, 74, 0.72);
  color: #bffdff;
  font-size: 0.94rem;
  text-align: center;
}

.detail-schedule-slider {
  width: 100%;
  accent-color: #4fdcff;
}

.detail-schedule-slider:disabled {
  opacity: 0.55;
}

.detail-model-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

.detail-select-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  color: #d7f1ff;
  font-size: 0.92rem;
}

.detail-model-select {
  width: 100%;
}

.visioner-goals-panel {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 0;
}

.artifact-empty {
  border: 1px dashed rgba(108, 167, 248, 0.28);
  border-radius: 14px;
  padding: 16px;
  color: #a7cbe7;
  background: rgba(6, 17, 39, 0.55);
}

.artifact-item summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.artifact-item .artifact-summary-label {
  font-family: "Orbitron", "Rajdhani", sans-serif;
  letter-spacing: 0.06em;
  color: #def8ff;
}

.artifact-item .artifact-summary-meta {
  color: #8fbad9;
  font-size: 0.85rem;
}

.visioner-goals-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.visioner-goals-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.visioner-goal-item {
  border: 1px solid rgba(86, 156, 249, 0.28);
  border-radius: 14px;
  background: rgba(5, 14, 34, 0.78);
  overflow: hidden;
}

.visioner-goal-item.current {
  border-color: rgba(24, 240, 255, 0.56);
  box-shadow:
    0 0 18px rgba(24, 240, 255, 0.12),
    inset 0 1px 0 rgba(217, 244, 255, 0.16);
}

.visioner-goal-toggle {
  width: 100%;
  border: none;
  background: transparent;
  color: inherit;
  padding: 12px 14px;
  text-align: left;
  cursor: pointer;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.visioner-goal-toggle:hover,
.visioner-goal-toggle:focus-visible {
  background: rgba(20, 46, 92, 0.24);
  outline: none;
}

.visioner-goal-main {
  display: flex;
  flex-direction: column;
  gap: 5px;
  min-width: 0;
}

.visioner-goal-title-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.visioner-goal-title {
  font-family: "Orbitron", "Rajdhani", sans-serif;
  font-size: 0.94rem;
  color: #dff6ff;
}

.visioner-goal-badge {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 9px;
  border-radius: 999px;
  border: 1px solid rgba(24, 240, 255, 0.4);
  background: rgba(10, 80, 104, 0.3);
  color: #8df8ff;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.visioner-goal-toggle-icon {
  color: #9dcfff;
  font-size: 0.84rem;
  padding-top: 3px;
}

.visioner-goal-content {
  display: none;
  padding: 0 14px 14px;
  border-top: 1px solid rgba(86, 156, 249, 0.18);
}

.visioner-goal-item.expanded .visioner-goal-content {
  display: block;
}

.visioner-goal-section + .visioner-goal-section {
  margin-top: 12px;
}

.visioner-goal-section h4 {
  margin: 0 0 6px;
  font-size: 0.84rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #8bcfff;
}

.visioner-goal-section p,
.visioner-goal-section li {
  color: #cfe7f9;
  line-height: 1.5;
}

.visioner-goal-section ul {
  margin: 0;
  padding-left: 18px;
}

.visioner-goal-form {
  display: grid;
  gap: 10px;
  padding-top: 4px;
}

.visioner-goal-form label {
  display: grid;
  gap: 6px;
  color: #bbdcf7;
  font-size: 0.9rem;
}

.visioner-goal-form textarea,
.visioner-goal-form input {
  border: 1px solid rgba(80, 151, 252, 0.4);
  border-radius: 10px;
  padding: 8px 10px;
  background: rgba(4, 15, 35, 0.92);
  color: #d3f3ff;
}

.inline-actions {
  margin-top: 8px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.focus-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.focus-list li,
.current-state-box {
  margin-top: 8px;
  border: none;
  border-radius: 12px;
  padding: 10px 12px;
  background: rgba(7, 20, 43, 0.52);
  box-shadow:
    0 8px 20px rgba(3, 8, 22, 0.44),
    inset 0 1px 0 rgba(190, 228, 255, 0.12);
}

.current-state-box {
  white-space: pre-wrap;
  min-height: 160px;
}

.current-state-box-compact {
  max-height: 220px;
  overflow: auto;
}

.task-board {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  align-items: start;
}

.task-status-column {
  min-width: 0;
  min-height: 100%;
  border: 1px solid rgba(76, 139, 232, 0.26);
  border-radius: 14px;
  background:
    linear-gradient(180deg, rgba(6, 18, 40, 0.82), rgba(3, 10, 24, 0.72)),
    radial-gradient(circle at top, rgba(24, 240, 255, 0.08), transparent 50%);
  box-shadow:
    inset 0 1px 0 rgba(192, 230, 255, 0.08),
    0 12px 28px rgba(3, 8, 22, 0.32);
}

.task-status-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid rgba(90, 153, 240, 0.18);
}

.task-status-title {
  margin: 0;
  font-family: "Orbitron", "Rajdhani", sans-serif;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #c9f3ff;
}

.task-status-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  min-height: 28px;
  padding: 0 8px;
  border-radius: 999px;
  border: 1px solid rgba(24, 240, 255, 0.36);
  background: rgba(12, 61, 81, 0.32);
  color: #8ff3ff;
  font-size: 0.76rem;
  font-weight: 700;
}

.task-status-body {
  display: grid;
  gap: 10px;
  padding: 12px;
  min-width: 0;
}

.task-item {
  min-width: 0;
  border: none;
  border-radius: 12px;
  padding: 10px 12px;
  background: rgba(7, 20, 43, 0.52);
  box-shadow:
    0 8px 20px rgba(3, 8, 22, 0.44),
    inset 0 1px 0 rgba(190, 228, 255, 0.12);
}

.task-item + .task-item {
  margin-top: 0;
}

.task-item-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 76px;
  color: #7e9bbb;
  font-size: 0.88rem;
  text-align: center;
}

.task-item-card {
  overflow: hidden;
  padding: 0;
}

.task-item-details {
  min-width: 0;
}

.task-item-summary {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  cursor: pointer;
  list-style: none;
}

.task-item-summary::-webkit-details-marker {
  display: none;
}

.task-item-summary-main {
  min-width: 0;
  flex: 1 1 auto;
}

.task-item-title-line {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  min-width: 0;
}

.task-title,
.task-meta,
.task-id,
.task-description,
.task-notes {
  min-width: 0;
  overflow-wrap: anywhere;
}

.task-title {
  margin: 0;
  color: #effbff;
  font-weight: 700;
}

.task-date {
  flex: 0 0 auto;
  color: #8ff3ff;
  font-size: 0.75rem;
  white-space: nowrap;
}

.task-id,
.task-meta {
  margin: 6px 0 0;
}

.task-description-preview {
  margin: 8px 0 0;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
}

.task-expand-toggle {
  flex: 0 0 auto;
  align-self: center;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 92px;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(24, 240, 255, 0.28);
  background: rgba(9, 32, 62, 0.72);
  color: #c9f3ff;
  font-size: 0.76rem;
}

.task-expand-label-open {
  display: none;
}

.task-item-details[open] .task-expand-label-closed {
  display: none;
}

.task-item-details[open] .task-expand-label-open {
  display: inline;
}

.task-item-content {
  display: grid;
  gap: 10px;
  padding: 0 12px 12px;
  border-top: 1px solid rgba(90, 153, 240, 0.18);
}

.task-item-actions {
  display: flex;
  justify-content: flex-end;
  padding-top: 10px;
}

.task-description-full,
.task-notes {
  margin: 0;
  white-space: pre-wrap;
}

.task-item-button {
  justify-self: start;
  border: 1px solid rgba(24, 240, 255, 0.24);
  border-radius: 999px;
  padding: 8px 12px;
  background: rgba(10, 28, 60, 0.74);
  color: inherit;
  text-align: left;
  cursor: pointer;
  transition:
    transform 150ms ease,
    box-shadow 180ms ease,
    border-color 180ms ease,
    background 180ms ease;
}

.task-item-button:hover,
.task-item-button:focus-visible,
.task-item-summary:hover,
.task-item-summary:focus-visible {
  box-shadow:
    0 12px 26px rgba(2, 11, 28, 0.56),
    0 0 0 1px rgba(24, 240, 255, 0.28),
    inset 0 1px 0 rgba(216, 242, 255, 0.16);
  background: rgba(10, 28, 60, 0.74);
  outline: none;
}

.task-item-button:hover,
.task-item-button:focus-visible {
  transform: translateY(-1px);
}

.report-box {
  margin-top: 4px;
  max-height: 290px;
  overflow: auto;
  border: none;
  border-radius: 12px;
  background: rgba(2, 13, 31, 0.72);
  color: #dcf9ff;
  padding: 12px;
  font-size: 0.86rem;
  line-height: 1.45;
  white-space: pre-wrap;
  box-shadow:
    inset 0 1px 0 rgba(182, 226, 255, 0.1),
    inset 0 -12px 20px rgba(1, 5, 16, 0.45);
}

.report-history-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 8px;
}

.report-history-item {
  border-radius: 12px;
  background: rgba(3, 13, 31, 0.58);
  box-shadow:
    inset 0 1px 0 rgba(182, 226, 255, 0.1),
    0 8px 20px rgba(3, 8, 22, 0.38);
  padding: 10px;
}

.report-history-item summary {
  cursor: pointer;
  list-style: none;
  font-weight: 700;
  color: #def8ff;
}

.report-history-item summary::-webkit-details-marker {
  display: none;
}

.report-history-item .meta {
  margin-top: 6px;
}

.report-history-item pre {
  margin-top: 8px;
  max-height: 260px;
}

.run-status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 88px;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(116, 188, 255, 0.34);
  background: rgba(10, 27, 55, 0.72);
  color: #dcf6ff;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.run-status-badge.success {
  border-color: rgba(58, 224, 166, 0.48);
  color: #9bf8d1;
  background: rgba(8, 52, 42, 0.58);
}

.run-status-badge.warning {
  border-color: rgba(255, 207, 102, 0.48);
  color: #ffe29b;
  background: rgba(68, 44, 9, 0.58);
}

.run-status-badge.skipped {
  border-color: rgba(141, 157, 184, 0.44);
  color: #d5deee;
  background: rgba(27, 34, 48, 0.62);
}

.run-status-badge.error {
  border-color: rgba(255, 107, 138, 0.5);
  color: #ffbdd0;
  background: rgba(69, 18, 33, 0.58);
}

.run-status-badge.running {
  border-color: rgba(102, 196, 255, 0.48);
  color: #a5e4ff;
  background: rgba(12, 47, 79, 0.58);
}

.run-status-badge.unknown {
  border-color: rgba(173, 151, 255, 0.46);
  color: #ddd0ff;
  background: rgba(40, 22, 72, 0.58);
}

.panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.file-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
}

.editor {
  margin-top: 10px;
  width: 100%;
  min-height: 300px;
  resize: vertical;
  border: none;
  border-radius: 12px;
  padding: 12px;
  background: rgba(3, 13, 30, 0.72);
  color: #d3f3ff;
  font-family: "JetBrains Mono", "Consolas", "Monaco", monospace;
  font-size: 0.9rem;
  box-shadow:
    inset 0 1px 0 rgba(182, 226, 255, 0.1),
    inset 0 -12px 20px rgba(1, 5, 16, 0.45);
}

.task-grid {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.task-column {
  border: 1px solid rgba(95, 145, 230, 0.44);
  border-radius: 12px;
  background: rgba(6, 18, 40, 0.7);
  padding: 10px;
}

.task-title {
  margin: 0;
  font-weight: 700;
  color: #e3f8ff;
}

.task-description {
  margin: 8px 0 0;
  color: #d3e7f7;
  line-height: 1.45;
}

.task-notes {
  margin: 8px 0 0;
  color: #9ec7e9;
}

.task-form {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.task-form label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 0.92rem;
}

.task-form textarea,
.task-form select,
.task-form input,
.file-toolbar select {
  border: 1px solid rgba(80, 151, 252, 0.4);
  border-radius: 10px;
  padding: 8px 10px;
  background: rgba(4, 15, 35, 0.92);
  color: #d3f3ff;
}

.task-form button {
  width: fit-content;
  padding: 10px 16px;
}

.report-grid {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.report-card {
  border: 1px solid rgba(95, 145, 230, 0.44);
  border-radius: 12px;
  background: rgba(6, 18, 40, 0.7);
  padding: 12px;
}

.primary,
.secondary {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  border-radius: 999px;
  min-height: 38px;
  padding: 0 16px;
  cursor: pointer;
  border: none;
  font-family: "Orbitron", "Rajdhani", sans-serif;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  text-shadow: 0 0 8px rgba(210, 247, 255, 0.45);
  transform: translateZ(0);
  transition:
    transform 170ms ease,
    box-shadow 180ms ease,
    filter 180ms ease;
}

.primary::before,
.secondary::before {
  content: "";
  position: absolute;
  top: -55%;
  left: -32%;
  width: 46%;
  height: 210%;
  background: linear-gradient(
    120deg,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.78) 50%,
    rgba(255, 255, 255, 0) 100%
  );
  transform: translateX(-220%) skewX(-16deg);
  opacity: 0;
  pointer-events: none;
  z-index: 3;
}

.primary::after,
.secondary::after {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  pointer-events: none;
  z-index: 2;
  opacity: 0.55;
  background:
    linear-gradient(90deg, rgba(31, 243, 255, 0) 0%, rgba(31, 243, 255, 0.35) 50%, rgba(31, 243, 255, 0) 100%)
      top / 100% 1px no-repeat,
    linear-gradient(90deg, rgba(255, 66, 203, 0) 0%, rgba(255, 66, 203, 0.3) 50%, rgba(255, 66, 203, 0) 100%)
      bottom / 100% 1px no-repeat;
}

.primary {
  color: var(--btn-text);
  background:
    linear-gradient(130deg, rgba(22, 165, 238, 0.96), rgba(58, 86, 255, 0.96)),
    linear-gradient(90deg, rgba(31, 243, 255, 0.15), rgba(255, 66, 203, 0.14));
  box-shadow:
    0 0 20px rgba(31, 243, 255, 0.32),
    0 0 30px rgba(74, 141, 255, 0.22),
    inset 0 1px 0 rgba(227, 248, 255, 0.34);
}

.secondary {
  color: #d6f2ff;
  background:
    linear-gradient(
      130deg,
      rgba(9, 26, 58, 0.9),
      rgba(11, 35, 76, 0.86) 52%,
      rgba(26, 22, 72, 0.86)
    );
  box-shadow:
    0 0 16px rgba(31, 243, 255, 0.16),
    0 0 24px rgba(255, 66, 203, 0.12),
    inset 0 1px 0 rgba(215, 238, 255, 0.2);
}

.primary:hover,
.primary:focus-visible,
.secondary:hover,
.secondary:focus-visible {
  transform: translateY(-1px);
  filter: brightness(1.12) saturate(1.12);
  box-shadow:
    0 0 22px rgba(31, 243, 255, 0.42),
    0 0 34px rgba(255, 66, 203, 0.2),
    inset 0 1px 0 rgba(227, 248, 255, 0.4);
  outline: none;
  animation: cyber-btn-flicker 1400ms steps(8, end) infinite;
}

.primary:hover::before,
.primary:focus-visible::before,
.secondary:hover::before,
.secondary:focus-visible::before {
  opacity: 0.95;
  animation: cyber-btn-scan 780ms linear infinite;
}

.primary:active,
.secondary:active {
  transform: translateY(0);
  filter: brightness(0.97);
}

@keyframes cyber-btn-scan {
  0% {
    transform: translateX(-220%) skewX(-16deg);
  }
  100% {
    transform: translateX(410%) skewX(-16deg);
  }
}

@keyframes cyber-btn-flicker {
  0%,
  100% {
    text-shadow:
      0 0 8px rgba(210, 247, 255, 0.45),
      0 0 12px rgba(31, 243, 255, 0.36);
  }
  35% {
    text-shadow:
      1px 0 0 rgba(255, 66, 203, 0.38),
      -1px 0 0 rgba(31, 243, 255, 0.4),
      0 0 14px rgba(74, 141, 255, 0.34);
  }
  55% {
    text-shadow:
      -1px 0 0 rgba(255, 66, 203, 0.34),
      1px 0 0 rgba(31, 243, 255, 0.38),
      0 0 10px rgba(31, 243, 255, 0.34);
  }
}

.status-line {
  margin-top: 10px;
  padding: 8px 10px;
  border-radius: 9px;
  font-size: 0.88rem;
  background: rgba(18, 35, 67, 0.75);
  color: #9ec5ff;
  border: 1px solid rgba(92, 141, 224, 0.38);
}

.status-line.success {
  background: var(--ok-bg);
  color: var(--ok-text);
  border-color: rgba(78, 232, 165, 0.4);
}

.status-line.error {
  background: var(--error-bg);
  color: var(--error-text);
  border-color: rgba(235, 79, 116, 0.45);
}

@media (max-width: 1040px) {
  .detail-hero {
    grid-template-columns: 1fr;
  }

  .archimeta-grid {
    grid-template-columns: 1fr;
  }

  .archimeta-drilldown {
    grid-template-columns: 1fr;
  }

  .zone-map {
    grid-template-columns: 1fr;
  }

  .report-grid {
    grid-template-columns: 1fr;
  }

  .task-grid {
    grid-template-columns: 1fr;
  }

  .agent-card-grid {
    grid-template-columns: 1fr;
  }

  .agent-card-media {
    height: clamp(340px, 52vh, 600px);
  }

  .archimeta-entry {
    flex-direction: column;
  }

  .soundtrack-toggle-button {
    width: 100%;
    min-width: 0;
  }
}

@media (max-width: 720px) {
  .page {
    padding: 16px 12px 32px;
  }

  .panel {
    padding: 14px;
    border-radius: 14px;
  }

  .task-form {
    grid-template-columns: 1fr;
  }

  .agent-card-media {
    height: min(68vh, 560px);
  }

  .diagram-fullscreen {
    padding: 10px;
  }

  .diagram-fullscreen-panel {
    width: 100%;
    height: 100%;
    border-radius: 12px;
    padding: 10px;
  }
}
