/* ─── TOKENS ─────────────────────────────────────────────── */
:root {
  color-scheme: dark;
  --bg-0: #040810;
  --bg-1: #081420;
  --bg-2: #0c1828;
  --glass-0: rgba(8, 16, 32, 0.68);
  --glass-1: rgba(10, 20, 38, 0.76);
  --glass-2: rgba(12, 24, 42, 0.82);
  --ink: #d8e4f4;
  --muted: #7a94ae;
  --dim: #5e8098;
  --edge: rgba(255, 255, 255, 0.11);
  --edge-hi: rgba(255, 255, 255, 0.16);
  --refract-top: rgba(255, 255, 255, 0.10);
  --spot: rgba(255, 255, 255, 0);
  --cyan: #79e8ff;
  --blue: #6fa6ff;
  --violet: #a88eff;
  --green: #72f2a8;
  --amber: #ffd077;
  --rose: #ff637e;
  --glow-c: rgba(121, 232, 255, 0.18);
  --glow-v: rgba(168, 142, 255, 0.14);
  --breathe-a: rgba(148, 188, 228, 0.05);
  --breathe-b: rgba(148, 188, 228, 0.10);
  --breathe-c: rgba(148, 188, 228, 0.16);
  --breathe-line: rgba(148, 188, 228, 0.22);
  --mono: "SF Mono", "Menlo", "Consolas", monospace;
  --sans: "Avenir Next", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}
/* ─── RESET ──────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { min-height: 100%; font-family: var(--sans); color: var(--ink); background-color: var(--bg-0); touch-action: manipulation; -webkit-tap-highlight-color: transparent; }
button, input { font: inherit; cursor: pointer; }
input { cursor: text; }
b, strong { font-weight: 700; }

/* ─── BACKGROUND ─────────────────────────────────────────── */
body {
  background: var(--bg-0);
  overflow-x: hidden;
}
/* grid texture */
body::before {
  content: "";
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background:
    linear-gradient(var(--edge) 1px, transparent 1px),
    linear-gradient(90deg, var(--edge) 1px, transparent 1px);
  background-size: 40px 40px;
  mask-image: radial-gradient(ellipse 100% 80% at center, black 30%, transparent 80%);
}
/* diagonal glint */
body::after {
  content: "";
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background: linear-gradient(112deg,
    transparent 0%, transparent 40%,
    rgba(255,255,255,0.025) 40.4%,
    transparent 40.8%,
    transparent 100%);
}

/* ─── AURORA — soft breathe glow (single hue) ─────────────── */
.aurora {
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  overflow: hidden;
}
.aurora span {
  position: absolute;
  width: 140px;
  top: -15%;
  border-radius: 999px;
  will-change: transform, opacity;
  filter: blur(12px);
  background: linear-gradient(180deg, transparent, var(--breathe-b), transparent);
  animation: breatheGlow 9s ease-in-out infinite;
}
.aurora span:nth-child(1) { left: 22%; height: 62vh; animation-delay: 0s; }
.aurora span:nth-child(2) { left: 50%; height: 72vh; animation-delay: -3s; }
.aurora span:nth-child(3) { left: 78%; height: 58vh; animation-delay: -6s; }
@keyframes breatheGlow {
  0%, 100% { opacity: 0.20; transform: translateY(0) scaleX(1); }
  50%      { opacity: 0.35; transform: translateY(2%) scaleX(1.04); }
}

/* ─── GLASS MIXIN ────────────────────────────────────────── */
.glass {
  position: relative; overflow: hidden;
  background:
    radial-gradient(circle at var(--mx,50%) var(--my,0%), var(--spot), transparent 36%),
    linear-gradient(155deg, rgba(255,255,255,0.03) 0%, rgba(255,255,255,0.01) 45%, transparent 100%),
    var(--glass-0);
  border: 1px solid var(--edge);
  border-top-color: var(--edge-hi);
  backdrop-filter: blur(12px) saturate(140%) brightness(0.60);
  -webkit-backdrop-filter: blur(12px) saturate(140%) brightness(0.60);
  box-shadow:
    inset 0 1px 0 var(--refract-top),
    0 4px 32px rgba(0,0,0,0.20),
    0 0 0 0.5px rgba(255,255,255,0.04);
  border-radius: 26px;
  transition: box-shadow 280ms var(--ease);
}
/* top edge highlight */
.glass::after {
  content: "";
  position: absolute; left: 10%; right: 10%; top: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--refract-top) 30%, rgba(255,255,255,0.18) 50%, var(--refract-top) 70%, transparent);
  pointer-events: none;
}
/* inner rim */
.glass::before {
  content: "";
  position: absolute; inset: 1px; border-radius: inherit;
  border: 1px solid rgba(255,255,255,0.04);
  pointer-events: none;
  background: linear-gradient(145deg, rgba(255,255,255,0.03), transparent 40%);
}

/* ─── LAYOUT ─────────────────────────────────────────────── */
.screen {
  position: relative; z-index: 1;
  width: min(1540px, calc(100vw - 28px));
  min-height: calc(100vh - 28px);
  margin: 14px auto;
  display: grid;
  grid-template-columns: 252px minmax(740px, 1fr) 380px;
  grid-template-rows: auto 1fr;
  gap: 13px;
  padding-bottom: 150px;
}

/* ─── FLOATING ORBs — soft breathe ───────────────────────── */
.orb {
  position: fixed; border-radius: 999px; pointer-events: none; z-index: 0;
  animation: breatheOrb 11s ease-in-out infinite;
  opacity: 0.20;
  background: radial-gradient(circle, var(--breathe-b), transparent 68%);
  filter: blur(2px);
  will-change: transform, opacity;
}
.orb:nth-child(1) {
  width: 220px; height: 220px; right: 26%; top: 6%;
  animation-delay: 0s;
}
.orb:nth-child(2) {
  width: 280px; height: 280px; left: 14%; bottom: 10%;
  animation-delay: -5.5s;
}
@keyframes breatheOrb {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.28; }
  50%      { transform: translate(-8px, 10px) scale(1.03); opacity: 0.30; }
}

