/* Phase 68: Spatial full-surface restore + visual mode workspace */

#spatial-app .svx-shell {
  position: absolute;
  top: 74px;
  right: 16px;
  z-index: 640;
  width: min(420px, calc(100vw - 32px));
  display: grid;
  gap: 10px;
  pointer-events: none;
}

#spatial-app .svx-shell * {
  box-sizing: border-box;
}

#spatial-app .svx-panel,
#spatial-app .svx-ledger {
  pointer-events: auto;
  border-radius: 20px;
  border: 1px solid rgba(120, 86, 38, .18);
  background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(246,240,228,.95));
  box-shadow: 0 18px 44px rgba(43, 28, 10, .16);
  backdrop-filter: blur(12px);
}

#spatial-app .svx-panel {
  padding: 14px;
}

#spatial-app .svx-kicker {
  font-size: .65rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-weight: 900;
  color: #9a5b18;
}

#spatial-app .svx-title {
  margin: 5px 0 6px;
  color: #2d1c0d;
  font-size: 1rem;
  font-weight: 900;
}

#spatial-app .svx-copy {
  color: #6b5948;
  font-size: .76rem;
  line-height: 1.45;
}

#spatial-app .svx-tabs,
#spatial-app .svx-tools,
#spatial-app .svx-stats,
#spatial-app .svx-palette,
#spatial-app .svx-legend {
  display: grid;
  gap: 8px;
}

#spatial-app .svx-tabs {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 12px;
}

#spatial-app .svx-tab,
#spatial-app .svx-tool,
#spatial-app .svx-pin-btn,
#spatial-app .svx-row-btn {
  min-height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(121, 88, 48, .16);
  background: rgba(255,255,255,.88);
  color: #3f2917;
  font: inherit;
  font-size: .72rem;
  font-weight: 900;
  cursor: pointer;
}

#spatial-app .svx-tab.active,
#spatial-app .svx-tool.active,
#spatial-app .svx-pin-btn.active,
#spatial-app .svx-row-btn.active {
  background: #1f1812;
  color: #fff7df;
}

#spatial-app .svx-tools {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 10px;
}

#spatial-app .svx-stats {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 10px;
}

#spatial-app .svx-stat {
  border-radius: 14px;
  padding: 10px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(121, 88, 48, .14);
  text-align: center;
}

#spatial-app .svx-stat strong {
  display: block;
  color: #2f1f11;
  font-size: 1rem;
}

#spatial-app .svx-stat span {
  color: #7a6854;
  font-size: .68rem;
}

#spatial-app .svx-body {
  display: none;
  margin-top: 12px;
}

#spatial-app .svx-body.active {
  display: block;
}

#spatial-app .svx-palette {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

#spatial-app .svx-pin-btn {
  display: grid;
  place-items: center;
  padding: 10px;
  min-height: 58px;
  text-align: center;
}

#spatial-app .svx-pin-btn small {
  display: block;
  margin-top: 3px;
  font-size: .62rem;
  font-weight: 700;
  opacity: .72;
}

#spatial-app .svx-hint {
  margin-top: 10px;
  border-radius: 12px;
  padding: 10px;
  background: #fff8ea;
  border: 1px solid rgba(145, 96, 32, .16);
  color: #7a634d;
  font-size: .72rem;
  line-height: 1.4;
}

#spatial-app .svx-ledger {
  max-height: 46vh;
  overflow: auto;
  padding: 12px;
}

#spatial-app .svx-ledger-head {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: center;
  margin-bottom: 8px;
}

#spatial-app .svx-ledger-title {
  color: #2f1f11;
  font-size: .82rem;
  font-weight: 900;
}

#spatial-app .svx-ledger-sub {
  color: #7b6750;
  font-size: .68rem;
}

#spatial-app .svx-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  padding: 10px 0;
  border-top: 1px dashed rgba(121, 88, 48, .16);
}

#spatial-app .svx-row:first-of-type {
  border-top: none;
}

#spatial-app .svx-row strong {
  display: block;
  color: #2d1c0d;
  font-size: .75rem;
}

#spatial-app .svx-row span {
  display: block;
  margin-top: 3px;
  color: #7a634d;
  font-size: .67rem;
}

#spatial-app .svx-row-actions {
  display: flex;
  gap: 6px;
}

#spatial-app .svx-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 8px;
  border-radius: 999px;
  background: #fff6dc;
  border: 1px solid rgba(145, 96, 32, .16);
  color: #7b4c12;
  font-size: .66rem;
  font-weight: 900;
}

#spatial-app .svx-system-list {
  display: grid;
  gap: 8px;
}

#spatial-app .svx-form-card {
  margin-bottom: 10px;
  padding: 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.74);
  border: 1px solid rgba(121, 88, 48, .14);
}

#spatial-app .svx-form-head strong {
  display: block;
  color: #2d1c0d;
  font-size: .78rem;
}

#spatial-app .svx-form-head span {
  display: block;
  margin-top: 4px;
  color: #7a634d;
  font-size: .68rem;
}

#spatial-app .svx-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 10px;
}

#spatial-app .svx-field {
  display: grid;
  gap: 4px;
  color: #7a634d;
  font-size: .68rem;
}

