:root{
  --bg-0:#070a12; --bg-1:#0f1420; --bg-2:#161d2e; --panel:#121829cc;
  --ink-0:#f4f7fb; --ink-1:#c4cde0; --ink-2:#8b97b3; --ink-3:#5c6885;
  --line:rgba(255,255,255,.08); --line-2:rgba(255,255,255,.14);
  --neon:#9b5cff; --neon-2:#37c2ff;
  --active:#2f9df4; --thinking:#f4c63d; --waiting:#f39b2f; --completed:#63c74d; --offline:#9b3f53; --meeting:#9b5cff;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;background:var(--bg-0);color:var(--ink-0);
  font-family:'Inter',-apple-system,system-ui,sans-serif;overflow:hidden;-webkit-tap-highlight-color:transparent;}
img{image-rendering:pixelated;}

/* top bar */
.topbar{position:fixed;top:0;left:0;right:0;height:54px;z-index:60;display:flex;align-items:center;gap:10px;
  padding:0 12px;background:rgba(8,11,18,.82);backdrop-filter:blur(16px) saturate(140%);border-bottom:1px solid var(--line);}
.logo{display:flex;align-items:center;gap:10px;min-width:0;flex-shrink:0;margin-right:8px}
.logo-mark{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;font-weight:800;font-size:12px;
  background:linear-gradient(135deg,var(--neon),#ec4899);box-shadow:0 0 18px rgba(155,92,255,.55);flex-shrink:0}
.logo-text{min-width:0;display:flex;flex-direction:column;line-height:1.15}
.logo-title{font-size:13px;font-weight:800;letter-spacing:.01em;white-space:nowrap;color:#fff}
.logo-sub{font-size:10px;color:var(--ink-2);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}
.nav{display:flex;gap:3px;flex-shrink:0}
.nav button{font:inherit;font-size:12px;font-weight:700;color:var(--ink-2);background:transparent;border:1px solid transparent;
  border-radius:9px;padding:7px 12px;cursor:pointer;white-space:nowrap}
.nav button:hover{color:var(--ink-0);background:rgba(255,255,255,.05)}
.nav button.active{color:#fff;background:rgba(155,92,255,.22);border-color:rgba(155,92,255,.5)}
.spacer{flex:1}
.finance-live{display:flex;align-items:center;gap:8px}
.fl-block{display:flex;flex-direction:column;align-items:flex-start;gap:1px;padding:5px 11px;
  background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:9px;
  font-family:'JetBrains Mono',monospace}
.fl-label{font-size:9px;font-weight:600;letter-spacing:.5px;color:var(--ink-2);text-transform:uppercase;white-space:nowrap}
.fl-val{font-size:14px;font-weight:800;color:var(--ink-0);white-space:nowrap;line-height:1.1}
.fl-today-val{color:var(--completed)}
.fl-mrr-val{color:var(--neon-2)}
.fl-pulse{width:8px;height:8px;border-radius:50%;background:#36e69b;box-shadow:0 0 12px #36e69b;animation:flPulse 2s ease-in-out infinite}
@keyframes flPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}
.goal{display:flex;align-items:center;gap:9px;padding:6px 12px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:9px}
.goal-label{font-size:11px;color:var(--ink-2);white-space:nowrap}
.goal-bar{width:84px;height:6px;background:rgba(255,255,255,.09);border-radius:999px;overflow:hidden}
.goal-fill{height:100%;background:linear-gradient(90deg,var(--completed),var(--neon-2),var(--neon));transition:width .6s}
.goal-num{font-size:12px;font-weight:700;font-family:'JetBrains Mono',monospace;white-space:nowrap}
.goal-cur{color:var(--completed)} .goal-div{color:var(--ink-3);margin:0 2px} .goal-tgt{color:var(--ink-1);font-size:11px}

/* scene */
#scene{position:fixed;inset:54px 0 0 0;background:
  radial-gradient(1200px 800px at 30% 20%,#1a1438 0%,transparent 60%),
  radial-gradient(900px 600px at 80% 80%,#08243e 0%,transparent 56%),#06070e;
  overflow:hidden;display:flex;align-items:center;justify-content:center;padding:60px 24px 16px}

/* Pixel-art office artwork as the main scene */
#officeWrap{display:flex;align-items:center;justify-content:center;width:100%;height:100%}
#officeFrame{position:relative;display:block;
  width:min(calc(100vw - 360px), calc((100vh - 140px) * 1.5));
  aspect-ratio:1536/1024;
  box-shadow:0 30px 80px rgba(0,0,0,.55),0 0 0 1px rgba(155,92,255,.25),0 0 60px rgba(155,92,255,.18);
  border-radius:6px;overflow:hidden}
#officeImg{display:block;width:100%;height:100%;
  image-rendering:pixelated;image-rendering:crisp-edges;-ms-interpolation-mode:nearest-neighbor;
  user-select:none;pointer-events:none}
#slotLayer{position:absolute;inset:0;pointer-events:none}
/* masks for baked-in speech bubbles in the artwork */
.bubble-mask{position:absolute;background:#2c2f40;border-radius:3px;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.35),inset 0 8px 14px rgba(0,0,0,.25);
  pointer-events:none;z-index:2}

/* central company logo (covers the painted neon "AI Room Club") */
#centerLogo{position:absolute;left:50%;top:33%;transform:translate(-50%,-50%);
  width:54%;max-width:520px;pointer-events:none;z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:6px}
#centerLogo .cl-mask{position:absolute;inset:-6px -10px;background:#2c2f40;
  border-radius:8px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.35),inset 0 10px 18px rgba(0,0,0,.25);z-index:0}