/* ─── TOP HUD ────────────────────────────────────────────── */
.hud {
  grid-column: 1 / 4;
  height: 72px;
  padding: 12px 10px 0 13px;
  display: grid;
  grid-template-columns: 252px 1fr auto;
  align-items: start;
  gap: 16px;
}
.hud-brand { width: 252px; flex-shrink: 0; }
.hud-text {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  line-height: 1.35;
}
.hud-question { font-size: 13px; color: var(--muted); margin-top: 2px; }
.hud-value { font-size: 14px; margin-top: 2px; }
.hud-value b { color: var(--cyan); font-size: 22px; font-weight: 800; }
.hud-dot { color: var(--dim); margin: 0 4px; }
.brand-label {
  font-size: 28px;
  font-weight: 900;
  letter-spacing: -0.06em;
  line-height: 1;
  background: linear-gradient(135deg, var(--cyan) 0%, #a8e6ff 40%, var(--blue) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 0 14px rgba(121,232,255,0.28)) drop-shadow(0 0 3px rgba(111,166,255,0.18));
}
.brand-sub {
  margin-top: 4px;
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--cyan);
  opacity: 0.7;
}
.headline { font-size: clamp(16px, 1.8vw, 24px); font-weight: 800; letter-spacing: -0.04em; line-height: 1.1; white-space: normal; text-wrap: balance; }
.sub { margin-top: 4px; color: var(--muted); font-size: 12px; }
.hud-right {
  position: absolute;
  right: 10px;
  top: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: nowrap;
  justify-content: flex-end;
}
.hud-right .bridge-badge,
.hud-right .btn {
  min-height: 34px;
}
.hud-right .bridge-badge {
  padding: 5px 10px;
}

/* chip */
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--mono); font-size: 11px; font-weight: 800;
  color: var(--amber);
  padding: 8px 14px;
  border: 1px solid rgba(255,209,119,0.36);
  border-radius: 999px;
  background: rgba(255,209,119,0.1);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.chip::before {
  content: "";
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--amber);
  box-shadow: 0 0 10px var(--amber);
  animation: blink 1.8s ease-in-out infinite;
}
@keyframes blink { 0%,100% { opacity: 1; } 50% { opacity: 0.35; } }
.demo-badge {
  display: inline-flex; align-items: center;
  font-family: var(--mono); font-size: 10px; font-weight: 900;
  letter-spacing: 0.08em; color: var(--dim);
  padding: 6px 10px; border: 1px solid var(--edge);
  border-radius: 999px; background: rgba(255,255,255,0.04);
  min-height: 40px; box-sizing: border-box;
}
.bridge-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--mono); font-size: 10px; font-weight: 900;
  color: var(--green);
  padding: 7px 11px;
  border: 1px solid rgba(114,242,168,0.32);
  border-radius: 999px;
  background: rgba(114,242,168,0.08);
  white-space: nowrap;
  min-height: 40px; box-sizing: border-box;
}
.bridge-badge::before {
  content: "";
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 10px var(--green);
}

/* buttons */
.btn {
  position: relative; overflow: hidden;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--edge-hi);
  border-radius: 999px;
  min-height: 40px; padding: 0 18px;
  font-family: var(--mono); font-size: 11px; font-weight: 800;
  color: var(--ink);
  background:
    linear-gradient(145deg, rgba(255,255,255,0.12), rgba(255,255,255,0.03)),
    rgba(121,232,255,0.04);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.1), 0 4px 16px rgba(0,0,0,0.06);
  transition: transform 220ms var(--ease), box-shadow 220ms var(--ease), border-color 220ms ease;
}
.btn:hover  { transform: translateY(-2px) scale(1.02); box-shadow: inset 0 1px 0 rgba(255,255,255,0.12), 0 8px 30px var(--glow-c); border-color: var(--cyan); }
.btn:active { transform: translateY(0) scale(0.98); }
.btn.primary {
  color: #05111e;
  background:
    radial-gradient(circle at 28% 8%, rgba(255,255,255,0.9), transparent 22%),
    linear-gradient(135deg, var(--cyan), var(--blue));
  border-color: transparent;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.35), 0 8px 32px rgba(121,232,255,0.32);
}
.btn.primary::after {
  content: "";
  position: absolute; top: 0; left: -110%; width: 55%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.55), transparent);
  transform: skewX(-22deg);
  animation: shimmer 4s ease-in-out infinite;
}
@keyframes shimmer {
  0%,100% { left: -110%; opacity: 0; }
  45%     { left: 160%;  opacity: 1; }
}
.btn.danger {
  color: var(--rose);
  border-color: rgba(255,99,126,0.42);
  background:
    linear-gradient(145deg, rgba(255,99,126,0.16), rgba(255,255,255,0.03)),
    rgba(255,99,126,0.05);
}

.gate-btn {
  border-color: rgba(121, 232, 255, 0.38) !important;
  animation: gateBreathe 3.8s ease-in-out infinite;
  box-shadow: 0 0 10px rgba(121, 232, 255, 0.10), inset 0 0 14px rgba(121, 232, 255, 0.08), inset 0 1px 0 rgba(255,255,255,0.1) !important;
}
.gate-btn:hover {
  animation: none;
  border-color: var(--cyan) !important;
  box-shadow: 0 0 28px rgba(121, 232, 255, 0.28), inset 0 0 28px rgba(121, 232, 255, 0.22), inset 0 1px 0 rgba(255,255,255,0.12) !important;
}

/* ─── LEFT SIDEBAR ───────────────────────────────────────── */
.left { grid-row: 2; padding: 14px; display: grid; grid-template-rows: auto auto minmax(0,1fr); gap: 12px; min-height: 0; }

.completion {
  position: relative; min-height: 228px;
  border: 1px solid var(--edge);
  border-radius: 18px;
  overflow: hidden;
  padding: 16px;
  cursor: pointer;
  background:
    radial-gradient(circle at 78% 18%, rgba(255,255,255,0.16), transparent 26%),
    linear-gradient(155deg, rgba(114,242,168,0.12), rgba(121,232,255,0.06) 44%, transparent),
    rgba(121,232,255,0.03);
  transition: transform 220ms var(--ease), border-color 220ms ease, box-shadow 220ms ease;
}
.completion:hover { transform: translateY(-2px); border-color: rgba(114,242,168,0.38); box-shadow: 0 12px 32px rgba(114,242,168,0.12); }
.completion::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(115deg, transparent 0 42%, rgba(255,255,255,0.08) 43%, transparent 45% 100%);
  pointer-events: none;
}
.completion-head {
  position: relative; z-index: 1;
  display: flex; justify-content: center; align-items: center;
  font-family: var(--mono); font-size: 10px; color: var(--muted);
  letter-spacing: 0.08em; text-transform: uppercase;
}
.completion-trend {
  color: var(--green);
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(114,242,168,0.08);
}
.completion-main {
  position: relative; z-index: 1;
  display: grid; place-items: center;
  margin: 14px auto 12px;
  width: 128px; height: 128px; border-radius: 50%;
  background:
    conic-gradient(var(--green) 0 84.6%, rgba(255,255,255,0.08) 84.6% 100%);
  box-shadow: 0 0 34px rgba(114,242,168,0.18);
  animation: completionPulse 3.6s ease-in-out infinite;
}
.completion-main::before {
  content: "";
  position: absolute; inset: -5px; border-radius: 50%;
  background:
    conic-gradient(from 0deg, transparent 0 18%, rgba(114,242,168,0.62) 24%, transparent 34% 100%);
  filter: blur(2px);
  animation: completionSweep 2.8s linear infinite;
  opacity: 0.78;
}
.completion-main::after {
  content: "";
  position: absolute; inset: 11px; border-radius: 50%;
  background: var(--bg-1);
  border: 1px solid var(--edge);
  box-shadow: inset 0 1px 0 var(--refract-top);
}
@keyframes completionPulse {
  0%,100% { box-shadow: 0 0 28px rgba(114,242,168,0.16); }
  50% { box-shadow: 0 0 28px rgba(114,242,168,0.18); }
}
@keyframes completionSweep {
  to { transform: rotate(360deg); }
}
.completion-value {
  position: relative; z-index: 1;
  font-family: var(--mono); font-size: 30px; font-weight: 900;
  color: var(--ink); letter-spacing: -0.06em;
  text-align: center;
}
.completion-label {
  position: relative; z-index: 1;
  margin-top: 6px;
  color: var(--muted); font-family: var(--mono); font-size: 10px;
  text-align: center;
}
.completion-meta {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1fr; gap: 8px;
}
.completion-mini {
  border: 1px solid var(--edge);
  border-radius: 13px;
  padding: 9px;
  background: rgba(255,255,255,0.04);
  text-align: center;
}
.completion-mini b {
  display: block;
  font-family: var(--mono); font-size: 14px; color: var(--cyan);
}
.completion-mini span {
  display: block;
  margin-top: 3px;
  font-family: var(--mono); font-size: 9.5px; color: var(--muted);
}

