/* ============================================================
   AI SOLUTIONS — mini-mock styles
   ============================================================ */

/* shared */
.aismck { padding: 14px; }

/* ---------- Agents ---------- */
.mock-agents { padding: 0; }
.mock-agents .ag-shell {
  position: absolute; inset: 14px;
  background: #06080d;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 10px;
  display: flex; flex-direction: column;
  overflow: hidden;
  font-family: 'JetBrains Mono','SF Mono',monospace;
}
.mock-agents .ag-bar {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 12px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.02);
}
.mock-agents .ag-dot { width: 8px; height: 8px; border-radius: 50%; }
.mock-agents .ag-r { background: #ff5f57; }
.mock-agents .ag-y { background: #febc2e; }
.mock-agents .ag-g { background: #28c840; }
.mock-agents .ag-title { margin-left: 10px; font-size: 11px; color: rgba(255,255,255,.55); letter-spacing: .04em; }
.mock-agents .ag-body { padding: 12px 14px; flex: 1; display: grid; align-content: start; gap: 6px; }
.mock-agents .ag-line {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 10px;
  font-size: 12px;
  align-items: baseline;
  opacity: .25;
  transition: opacity .35s ease;
}
.mock-agents .ag-line.on { opacity: 1; }
.mock-agents .ag-tag {
  font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
  padding: 2px 6px;
  border-radius: 4px;
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.7);
  text-align: center;
}
.mock-agents .ag-plan .ag-tag { background: rgba(0,85,255,.18); color: #8aa9ff; }
.mock-agents .ag-tool .ag-tag { background: rgba(244,183,64,.18); color: #f4b740; }
.mock-agents .ag-ok   .ag-tag { background: rgba(110,231,199,.18); color: #6ee7c7; }
.mock-agents .ag-done .ag-tag { background: rgba(110,231,199,.28); color: #6ee7c7; }
.mock-agents .ag-text { color: rgba(255,255,255,.85); font-size: 12px; }
.mock-agents .ag-cursor {
  width: 7px; height: 14px;
  background: var(--aisol-mint, #6ee7c7);
  margin-top: 2px;
  animation: ag-blink 1s steps(2) infinite;
}
@keyframes ag-blink { 50% { opacity: 0; } }

/* ---------- Automation (cinematic v2) ---------- */
.mock-auto2 {
  position: absolute; inset: 0;
  padding: 14px 16px 12px;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 10px;
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(0,85,255,.10), transparent 55%),
    radial-gradient(80% 60% at 100% 100%, rgba(110,231,199,.07), transparent 60%),
    #05070d;
  overflow: hidden;
  font-family: 'JetBrains Mono','SF Mono',monospace;
}
.mock-auto2 .ma2-vignette {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(120% 120% at 50% 50%, transparent 55%, rgba(0,0,0,.55) 100%);
}

/* HEADER */
.ma2-head {
  position: relative; z-index: 2;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 7px 11px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
  border-radius: 7px;
}
.ma2-live {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 10px; letter-spacing: .14em;
  color: #6ee7c7;
}
.ma2-live .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: #6ee7c7;
  box-shadow: 0 0 10px #6ee7c7;
  animation: ma2-pulse 1.6s ease-in-out infinite;
}
@keyframes ma2-pulse { 50% { opacity: .35; transform: scale(.85); } }
.ma2-runs {
  font-size: 13px; color: #fff; font-weight: 600;
  letter-spacing: .01em; text-align: center;
}
.ma2-runs em {
  font-style: normal; font-weight: 400;
  color: rgba(255,255,255,.45);
  font-size: 10px; letter-spacing: .14em;
  margin-left: 2px;
}
.ma2-spark {
  display: inline-flex; align-items: flex-end; gap: 2px;
  height: 22px; width: 84px;
  justify-self: end;
}
.ma2-spark span {
  flex: 1; background: linear-gradient(180deg, #6ee7c7, rgba(0,85,255,.5));
  border-radius: 1px;
  min-height: 2px;
  transition: height .6s cubic-bezier(.2,.7,.3,1);
}

/* TRACKS */
.ma2-tracks {
  position: relative; z-index: 2;
  display: grid; gap: 9px;
  align-content: center;
}
.ma2-track {
  display: grid;
  grid-template-columns: 44px 1fr;
  align-items: center;
  gap: 10px;
}
.ma2-track-tag {
  font-size: 9px; letter-spacing: .16em;
  color: rgba(255,255,255,.42);
  text-align: right;
  padding-right: 6px;
  border-right: 1px solid rgba(255,255,255,.08);
}
.ma2-rail {
  display: grid;
  grid-template-columns: 1fr 18px 1fr 18px 1fr 18px 1fr;
  align-items: center;
  gap: 0;
}
.ma2-node {
  position: relative;
  padding: 7px 9px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 5px;
  min-height: 28px;
  display: flex; align-items: center;
  transition: all .35s ease;
}
.ma2-node .lbl {
  font-size: 10.5px;
  color: rgba(255,255,255,.78);
  letter-spacing: .01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ma2-node.flash {
  border-color: rgba(0,85,255,.55);
  background: rgba(0,85,255,.10);
  box-shadow: 0 0 0 1px rgba(0,85,255,.25), 0 0 18px rgba(0,85,255,.35);
}
.ma2-node.flash .lbl { color: #fff; }

.ma2-link {
  position: relative;
  height: 28px;
  display: flex; align-items: center;
}
.ma2-link-line {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, rgba(255,255,255,.06), rgba(255,255,255,.18), rgba(255,255,255,.06));
}
.ma2-link-pulse {
  position: absolute;
  top: 50%;
  width: 12px; height: 6px;
  transform: translate(-50%, -50%);
  background: radial-gradient(ellipse, rgba(110,231,199,.95) 0%, rgba(0,85,255,.6) 40%, transparent 70%);
  filter: blur(.5px);
  transition: opacity .15s ease;
  pointer-events: none;
}

/* FEED */
.ma2-feed {
  position: relative; z-index: 2;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 14px;
}
.ma2-feed-lbl {
  font-size: 9px; letter-spacing: .16em;
  color: rgba(255,255,255,.4);
}
.ma2-feed-rows {
  display: flex; gap: 6px;
  overflow: hidden;
  flex-wrap: nowrap;
}
.ma2-feed-row {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 8px;
  border: 1px solid rgba(110,231,199,.25);
  background: rgba(110,231,199,.06);
  border-radius: 4px;
  font-size: 10px;
  color: rgba(255,255,255,.78);
  letter-spacing: .04em;
  animation: ma2-feed-in .35s cubic-bezier(.2,.7,.3,1);
  white-space: nowrap;
}
.ma2-feed-row.warn {
  border-color: rgba(244,183,64,.4);
  background: rgba(244,183,64,.08);
}
.ma2-feed-row .status {
  color: #6ee7c7;
  font-weight: 700;
}
.ma2-feed-row.warn .status { color: #f4b740; }
@keyframes ma2-feed-in {
  from { opacity: 0; transform: translateX(-8px); }
  to   { opacity: 1; transform: translateX(0); }
}

@media (max-width: 640px) {
  .ma2-track-tag { display: none; }
  .ma2-track { grid-template-columns: 1fr; }
  .ma2-feed { grid-template-columns: 1fr; }
  .ma2-feed-rows { flex-wrap: wrap; }
}

/* ---------- Automation (legacy v1, unused) ---------- */
.mock-auto { padding: 24px; flex-direction: column; gap: 18px; }
.mock-auto .auto-row {
  display: flex; align-items: center; gap: 8px;
  width: 100%;
  z-index: 1;
}
.mock-auto .auto-node {
  flex: 1;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px;
  padding: 10px 8px;
  text-align: center;
  transition: all .35s ease;
}
.mock-auto .auto-node.done {
  border-color: rgba(110,231,199,.4);
  background: rgba(110,231,199,.06);
}
.mock-auto .auto-node.on {
  border-color: var(--aisol-blue, #0055FF);
  background: rgba(0,85,255,.12);
  box-shadow: 0 0 0 4px rgba(0,85,255,.12);
}
.mock-auto .auto-node-l {
  font-size: 12px;
  color: #fff;
  font-weight: 600;
  letter-spacing: .02em;
}
.mock-auto .auto-node-s {
  font-size: 10px;
  color: rgba(255,255,255,.5);
  text-transform: uppercase;
  letter-spacing: .12em;
  margin-top: 3px;
}
.mock-auto .auto-edge {
  flex: 0 0 18px;
  height: 2px;
  background: rgba(255,255,255,.08);
  position: relative;
  overflow: hidden;
}
.mock-auto .auto-edge.flow::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, var(--aisol-blue, #0055FF), transparent);
  animation: auto-flow 1.2s linear infinite;
}
@keyframes auto-flow {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}
.mock-auto .auto-stats {
  display: flex; gap: 14px;
  font-size: 11px;
  color: rgba(255,255,255,.55);
  letter-spacing: .03em;
}

/* ---------- Voice ---------- */
.mock-voice { padding: 18px; flex-direction: column; gap: 10px; align-items: stretch; justify-content: flex-start; }
.mock-voice .voice-call {
  display: grid;
  grid-template-columns: 32px 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
}
.mock-voice .voice-avatar {
  width: 32px; height: 32px;
  display: grid; place-items: center;
  background: rgba(0,85,255,.18);
  border-radius: 50%;
  color: #8aa9ff;
}
.mock-voice .voice-name { font-size: 12px; color: #fff; font-family: -apple-system,Segoe UI,Inter,sans-serif; font-weight: 500; }
.mock-voice .voice-time { font-size: 10px; color: rgba(255,255,255,.5); margin-top: 2px; font-family: -apple-system,Segoe UI,Inter,sans-serif; }
.mock-voice .voice-meta { line-height: 1.3; }
.mock-voice .voice-wave {
  display: flex; gap: 2px; align-items: center; height: 24px;
}
.mock-voice .voice-wave span {
  display: block;
  width: 2px;
  background: var(--aisol-mint, #6ee7c7);
  border-radius: 1px;
  animation: voice-wave 1s ease-in-out infinite alternate;
}
@keyframes voice-wave {
  0% { height: 4px; }
  100% { height: 18px; }
}
.mock-voice .voice-wave span:nth-child(odd) { animation-duration: .85s; }
.mock-voice .voice-wave span:nth-child(3n)  { animation-duration: 1.15s; }

.mock-voice .voice-bubble {
  font-family: -apple-system,Segoe UI,Inter,sans-serif;
  font-size: 12px;
  padding: 8px 12px;
  border-radius: 12px;
  max-width: 80%;
  line-height: 1.4;
}
.mock-voice .v-them {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.07);
  color: rgba(255,255,255,.85);
  align-self: flex-start;
  border-bottom-left-radius: 4px;
}
.mock-voice .v-me {
  background: var(--aisol-blue, #0055FF);
  color: #fff;
  align-self: flex-end;
  border-bottom-right-radius: 4px;
}

/* ---------- Vision ---------- */
.mock-vision { padding: 14px; }
.mock-vision .vision-frame {
  position: absolute; inset: 14px;
  background:
    radial-gradient(ellipse at 30% 40%, rgba(0,85,255,.18), transparent 60%),
    linear-gradient(180deg, #0a1422 0%, #06090f 100%);
  border-radius: 8px;
  overflow: hidden;
}
/* warehouse floor perspective */
.mock-vision .vision-floor {
  position: absolute; left: 0; right: 0; bottom: 0;
  height: 38%;
  background:
    linear-gradient(180deg, transparent 0%, rgba(0,0,0,.35) 100%),
    repeating-linear-gradient(90deg, transparent 0 28px, rgba(255,255,255,.03) 28px 30px);
  transform: perspective(220px) rotateX(48deg);
  transform-origin: bottom;
}
.mock-vision .vision-bay {
  position: absolute;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0));
  border-top: 1px solid rgba(255,255,255,.06);
  border-left: 1px solid rgba(255,255,255,.04);
}
.mock-vision .v-bay-1 { left: 5%; top: 18%; width: 14%; height: 32%; }
.mock-vision .v-bay-2 { left: 86%; top: 22%; width: 10%; height: 26%; }
.mock-vision .v-bay-3 { left: 38%; top: 14%; width: 8%; height: 22%; }
.mock-vision .vision-pallet {
  position: absolute;
  left: 8%; bottom: 18%;
  width: 16%; height: 8%;
  background: repeating-linear-gradient(90deg, #2a1f10 0 4px, #3a2c18 4px 7px);
  border: 1px solid rgba(0,0,0,.4);
  border-radius: 1px;
  box-shadow: 0 4px 0 rgba(0,0,0,.4);
}
.mock-vision .vision-fig {
  position: absolute;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,.5));
}
.mock-vision .vfig-person {
  top: 30%; left: 21%; width: 14%; height: 38%;
}
.mock-vision .vfig-forklift {
  top: 44%; left: 52%; width: 26%; height: 28%;
}
.mock-vision .vfig-person2 {
  top: 24%; left: 67%; width: 12%; height: 28%;
}
.mock-vision .vision-corner {
  position: absolute; width: 22px; height: 22px;
  border: 2px solid rgba(110,231,199,.55);
}
.mock-vision .vision-corner.tl { top: 10px; left: 10px; border-right: 0; border-bottom: 0; }
.mock-vision .vision-corner.tr { top: 10px; right: 10px; border-left: 0; border-bottom: 0; }
.mock-vision .vision-corner.bl { bottom: 10px; left: 10px; border-right: 0; border-top: 0; }
.mock-vision .vision-corner.br { bottom: 10px; right: 10px; border-left: 0; border-top: 0; }
.mock-vision .vision-scanline {
  position: absolute;
  left: 6%; right: 6%;
  top: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(110,231,199,.5), transparent);
  animation: vision-scan 4s linear infinite;
}
@keyframes vision-scan {
  0% { top: 6%; }
  50% { top: 90%; }
  100% { top: 6%; }
}
.mock-vision .vision-meta {
  position: absolute; left: 14px; bottom: 14px;
  font-size: 10px; color: rgba(255,255,255,.7);
  display: flex; align-items: center; gap: 6px;
  letter-spacing: .05em;
}
.mock-vision .rec {
  width: 6px; height: 6px; border-radius: 50%;
  background: #ff5f57;
  animation: vision-rec 1.2s ease-in-out infinite;
}
@keyframes vision-rec { 50% { opacity: .3; } }

.mock-vision .vision-box {
  position: absolute;
  border: 1.5px solid rgba(110,231,199,.85);
  background: rgba(110,231,199,.04);
  border-radius: 2px;
}
.mock-vision .vision-box span {
  position: absolute;
  bottom: 100%;
  left: 0;
  background: rgba(110,231,199,.95);
  color: #06090f;
  font-size: 9px;
  font-weight: 600;
  padding: 1px 6px;
  letter-spacing: .03em;
  white-space: nowrap;
  border-radius: 2px 2px 0 0;
}
.mock-vision .vb-1 { top: 28%; left: 18%; width: 22%; height: 42%; }
.mock-vision .vb-2 { top: 42%; left: 50%; width: 30%; height: 32%; }
.mock-vision .vb-3 {
  top: 22%; left: 65%; width: 18%; height: 30%;
  border-color: rgba(244,87,87,.9);
  background: rgba(244,87,87,.06);
}
.mock-vision .vb-3 span { background: rgba(244,87,87,.95); color: #fff; }

/* ---------- LLM ---------- */
.mock-llm { padding: 14px; }
.mock-llm {
  display: grid !important;
  grid-template-columns: 1.4fr 1fr;
  gap: 10px;
  padding: 14px !important;
  align-items: stretch !important;
}
.mock-llm .llm-doc {
  background: #fff;
  color: #0a0d14;
  border-radius: 6px;
  padding: 14px;
  display: grid;
  gap: 6px;
  align-content: start;
  font-family: -apple-system,Segoe UI,Inter,sans-serif;
}
.mock-llm .llm-doc-title {
  font-size: 10px; letter-spacing: .12em; text-transform: uppercase;
  color: rgba(10,13,20,.5);
  margin-bottom: 6px;
}
.mock-llm .llm-line {
  height: 6px;
  background: rgba(10,13,20,.08);
  border-radius: 2px;
  position: relative;
}
.mock-llm .llm-line.w-90 { width: 90%; }
.mock-llm .llm-line.w-95 { width: 95%; }
.mock-llm .llm-line.w-92 { width: 92%; }
.mock-llm .llm-line.w-88 { width: 88%; }
.mock-llm .llm-line.w-85 { width: 85%; }
.mock-llm .llm-line.w-80 { width: 80%; }
.mock-llm .llm-line.w-78 { width: 78%; }
.mock-llm .llm-h {
  position: absolute; inset: -2px -4px;
  border-radius: 3px;
  font-size: 9px; font-weight: 600;
  padding: 2px 6px;
  width: max-content;
  display: inline-flex; align-items: center;
}
.mock-llm .h-blue { background: rgba(0,85,255,.18); color: #0055FF; left: 8%; right: auto; }
.mock-llm .h-amber { background: rgba(244,183,64,.22); color: #b87f00; left: 12%; right: auto; }
.mock-llm .h-mint { background: rgba(110,231,199,.32); color: #0a6e51; left: 4%; right: auto; }

.mock-llm .llm-side {
  background: #06080d;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 6px;
  padding: 10px;
  display: grid; gap: 6px;
  align-content: start;
}
.mock-llm .llm-side-head {
  font-size: 10px; letter-spacing: .12em; text-transform: uppercase;
  color: rgba(255,255,255,.5);
}
.mock-llm .llm-msg {
  font-family: -apple-system,Segoe UI,Inter,sans-serif;
  font-size: 11px;
  line-height: 1.45;
  color: rgba(255,255,255,.85);
  padding: 8px 10px;
  background: rgba(0,85,255,.14);
  border: 1px solid rgba(0,85,255,.32);
  border-radius: 6px;
}

/* ---------- Infra ---------- */
.mock-infra { padding: 18px; }
.mock-infra .infra-stack {
  display: grid; gap: 6px;
  width: 100%;
  z-index: 1;
}
.mock-infra .infra-row {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 8px 10px;
  border-radius: 8px;
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(255,255,255,.06);
  justify-content: center;
}
.mock-infra .infra-pill {
  font-family: -apple-system,Segoe UI,Inter,sans-serif;
  font-size: 11px;
  padding: 4px 9px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.85);
}
.mock-infra .r-surface .infra-pill { border-color: rgba(110,231,199,.32); background: rgba(110,231,199,.08); }
.mock-infra .r-orch    .infra-pill { border-color: rgba(0,85,255,.32);   background: rgba(0,85,255,.08); }
.mock-infra .r-data    .infra-pill { border-color: rgba(244,183,64,.28); background: rgba(244,183,64,.08); }
.mock-infra .r-model .infra-pill.model { font-family: 'JetBrains Mono','SF Mono',monospace; font-size: 10.5px; }
.mock-infra .r-cloud .infra-pill.cloud { font-family: 'JetBrains Mono','SF Mono',monospace; font-size: 10.5px; }
