/* 1Ness · Home Base — Day 81 additions
   Pixel laborers · immersive wing worlds · office floor · live terminal · widget wall.
   Layers on top of the inline blueprint stylesheet; reuses its CSS variables.            */

/* ============================================================= PIXEL LABORER */
.pw{display:block;shape-rendering:crispEdges;overflow:visible}
.pw .pw-shadow{fill:rgba(30,63,41,.14)}
/* worker bob — active hammers harder, idle just breathes */
.pw-body{transform-box:view-box;transform-origin:30px 56px}
.pw.active .pw-body{animation:pwBob .52s steps(2,end) infinite}
.pw.idle   .pw-body{animation:pwBreathe 3.4s ease-in-out infinite}
@keyframes pwBob{0%{transform:translateY(0)}50%{transform:translateY(1.4px)}100%{transform:translateY(0)}}
@keyframes pwBreathe{0%,100%{transform:translateY(0)}50%{transform:translateY(-.8px)}}
/* hammer arm — swings on the shoulder pivot when active, rests when idle */
.pw-arm{transform-box:view-box;transform-origin:37px 31px}
.pw.idle .pw-arm{transform:rotate(-46deg)}
.pw.active .pw-arm{animation:pwSwing .52s ease-in-out infinite}
@keyframes pwSwing{
  0%{transform:rotate(-58deg)}
  38%{transform:rotate(20deg)}
  50%{transform:rotate(24deg)}
  70%{transform:rotate(-10deg)}
  100%{transform:rotate(-58deg)}
}
/* impact spark — flashes at the bottom of each swing */
.pw .pw-spark{opacity:0}
.pw.active .pw-spark{animation:pwSpark .52s steps(1,end) infinite}
@keyframes pwSpark{0%,40%{opacity:0}50%{opacity:1}62%,100%{opacity:0}}
/* the plank that "gets built" — fades the top board in on active sites */
.pw .pw-newboard{opacity:.25}
.pw.active .pw-newboard{animation:pwBuild 4.2s ease-in-out infinite}
@keyframes pwBuild{0%,18%{opacity:.18}40%,100%{opacity:1}}

/* ============================================================= WIDGET WALL */
.widget{position:absolute;background:rgba(250,246,236,.86);border:1.5px solid var(--green-deep);border-radius:4px;
  cursor:pointer;display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .2s,transform .2s}
.widget::after{content:"";position:absolute;inset:4px;border:1px solid rgba(30,63,41,.16);border-radius:2px;pointer-events:none}
.widget:hover{box-shadow:0 14px 34px -20px rgba(31,42,34,.5);transform:translateY(-1px)}
.widget:hover .open-hint{opacity:1}
.w-cron{border-color:var(--gold);border-width:2px;background:rgba(250,244,226,.9)}
.w-cron::after{border-color:rgba(184,146,58,.32)}
.w-head{display:flex;align-items:center;gap:9px;padding:11px 14px 9px;border-bottom:1px solid rgba(30,63,41,.13)}
.w-icon{width:26px;height:26px;border-radius:6px;display:grid;place-items:center;flex-shrink:0;
  background:var(--paper);border:1px solid var(--line-strong);color:var(--green-deep)}