.nav { display: grid; gap: 7px; }
.nav-btn {
  display: flex; justify-content: space-between; align-items: center;
  border: 1px solid var(--edge); border-radius: 13px;
  background: rgba(255,255,255,0.04); color: var(--muted);
  padding: 11px 13px; font-family: var(--mono); font-size: 11px;
  text-align: left;
  transition: all 200ms var(--ease);
}
.nav-btn:hover, .nav-btn.active {
  color: var(--cyan); border-color: rgba(121,232,255,0.35);
  background: rgba(121,232,255,0.06);
  transform: translateX(2px);
}
.nav-btn span { font-size: 10px; opacity: 0.7; }

.op-log {
  min-height: 0; overflow-y: auto;
  border: 1px solid var(--edge); border-radius: 16px;
  padding: 12px; font-family: var(--mono); font-size: 10.5px; line-height: 1.75;
  color: var(--muted);
  background: rgba(0,0,0,0.14);
}
.op-log div + div { border-top: 1px solid var(--edge); padding-top: 6px; margin-top: 6px; }
.op-log .ok  { color: var(--green); }
.op-log .warn { color: var(--amber); }

/* ─── MAIN BOARD ─────────────────────────────────────────── */
.main { grid-column: 2; grid-row: 2; padding: 16px; display: grid; grid-template-rows: auto 128px minmax(0,1fr); gap: 13px; min-height: 0; overflow: hidden; }

.section-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 16px; }
.section-title { font-size: 23px; font-weight: 800; letter-spacing: -0.055em; }
.section-desc { margin-top: 4px; color: var(--muted); font-family: var(--mono); font-size: 10.5px; }
.metrics { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; }
.metric {
  position: relative; overflow: hidden;
  border: 1px solid var(--edge); border-radius: 14px; padding: 10px;
  background: linear-gradient(145deg, rgba(255,255,255,0.12), rgba(255,255,255,0.03)), rgba(121,232,255,0.04);
  transition: all 220ms var(--ease);
}
.metric:hover { border-color: rgba(121,232,255,0.3); transform: translateY(-2px); box-shadow: 0 8px 28px var(--glow-c); }
.metric-sm { padding: 5px 8px !important; }
.metric-sm .metric-val { font-size: 16px !important; }
.metric-sm .metric-lbl { font-size: 8px !important; margin-top: 2px !important; }
.metric-val { font-family: var(--mono); color: var(--cyan); font-size: 24px; font-weight: 800; line-height: 1; text-align: center; }
.metric-lbl { color: var(--muted); font-family: var(--mono); font-size: 9.5px; margin-top: 5px; text-transform: uppercase; letter-spacing: 0.08em; text-align: center; }

/* workflow strip */
.workflow {
  position: relative; display: grid; grid-template-columns: repeat(6,1fr); gap: 8px;
  border: 1px solid var(--edge); border-radius: 20px; padding: 10px;
  background: linear-gradient(145deg, rgba(255,255,255,0.08), transparent), rgba(121,232,255,0.03);
  overflow: hidden;
}
.workflow::before {
  content: "";
  position: absolute; left: 28px; right: 28px; top: 50%;
  height: 1px;
  background: linear-gradient(90deg,
    rgba(121,232,255,0.06) 0%,
    rgba(121,232,255,0.15) 50%,
    rgba(121,232,255,0.35) 100%
  );
  pointer-events: none;
}
.wf-node {
  position: relative; z-index: 1; min-height: 106px;
  border: 1px solid var(--edge); border-radius: 14px;
  background: linear-gradient(155deg, rgba(255,255,255,0.14), rgba(255,255,255,0.03)), var(--glass-1);
  padding: 10px;
  backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
}
.wf-node.gate {
  border-color: rgba(121, 232, 255, 0.38);
  animation: gateBreathe 3.8s ease-in-out infinite;
  cursor: pointer;
  transition: transform 220ms var(--ease), border-color 220ms ease;
}
.wf-node.gate:hover {
  transform: translateY(-2px);
}
.wf-node.gate::after {
  content: "";
  position: absolute; inset: 0; border-radius: inherit;
  border: 1px solid rgba(121, 232, 255, 0.32);
  box-shadow: inset 0 0 14px rgba(121, 232, 255, 0.08);
  animation: gateBreathe 3.8s ease-in-out infinite;
  pointer-events: none;
}
@keyframes gateBreathe {
  0%, 100% {
    box-shadow: inset 0 0 14px rgba(121, 232, 255, 0.08), 0 0 10px rgba(121, 232, 255, 0.10);
    border-color: rgba(121, 232, 255, 0.32);
  }
  50% {
    box-shadow: inset 0 0 14px rgba(121, 232, 255, 0.12), 0 0 14px rgba(121, 232, 255, 0.16);
    border-color: rgba(121, 232, 255, 0.50);
  }
}
.node-badge { color: var(--dim); font-family: var(--mono); font-size: 9.5px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.1em; }
.node-name  { font-size: 13px; font-weight: 800; margin: 7px 0 5px; }
.node-desc  { color: var(--muted); font-family: var(--mono); font-size: 9.5px; line-height: 1.45; }