#spatial-app .svx-field input,
#spatial-app .svx-field select {
  min-height: 36px;
  border-radius: 12px;
  border: 1px solid rgba(121, 88, 48, .16);
  background: rgba(255,255,255,.9);
  color: #312013;
  padding: 0 10px;
  font: inherit;
}

#spatial-app .svx-system {
  border-radius: 14px;
  padding: 10px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(121, 88, 48, .14);
}

#spatial-app .svx-system strong {
  display: block;
  color: #2d1c0d;
  font-size: .74rem;
}

#spatial-app .svx-system span {
  display: block;
  margin-top: 4px;
  color: #7a634d;
  font-size: .68rem;
}

#spatial-app .idt[data-svx-kind] {
  box-shadow: 0 18px 34px rgba(49, 30, 12, .18);
  border-width: 2px;
}

#spatial-app .idt[data-svx-kind="generator"] { border-color: rgba(245,158,11,.65); }
#spatial-app .idt[data-svx-kind="camera"] { border-color: rgba(59,130,246,.62); }
#spatial-app .idt[data-svx-kind="talent"] { border-color: rgba(236,72,153,.62); }
#spatial-app .idt[data-svx-kind="lighting"] { border-color: rgba(250,204,21,.62); }
#spatial-app .idt[data-svx-kind="sound"] { border-color: rgba(16,185,129,.62); }
#spatial-app .idt[data-svx-kind="basecamp"] { border-color: rgba(139,92,246,.62); }
#spatial-app .idt[data-svx-kind="vehicle"] { border-color: rgba(99,102,241,.62); }
#spatial-app .idt[data-svx-kind="hazard"] { border-color: rgba(239,68,68,.62); }
#spatial-app .idt[data-svx-kind="note"] { border-color: rgba(34,197,94,.62); }

#spatial-app .idt.svx-locate {
  animation: svxPulse 1s ease 2;
}

@keyframes svxPulse {
  0% { transform: scale(1); box-shadow: 0 0 0 0 rgba(255,176,64,.45); }
  50% { transform: scale(1.04); box-shadow: 0 0 0 14px rgba(255,176,64,0); }
  100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(255,176,64,0); }
}

body.svx-layer-visual #scc-canvas {
  background-image:
    radial-gradient(circle at 15% 20%, rgba(255,255,255,.06), transparent 18%),
    radial-gradient(circle at 80% 70%, rgba(255,255,255,.04), transparent 18%),
    repeating-linear-gradient(var(--scc-grid) 0 1px, transparent 1px 100%),
    repeating-linear-gradient(90deg, var(--scc-grid) 0 1px, transparent 1px 100%);
}

body.svx-layer-visual #scc-binder::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.08)),
    radial-gradient(circle at center, rgba(252,211,77,.06), transparent 38%);
  z-index: 2;
}

body.svx-layer-systems #scc-chain-ledger {
  display: block !important;
}

.svx-path-line {
  position: absolute;
  height: 6px;
  transform-origin: 0 50%;
  border-radius: 999px;
  background: repeating-linear-gradient(90deg, rgba(233,126,31,.96) 0 16px, rgba(255,225,184,.92) 16px 24px);
}

.svx-path-marker {
  position: absolute;
  width: 20px;
  height: 20px;
  margin-left: -10px;
  margin-top: -10px;
  border-radius: 999px;
  background: #fff7df;
  border: 4px solid #e97e1f;
  filter: drop-shadow(0 6px 12px rgba(56,29,4,.24));
}

#svx-path-overlay {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
}

body.dark #spatial-app .svx-panel,
body.dark #spatial-app .svx-ledger,
body.dark #spatial-app .svx-stat,
body.dark #spatial-app .svx-system {
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.08);
}

body.dark #spatial-app .svx-title,
body.dark #spatial-app .svx-ledger-title,
body.dark #spatial-app .svx-row strong,
body.dark #spatial-app .svx-system strong,
body.dark #spatial-app .svx-stat strong {
  color: #f7e7cf;
}

body.dark #spatial-app .svx-copy,
body.dark #spatial-app .svx-ledger-sub,
body.dark #spatial-app .svx-row span,
body.dark #spatial-app .svx-system span,
body.dark #spatial-app .svx-stat span,
body.dark #spatial-app .svx-hint {
  color: #ead6bb;
}

body.dark #spatial-app .svx-tab,
body.dark #spatial-app .svx-tool,
body.dark #spatial-app .svx-pin-btn,
body.dark #spatial-app .svx-row-btn {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.1);
  color: #f7e7cf;
}

@media (max-width: 920px) {
  #spatial-app .svx-shell {
    width: min(360px, calc(100vw - 20px));
    right: 10px;
    top: 68px;
  }
}

@media (max-width: 640px) {
  #spatial-app .svx-shell {
    left: 10px;
    right: 10px;
    width: auto;
    top: 62px;
    bottom: calc(126px + env(safe-area-inset-bottom, 0px));
  }

  #spatial-app .svx-ledger {
    max-height: none;
  }

  #spatial-app .svx-tabs,
  #spatial-app .svx-tools,
  #spatial-app .svx-stats,
  #spatial-app .svx-palette {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  #spatial-app .svx-form-grid {
    grid-template-columns: 1fr;
  }
}