#centerLogo .cl-card{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:8px 14px;border-radius:10px;background:rgba(8,10,22,.78);
  border:1px solid var(--c, #9b5cff);box-shadow:0 0 24px color-mix(in srgb, var(--c, #9b5cff) 45%, transparent),inset 0 0 18px rgba(0,0,0,.35)}
#centerLogo .cl-ic{font-size:28px;line-height:1;filter:drop-shadow(0 0 8px var(--c, #9b5cff))}
#centerLogo .cl-nm{font-size:18px;font-weight:800;letter-spacing:1.5px;color:#fff;
  text-shadow:0 0 12px var(--c, #9b5cff),0 0 2px var(--c, #9b5cff);text-transform:uppercase}
#centerLogo .cl-sub{font-size:10px;font-weight:600;letter-spacing:1px;color:#cfd6e6;text-transform:uppercase;opacity:.85}
@media (max-width: 900px){
  #centerLogo .cl-ic{font-size:22px} #centerLogo .cl-nm{font-size:14px} #centerLogo .cl-sub{font-size:9px}
}

/* nameplate slot floating above each character */
.slot{position:absolute;transform:translate(-50%,-100%);pointer-events:auto;cursor:pointer;
  transition:transform .18s ease;z-index:5}
.slot:hover{transform:translate(-50%,-100%) translateY(-3px);z-index:10}
.slot.is-active .slot-tag{box-shadow:0 4px 14px rgba(47,157,244,.45),0 0 0 1px rgba(47,157,244,.45)}
.slot.is-active .slot-pin{animation:slotPulse 1.6s infinite ease-in-out}
@keyframes slotPulse{0%,100%{opacity:.9;transform:translate(-50%,0) scale(1)}50%{opacity:.4;transform:translate(-50%,0) scale(1.35)}}
.slot-tag{background:rgba(10,15,28,.94);border:1px solid rgba(155,180,220,.25);border-radius:7px;padding:5px 9px 6px;
  display:flex;flex-direction:column;align-items:flex-start;gap:1px;min-width:74px;max-width:170px;
  font-family:'Inter',system-ui,sans-serif;line-height:1.15}
.slot-tag .dot{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;
  box-shadow:0 0 6px currentColor}
.slot-tag .nm{font-size:11px;font-weight:800;color:#f4f7fb;padding-right:12px;white-space:nowrap}
.slot-tag .ti{font-size:9px;font-weight:500;color:#9fb0cc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}
.slot-kpi{font-size:10px;font-weight:700;font-family:'JetBrains Mono',monospace;margin-top:3px;white-space:nowrap;letter-spacing:.2px}
.slot-kpi-tgt{color:#5c6885;font-weight:500}
.slot-next{font-size:9px;font-weight:600;color:#37c2ff;margin-top:2px;letter-spacing:.2px;white-space:nowrap}
.slot-pin{position:absolute;bottom:-6px;left:50%;transform:translate(-50%,0);
  width:7px;height:7px;border-radius:50%}
.slot-bubble{position:absolute;left:50%;bottom:calc(100% + 12px);transform:translate(-50%,0);
  background:rgba(255,255,255,.98);color:#111827;font-size:10px;font-weight:600;line-height:1.3;
  padding:5px 9px;border-radius:7px;white-space:nowrap;max-width:200px;
  box-shadow:0 4px 12px rgba(0,0,0,.4);pointer-events:none}
.slot-bubble::after{content:'';position:absolute;left:50%;top:100%;transform:translateX(-50%);
  border:5px solid transparent;border-top-color:rgba(255,255,255,.98)}

.emptyMsg{position:absolute;left:50%;top:55%;transform:translate(-50%,-50%);
  background:rgba(8,10,20,.86);border:1px solid var(--line-2);border-radius:10px;
  padding:14px 22px;font-size:13px;font-weight:700;color:#cdd6e6;pointer-events:none}

/* ===== CHARACTER SPRITES — gpt-image-1 generated, walking animation ===== */
/* Each sprite is full-body 1024×1024 source, displayed 120×120 in css, bottom-anchored.
   Walking = small translation animation moving sprite between 3 waypoints within their room. */
.sprite{position:absolute;width:90px;height:90px;
  background-repeat:no-repeat;background-size:contain;background-position:center bottom;
  transform:translate(-50%,-100%);
  pointer-events:none;z-index:3;
  filter:drop-shadow(0 4px 6px rgba(0,0,0,.55));
  image-rendering:pixelated;-ms-interpolation-mode:nearest-neighbor;
  will-change:transform}
.sprite.dim{opacity:.55;filter:saturate(.4) drop-shadow(0 4px 6px rgba(0,0,0,.55))}

/* Walking — sprite wanders within its room between waypoints + slight vertical bob */
@keyframes walkA{
  0%   {transform:translate(-50%,-100%) translate(0,0)}
  25%  {transform:translate(-50%,-100%) translate(22px,-2px)}
  50%  {transform:translate(-50%,-100%) translate(10px,3px)}
  75%  {transform:translate(-50%,-100%) translate(-18px,-2px)}
  100% {transform:translate(-50%,-100%) translate(0,0)}
}
@keyframes walkB{
  0%   {transform:translate(-50%,-100%) translate(0,0)}
  20%  {transform:translate(-50%,-100%) translate(-20px,2px)}
  45%  {transform:translate(-50%,-100%) translate(17px,-2px)}
  70%  {transform:translate(-50%,-100%) translate(8px,3px)}
  100% {transform:translate(-50%,-100%) translate(0,0)}
}
@keyframes walkC{
  0%   {transform:translate(-50%,-100%) translate(0,0)}
  30%  {transform:translate(-50%,-100%) translate(15px,-3px)}
  60%  {transform:translate(-50%,-100%) translate(-15px,2px)}
  100% {transform:translate(-50%,-100%) translate(0,0)}
}
/* Bobbing for active workers */
@keyframes bob{
  0%,100%{filter:drop-shadow(0 4px 6px rgba(0,0,0,.55))}
  50%   {filter:drop-shadow(0 2px 4px rgba(0,0,0,.45)) brightness(1.05)}
}
.sprite.walk-a{animation:walkA 14s ease-in-out infinite}
.sprite.walk-b{animation:walkB 16s ease-in-out infinite}
.sprite.walk-c{animation:walkC 12s ease-in-out infinite}

/* nameplate sits above character head */
.slot{transform:translate(-50%,calc(-100% - 8px))}
@media (max-width: 900px){
  .sprite{width:80px;height:80px}
  .slot{transform:translate(-50%,calc(-100% - 6px))}
}

/* ===== ACTIVITY ANIMATIONS (overlays on top of static artwork) ===== */
/* Monitor screen flicker — placed near each active slot, simulates working screen */
.slot .screen-glow{position:absolute;left:-22px;top:14px;width:34px;height:24px;
  background:rgba(8,18,40,.7);border-radius:2px;padding:3px;display:flex;flex-direction:column;gap:2px;
  box-shadow:0 0 10px rgba(96,165,250,.45);pointer-events:none}
.slot .screen-glow i{display:block;height:3px;border-radius:1px;background:#60a5fa;
  animation:scrFlicker 1.4s infinite ease-in-out}
.slot .screen-glow i:nth-child(2){background:#6ee7b7;animation-delay:.2s}
.slot .screen-glow i:nth-child(3){background:#fbbf24;animation-delay:.4s}
@keyframes scrFlicker{
  0%,100%{width:50%;opacity:.55}
  30%{width:90%;opacity:1}
  60%{width:30%;opacity:.7}
  80%{width:75%;opacity:.9}
}
/* typing dots — printed under nameplate while active */
.slot .typing-dots{display:flex;gap:3px;margin-top:5px;padding-left:2px}
.slot .typing-dots span{width:4px;height:4px;border-radius:50%;background:#60a5fa;opacity:.4;
  animation:typeDot 1.1s infinite ease-in-out}
.slot .typing-dots span:nth-child(2){animation-delay:.18s}
.slot .typing-dots span:nth-child(3){animation-delay:.36s}
@keyframes typeDot{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-3px);opacity:1}}
/* speech bubble fade transition for cycling */
.slot .slot-bubble{transition:opacity .25s ease}
/* floating activity particles (data dots rising from active stations) */
.slot .actparticle{position:absolute;left:50%;bottom:-4px;width:4px;height:4px;border-radius:50%;
  opacity:0;animation:partFloat 2.1s ease-out forwards;pointer-events:none}
@keyframes partFloat{
  0%{transform:translate(-50%,0) scale(.6);opacity:0}
  15%{opacity:.9}
  100%{transform:translate(calc(-50% + 14px),-70px) scale(.4);opacity:0}
}
/* gently bob the slot pin to suggest movement */
.slot.is-active .slot-pin{animation:pinBob 2.4s infinite ease-in-out}
@keyframes pinBob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,-2px)}}

#scene canvas{display:block}

@media (max-width:1100px){
  #officeFrame{width:min(calc(100vw - 32px),calc((100vh - 200px) * 1.5))}
}

.hint{position:fixed;top:64px;left:50%;transform:translateX(-50%);z-index:40;background:rgba(0,0,0,.7);color:var(--ink-1);
  font-size:12px;padding:7px 14px;border-radius:999px;border:1px solid var(--line);pointer-events:none;transition:opacity .4s}

/* zoom */
.zoom{position:fixed;right:14px;bottom:84px;z-index:40;display:flex;flex-direction:column;gap:6px}
.zoom button{width:38px;height:38px;border-radius:11px;background:rgba(14,19,32,.85);border:1px solid var(--line-2);
  color:var(--ink-0);font-size:18px;font-weight:700;cursor:pointer;backdrop-filter:blur(8px)}
.zoom button:active{background:rgba(155,92,255,.4)}

/* generic floating panel */
.panel{position:fixed;z-index:50;background:var(--panel);backdrop-filter:blur(16px) saturate(140%);
  border:1px solid var(--line-2);border-radius:14px;box-shadow:0 16px 50px rgba(0,0,0,.5)}
.panel h3{margin:0;padding:12px 14px;font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink-1);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none}
.panel .body{padding:10px 12px;overflow:auto}

/* status legend */
#legend{left:14px;top:68px;width:188px}
#legend .body{display:flex;flex-direction:column;gap:7px;padding:11px 12px}
.leg-row{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--ink-1)}
.leg-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0;box-shadow:0 0 7px currentColor}
.leg-count{margin-left:auto;font-size:11px;font-weight:700;color:var(--ink-2);font-family:'JetBrains Mono',monospace}

/* mini-map */
#minimap{left:14px;bottom:14px;width:188px}
#minimap canvas{display:block;width:164px;height:104px;border-radius:8px;background:#0a0e18}

/* task board */
#board{right:14px;top:68px;width:300px;max-height:calc(100vh - 96px);display:flex;flex-direction:column}
#board .body{display:flex;flex-direction:column;gap:12px}
.col-title{font-size:11px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;margin:2px 0 6px;display:flex;gap:7px;align-items:center}
.col-title .n{margin-left:auto;color:var(--ink-3)}
.col-todo .dot{color:var(--ink-2)} .col-prog .dot{color:var(--active)} .col-done .dot{color:var(--completed)}
.tcard{background:#eef1f6;color:#1a2233;border-radius:9px;padding:9px 10px;margin-bottom:7px;box-shadow:0 3px 10px rgba(0,0,0,.35);cursor:pointer;border-left:3px solid #cbd2df}
.tcard:hover{transform:translateY(-1px)}
.tcard .tt{font-size:12px;font-weight:700;line-height:1.25}
.tcard .meta{display:flex;align-items:center;gap:6px;margin-top:7px;font-size:10px;color:#5c6885}
.tcard .who{font-weight:700} .tcard .due{margin-left:auto;font-family:'JetBrains Mono',monospace}
.tcard.is-prog{border-left-color:var(--active)} .tcard.is-done{border-left-color:var(--completed);opacity:.92}
.tprog{height:5px;background:#d3d9e4;border-radius:999px;margin-top:7px;overflow:hidden}
.tprog i{display:block;height:100%;background:linear-gradient(90deg,var(--active),var(--neon))}

/* notification / chat feed — custom resize + maximize toggle */
#feed{right:14px;bottom:14px;width:420px;height:60vh;max-height:96vh;min-width:300px;min-height:200px;
  display:flex;flex-direction:column;overflow:hidden;
  border:1px solid var(--line-2);box-shadow:0 16px 48px rgba(0,0,0,.55)}
#feed.is-maximized{width:calc(100vw - 28px)!important;height:calc(100vh - 80px)!important}
#feed.collapsed{min-height:0 !important;min-width:240px !important;height:auto !important;width:auto !important}
#feed.collapsed .feed-resize{display:none}
#feed .body{display:flex;flex-direction:column;gap:8px;flex:1;min-height:0;overflow:auto}

/* Header buttons (collapse + maximize) */
#feed h3{display:flex;align-items:center;gap:6px}
.feed-ctrls{display:flex;gap:4px;margin-left:auto;align-items:center}
.feed-btn{background:rgba(255,255,255,.06);border:1px solid var(--line);color:var(--ink-1);
  width:24px;height:22px;border-radius:5px;font-size:11px;cursor:pointer;display:grid;place-items:center;
  font-family:inherit;line-height:1;padding:0;transition:all .15s}
.feed-btn:hover{background:rgba(155,92,255,.2);color:#fff;border-color:rgba(155,92,255,.45)}
.feed-btn.is-on{background:rgba(155,92,255,.25);color:#fff;border-color:rgba(155,92,255,.5)}

/* Custom resize grip — top-left corner (since feed is anchored bottom-right) */
.feed-resize{position:absolute;left:0;top:0;width:20px;height:20px;cursor:nwse-resize;z-index:8;
  background:linear-gradient(135deg,rgba(155,92,255,.6) 0%,rgba(155,92,255,.6) 38%,transparent 39%);
  border-top-left-radius:8px;transition:background .15s}
.feed-resize:hover{background:linear-gradient(135deg,rgba(155,92,255,1) 0%,rgba(155,92,255,1) 48%,transparent 49%)}
.feed-resize::after{content:'⤡';position:absolute;left:3px;top:1px;font-size:11px;color:#fff;font-weight:800;
  text-shadow:0 0 4px rgba(0,0,0,.9);pointer-events:none}
.ch-tabs{display:flex;gap:4px;flex-wrap:wrap;padding:6px 8px 0;border-bottom:1px solid var(--line);margin-bottom:8px}
.ch-tab{background:transparent;border:1px solid transparent;color:var(--ink-2);font-size:11px;font-weight:700;padding:6px 10px;border-radius:7px 7px 0 0;cursor:pointer;font-family:inherit;white-space:nowrap}
.ch-tab:hover{color:var(--ink-0);background:rgba(255,255,255,.04)}
.ch-tab.is-active{color:#fff;background:rgba(155,92,255,.18);border-color:rgba(155,92,255,.4);border-bottom-color:transparent}
.ch-msgs{display:flex;flex-direction:column;gap:7px;padding:0 8px;flex:1;min-height:0;overflow-y:auto}
.ch-input{padding:9px;border-top:1px solid var(--line);margin-top:6px}
.ch-input input{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--line);color:var(--ink-0);padding:9px 12px;border-radius:8px;font-size:13px;font-family:inherit;outline:none}
.ch-input input:focus{border-color:rgba(155,92,255,.5);background:rgba(155,92,255,.05)}
.msg{display:flex;gap:10px;padding:10px 12px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:11px;transition:background .15s}
.msg:hover{background:rgba(255,255,255,.07)}
.msg.q{background:rgba(244,155,47,.12);border-color:rgba(244,155,47,.45);box-shadow:0 0 0 1px rgba(244,155,47,.18)}
.msg .av{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:800;color:#fff;flex-shrink:0;box-shadow:0 0 0 2px rgba(0,0,0,.3)}
.msg .nm{font-size:13px;font-weight:800;color:var(--ink-0)}
.msg .tx{font-size:13px;color:var(--ink-1);line-height:1.5;margin-top:2px;word-wrap:break-word}
.msg .tm{font-size:10px;color:var(--ink-3);font-family:'JetBrains Mono',monospace;margin-left:auto}
.msg .mention{color:#cfb4ff;font-weight:700}
.msg .badge{font-size:10px;font-weight:800;color:#fbbf24;background:rgba(244,155,47,.18);padding:2px 7px;border-radius:6px;margin-left:6px}

/* collapsed panels (need !important to beat #board .body / #feed .body / #legend .body) */
.panel.collapsed > .body{display:none !important}
.panel.collapsed{max-height:none !important;height:auto !important}
.panel h3{user-select:none;cursor:pointer}
.panel h3 .chev{margin-left:auto;font-size:11px;color:var(--ink-3);
  transition:transform .2s ease;display:inline-block}
.panel.collapsed h3 .chev{transform:rotate(-90deg)}

.doc-link-btn{margin-top:14px;width:100%;background:linear-gradient(135deg,#9b5cff,#6d3df0);border:none;color:#fff;padding:12px 16px;border-radius:10px;font-weight:700;font-size:13px;cursor:pointer;font-family:inherit;letter-spacing:.2px;transition:all .15s ease;box-shadow:0 4px 14px rgba(155,92,255,.35)}
.doc-link-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(155,92,255,.55)}

/* views (tabs toggle big overlays) */
.view{position:fixed;inset:54px 0 0 0;z-index:55;background:rgba(7,10,18,.96);backdrop-filter:blur(6px);overflow:auto;padding:24px;display:none}
.kb-card{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:12px;padding:18px 20px;cursor:pointer;transition:all .15s ease}
.kb-card:hover{background:rgba(155,92,255,.12);border-color:rgba(155,92,255,.5);transform:translateY(-2px)}
.kb-card-name{font-size:16px;font-weight:800;color:var(--ink-0);margin-bottom:6px}
.kb-card-desc{font-size:12px;color:var(--ink-2);line-height:1.4;margin-bottom:10px}
.kb-card-cta{font-size:11px;font-weight:700;color:var(--neon-2);text-transform:uppercase;letter-spacing:.5px}
.kb-doc-header{display:flex;gap:10px;align-items:center;margin-bottom:18px;flex-wrap:wrap}
.kb-back{background:rgba(255,255,255,.06);border:1px solid var(--line);color:var(--ink-0);padding:7px 14px;border-radius:8px;cursor:pointer;font-size:12px;font-weight:700;font-family:inherit}
.kb-back:hover{background:rgba(255,255,255,.12)}
.kb-edit,.kb-browse{background:rgba(155,92,255,.18);border:1px solid rgba(155,92,255,.4);color:#fff;padding:7px 14px;border-radius:8px;text-decoration:none;font-size:12px;font-weight:700}
.kb-edit:hover,.kb-browse:hover{background:rgba(155,92,255,.3)}
.kb-doc-content{max-width:820px;color:var(--ink-1);font-size:14px;line-height:1.55}
.kb-doc-content h1{font-size:24px;color:#fff;margin:0 0 16px;border-bottom:1px solid var(--line);padding-bottom:10px}
.kb-doc-content h2{font-size:18px;color:#fff;margin:24px 0 10px}
.kb-doc-content h3{font-size:15px;color:var(--neon-2);margin:18px 0 8px}
.kb-doc-content h4{font-size:13px;color:var(--ink-0);margin:14px 0 6px}
.kb-doc-content p{margin:8px 0}
.kb-doc-content ul{padding-left:22px;margin:8px 0}
.kb-doc-content li{margin:4px 0}
.kb-doc-content code{background:rgba(255,255,255,.08);padding:2px 6px;border-radius:4px;font-size:12px;font-family:'JetBrains Mono',monospace;color:#fbcfe8}
.kb-doc-content pre{background:rgba(0,0,0,.4);border:1px solid var(--line);padding:12px;border-radius:8px;overflow-x:auto;font-size:12px}
.kb-doc-content pre code{background:transparent;padding:0;color:var(--ink-0)}
.kb-doc-content table{width:100%;border-collapse:collapse;margin:12px 0;font-size:12px}
.kb-doc-content td{padding:8px 10px;border-bottom:1px solid var(--line);vertical-align:top}
.kb-doc-content tr:first-child td{font-weight:800;color:var(--ink-0);border-bottom-color:var(--line-2)}
.kb-doc-content a{color:var(--neon-2);text-decoration:underline}
.kb-doc-content a:hover{color:#fff}
.kb-doc-content strong{color:#fff;font-weight:700}
.view.open{display:block}
.view h2{margin:4px 0 18px;font-size:20px;font-weight:800}
.grid{display:grid;gap:14px}
.team-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}
.tcardL{background:var(--bg-2);border:1px solid var(--line);border-radius:14px;padding:16px;cursor:pointer}
.tcardL:hover{border-color:var(--line-2)}
.tcardL .row1{display:flex;align-items:center;gap:12px}
.tcardL .av{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-size:17px;font-weight:700;color:#fff}
.tcardL .nm{font-size:15px;font-weight:700} .tcardL .ti{font-size:12px;color:var(--ink-2);margin-top:2px}
.tcardL .st{margin-top:12px;display:flex;align-items:center;gap:7px;font-size:12px;color:var(--ink-1)}
.report{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.kpi{background:var(--bg-2);border:1px solid var(--line);border-radius:14px;padding:18px}
.kpi .v{font-size:30px;font-weight:800;font-family:'JetBrains Mono',monospace}
.kpi .l{font-size:12px;color:var(--ink-2);margin-top:4px}
.viewClose{position:absolute;top:16px;right:18px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);
  border:none;color:#fff;font-size:20px;cursor:pointer}

/* agent modal */
.modal{display:none;position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.72);backdrop-filter:blur(8px);
  align-items:center;justify-content:center;padding:20px}
.modal.open{display:flex}
.modal-card{background:var(--bg-2);border:1px solid var(--line-2);border-radius:18px;width:100%;max-width:760px;max-height:85vh;overflow-y:auto;padding:26px;position:relative;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.txfilt{background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--ink-1);padding:5px 11px;border-radius:7px;font-size:11px;font-weight:700;cursor:pointer;font-family:inherit}
.txfilt:hover{background:rgba(255,255,255,.1);color:#fff}
.txfilt.is-active{background:rgba(155,92,255,.22);border-color:rgba(155,92,255,.6);color:#fff}
.txtable{display:flex;flex-direction:column;gap:0;font-family:'JetBrains Mono',monospace;font-size:11px}
.txhead{display:grid;grid-template-columns:80px 80px 50px 110px 1fr;gap:8px;padding:7px 4px;color:var(--ink-2);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--bg-2);z-index:1}
.txrow{display:grid;grid-template-columns:80px 80px 50px 110px 1fr;gap:8px;padding:8px 4px;border-bottom:1px solid rgba(255,255,255,.04);align-items:center}
.txrow:hover{background:rgba(255,255,255,.03)}
.txdt{color:var(--ink-2);font-size:10px}
.txamt{color:var(--ink-0);font-weight:700}
.txusd{color:#36e69b;font-weight:800}
.txstat{font-size:10px;font-weight:700;white-space:nowrap}
.txcli{color:var(--ink-1);font-size:11px;font-family:'Inter',sans-serif;line-height:1.3;overflow:hidden}
.txreason{font-size:9px;color:#e54d6f;margin-top:2px;font-style:italic}
.finance-live .fl-block:hover,.finance-live .goal:hover{background:rgba(255,255,255,.08);border-color:rgba(155,92,255,.4)}
.modal-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.08);border:none;color:#fff;font-size:19px;cursor:pointer}
.mrow{display:flex;justify-content:space-between;gap:14px;padding:10px 0;border-bottom:1px solid var(--line);font-size:13px}
.mrow .l{color:var(--ink-2)} .mrow .r{color:var(--ink-0);text-align:right;max-width:62%}
.statusPill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700}

/* ===== Modal v2 — tabs + KPI + Posadova ===== */
.modal-head{display:flex;align-items:center;gap:14px;margin-bottom:14px;padding-right:30px}
.mh-av{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;font-size:21px;font-weight:800;color:#fff;flex-shrink:0}
.mh-info{flex:1;min-width:0}
.mh-name{font-size:19px;font-weight:800;color:#fff}
.mh-title{font-size:12px;color:var(--ink-2);margin-top:2px}
.mh-status{display:flex;align-items:center;gap:6px;margin-top:6px;flex-wrap:wrap}
.mh-sep{color:var(--ink-3)}
.mh-team{font-size:11px;color:var(--ink-2)}

.modal-tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:14px;overflow-x:auto;scrollbar-width:none}
.modal-tabs::-webkit-scrollbar{display:none}
.mtab{font:inherit;font-size:12px;font-weight:700;background:transparent;color:var(--ink-2);border:none;
  padding:9px 12px;cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;transition:all .15s}
.mtab:hover{color:var(--ink-0)}
.mtab.is-active{color:#fff;border-bottom-color:var(--neon)}

.modal-tab-content{min-height:140px}

/* KPI tab */
.kpi-list{display:flex;flex-direction:column;gap:14px}
.kpi-item{background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:10px;padding:12px 14px}
.kpi-row1{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}
.kpi-label{font-size:13px;font-weight:600;color:var(--ink-1)}
.kpi-vals{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:700;white-space:nowrap}
.kpi-cur{font-weight:800}
.kpi-sep{color:var(--ink-3);margin:0 4px}
.kpi-tgt{color:var(--ink-2);font-size:11px}
.kpi-bar{height:6px;background:rgba(255,255,255,.07);border-radius:999px;overflow:hidden}
.kpi-fill{height:100%;border-radius:999px;transition:width .6s ease}

/* Posadova tab */
.pos-block{margin-bottom:16px}
.pos-label{font-size:11px;font-weight:800;color:var(--ink-2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.pos-ckp{font-size:14px;color:var(--ink-0);line-height:1.45;padding:11px 14px;background:rgba(155,92,255,.1);border-left:3px solid var(--neon);border-radius:0 8px 8px 0}
.pos-list{margin:0;padding-left:18px;color:var(--ink-1);font-size:13px;line-height:1.55}
.pos-list li{margin-bottom:4px}
.pos-chips{display:flex;flex-wrap:wrap;gap:6px}
.pos-chip{font-size:11px;font-weight:600;padding:4px 9px;background:rgba(55,194,255,.12);border:1px solid rgba(55,194,255,.3);color:#aee6ff;border-radius:6px}
.pos-replaces-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px;color:var(--ink-0)}
.pos-savings{color:#36e69b;font-weight:700;font-family:'JetBrains Mono',monospace;font-size:12px}

/* Onboarding tab */
.onb-stage{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.onb-stage-label{font-size:15px;font-weight:800;color:#fff}
.onb-since{font-size:11px;color:var(--ink-2)}
.onb-bar{height:8px;background:rgba(255,255,255,.07);border-radius:999px;overflow:hidden;margin-bottom:14px}
.onb-fill{height:100%;background:linear-gradient(90deg,var(--completed),var(--neon-2));border-radius:999px;transition:width .6s}
.onb-checklist{display:flex;flex-direction:column;gap:6px}
.onb-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-1);padding:7px 10px;background:rgba(255,255,255,.03);border-radius:7px}
.onb-item.is-done{color:var(--ink-2)}
.onb-check{font-size:14px}

/* ===== Schedule tab ===== */
.sched-header{margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.sched-next{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.sched-next-label{font-size:12px;color:var(--ink-2)}
.sched-next-time{font-size:16px;color:var(--neon-2);font-family:'JetBrains Mono',monospace;font-weight:800}
.sched-list{display:flex;flex-direction:column;gap:6px}
.sched-item{display:grid;grid-template-columns:110px 1fr 90px;gap:10px;align-items:center;padding:8px 10px;background:rgba(255,255,255,.03);border-radius:8px;border-left:2px solid var(--neon)}
.sched-time{font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:800;color:#aee6ff}
.sched-task{font-size:12px;color:var(--ink-1);line-height:1.35}
.sched-recurrence{font-size:10px;color:var(--ink-3);text-align:right;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}
.sched-note{margin-top:14px;padding:10px 12px;background:rgba(155,92,255,.08);border-left:3px solid var(--neon);border-radius:0 8px 8px 0;font-size:12px;color:var(--ink-1);line-height:1.5}
@media (max-width:560px){
  .sched-item{grid-template-columns:1fr;gap:4px}
  .sched-recurrence{text-align:left}
}

/* ===== "🆕 Новачок" badge on slot (Phase D — HR onboarding) ===== */
.slot-newbie{position:absolute;top:-22px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;font-size:9px;font-weight:800;
  padding:2px 7px;border-radius:5px;white-space:nowrap;
  box-shadow:0 2px 8px rgba(249,115,22,.5);letter-spacing:.3px;
  animation:newbieBounce 2.4s ease-in-out infinite;z-index:6}
.slot-newbie::after{content:'';position:absolute;left:50%;top:100%;transform:translateX(-50%);
  border:4px solid transparent;border-top-color:#ea580c}
.slot.is-newbie .slot-pin{animation:newbiePulse 1.4s ease-in-out infinite}
@keyframes newbieBounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-3px)}}
@keyframes newbiePulse{0%,100%{box-shadow:0 0 0 0 rgba(249,115,22,.6),0 0 10px currentColor}50%{box-shadow:0 0 0 6px rgba(249,115,22,0),0 0 10px currentColor}}

/* ===== "+ Додати агента" button in topbar ===== */
.add-agent-btn{font:inherit;font-size:12px;font-weight:800;
  background:linear-gradient(135deg,#9b5cff,#6d3df0);color:#fff;border:none;
  padding:8px 14px;border-radius:9px;cursor:pointer;
  box-shadow:0 4px 14px rgba(155,92,255,.4);transition:all .15s;
  white-space:nowrap;margin-right:6px}
.add-agent-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(155,92,255,.65)}

/* ===== Recruiter wizard modal ===== */
.recruiter-card{max-width:680px}
.wiz-steps{display:flex;align-items:center;gap:0;margin-bottom:16px}
.wiz-step{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.06);color:var(--ink-2);font-size:12px;font-weight:800;
  border:1px solid var(--line);transition:all .2s;flex-shrink:0}
.wiz-step.is-active{background:var(--neon);color:#fff;box-shadow:0 0 14px rgba(155,92,255,.5)}
.wiz-step.is-done{background:#36e69b;color:#06120c;border-color:#36e69b}
.wiz-step.is-done::before{content:'✓';font-size:14px}
.wiz-step.is-done > *{display:none}
.wiz-line{flex:1;height:2px;background:var(--line);margin:0 4px}

.wiz-rec-header{display:flex;align-items:center;gap:12px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.wiz-rec-av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#f97316,#ea580c);
  display:grid;place-items:center;color:#fff;font-weight:800;font-size:15px;flex-shrink:0}
.wiz-rec-name{font-size:14px;font-weight:800;color:#fff}
.wiz-rec-sub{font-size:12px;color:var(--ink-2);margin-top:2px}

.wiz-body{min-height:200px}

/* Step 1 — templates */
.wiz-tpls{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.wiz-tpl{padding:14px 16px;background:rgba(255,255,255,.04);border:1px solid var(--line);
  border-radius:11px;cursor:pointer;transition:all .15s}
.wiz-tpl:hover{background:rgba(155,92,255,.1);border-color:rgba(155,92,255,.4);transform:translateY(-1px)}
.wiz-tpl-name{font-size:13px;font-weight:800;color:#fff;margin-bottom:4px}
.wiz-tpl-desc{font-size:11px;color:var(--ink-2);line-height:1.35}

/* Steps 2-3 — inputs */
.wiz-q{display:flex;flex-direction:column;gap:10px}
.wiz-label{font-size:12px;font-weight:700;color:var(--ink-1);margin-top:6px}
.wiz-hint{font-weight:500;color:var(--ink-3);font-size:11px}
.wiz-input,.wiz-textarea{font:inherit;font-size:13px;color:var(--ink-0);
  background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:8px;padding:9px 11px;width:100%;
  font-family:inherit;resize:vertical}
.wiz-input:focus,.wiz-textarea:focus{outline:none;border-color:rgba(155,92,255,.6);background:rgba(155,92,255,.06)}
.wiz-textarea{min-height:64px;line-height:1.5}

/* Step 3 — preview */
.wiz-preview{display:flex;flex-direction:column;gap:12px}
.wiz-pv-title{font-size:13px;font-weight:800;color:#fff;margin-bottom:4px}
.wiz-pv-block{display:flex;flex-direction:column;gap:6px}
.wiz-pv-label{font-size:11px;font-weight:800;color:var(--ink-2);text-transform:uppercase;letter-spacing:.5px}
.wiz-kpi-list{display:flex;flex-direction:column;gap:5px}
.wiz-kpi-row{display:flex;justify-content:space-between;padding:7px 10px;background:rgba(255,255,255,.03);border-radius:6px;font-size:12px}
.wiz-kpi-row strong{font-family:'JetBrains Mono',monospace;color:#aee6ff}

/* Step 4 — confirm */
.wiz-confirm{text-align:center;padding:20px 10px}
.wiz-confirm-text{font-size:16px;color:#fff;font-weight:700;margin-bottom:8px}
.wiz-confirm-meta{font-size:12px;color:var(--ink-2);line-height:1.5}
.wiz-creating{text-align:center;padding:40px 20px;color:var(--ink-1)}
.wiz-spinner{width:36px;height:36px;border:3px solid rgba(155,92,255,.2);border-top-color:var(--neon);border-radius:50%;
  animation:spin 0.8s linear infinite;margin:0 auto 14px}
@keyframes spin{to{transform:rotate(360deg)}}
.wiz-done{text-align:center;padding:30px 10px}
.wiz-done-icon{font-size:48px;margin-bottom:10px}
.wiz-done-title{font-size:18px;color:#fff;font-weight:800;margin-bottom:8px}
.wiz-done-sub{font-size:12px;color:var(--ink-2);line-height:1.5;margin-bottom:16px}
.wiz-error{color:#e54d6f;font-size:13px;padding:14px}

/* Nav */
.wiz-nav{display:flex;justify-content:space-between;gap:8px;margin-top:18px;padding-top:14px;border-top:1px solid var(--line)}
.wiz-back,.wiz-next{font:inherit;font-size:13px;font-weight:700;padding:9px 16px;border-radius:9px;cursor:pointer;border:1px solid transparent}
.wiz-back{background:rgba(255,255,255,.05);color:var(--ink-1);border-color:var(--line)}
.wiz-back:hover{background:rgba(255,255,255,.1)}
.wiz-next{background:linear-gradient(135deg,#9b5cff,#6d3df0);color:#fff}
.wiz-next:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(155,92,255,.5)}
.wiz-hire{background:linear-gradient(135deg,#36e69b,#1fa56e);color:#06120c}

@media (max-width:760px){
  .add-agent-btn{padding:6px 10px;font-size:11px}
  .wiz-tpls{grid-template-columns:1fr}
  .recruiter-card{max-width:94vw;padding:18px}
}


/* company switcher tabs */
#ctabs{position:fixed;top:62px;left:50%;transform:translateX(-50%);z-index:48;display:flex;align-items:center;gap:6px;
  background:rgba(10,15,28,.78);backdrop-filter:blur(12px);border:1px solid var(--line-2);border-radius:14px;padding:5px;max-width:94vw}
.ctab-wrap{display:flex;gap:4px;overflow-x:auto;scrollbar-width:none}
.ctab-wrap::-webkit-scrollbar{display:none}
.ctab{display:inline-flex;align-items:center;gap:7px;white-space:nowrap;font:inherit;font-size:13px;font-weight:700;color:var(--ink-2);
  background:transparent;border:1px solid transparent;border-radius:10px;padding:7px 13px;cursor:pointer;transition:all .15s}
.ctab:hover{background:rgba(255,255,255,.05);color:var(--ink-0)}
.ctab.active{background:var(--c);color:#fff;box-shadow:0 2px 12px -2px var(--c)}
.ctab .ic{font-size:15px}
.ctab .cnt{font-size:10px;font-weight:700;opacity:.7;background:rgba(255,255,255,.18);padding:1px 6px;border-radius:7px}
.ctab-arrow{flex-shrink:0;width:30px;height:32px;border-radius:9px;cursor:pointer;background:rgba(255,255,255,.05);
  border:1px solid var(--line);color:var(--ink-1);font-size:18px;font-weight:700;line-height:1}
.ctab-arrow:hover{background:rgba(255,255,255,.1);color:#fff}
/* nudge legend/board below tabs */
#legend,#board{top:108px}
@media (max-width:640px){#ctabs{top:58px}.ctab{font-size:12px;padding:6px 9px}}

@media (max-width:920px){
  #board,#feed{width:min(86vw,300px)}
  #legend,#minimap{width:158px}
  #minimap canvas{width:134px;height:86px}
  .nav button{padding:7px 9px}
  .logo-sub{display:none}
}
@media (max-width:640px){
  #legend{display:none}
  #board{top:60px;max-height:44vh}
  #feed{bottom:10px;max-height:30vh}
  #minimap{display:none}
  .goal-label{display:none}
}

/* ===== Nav badge (Inbox counter) ===== */
.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;
  padding:0 5px;margin-left:5px;border-radius:9px;background:#e54d6f;color:#fff;font-size:10px;font-weight:800;
  box-shadow:0 0 8px rgba(229,77,111,.6);animation:badgePulse 2.2s ease-in-out infinite}
@keyframes badgePulse{0%,100%{transform:scale(1);box-shadow:0 0 8px rgba(229,77,111,.6)}50%{transform:scale(1.08);box-shadow:0 0 14px rgba(229,77,111,.9)}}

/* ===== Inbox / Decision Center ===== */
#view-inbox h2{font-size:22px;margin:0 0 6px}
.inbox-empty{text-align:center;padding:60px 20px;color:var(--ink-1)}
.inbox-summary{font-size:13px;color:var(--ink-2);margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.inbox-summary strong{color:var(--ink-0);font-size:15px}
.inbox-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:14px;max-width:1100px}
.inbox-card{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:14px;padding:16px;
  display:flex;flex-direction:column;gap:12px;transition:all .15s ease}
.inbox-card:hover{border-color:rgba(155,92,255,.4);background:rgba(155,92,255,.06)}
.inbox-head{display:flex;align-items:center;gap:10px}
.inbox-av{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:800;font-size:14px;flex-shrink:0}
.inbox-meta{flex:1;min-width:0}
.inbox-nm{font-size:14px;font-weight:700;color:var(--ink-0)}
.inbox-ch{font-size:11px;color:var(--ink-2);font-weight:500;margin-left:6px}
.inbox-tm{font-size:11px;color:var(--ink-3);margin-top:1px}
.inbox-text{font-size:13px;line-height:1.5;color:var(--ink-1);padding:10px 12px;background:rgba(255,255,255,.03);border-left:3px solid var(--neon);border-radius:0 8px 8px 0}
.inbox-actions{display:flex;gap:6px;flex-wrap:wrap}
.ibx-btn{flex:1;min-width:90px;font:inherit;font-size:12px;font-weight:700;padding:9px 12px;border-radius:9px;
  cursor:pointer;border:1px solid transparent;transition:all .15s}
.ibx-approve{background:linear-gradient(135deg,#36e69b,#1fa56e);color:#06120c;border-color:rgba(54,230,155,.5)}
.ibx-approve:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(54,230,155,.4)}
.ibx-edit{background:rgba(155,92,255,.15);color:#cfb4ff;border-color:rgba(155,92,255,.4)}
.ibx-edit:hover{background:rgba(155,92,255,.25)}
.ibx-skip{background:rgba(255,255,255,.04);color:var(--ink-2);border-color:var(--line)}
.ibx-skip:hover{background:rgba(255,255,255,.08);color:var(--ink-0)}

/* ===== Mobile responsive ===== */
@media (max-width:760px){
  .topbar{flex-wrap:wrap;height:auto;min-height:54px;padding:6px 10px;gap:6px}
  .logo{order:1}
  .nav{order:3;width:100%;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}
  .nav::-webkit-scrollbar{display:none}
  .nav button{font-size:11px;padding:6px 9px;flex-shrink:0}
  .finance-live{order:2;gap:5px;flex-wrap:wrap}
  .fl-block{padding:4px 8px}
  .fl-val{font-size:12px}
  .goal{padding:4px 8px;gap:6px}
  .goal-bar{width:60px}
  .spacer{display:none}
  body{overflow-y:auto}
  #scene{position:fixed;top:96px;bottom:50vh;left:0;right:0}
  #board,#feed,#legend,#minimap{position:fixed;left:0;right:0;width:auto;max-height:none;top:auto;border-radius:0;border-left:none;border-right:none}
  #board{display:none}
  #legend{display:none}
  #minimap{display:none}
  #feed{bottom:0;top:50vh;background:rgba(8,11,18,.96)}
  .inbox-list{grid-template-columns:1fr}
  .view{padding:14px}
  .view h2{font-size:18px}
  .modal-card{padding:18px;max-width:94vw;max-height:88vh}
  .ctab-wrap{gap:4px}
  .ctab{padding:5px 8px;font-size:11px}
  .hint{display:none}
  .zoom{bottom:auto;top:auto;display:none}
}


/* ════════════════════════════════════════════════════════════
   v43 — WOW LAYER: neural fx, levitation, sweeps, entrances
   ════════════════════════════════════════════════════════════ */
#fxCanvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.85}

body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(900px 600px at 12% 8%, rgba(155,92,255,.16) 0%, transparent 60%),
    radial-gradient(700px 500px at 88% 92%, rgba(255,107,53,.13) 0%, transparent 65%),
    radial-gradient(500px 400px at 60% 50%, rgba(55,194,255,.08) 0%, transparent 60%);
  animation:bgDrift 24s ease-in-out infinite alternate}
@keyframes bgDrift{0%{transform:translate3d(0,0,0) scale(1)}100%{transform:translate3d(-2%,1%,0) scale(1.04)}}

#officeWrap{perspective:1200px;position:relative}
#officeFrame{animation:officeFloat 9s ease-in-out infinite;will-change:transform}
@keyframes officeFloat{0%,100%{transform:translateY(0) rotateX(0deg)}50%{transform:translateY(-10px) rotateX(.6deg)}}
#officeFrame::after{content:"";position:absolute;inset:0;z-index:4;pointer-events:none;
  background:linear-gradient(115deg,transparent 0%,transparent 42%,rgba(255,255,255,.07) 50%,transparent 58%,transparent 100%);
  background-size:300% 100%;animation:lightSweep 12s ease-in-out infinite}
@keyframes lightSweep{0%,55%{background-position:130% 0}75%{background-position:-30% 0}100%{background-position:-30% 0}}
#officeWrap::before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:85%;aspect-ratio:480/272;border-radius:24px;z-index:-1;filter:blur(46px);opacity:.45;
  background:conic-gradient(from 0deg, #9b5cff, #37c2ff, #ff6b35, #9b5cff);
  animation:auroraSpin 14s linear infinite}
@keyframes auroraSpin{to{transform:translate(-50%,-50%) rotate(360deg)}}

.panel{animation:panelIn .7s cubic-bezier(.22,1,.36,1) backwards}
#legend{animation-delay:.15s}
#board{animation-delay:.3s}
#minimap{animation-delay:.45s}
#feed{animation-delay:.6s}
@keyframes panelIn{from{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
#ctabs{animation:tabsIn .6s cubic-bezier(.22,1,.36,1) .1s backwards}
@keyframes tabsIn{from{opacity:0;transform:translate(-50%,-12px)}to{opacity:1;transform:translate(-50%,0)}}

.goal-bar{position:relative}
.goal-bar::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);
  background-size:200% 100%;animation:goalShimmer 2.6s ease-in-out infinite}
@keyframes goalShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

.leg-dot{animation:dotBreathe 2.8s ease-in-out infinite}
.leg-row:nth-child(2) .leg-dot{animation-delay:.4s}
.leg-row:nth-child(3) .leg-dot{animation-delay:.8s}
.leg-row:nth-child(4) .leg-dot{animation-delay:1.2s}
@keyframes dotBreathe{0%,100%{transform:scale(1)}50%{transform:scale(1.25)}}

.topbar{position:fixed}
.topbar::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;
  background:linear-gradient(90deg,transparent 0%,#9b5cff 25%,#37c2ff 50%,#ff6b35 75%,transparent 100%);
  background-size:200% 100%;animation:lineFlow 6s linear infinite;opacity:.7}
@keyframes lineFlow{to{background-position:-200% 0}}

.logo-mark{position:relative}
.logo-mark::before{content:"";position:absolute;inset:-4px;border-radius:13px;
  border:1px solid rgba(155,92,255,.5);animation:logoRing 2.5s ease-out infinite;pointer-events:none}
@keyframes logoRing{0%{opacity:.8;transform:scale(.9)}100%{opacity:0;transform:scale(1.35)}}

.slot.is-active::before{content:"";position:absolute;left:50%;bottom:-44px;width:80px;height:80px;
  transform:translate(-50%,0);border-radius:50%;
  background:radial-gradient(circle, rgba(47,157,244,.35) 0%, transparent 70%);
  animation:haloPulse 2.4s ease-in-out infinite;pointer-events:none;z-index:-1}
@keyframes haloPulse{0%,100%{opacity:.45;transform:translate(-50%,0) scale(.9)}50%{opacity:.85;transform:translate(-50%,0) scale(1.1)}}

.msg{animation:msgIn .35s ease-out}
@keyframes msgIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

.modal.open{animation:modalIn .25s ease-out}
@keyframes modalIn{from{opacity:0}to{opacity:1}}
.modal-card{animation:cardIn .3s cubic-bezier(.22,1,.36,1)}
@keyframes cardIn{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important}
}