/* kanban */
.kanban { min-height: 0; display: grid; grid-template-columns: repeat(7, minmax(118px,1fr)); gap: 8px; overflow-x: auto; padding-bottom: 4px; }
.stage {
  border: 1px solid var(--edge); border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.08), transparent 28%), rgba(121,232,255,0.03);
  padding: 9px; min-height: 300px; position: relative;
}
.stage-head { display: flex; justify-content: space-between; align-items: center; gap: 6px; margin-bottom: 9px; }
.stage-name { font-family: var(--mono); font-size: 11px; font-weight: 800; }
.stage-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 30px; min-height: 20px; padding: 0 7px;
  border: 1px solid rgba(121,232,255,0.24);
  border-radius: 999px;
  color: var(--cyan); background: rgba(121,232,255,0.07);
  font-family: var(--mono); font-size: 10px; font-weight: 800;
  white-space: nowrap;
}

.card {
  position: relative; overflow: hidden;
  contain: layout style paint;
  content-visibility: auto;
  border: 1px solid var(--edge); border-radius: 13px;
  background: linear-gradient(155deg, rgba(255,255,255,0.13), rgba(255,255,255,0.03)), rgba(5,8,14,0.26);
  padding: 10px; margin-bottom: 8px; cursor: pointer;
  backdrop-filter: none; -webkit-backdrop-filter: none;
  transform: translateZ(0); -webkit-font-smoothing: antialiased;
  transition: transform 220ms var(--ease), border-color 220ms ease, box-shadow 220ms ease;
  animation: cardIn 480ms var(--ease) both;
}
.card:nth-child(3) { animation-delay: 60ms; }
.card:nth-child(4) { animation-delay: 120ms; }
@keyframes cardIn { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }
.card:hover { transform: none; overflow: visible; position: relative; z-index: 1; border-color: rgba(121,232,255,0.52); }
.card:hover::after { opacity: 0.28; }
.card::after {
  content: ""; position: absolute; inset: 0; border-radius: inherit;
  background: radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(255,255,255,0.18), transparent 40%);
  opacity: 0; pointer-events: none; transition: opacity 160ms ease;
}
.card.risk { border-color: rgba(255,99,126,0.48); animation: cardIn 480ms var(--ease) both, risk 2s ease-in-out infinite; }
@keyframes risk { 0%,100%{box-shadow:0 0 0 rgba(255,99,126,0)} 50%{box-shadow:0 0 22px rgba(255,99,126,0.22)} }
.prio { font-family: var(--mono); font-size: 9.5px; font-weight: 900; color: var(--amber); }
.card.risk .prio { color: var(--rose); }
.card h5 { font-size: 12.5px; font-weight: 700; line-height: 1.36; margin: 7px 0 8px; }
.card p  { color: var(--muted); font-family: var(--mono); font-size: 9.5px; line-height: 1.5; }

/* ─── RIGHT PANEL ────────────────────────────────────────── */
.right {
  grid-column: 3;
  grid-row: 2;
  display: flex;
  flex-direction: column;
  gap: 8px;
  height: 100%;
  overflow-y: auto;
  overscroll-behavior: contain;
}
.right > section {
  flex: 0 0 auto;
}

.panel-title { font-size: 15px; font-weight: 800; letter-spacing: -0.04em; margin: 4px 0 3px; }
.section-label { font-family: var(--mono); font-size: 9px; font-weight: 900; color: var(--cyan); letter-spacing: 0.14em; text-transform: uppercase; }
.panel-desc { color: var(--muted); font-family: var(--mono); font-size: 10.5px; line-height: 1.55; }

/* approval */
.approval {
  padding: 8px 10px;
  border-color: rgba(255,208,119,0.35) !important;
  background:
    radial-gradient(circle at 76% 14%, rgba(255,255,255,0.18), transparent 22%),
    linear-gradient(135deg, rgba(255,208,119,0.1), transparent),
    var(--glass-0) !important;
}
.pods { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin-top: 8px; }
.pod {
  position: relative; overflow: hidden;
  min-height: 48px; border: 1px solid var(--edge); border-radius: 14px;
  padding: 8px 10px;
  cursor: pointer;
  background: linear-gradient(145deg, rgba(255,255,255,0.12), rgba(255,255,255,0.03)), rgba(121,232,255,0.04);
  transition: all 220ms var(--ease);
}
.pod:hover { transform: translateY(-2px); border-color: rgba(121,232,255,0.35); box-shadow: 0 10px 28px var(--glow-c); }
.pod-name { font-size: 11px; font-weight: 800; margin-bottom: 3px; }
.pod-desc { color: var(--muted); font-family: var(--mono); font-size: 9.5px; }
.pod-led {
  position: absolute; right: 10px; top: 11px;
  width: 22px; height: 13px; border-radius: 999px;
  background: rgba(255,255,255,0.14); border: 1px solid var(--edge);
}
.pod-led::after {
  content: ""; position: absolute; right: 2px; top: 2px;
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--green); box-shadow: 0 0 12px var(--green);
}
.pod.warn .pod-led::after { background: var(--amber); box-shadow: 0 0 12px var(--amber); }
.pod.danger .pod-led::after { background: var(--rose); box-shadow: 0 0 12px var(--rose); animation: blink 1.4s ease-in-out infinite; }

/* completion card LED - 外层竖排 */
.completion .pod-led {
  position: absolute; right: -12px; top: 50%; transform: translateY(-50%);
  width: 10px; height: 22px; border-radius: 999px;
  background: rgba(255,255,255,0.12); border: 1px solid var(--edge);
}
.completion .pod-led::after {
  content: ""; position: absolute; right: 2px; top: 50%; transform: translateY(-50%);
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--green); box-shadow: 0 0 10px var(--green);
}
.completion .pod-led.warn::after { background: var(--amber); box-shadow: 0 0 10px var(--amber); }
.completion .pod-led.danger::after { background: var(--rose); box-shadow: 0 0 10px var(--rose); animation: blink 1.4s ease-in-out infinite; }

/* agents */
.agents { padding: 8px 10px; }
.agent-list { display: grid; gap: 5px; margin-top: 6px; }
.agent {
  position: relative; overflow: hidden;
  display: grid; grid-template-columns: 34px 1fr auto; gap: 8px; align-items: center;
  border: 1px solid var(--edge); border-radius: 12px; padding: 7px 8px;
  cursor: pointer;
  background: linear-gradient(145deg, rgba(255,255,255,0.10), rgba(255,255,255,0.03)), rgba(121,232,255,0.04);
  transition: all 220ms var(--ease);
}
.agent:hover { transform: translateX(-3px); border-color: rgba(121,232,255,0.35); box-shadow: 0 10px 28px var(--glow-c); }
.agent:hover::after { opacity: 1; }
.agent::after {
  content: ""; position: absolute; inset: 0; border-radius: inherit;
  background: radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(255,255,255,0.18), transparent 42%);
  opacity: 0; pointer-events: none; transition: opacity 160ms ease;
}
.avatar {
  width: 34px; height: 34px; border-radius: 11px;
  display: grid; place-items: center; font-weight: 900; font-size: 12px; color: #05111e;
  background:
    radial-gradient(circle at 28% 14%, rgba(255,255,255,0.72), transparent 22%),
    linear-gradient(135deg, var(--cyan), var(--blue));
}
.agent strong { display: block; font-size: 12px; font-weight: 700; }
.agent span   { display: block; margin-top: 2px; color: var(--muted); font-family: var(--mono); font-size: 9.5px; }