.w-cron .w-icon{color:var(--gold);border-color:#d8c38a}
.w-name{font-family:"Fraunces",serif;font-weight:500;font-size:15.5px;color:var(--ink);letter-spacing:.01em}
.w-tag{margin-left:auto;font:600 8px "JetBrains Mono",monospace;letter-spacing:.12em;text-transform:uppercase;
  padding:3px 7px;border-radius:999px;background:rgba(47,93,58,.16);color:var(--green)}
.w-tag.amber{background:#f0e3c4;color:#8a6a14}
.w-body{padding:12px 14px;display:flex;flex-direction:column;gap:9px;flex:1;min-height:0}
.w-metric{display:flex;align-items:baseline;gap:8px}
.w-num{font:500 30px "Fraunces",serif;line-height:1;color:var(--green-deep)}
.w-cron .w-num{color:var(--gold)}
.w-mlbl{font:500 9.5px "JetBrains Mono",monospace;text-transform:uppercase;letter-spacing:.09em;color:var(--ink-soft)}
.w-list{display:flex;flex-direction:column;gap:5px;overflow:hidden}
.w-li{display:flex;align-items:center;gap:8px;font:500 10.5px "Inter";color:var(--ink-2);line-height:1.35}
.w-li b{font-family:"JetBrains Mono",monospace;font-weight:600;color:var(--green-deep);font-size:9.5px;flex-shrink:0}
.w-li-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;background:var(--moss)}
.w-li-dot.live{background:var(--green);box-shadow:0 0 0 3px rgba(47,93,58,.14)}
.w-li-dot.sched{background:var(--slate)}
.w-li-dot.idle{background:#cdbf9d}
.w-li-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.w-li-time{margin-left:auto;font:400 9px "JetBrains Mono",monospace;color:var(--ink-soft);flex-shrink:0}
.w-foot{margin-top:auto;font:500 9.5px "JetBrains Mono",monospace;color:var(--ink-soft);letter-spacing:.02em;
  display:flex;align-items:center;gap:6px}
.w-chiprow{display:flex;gap:5px;flex-wrap:wrap}
.w-chip{font:600 8.5px "JetBrains Mono",monospace;letter-spacing:.04em;padding:3px 8px;border-radius:999px}
.w-chip.live{background:rgba(47,93,58,.16);color:var(--green)}
.w-chip.sched{background:rgba(70,115,168,.15);color:#3a5e88}
.w-chip.idle{background:#f0e3c4;color:#8a6a14}

/* Home Base placard (left of the Build marquee) */
.placard{position:absolute;background:linear-gradient(180deg,#fbf6ea,#f3ecdb);border:1.5px solid var(--blueprint);
  border-radius:4px;padding:18px 20px;display:flex;flex-direction:column;gap:11px}
.placard::after{content:"";position:absolute;inset:5px;border:1px solid rgba(154,167,147,.4);border-radius:2px;pointer-events:none}
.pl-eyebrow{font:600 9px "JetBrains Mono",monospace;letter-spacing:.2em;text-transform:uppercase;color:#8a937e}
.pl-title{font-family:"Fraunces",serif;font-weight:500;font-size:30px;line-height:1.04;color:var(--ink)}
.pl-sub{font:400 12px/1.55 "Inter";color:var(--ink-soft);text-wrap:pretty}
.pl-legend{display:flex;flex-direction:column;gap:7px;margin-top:2px;padding-top:12px;border-top:1px dashed rgba(30,63,41,.2)}
.pl-leg{display:flex;align-items:center;gap:9px;font:500 11px "Inter";color:var(--ink-2)}
.pl-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.pl-enter{margin-top:6px;font:600 9.5px "JetBrains Mono",monospace;letter-spacing:.06em;color:var(--green-deep);
  display:flex;align-items:center;gap:7px}

/* the wing rooms become "doors" — give them an enter affordance */
.room.is-door .open-hint{opacity:.55}
.room.is-door:hover .open-hint{opacity:1}
.room .enter-badge{position:absolute;top:11px;right:12px;font:600 8.5px "JetBrains Mono",monospace;letter-spacing:.1em;
  text-transform:uppercase;color:var(--green-deep);background:#fffdf6;border:1px solid var(--green-deep);
  border-radius:999px;padding:3px 9px;opacity:0;transition:opacity .18s}
.room.is-door:hover .enter-badge{opacity:1}

/* Build marquee — wide office preview door */
.r-buildmq{border-color:var(--gold);border-width:2px;background:
  linear-gradient(180deg,rgba(250,244,226,.92),rgba(245,238,214,.92))}
.r-buildmq::after{border-color:rgba(184,146,58,.32)}
.mq-wrap{display:flex;height:100%;gap:0}
.mq-left{flex:0 0 230px;padding:16px 18px;display:flex;flex-direction:column;gap:8px;border-right:1px dashed rgba(184,146,58,.4)}
.mq-eyebrow{font:600 9px "JetBrains Mono",monospace;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.mq-title{font-family:"Fraunces",serif;font-weight:500;font-size:25px;line-height:1.05;color:var(--ink)}
.mq-sub{font:400 11.5px/1.5 "Inter";color:var(--ink-soft);text-wrap:pretty}
.mq-stat{margin-top:auto;display:flex;align-items:baseline;gap:8px}
.mq-statnum{font:500 26px "Fraunces",serif;color:var(--gold);line-height:1}
.mq-statlbl{font:500 9.5px "JetBrains Mono",monospace;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}
.mq-floor{flex:1;position:relative;overflow:hidden}
.mq-desks{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:space-around;padding:0 18px 30px}
.mq-desk{display:flex;flex-direction:column;align-items:center;gap:1px}
.mq-deskname{font:600 8px "JetBrains Mono",monospace;letter-spacing:.04em;color:var(--ink-2)}
.mq-deskline{position:absolute;left:14px;right:14px;bottom:28px;height:2px;background:rgba(138,106,68,.5)}
.mq-walklane{position:absolute;left:0;right:0;bottom:6px;height:24px;overflow:hidden}
.mq-walker{position:absolute;bottom:0;left:-40px}
.mq-enter{position:absolute;bottom:9px;right:14px;font:600 9px "JetBrains Mono",monospace;letter-spacing:.1em;
  text-transform:uppercase;color:var(--gold);background:#fffdf6;border:1px solid var(--gold);border-radius:999px;
  padding:4px 11px;opacity:0;transition:opacity .18s}
.r-buildmq:hover .mq-enter{opacity:1}

/* a walker pacing across a lane (used in marquee + world floor) */
.walker{animation:walkAcross linear infinite}
@keyframes walkAcross{from{transform:translateX(0)}to{transform:translateX(var(--walk-dist,520px))}}

/* ============================================================= IMMERSIVE WORLDS */
#world{position:fixed;inset:0;z-index:60;display:none;flex-direction:column;
  background:radial-gradient(ellipse at 50% -10%, #f4eddb 0%, #e8dec7 60%, #ddd2b8 100%)}
#world.open{display:flex}
.world-top{flex-shrink:0;display:flex;align-items:center;gap:18px;padding:16px 26px;
  border-bottom:1px solid var(--line);background:linear-gradient(180deg,var(--paper),#f1e9d6)}
.world-back{display:inline-flex;align-items:center;gap:8px;font:600 12px "Inter";color:var(--green-deep);
  background:#fffdf6;border:1px solid var(--green-deep);border-radius:999px;padding:8px 16px;cursor:pointer;transition:all .15s}
.world-back:hover{background:var(--green-deep);color:var(--paper)}
.world-titles{display:flex;flex-direction:column;gap:2px;min-width:0}
.world-eyebrow{font:600 9.5px "JetBrains Mono",monospace;letter-spacing:.16em;text-transform:uppercase}
.world-title{font-family:"Fraunces",serif;font-weight:500;font-size:24px;line-height:1;color:var(--ink)}
.world-score{margin-left:auto;display:flex;align-items:center;gap:9px;flex-shrink:0}
.ws-pill{font:600 11px "JetBrains Mono",monospace;color:#fff;padding:5px 12px;border-radius:999px}
.ws-raw{font:500 10px "JetBrains Mono",monospace;color:var(--ink-soft)}
.world-scroll{flex:1;overflow-y:auto;overscroll-behavior:contain}
.world-pad{max-width:1280px;margin:0 auto;padding:26px 30px 60px}

/* domain accents in the world header */
.wd-build .world-eyebrow{color:var(--dom-build)} .wd-build .ws-pill{background:var(--dom-build)}
.wd-health .world-eyebrow{color:var(--dom-health)} .wd-health .ws-pill{background:var(--dom-health)}
.wd-family .world-eyebrow{color:var(--dom-family)} .wd-family .ws-pill{background:var(--dom-family)}

/* ---- Build world: the office floor ---- */
.floor{position:relative;background:
    repeating-linear-gradient(90deg, rgba(138,106,68,.10) 0 1px, transparent 1px 96px),
    repeating-linear-gradient(0deg, rgba(138,106,68,.07) 0 1px, transparent 1px 96px),
    linear-gradient(180deg,#f7f0df,#efe6d0);
  border:1.5px solid var(--line-strong);border-radius:12px;padding:26px 26px 70px;overflow:hidden}
.floor-cap{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-bottom:20px}
.floor-cap-h{font:600 10px "JetBrains Mono",monospace;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-soft)}
.floor-cap-s{font:400 11px "Inter";color:var(--ink-soft);font-style:italic}
.stations{display:grid;grid-template-columns:repeat(auto-fit,minmax(216px,1fr));gap:18px;position:relative;z-index:2}
.station{position:relative;display:flex;flex-direction:column;background:linear-gradient(180deg,#fffdf6,#f7f1e2);
  border:1px solid var(--line-strong);border-radius:11px;padding:14px 15px 13px;cursor:pointer;
  transition:border-color .15s,box-shadow .15s,transform .15s}
.station:hover{border-color:var(--green-deep);box-shadow:0 16px 36px -22px rgba(31,42,34,.6);transform:translateY(-2px)}
.station.st-active{border-left:3px solid var(--green)}
.station.st-idle{border-left:3px solid #cdbf9d}
.st-deskrow{display:flex;align-items:flex-end;justify-content:space-between;gap:8px;margin-bottom:9px}
.st-pwwrap{position:relative;flex-shrink:0}
.st-statechip{font:600 8px "JetBrains Mono",monospace;letter-spacing:.06em;text-transform:uppercase;
  padding:3px 8px;border-radius:999px;align-self:flex-start}
.st-statechip.active{background:rgba(47,93,58,.16);color:var(--green)}
.st-statechip.idle{background:#ece4cf;color:#8a7a54}
.st-statechip i{display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:5px;vertical-align:middle}
.st-statechip.active i{background:var(--green);animation:figpulse 2.2s ease-in-out infinite}
.st-statechip.idle i{background:#b9a87e}
.st-deskline{height:3px;border-radius:2px;background:linear-gradient(90deg,#b58a52,#8a6a44);margin:0 -2px 11px;opacity:.65}
.st-name{font-family:"Fraunces",serif;font-weight:600;font-size:18px;color:var(--ink);line-height:1.05}
.st-svc{font:400 8.5px "JetBrains Mono",monospace;color:var(--ink-soft);letter-spacing:.03em;margin-top:2px}
.st-role{font:400 11px/1.45 "Inter";color:var(--ink-2);margin-top:8px;text-wrap:pretty}
.st-wo{margin-top:9px;display:flex;align-items:flex-start;gap:7px;font:500 10.5px/1.4 "Inter";color:var(--ink);
  background:var(--paper-2);border:1px solid var(--line);border-radius:6px;padding:7px 9px}
.st-wo i{color:var(--gold);flex-shrink:0;font-style:normal}
.st-open{margin-top:11px;display:flex;align-items:center;justify-content:space-between;gap:8px;
  font:600 9.5px "JetBrains Mono",monospace;letter-spacing:.05em;color:var(--green-deep)}
.st-open .st-arrow{transition:transform .15s}
.station:hover .st-open .st-arrow{transform:translateX(3px)}
.st-open .st-full{font:600 8px "JetBrains Mono",monospace;letter-spacing:.06em;text-transform:uppercase;
  color:var(--paper);background:var(--green-deep);border-radius:999px;padding:3px 8px}

/* free-roaming laborers walking the floor */
.floor-walkers{position:absolute;left:0;right:0;bottom:14px;height:42px;z-index:1;pointer-events:none;overflow:hidden}
.floor-walkers .walker{position:absolute;bottom:0}

/* support fleet row (topic workers + bridges) inside the build world */
.fleet{margin-top:24px;display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:760px){.fleet{grid-template-columns:1fr}}
.fleet-card{background:var(--paper);border:1px solid var(--line);border-radius:11px;padding:15px 17px}
.fleet-cap{font:600 9.5px "JetBrains Mono",monospace;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:12px}
.fleet-tw{display:flex;flex-wrap:wrap;gap:8px}
.fl-tw{display:inline-flex;align-items:center;gap:7px;font:500 10px "JetBrains Mono",monospace;color:var(--ink-2);
  background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:5px 11px;cursor:pointer;transition:border-color .14s}
.fl-tw:hover{border-color:var(--green-deep);color:var(--green-deep)}
.fl-tw i{width:6px;height:6px;border-radius:50%;background:#b9a87e}
.fl-tw.active i{background:var(--green);animation:figpulse 2.4s ease-in-out infinite}
.fleet-br{display:flex;flex-direction:column;gap:8px}
.fl-br{display:flex;align-items:center;gap:9px;text-align:left;font:500 10.5px "JetBrains Mono",monospace;color:var(--ink-2);
  background:var(--paper-2);border:1px solid var(--line);border-radius:8px;padding:9px 12px;cursor:pointer;transition:border-color .14s}
.fl-br:hover{border-color:var(--green-deep)}
.fl-br .br-on{width:7px;height:7px;border-radius:50%;background:var(--green);animation:figpulse 2.6s ease-in-out infinite;flex-shrink:0}
.fl-br-desc{font:400 9.5px "Inter";color:var(--ink-soft);margin-left:auto;text-align:right;max-width:54%}

/* world context strip (McGonigal framing carried over from the old side panel) */
.world-ctx{margin-top:26px;background:var(--paper);border:1px solid var(--line);border-radius:11px;padding:18px 20px;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px 22px}
.wc-cell{display:flex;flex-direction:column;gap:5px}
.wc-k{font:600 9px "JetBrains Mono",monospace;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-soft)}
.wc-v{font:400 12.5px/1.55 "Inter";color:var(--ink);text-wrap:pretty}
.wc-fixes{display:flex;flex-wrap:wrap;gap:6px}
.wc-fix{font:500 10px "Inter";padding:3px 9px;border-radius:999px;border:1px solid var(--line-strong);color:var(--ink-2);background:#fff}
.wc-ds{display:inline-flex;align-items:center;gap:7px;font:600 9.5px "JetBrains Mono",monospace;
  padding:3px 9px;border-radius:999px;align-self:flex-start}
.wc-ds.live{background:rgba(47,93,58,.16);color:var(--green)}
.wc-ds.deferred{background:#f0e3c4;color:#8a6a14}

/* ---- Health / Family worlds: roomy scenes ---- */
.scene{display:grid;gap:20px}
.scene-hero{background:linear-gradient(180deg,#fffdf6,#f6efdf);border:1.5px solid var(--line-strong);
  border-radius:14px;padding:26px 28px;display:flex;align-items:center;gap:30px;flex-wrap:wrap}
.scene-hero .resident{transform:scale(1.25);transform-origin:bottom center}
.scene-panels{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:820px){.scene-panels{grid-template-columns:1fr}}
.scene-panel{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:18px 20px}
.scene-panel-h{font:600 10px "JetBrains Mono",monospace;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:14px}
.scene-wide{grid-column:1/-1}

/* ============================================================= LIVE TERMINAL */
#terminal{position:fixed;inset:0;z-index:70;display:none;align-items:center;justify-content:center;
  background:rgba(20,26,21,.55);backdrop-filter:blur(3px)}
#terminal.open{display:flex}
.term-win{width:min(760px,94vw);max-height:86vh;display:flex;flex-direction:column;
  background:#161d18;border:1px solid #2c3a2e;border-radius:12px;overflow:hidden;
  box-shadow:0 40px 90px -30px rgba(0,0,0,.7)}
.term-bar{display:flex;align-items:center;gap:11px;padding:11px 15px;background:#1d261f;border-bottom:1px solid #2c3a2e;flex-shrink:0}
.term-dots{display:flex;gap:7px}
.term-dots i{width:11px;height:11px;border-radius:50%}
.term-dots i:nth-child(1){background:#d65f4e}.term-dots i:nth-child(2){background:#d8a93a}.term-dots i:nth-child(3){background:#5aa867}
.term-title{font:600 11.5px "JetBrains Mono",monospace;color:#d9e4d6;letter-spacing:.02em}
.term-live{display:inline-flex;align-items:center;gap:6px;margin-left:auto;font:600 9px "JetBrains Mono",monospace;
  letter-spacing:.08em;text-transform:uppercase;color:#7fd08a}
.term-live i{width:7px;height:7px;border-radius:50%;background:#5aa867;animation:figpulse 1.8s ease-in-out infinite}
.term-close{margin-left:6px;width:24px;height:24px;border:0;background:transparent;color:#7e8c7d;cursor:pointer;
  border-radius:5px;display:grid;place-items:center;font-size:15px}
.term-close:hover{background:#ffffff14;color:#d9e4d6}
.term-body{flex:1;overflow-y:auto;padding:18px 20px;font:400 12.5px/1.7 "JetBrains Mono",monospace;color:#cfe0cc;
  background:repeating-linear-gradient(0deg,transparent 0 27px,rgba(255,255,255,.012) 27px 28px)}
.term-line{white-space:pre-wrap;word-break:break-word}
.term-prompt{color:#6f9c72}
.term-meta{color:#8aa28a}
.term-key{color:#d8a93a}
.term-val{color:#e8efe4}
.term-ok{color:#7fd08a}
.term-idle{color:#c89a3a}
.term-dim{color:#7e8c7d}
.term-head{color:#9cc7a0;font-weight:500}
.term-cursor{display:inline-block;width:8px;height:15px;background:#7fd08a;vertical-align:text-bottom;
  margin-left:3px;animation:termBlink 1s steps(1,end) infinite}
@keyframes termBlink{0%,50%{opacity:1}51%,100%{opacity:0}}
.term-foot{flex-shrink:0;display:flex;align-items:center;gap:12px;padding:12px 18px;border-top:1px solid #2c3a2e;background:#1a221b}
.term-fullbtn{font:600 11px "Inter";color:#161d18;background:#7fd08a;border:0;border-radius:999px;padding:8px 16px;cursor:pointer}
.term-fullbtn:hover{background:#9bdca4}
.term-foot-note{font:400 10px "JetBrains Mono",monospace;color:#7e8c7d}

/* keep the header title+subtitle on one line; truncate gracefully on narrow viewports */
header.top .brand{min-width:0}
header.top h1{min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}

/* ============================================================= OFFICE ZOOM (in-place architecture view) */
#office-zoom{position:fixed;inset:62px 0 0 0;z-index:50;display:none;align-items:center;justify-content:center;
  background:rgba(20,26,21,.45);backdrop-filter:blur(2px)}
#office-zoom.open{display:flex}
.oz-card{width:96%;height:94%;display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line-strong);
  border-radius:12px;overflow:hidden;box-shadow:0 40px 100px -30px rgba(0,0,0,.5);transform-origin:62% 70%}
#office-zoom.open .oz-card{animation:ozZoom .42s cubic-bezier(.2,.7,.2,1)}
@keyframes ozZoom{from{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}
.oz-bar{display:flex;align-items:center;gap:16px;padding:12px 18px;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,#fcf8ee,var(--paper));flex-shrink:0}
.oz-titles{display:flex;flex-direction:column;gap:1px;min-width:0}
.oz-eyebrow{font:600 9px "JetBrains Mono",monospace;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.oz-title{font-family:"Fraunces",serif;font-weight:500;font-size:18px;color:var(--ink);line-height:1}
.oz-floor{margin-left:auto;font:600 11px "Inter";color:var(--green-deep);background:#fffdf6;border:1px solid var(--green-deep);
  border-radius:999px;padding:7px 14px;cursor:pointer;transition:all .15s}
.oz-floor:hover{background:var(--green-deep);color:var(--paper)}
.oz-close{width:30px;height:30px;flex-shrink:0;border:1px solid var(--line-strong);background:var(--paper);border-radius:50%;
  cursor:pointer;display:grid;place-items:center;color:var(--ink-soft);font-size:15px}
.oz-close:hover{border-color:var(--ink);color:var(--ink)}
.oz-frame{flex:1;width:100%;border:0;background:var(--bg)}

/* ============================================================= WORK-ORDER BOARD (scrubbable) */
.wo-w-eyebrow{font:600 8.5px "JetBrains Mono",monospace;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}
.wo-scrub{display:flex;align-items:center;gap:12px;margin-bottom:11px}
.wo-arrow{width:34px;height:34px;flex-shrink:0;border:1px solid var(--line-strong);background:var(--paper);border-radius:9px;
  cursor:pointer;display:grid;place-items:center;color:var(--ink-2);font-size:12px;transition:border-color .14s,color .14s}
.wo-arrow:hover:not(:disabled){border-color:var(--green-deep);color:var(--green-deep)}
.wo-arrow:disabled{opacity:.32;cursor:default}
.wo-scrub-date{flex:1;display:flex;flex-direction:column;align-items:center;line-height:1.05}
.wo-day{font:500 19px "Fraunces",serif;color:var(--ink)}
.wo-date{font:500 10px "JetBrains Mono",monospace;color:var(--ink-soft);letter-spacing:.03em;margin-top:3px}
.wo-rel{font:600 8.5px "JetBrains Mono",monospace;letter-spacing:.08em;text-transform:uppercase;color:var(--green);
  background:rgba(47,93,58,.14);border-radius:999px;padding:2px 9px;margin-top:6px}
.wo-rel.past{color:#8a6a14;background:#f0e3c4}
.wo-slider{width:100%;margin:0 0 6px;accent-color:var(--green-deep);cursor:pointer}
.wo-ticks{display:flex;justify-content:space-between;font:500 8.5px "JetBrains Mono",monospace;color:var(--ink-soft);margin-bottom:11px}
.wo-quick{display:flex;gap:7px;margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid #e6ddc7}
.wo-quick button{flex:1;font:600 10px "Inter";color:var(--ink-2);background:var(--paper-2);border:1px solid var(--line);
  border-radius:7px;padding:8px 6px;cursor:pointer;transition:border-color .14s,color .14s}
.wo-quick button:hover{border-color:var(--green-deep);color:var(--green-deep)}
.wo-today{background:linear-gradient(180deg,#fffdf6,var(--paper-2));border:1px solid var(--line-strong);
  border-left:3px solid var(--gold);border-radius:10px;padding:14px 16px;margin-bottom:18px}
.wo-today-top{display:flex;align-items:center;gap:9px;margin-bottom:8px}
.wo-today-code{font:600 12px "JetBrains Mono",monospace;color:var(--green-deep)}
.wo-today-status{margin-left:auto;font:600 8.5px "JetBrains Mono",monospace;letter-spacing:.06em;text-transform:uppercase;
  padding:3px 9px;border-radius:999px}
.wo-st-active{background:rgba(184,146,58,.2);color:#8a6a14}
.wo-st-closed{background:rgba(47,93,58,.16);color:var(--green)}
.wo-today-title{font:600 16px "Fraunces",serif;color:var(--ink);margin-bottom:7px;line-height:1.18}
.wo-today-desc{font:400 12.5px/1.55 "Inter";color:var(--ink-2);text-wrap:pretty}
.wo-moves-cap{font:600 9.5px "JetBrains Mono",monospace;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:11px}
.wo-moves{display:flex;flex-direction:column;gap:8px}
.wo-move{display:flex;align-items:center;gap:11px;background:#fffdf6;border:1px solid var(--line);border-radius:9px;padding:9px 12px}
.wo-move-n{display:grid;place-items:center;width:36px;height:24px;border-radius:6px;flex-shrink:0;
  background:var(--paper-2);border:1px solid var(--line-strong);font:600 9.5px "JetBrains Mono",monospace;color:var(--ink-2)}
.wo-move-main{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}
.wo-move-code{font:500 8.5px "JetBrains Mono",monospace;color:var(--ink-soft);letter-spacing:.04em}
.wo-move-title{font:500 12px "Inter";color:var(--ink);text-wrap:pretty}
.wo-move-lane{font:600 8px "JetBrains Mono",monospace;letter-spacing:.05em;text-transform:uppercase;
  padding:3px 8px;border-radius:999px;flex-shrink:0;align-self:flex-start;margin-top:2px}
.wo-lane-next{background:rgba(70,115,168,.16);color:#3a5e88}
.wo-lane-queued{background:#ece4cf;color:#8a7a54}
.wo-lane-shipped{background:rgba(47,93,58,.16);color:var(--green)}