.agent-scroll {
  display: block; margin-top: 2px; position: relative; height: 14px; overflow: hidden;
}
.agent-scroll span {
  position: absolute; width: 100%; opacity: 0;
  color: var(--rose); font-family: var(--mono); font-size: 9.5px;
  animation: agentScroll 4s ease-in-out infinite;
}
.agent-scroll span:nth-child(1) { animation-delay: 0s; }
.agent-scroll span:nth-child(2) { animation-delay: 2s; }
.agent-scroll span:nth-child(3) { animation-delay: 4s; }
@keyframes agentScroll {
  0%, 20% { opacity: 1; transform: translateY(0); }
  40%, 100% { opacity: 0; transform: translateY(-2px); }
}
.status { font-family: var(--mono); font-size: 9.5px; font-weight: 900; color: var(--green); }
.status.wait { color: var(--amber); }

/* briefing */
.briefing { padding: 8px 10px; }
.stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 6px; margin: 6px 0; }
.stat {
  position: relative; overflow: hidden;
  border: 1px solid var(--edge); border-radius: 13px; padding: 9px;
  cursor: pointer;
  background: linear-gradient(145deg, rgba(255,255,255,0.11), rgba(255,255,255,0.03)), rgba(121,232,255,0.04);
  transition: all 220ms var(--ease);
}
.stat:hover { border-color: rgba(121,232,255,0.3); transform: translateY(-2px); }
.stat:hover::after { opacity: 1; }
.stat::after {
  content: ""; position: absolute; inset: 0; border-radius: inherit;
  background: radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(255,255,255,0.18), transparent 42%);
  opacity: 0; pointer-events: none; transition: opacity 160ms ease;
}
.stat b { display: block; font-family: var(--mono); color: var(--cyan); font-size: 18px; line-height: 1; }
.stat span { color: var(--muted); font-family: var(--mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: 0.08em; }
.deck { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 7px; margin: 9px 0; }
.deck-card {
  position: relative; overflow: hidden;
  min-height: 88px; border: 1px solid var(--edge); border-radius: 18px; padding: 12px 64px 12px 12px;
  cursor: pointer;
  background:
    radial-gradient(circle at 82% 16%, rgba(255,255,255,0.18), transparent 22%),
    linear-gradient(145deg, rgba(255,255,255,0.12), rgba(255,255,255,0.03)),
    rgba(121,232,255,0.04);
  transition: all 220ms var(--ease);
}
.deck-card:hover { transform: translateY(-2px); border-color: rgba(121,232,255,0.32); box-shadow: 0 10px 28px var(--glow-c); }
.deck-card strong { position: relative; z-index: 1; display: block; font-size: 12px; font-weight: 800; margin-bottom: 5px; }
.deck-card span   { position: relative; z-index: 1; display: block; color: var(--muted); font-family: var(--mono); font-size: 9.5px; line-height: 1.45; }
.brief-actions {
  display: flex; gap: 8px; margin-top: 10px;
}
.brief-actions .btn {
  min-height: 32px; padding: 0 13px; font-size: 10px;
}
.right > .daily-report {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.daily-body {
  flex: 1 1 auto;
  min-height: 0;
  margin-top: 2px;
}
.daily-sec {
  margin-bottom: 10px;
}
.daily-sec-title {
  font-size: 11px;
  font-weight: 800;
  color: var(--cyan);
  margin-bottom: 4px;
  padding-bottom: 3px;
  border-bottom: 1px solid var(--edge);
}
.daily-sec-body {
  font-family: var(--mono);
  font-size: 10px;
  line-height: 1.6;
  color: var(--muted);
}
.daily-sec-body p {
  margin: 2px 0;
}
.daily-sec-body .daily-subhead {
  font-weight: 700;
  color: var(--ink);
  margin-top: 6px;
}
.daily-sec-body li {
  margin-left: 12px;
  list-style: disc;
  color: var(--muted);
}
.daily-sec-body li::marker {
  color: var(--dim);
}
.daily-sec-body strong {
  color: var(--ink);
  font-weight: 700;
}
.daily-sec-body code {
  background: rgba(255,255,255,0.06);
  padding: 1px 5px;
  border-radius: 4px;
  font-size: 9.5px;
}
.daily-sec-body table {
  width: 100%;
  border-collapse: collapse;
  margin: 4px 0;
  font-size: 9.5px;
}
.daily-sec-body td {
  padding: 3px 6px;
  border-bottom: 1px solid var(--edge);
  vertical-align: top;
}
.daily-body .daily-actions {
  display: flex;
  gap: 8px;
  margin-top: 10px;
  padding-top: 8px;
  border-top: 1px solid var(--edge);
}
.daily-body .daily-actions .btn {
  min-height: 28px;
  padding: 0 12px;
  font-size: 10px;
}
.daily-sec-body td:first-child {
  white-space: nowrap;
  color: var(--ink);
  font-weight: 600;
}
.daily-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}
.daily-head .panel-title {
  margin: 0;
}
.daily-actions {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}
.daily-actions .btn {
  min-height: 28px;
  padding: 0 12px;
  font-size: 10px;
}
.ring {
  position: absolute; right: 11px; bottom: 11px;
  width: 34px; height: 34px; border-radius: 50%;
  background: conic-gradient(var(--green) 0 78%, rgba(255,255,255,0.1) 78% 100%);
  display: grid; place-items: center;
  box-shadow: 0 0 18px rgba(114,242,168,0.18);
}
.ring::after {
  content: ""; width: 22px; height: 22px; border-radius: 50%;
  background: var(--bg-1);
}
.memo {
  border: 1px solid var(--edge); border-radius: 13px; padding: 10px;
  color: var(--muted); font-family: var(--mono); font-size: 10.5px; line-height: 1.68;
  background: rgba(0,0,0,0.12);
}

/* ─── COMPOSER ───────────────────────────────────────────── */
.composer {
  position: fixed; bottom: 12px;
  /* Align with kanban board (grid col 2). Right panel (380px) is 128px wider than left sidebar (252px),
     so kanban center is offset 64px left from viewport center. */
  left: 50%; transform: translateX(calc(-50% - 64px));
  /* Width matches workflow nodes area: kanban - main padding(16px*2) - workflow padding(10px*2) */
  width: min(830px, calc(100vw - 738px)); z-index: 20;
  padding: 0; border-radius: 24px;
  box-shadow: 0 8px 48px rgba(0,0,0,0.35), inset 0 1px 0 var(--refract-top);
}
.composer-toggle {
  position: absolute; top: 10px; right: 14px;
  width: 24px; height: 24px; min-height: 24px; padding: 0;
  border-radius: 999px; z-index: 2;
  display: grid; place-items: center;
  color: var(--muted);
  background: var(--glass-2);
}
.composer.collapsed {
  width: 52px !important;
  height: 52px !important;
  padding: 0 !important;
  border-radius: 999px !important;
  display: block;
  overflow: hidden;
  border: 1px solid rgba(121, 232, 255, 0.45) !important;
  border-top-color: rgba(121, 232, 255, 0.55) !important;
  background:
    linear-gradient(145deg, rgba(121, 232, 255, 0.18), rgba(255, 255, 255, 0.04)),
    var(--glass-2) !important;
  box-shadow: inset 0 1px 0 var(--refract-top), 0 12px 36px rgba(121, 232, 255, 0.18) !important;
}
.composer.collapsed.glass::before,
.composer.collapsed.glass::after {
  display: none;
}
.composer.collapsed .composer-toggle {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  min-height: 0;
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
  border-radius: inherit;
  overflow: hidden;
  display: grid;
  place-items: center;
  color: var(--cyan);
  font-size: 0;
}
.composer.collapsed .composer-toggle::after {
  content: "";
  position: absolute;
  width: 22px; height: 22px;
  top: 50%; left: 50%;
  margin: -11px 0 0 -11px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,0.65) 0%, rgba(121,232,255,0.32) 40%, transparent 70%);
  filter: blur(1.5px);
  animation: aiLightDrift 18s ease-in-out infinite;
  pointer-events: none;
  z-index: 0;
}
.composer.collapsed .composer-toggle::before {
  content: "AI";
  position: relative;
  z-index: 1;
  font-family: var(--mono);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: -0.06em;
}
@keyframes aiLightDrift {
  0%   { transform: translate(-6px, -5px); opacity: 0.65; }
  16%  { transform: translate(5px, -6px); opacity: 0.82; }
  32%  { transform: translate(6px, 3px); opacity: 0.7; }
  48%  { transform: translate(2px, 6px); opacity: 0.78; }
  64%  { transform: translate(-5px, 5px); opacity: 0.68; }
  80%  { transform: translate(-6px, -1px); opacity: 0.8; }
  100% { transform: translate(-6px, -5px); opacity: 0.65; }
}
.role-chip {
  border: 1px solid var(--edge);
  border-radius: 999px;
  padding: 4px 12px;
  color: var(--muted);
  background: transparent;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
}
.role-chip.active {
  background: var(--cyan);
  color: #03060c;
  border-color: transparent;
}
.input-hint {
  font-family: var(--mono); font-size: 10px; color: var(--dim);
  margin-bottom: 5px; padding-left: 18px;
}
.composer-input {
  display: block; width: 100%; height: 56px;
  border: 1px solid var(--edge-hi); border-radius: 999px;
  background: linear-gradient(145deg, rgba(255,255,255,0.13), rgba(255,255,255,0.04)), rgba(121,232,255,0.04);
  color: var(--ink); outline: none; padding: 0 20px;
  font-family: var(--mono); font-size: 12px;
  backdrop-filter: blur(22px); -webkit-backdrop-filter: blur(22px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.1), 0 4px 18px rgba(0,0,0,0.08);
  transition: border-color 220ms ease, box-shadow 220ms ease;
}
.composer-input:focus {
  border-color: rgba(121,232,255,0.55);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.12), 0 0 0 4px rgba(121,232,255,0.1), 0 4px 24px rgba(0,0,0,0.1);
}

/* ─── MODAL ──────────────────────────────────────────────── */
.modal {
  position: fixed; inset: 0; z-index: 10001;
  display: none; place-items: center; padding: 24px;
  background: rgba(0,0,0,0.52);
  backdrop-filter: none;
  overflow: hidden;
}
.modal.show { display: grid; }
.sheet {
  position: relative; overflow: hidden;
  width: min(740px, 100%);
  max-height: 92vh;
  border: 1px solid rgba(121,232,255,0.5); border-radius: 32px;
  background: linear-gradient(145deg, rgba(255,255,255,0.18), rgba(255,255,255,0.04)), var(--glass-2);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.2), 0 30px 100px rgba(0,0,0,0.5), 0 0 60px rgba(121,232,255,0.14);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  padding: 24px;
  animation: sheetIn 280ms cubic-bezier(0.2,0.8,0.2,1) both;
  display: flex;
  flex-direction: column;
}
.sheet > * { flex-shrink: 0; }
.sheet > [style*="overflow-y"], .sheet > div[style*="overflowY"] { flex: 1; min-height: 0; overscroll-behavior: contain; }
@keyframes sheetIn { from { transform: translateY(16px) scale(0.96); opacity: 0; } to { transform: none; opacity: 1; } }
.sheet::after {
  content: ""; position: absolute; left: 8%; right: 8%; top: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.7), transparent);
}
.sheet-close {
  position: sticky; top: 0; margin-left: auto; z-index: 5;
  width: 32px; height: 32px; min-height: 32px; padding: 0;
  border: 1px solid var(--edge); border-radius: 50%;
  background: rgba(12,24,42,0.92); color: var(--muted);
  font-size: 14px; display: grid; place-items: center;
  cursor: pointer; transition: all 200ms var(--ease);
}
.sheet-close:hover { color: var(--ink); border-color: var(--edge-hi); background: rgba(255,255,255,0.12); }
.sheet p  { color: var(--muted); font-family: var(--mono); font-size: 12px; line-height: 1.7; }
.sheet-actions { display: flex; justify-content: flex-end; align-items: center; gap: 10px; margin-top: 18px; flex-wrap: wrap; }
.sheet-actions.is-info { justify-content: center; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .orb { opacity: 0.12; }
  .aurora span { opacity: 0.12; }
}


/* ─── ONBOARDING WELCOME ──────────────────────────────────── */
.onboard { position:fixed; inset:0; z-index:999; display:flex; align-items:center; justify-content:center;
  background:rgba(3,6,12,0.45); backdrop-filter:blur(16px); opacity:0; pointer-events:none; transition:opacity .4s var(--ease); }
.onboard.show { opacity:1; pointer-events:auto; }
.onboard-card { width:520px; padding:36px; border-radius:28px; text-align:center;
  background:var(--glass-2); border:1px solid var(--edge-hi);
  box-shadow:0 20px 60px rgba(0,0,0,0.4), inset 0 1px 0 var(--refract-top);
  backdrop-filter:blur(40px); -webkit-backdrop-filter:blur(40px); }
.onboard-card h2 { font-size:22px; margin-bottom:8px; }
.onboard-card .subtitle { color:var(--muted); font-size:14px; margin-bottom:24px; }
.onboard-steps { display:flex; gap:12px; margin-bottom:28px; }
.onboard-step { flex:1; padding:16px 12px; border-radius:16px; background:var(--glass-0); border:1px solid var(--edge); text-align:center; }
.onboard-step .step-num { font-size:28px; margin-bottom:6px; }
.onboard-step .step-title { font-size:13px; font-weight:600; margin-bottom:4px; }
.onboard-step .step-desc { font-size:11px; color:var(--muted); }
.onboard-card .btn { margin-top:8px; }

/* ─── TOAST ──────────────────────────────────────────────── */
.toast {
  position: fixed; left: 50%; top: 20px; transform: translateX(-50%); z-index: 10002;
  display: none; padding: 10px 22px;
  border: 1px solid rgba(121,232,255,0.45); border-radius: 999px;
  background: linear-gradient(145deg, rgba(255,255,255,0.15), rgba(255,255,255,0.04)), var(--glass-2);
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.12), 0 8px 32px rgba(0,0,0,0.18);
  color: var(--ink); font-family: var(--mono); font-size: 11px; font-weight: 700;
}
.toast.show { display: block; animation: cardIn 220ms var(--ease) both; }

@media (max-height: 860px) {
  .completion { min-height: 208px; }
  .completion-main { width: 108px; height: 108px; margin: 10px auto; }
  .completion-value { font-size: 26px; }
  .screen { padding-bottom: 124px; }
  .right { gap: 8px; }
  .stage { min-height: 330px; }
}

/* ═══════════════ P-20260618-002 新增 ═══════════════ */

/* ─── Find Block · Directory Tree (redesigned) ───────────── */
.find-block{display:flex;flex-direction:column;gap:0}
.find-empty{color:var(--dim);font-size:10px;text-align:center;padding:16px 0;font-family:var(--mono)}

/* ─── Project row ───────────────────────────────────────── */
.proj{padding:5px 8px;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:6px;font-size:10.5px;color:var(--ink);font-weight:600;transition:all .18s var(--ease);position:relative;font-family:var(--mono)}
.proj:hover{background:rgba(121,232,255,0.04);color:var(--cyan)}
.proj .arw{font-size:8px;color:var(--dim);width:10px;text-align:center;transition:transform .28s var(--spring);display:inline-block;flex-shrink:0}
.proj.open .arw{transform:rotate(90deg);color:var(--cyan)}
.proj.open{border-left:2px solid rgba(121,232,255,0.3);border-radius:0 6px 6px 0;padding-left:6px;background:rgba(121,232,255,0.03)}

/* ─── Children container ────────────────────────────────── */
.kids{padding-left:14px;margin:1px 0;overflow:hidden;max-height:0;opacity:0;transition:max-height .3s var(--ease),opacity .2s var(--ease),margin .2s var(--ease)}
.kids.show{max-height:600px;opacity:1;margin:3px 0}

/* ─── Document row ──────────────────────────────────────── */
.doc{display:flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px;font-size:9.5px;color:var(--muted);cursor:pointer;font-family:var(--mono);transition:all .15s var(--ease);animation:docSlideIn .3s var(--ease) both}
.doc:hover{color:var(--ink);background:rgba(121,232,255,0.04);transform:translateX(2px)}
.doc:nth-child(1){animation-delay:.03s}
.doc:nth-child(2){animation-delay:.06s}
.doc:nth-child(3){animation-delay:.09s}
.doc:nth-child(4){animation-delay:.12s}
.doc:nth-child(5){animation-delay:.15s}
@keyframes docSlideIn{from{opacity:0;transform:translateX(-6px)}to{opacity:1;transform:translateX(0)}}
.doc .pv{font-size:7.5px;color:var(--cyan);margin-left:auto;padding:1px 6px;border-radius:3px;border:1px solid rgba(121,232,255,0.2);opacity:0;transition:opacity .15s var(--ease);font-weight:600}
.doc:hover .pv{opacity:1}
.doc.stale{color:var(--dim);text-decoration:line-through}

/* ─── Document count badge ──────────────────────────────── */
.doc-count{font-size:8px;color:var(--dim);background:rgba(255,255,255,0.04);padding:1px 6px;border-radius:999px;margin-left:auto;font-family:var(--mono)}
.proj.open .doc-count{color:var(--cyan);background:rgba(121,232,255,0.08)}
.kb-search input{flex:1;height:30px;border-radius:8px;border:1px solid var(--edge);background:rgba(255,255,255,0.03);color:var(--ink);padding:0 8px;font-size:10px;outline:none;font-family:var(--mono);transition:border-color .2s}
.kb-search input:focus{border-color:rgba(121,232,255,0.35)}
.kb-search input::placeholder{color:var(--dim)}
/* ─── Knowledge Base Files ────────────────────────────── */
.kb-file{font-size:10.5px;font-weight:600;color:var(--ink);padding:5px 8px;border-radius:6px;cursor:pointer;font-family:var(--mono);transition:all .15s var(--ease);animation:docSlideIn .3s var(--ease) both}
.kb-file:hover{color:var(--cyan);background:rgba(121,232,255,0.04)}
.kb-file:nth-child(1){animation-delay:0s}
.kb-file:nth-child(2){animation-delay:.04s}
.kb-file:nth-child(3){animation-delay:.08s}
.kb-file:nth-child(4){animation-delay:.12s}

/* ─── Daily Tabs ──────────────────────────────────────────── */
.daily-tabs{display:flex;gap:3px}
.daily-tab{padding:3px 10px;font-size:9.5px;font-weight:700;border-radius:5px;cursor:pointer;border:1px solid var(--edge);background:none;color:var(--muted);font-family:var(--mono);transition:all .15s}
.daily-tab.active{background:rgba(121,232,255,0.08);border-color:rgba(121,232,255,0.22);color:var(--cyan)}
.brief-block{margin-bottom:6px}
.brief-label{font-size:11px;font-weight:700;color:var(--cyan);margin-bottom:3px}
.brief-value{font-size:10px;color:var(--muted);line-height:1.5;font-family:var(--mono)}
.brief-item{font-size:10px;color:var(--muted);padding:1px 0 1px 10px;position:relative;font-family:var(--mono)}
.brief-item::before{content:"·";position:absolute;left:0;color:var(--cyan)}

/* ─── Chat Panel ──────────────────────────────────────────── */
.chat-backdrop{position:fixed;inset:0;z-index:99;background:transparent}
.chat-panel{position:fixed;left:12px;top:14px;bottom:12px;width:423px;z-index:100;border:1px solid rgba(255,255,255,0.10);border-top-color:rgba(255,255,255,0.14);border-radius:18px;display:flex;flex-direction:column;background:linear-gradient(160deg,rgba(8,18,34,0.98),rgba(12,24,42,0.96)),var(--glass-0);backdrop-filter:blur(40px) saturate(110%) brightness(0.85);-webkit-backdrop-filter:blur(40px) saturate(110%) brightness(0.62);box-shadow:inset 0 1px 0 rgba(255,255,255,0.08),0 4px 32px rgba(0,0,0,0.22),0 0 0 0.5px rgba(255,255,255,0.03);animation:chatSlideIn .26s var(--spring) both}
@keyframes chatSlideIn{from{transform:translateX(-20px);opacity:0}to{transform:none;opacity:1}}
.chat-panel::after{content:"";position:absolute;left:10%;right:10%;top:0;height:1px;background:linear-gradient(90deg,transparent,var(--refract-top) 30%,rgba(255,255,255,0.18) 50%,var(--refract-top) 70%,transparent);pointer-events:none}
@keyframes chatSlideIn{from{transform:translateX(20px);opacity:0}to{transform:none;opacity:1}}
.chat-panel .ch{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-bottom:1px solid var(--edge);flex-shrink:0;gap:4px}
.chat-panel .ch .agent-chips{display:flex;gap:6px;flex-wrap:nowrap;overflow-x:auto}
.chat-panel .ch .agent-chip{padding:4px 12px;border-radius:999px;font-size:10.5px;font-weight:600;cursor:pointer;font-family:var(--mono);transition:all .15s;color:var(--muted);border:1px solid var(--edge);background:transparent}
.chat-panel .ch .agent-chip.active{background:var(--cyan);color:#04121e;border-color:transparent}
.chat-panel .cb{flex:1;overflow-y:auto;padding:10px 12px;display:flex;flex-direction:column;gap:8px}
.chat-panel .msg{position:relative;max-width:86%;font-size:10.5px;line-height:1.5;padding:8px 11px;border-radius:12px;word-break:break-word}
.chat-panel .msg.ai{background:rgba(121,232,255,0.04);border:1px solid rgba(121,232,255,0.06);align-self:flex-start;border-bottom-left-radius:3px}
.chat-panel .msg.me{background:rgba(255,255,255,0.04);align-self:flex-end;border-bottom-right-radius:3px}
.chat-panel .msg .who{font-size:8px;font-weight:700;color:var(--cyan);margin-bottom:2px;text-transform:uppercase;letter-spacing:.05em}
.chat-panel .msg .ts{font-size:7px;color:var(--dim);float:right;margin-left:8px}
.chat-panel .msg img.preview{max-width:240px;border-radius:8px;margin-top:6px;cursor:pointer}
.chat-panel .msg .file-card{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;border:1px solid var(--edge);background:rgba(255,255,255,0.02);max-width:260px;margin-top:6px}
.chat-panel .msg .file-card.clickable{cursor:pointer;transition:all .15s}
.chat-panel .msg .file-card.clickable:hover{border-color:rgba(121,232,255,0.35);background:rgba(121,232,255,0.04)}
.chat-panel .msg .msg-copy{position:absolute;bottom:4px;right:6px;width:20px;height:16px;border:1px solid var(--edge);border-radius:3px;background:rgba(255,255,255,0.06);color:var(--muted);cursor:pointer;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;opacity:0;transition:opacity .12s;font-family:var(--mono)}
.chat-panel .msg:hover .msg-copy{opacity:1}
.chat-panel .msg .msg-copy:hover{background:rgba(121,232,255,0.12);color:var(--cyan)}
.chat-panel .cf{display:flex;align-items:flex-end;gap:6px;padding:8px 10px;border-top:1px solid var(--edge);flex-shrink:0}
.chat-panel .cf .input-wrap{position:relative;flex:1;display:flex;align-items:flex-end}
.chat-panel .cf textarea{flex:1;min-height:44px;max-height:160px;border-radius:22px;border:1px solid rgba(121,232,255,0.45);background:var(--glass-2);color:var(--ink);padding:11px 18px;font-size:12px;outline:none;font-family:var(--mono);resize:none;line-height:1.45;transition:border-color .2s}
.chat-panel .cf textarea:focus{border-color:rgba(121,232,255,0.35);border-style:solid}
.chat-panel .cf textarea::placeholder{color:var(--dim)}

/* ─── Chat Markdown Content ──────────────────────────── */
.md-body h1{font-size:15px;font-weight:800;color:var(--ink);margin:8px 0 4px;line-height:1.3}
.md-body h2{font-size:13px;font-weight:700;color:var(--cyan);margin:6px 0 3px;line-height:1.3}
.md-body h3{font-size:11.5px;font-weight:700;color:var(--ink);margin:5px 0 2px;line-height:1.3}
.md-body h4{font-size:10.5px;font-weight:700;color:var(--muted);margin:4px 0 2px;line-height:1.3}
.md-body p{font-size:10.5px;line-height:1.6;color:var(--muted);margin:3px 0}
.md-body ul,.md-body ol{padding-left:16px;margin:3px 0}
.md-body li{font-size:10.5px;line-height:1.6;color:var(--muted);margin:1px 0}
.md-body li::marker{color:var(--dim)}
.md-body strong{color:var(--ink);font-weight:700}
.md-body em{color:var(--cyan);font-style:italic}
.md-body code{background:rgba(121,232,255,0.08);color:var(--cyan);padding:1px 5px;border-radius:3px;font-family:var(--mono);font-size:9.5px}
.md-body pre{background:rgba(0,0,0,0.25);border:1px solid var(--edge);border-radius:8px;padding:10px 12px;margin:6px 0;overflow-x:auto}
.md-body pre code{background:none;color:var(--muted);padding:0;font-size:9.5px;line-height:1.55;display:block}
.md-body hr{border:none;border-top:1px solid var(--edge);margin:8px 0}
.md-file-link{color:var(--cyan);cursor:pointer;text-decoration:underline;text-underline-offset:2px;transition:color .12s}
.md-file-link:hover{color:var(--blue)}

/* ─── Quick Entry ─────────────────────────────────────────── */
.quick-entry-input{border:1px solid rgba(121,232,255,0.45)!important;background:var(--glass-2)!important}
.quick-entry-input:focus{border-color:rgba(121,232,255,0.35)!important;border-style:solid!important}
.quick-entry-input::placeholder{color:var(--dim)}
.breathe-input{animation:gateBreathe 4.5s ease-in-out infinite}
.breathe-input:focus{animation:none}

/* ─── AI Circle Glow (mirrors gateBreathe) ───────────────── */
.ai-glow{animation:gateBreathe 3.8s ease-in-out infinite!important}
.ai-glow:hover{animation:none!important;border-color:var(--cyan)!important;box-shadow:0 0 28px rgba(121,232,255,0.28),inset 0 0 28px rgba(121,232,255,0.22)!important}

/* ─── Performance ──────────────────────────────────────────── */
.stage{content-visibility:auto;contain:layout style paint}
.aurora span{will-change:opacity}
.orb{will-change:transform,opacity}
  
