/* ── shell.css — ExecBot Shell SPA (W1a) ───────────────────────────
   Extracted verbatim from execbot-shell.html design reference (the
   untracked top-of-repo file, kept out of git intentionally). Diffs
   against the reference's <style> block should reduce to:
     • W1a: .proj-menu, .proj-menu-item, .proj-default, .proj-err (live picker)
     • W1b: .loading, .tile-err, .tile-empty, .gauge.cap-hit (dashboard states)
   Everything else is content-frozen vs the reference modulo leading
   whitespace (verified diff -uw at W1a).
   ─────────────────────────────────────────────────────────────────── */

:root{
  --bg:#060810;--bg2:#0a0e1a;--surface:#0e1422;--surface2:#121a2c;--card:#111829;
  --border:#1b2740;--border2:#243352;
  --cyan:#00e5ff;--cyan2:#18b8d8;--cyan-dim:#0a3a47;--cyan-glow:rgba(0,229,255,.45);
  --amber:#ffb830;--green:#00ff9c;--red:#ff4d6d;--violet:#8b7cff;--pink:#ff7eb6;
  --text:#dbe7f5;--text2:#8da4c4;--muted:#50617f;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{background:var(--bg);color:var(--text);font-family:'Rajdhani',sans-serif;overflow-x:hidden;min-height:100vh;}
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(1100px 560px at 80% -10%,rgba(0,229,255,.10),transparent 60%),radial-gradient(880px 480px at 6% 110%,rgba(139,124,255,.08),transparent 55%),linear-gradient(rgba(0,229,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(0,229,255,.02) 1px,transparent 1px);background-size:100% 100%,100% 100%,46px 46px,46px 46px;}
body::after{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;background:repeating-linear-gradient(0deg,rgba(0,0,0,0) 0 2px,rgba(0,0,0,.12) 2px 4px);mix-blend-mode:overlay;opacity:.4;}

.app{position:relative;z-index:1;display:grid;grid-template-columns:240px 1fr;min-height:100vh;}

/* RAIL */
.rail{border-right:1px solid var(--border);background:linear-gradient(180deg,var(--bg2),var(--bg) 60%);padding:20px 14px;display:flex;flex-direction:column;gap:5px;position:sticky;top:0;height:100vh;overflow-y:auto;}
.rail::-webkit-scrollbar{width:0;}
.brand{display:flex;align-items:center;gap:11px;padding:4px 8px 14px;}
.brand .mark{width:32px;height:32px;border-radius:9px;background:radial-gradient(circle at 30% 25%,var(--cyan),var(--cyan2) 70%);box-shadow:0 0 18px var(--cyan-glow),inset 0 0 8px rgba(255,255,255,.4);position:relative;flex-shrink:0;}
.brand .mark::after{content:'';position:absolute;inset:6px;border:2px solid rgba(6,8,16,.7);border-radius:5px;border-right-color:transparent;border-bottom-color:transparent;animation:spin 4s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.brand .name{font-family:'Orbitron';font-weight:900;letter-spacing:1px;font-size:15px;}
.brand .name span{color:var(--cyan);}
.proj-sw{background:var(--surface);border:1px solid var(--border2);border-radius:11px;padding:9px 12px;margin-bottom:8px;cursor:pointer;transition:.16s;}
.proj-sw:hover{border-color:var(--cyan);}
.proj-sw .pl{font-family:'JetBrains Mono';font-size:8px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;}
.proj-sw .pn{display:flex;align-items:center;justify-content:space-between;margin-top:3px;}
.proj-sw .pn b{font-family:'Orbitron';font-size:13px;font-weight:700;} .proj-sw .pn .cv{color:var(--muted);}

/* W1a — picker dropdown (live data). Not in execbot-shell.html reference; the
   reference's .proj-sw was a navigate-to-projects affordance, we replaced it
   with a real switcher because the wedge gate requires live /api/projects +
   localStorage persistence + rows[0] fallback. */
.proj-menu{margin-top:8px;background:var(--surface);border:1px solid var(--border2);border-radius:11px;padding:6px;}
.proj-menu-item{padding:7px 10px;border-radius:7px;cursor:pointer;font-size:13px;color:var(--text2);font-weight:600;}
.proj-menu-item:hover{background:var(--surface2);color:var(--text);}
.proj-menu-item.active{background:var(--cyan-dim);color:var(--cyan);}
.proj-default{font-family:'JetBrains Mono';font-size:8px;color:var(--green);letter-spacing:.5px;margin-left:6px;}
.proj-err{font-family:'JetBrains Mono';font-size:9px;color:var(--red);padding:6px 10px;}

/* W1b — dashboard tile states (loading / per-tile error / empty / cap-hit). */
.loading{opacity:.35;font-style:italic;}
.tile-err{font-family:'JetBrains Mono';font-size:10px;color:var(--red);padding:8px 12px;letter-spacing:.5px;}
.tile-empty{font-family:'JetBrains Mono';font-size:10px;color:var(--muted);padding:8px 12px;letter-spacing:.5px;}
.gauge.cap-hit{box-shadow:0 0 18px var(--red);background:conic-gradient(var(--red) calc(var(--p)*1%),var(--border) 0);}
.gauge.cap-hit .gi .pct{color:var(--red);}

.nav-label{font-family:'JetBrains Mono';font-size:8px;letter-spacing:2.5px;color:var(--muted);text-transform:uppercase;padding:11px 10px 5px;}
.nav-item{display:flex;align-items:center;gap:11px;padding:8px 11px;border-radius:8px;color:var(--text2);font-weight:600;font-size:14px;cursor:pointer;transition:all .16s;position:relative;}
.nav-item .ico{width:17px;text-align:center;font-size:14px;opacity:.85;}
.nav-item:hover{background:var(--surface);color:var(--text);}
.nav-item.active{background:linear-gradient(90deg,var(--cyan-dim),transparent);color:var(--cyan);}
.nav-item.active::before{content:'';position:absolute;left:0;top:7px;bottom:7px;width:3px;background:var(--cyan);border-radius:3px;box-shadow:0 0 10px var(--cyan-glow);}
.nav-item .pill{margin-left:auto;font-family:'JetBrains Mono';font-size:9.5px;background:var(--cyan);color:#04121a;padding:1px 7px;border-radius:20px;font-weight:700;}
.nav-item .pill.warn{background:var(--amber);}
.rail-foot{margin-top:auto;border-top:1px solid var(--border);padding-top:12px;}
.usr{display:flex;align-items:center;gap:10px;padding:5px 8px;}
.usr .av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--violet),var(--cyan));display:grid;place-items:center;font-weight:700;color:#06101a;font-size:13px;}
.usr .who{font-size:13px;font-weight:600;} .usr .tier{font-family:'JetBrains Mono';font-size:8px;color:var(--cyan);letter-spacing:1px;}

/* MAIN */
.main{padding:22px 28px 50px;max-width:1440px;}
.view{display:none;} .view.show{display:block;animation:fade .4s ease;}
@keyframes fade{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}

.vhead{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;gap:16px;flex-wrap:wrap;}
.vhead h1{font-family:'Orbitron';font-weight:700;font-size:24px;letter-spacing:.5px;}
.vhead h1 b{color:var(--cyan);font-weight:900;}
.vhead .sub{color:var(--text2);font-size:13.5px;margin-top:3px;font-family:'JetBrains Mono';letter-spacing:.4px;}
.vhead .live{color:var(--green);} .vhead .live::before{content:'●';margin-right:5px;animation:blink 1.8s infinite;}
@keyframes blink{50%{opacity:.3;}}
.actions{display:flex;align-items:center;gap:10px;}
.icon-btn{width:40px;height:40px;border-radius:11px;border:1px solid var(--border2);background:var(--surface);color:var(--text2);display:grid;place-items:center;cursor:pointer;transition:all .16s;font-size:16px;position:relative;}
.icon-btn:hover{border-color:var(--cyan);color:var(--cyan);}
.icon-btn .dot{position:absolute;top:8px;right:9px;width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 8px var(--red);}
.btn-primary{border:none;cursor:pointer;font-family:'Rajdhani';font-weight:700;font-size:14px;letter-spacing:.5px;background:linear-gradient(135deg,var(--cyan),var(--cyan2));color:#04121a;padding:0 18px;height:40px;border-radius:11px;display:flex;align-items:center;gap:7px;box-shadow:0 0 20px rgba(0,229,255,.3);transition:all .16s;}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 24px rgba(0,229,255,.5);}
.btn-ghost{border:1px solid var(--border2);background:var(--surface);color:var(--text2);font-family:'Rajdhani';font-weight:600;font-size:13.5px;padding:0 16px;height:40px;border-radius:11px;cursor:pointer;display:flex;align-items:center;gap:7px;transition:.16s;}
.btn-ghost:hover{border-color:var(--cyan);color:var(--cyan);}

.panel{background:linear-gradient(165deg,var(--card),var(--surface));border:1px solid var(--border);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 11px;border-bottom:1px solid var(--border);}
.panel-head h2{font-family:'Orbitron';font-weight:700;font-size:13px;letter-spacing:.7px;display:flex;align-items:center;gap:8px;}
.panel-head h2 .tag{font-family:'JetBrains Mono';font-size:8.5px;letter-spacing:1px;color:var(--cyan);background:var(--cyan-dim);padding:2px 7px;border-radius:20px;}
.panel-head .more{color:var(--text2);font-family:'JetBrains Mono';font-size:10px;cursor:pointer;letter-spacing:.4px;} .panel-head .more:hover{color:var(--cyan);}

.sw{width:38px;height:21px;border-radius:20px;background:var(--border2);position:relative;cursor:pointer;transition:.2s;flex-shrink:0;}
.sw::after{content:'';position:absolute;top:3px;left:3px;width:15px;height:15px;border-radius:50%;background:var(--muted);transition:.2s;}
.sw.on{background:linear-gradient(90deg,var(--cyan2),var(--cyan));box-shadow:0 0 12px var(--cyan-glow);} .sw.on::after{left:20px;background:#04121a;}

/* ===== DASHBOARD ===== */
.metrics{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:18px;}
.metric{background:linear-gradient(160deg,var(--card),var(--surface));border:1px solid var(--border);border-radius:13px;padding:14px 15px;position:relative;overflow:hidden;}
.metric::after{content:'';position:absolute;right:-18px;top:-18px;width:78px;height:78px;border-radius:50%;background:radial-gradient(circle,var(--mc,var(--cyan)),transparent 70%);opacity:.1;}
.metric .lab{font-family:'JetBrains Mono';font-size:9px;letter-spacing:1.4px;color:var(--muted);text-transform:uppercase;}
.metric .val{font-family:'Orbitron';font-weight:700;font-size:25px;margin-top:6px;line-height:1;} .metric .val small{font-size:13px;color:var(--text2);font-family:'Rajdhani';}
.metric .delta{font-size:11.5px;font-weight:600;margin-top:6px;font-family:'JetBrains Mono';} .metric .delta.up{color:var(--green);} .metric .delta.flat{color:var(--text2);}
.bento{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:16px;}
.span2{grid-column:span 2;}
.queue{padding:14px 16px;display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.qcol .qh{font-family:'JetBrains Mono';font-size:9.5px;letter-spacing:1.5px;text-transform:uppercase;display:flex;align-items:center;gap:7px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border);}
.qcol .qh .n{margin-left:auto;background:var(--surface2);padding:1px 8px;border-radius:20px;color:var(--text2);}
.qh.queued{color:var(--amber);} .qh.running{color:var(--cyan);} .qh.done{color:var(--green);}
.qcard{background:var(--surface);border:1px solid var(--border2);border-radius:11px;padding:11px 12px;margin-bottom:9px;transition:.16s;cursor:pointer;}
.qcard:hover{border-color:var(--cyan);transform:translateY(-1px);} .qcard.live{border-color:var(--cyan);box-shadow:inset 0 0 14px rgba(0,229,255,.12);}
.qcard .qt{font-weight:700;font-size:13.5px;display:flex;align-items:center;gap:7px;} .qcard .qbot{font-family:'JetBrains Mono';font-size:8.5px;background:var(--cyan-dim);color:var(--cyan);padding:1px 6px;border-radius:5px;}
.qcard .qm{font-family:'JetBrains Mono';font-size:9.5px;color:var(--text2);margin-top:5px;}
.qcard .prog{height:3px;background:var(--border2);border-radius:3px;margin-top:9px;overflow:hidden;} .qcard .prog i{display:block;height:100%;background:linear-gradient(90deg,var(--cyan2),var(--cyan));border-radius:3px;animation:flow 1.5s ease-in-out infinite;}
@keyframes flow{0%{width:20%;}50%{width:70%;}100%{width:20%;}}
.spin{width:11px;height:11px;border:2px solid var(--cyan);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite;} .check{color:var(--green);}
.list{padding:6px 8px 10px;flex:1;}
.row{display:grid;grid-template-columns:32px 1fr auto;gap:11px;align-items:center;padding:10px;border-radius:10px;transition:.16s;cursor:pointer;}
.row:hover{background:var(--surface2);} .row+.row{border-top:1px solid var(--border);}
.ricon{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;font-size:14px;background:var(--surface);border:1px solid var(--border2);flex-shrink:0;} .ricon.cy{border-color:var(--cyan);color:var(--cyan);}
.rmid .rn{font-weight:700;font-size:13.5px;} .rmid .rs{font-family:'JetBrains Mono';font-size:9.5px;color:var(--text2);margin-top:2px;} .rmid .rs .hi{color:var(--cyan);} .rmid .rs .gr{color:var(--green);}
.rt{font-family:'JetBrains Mono';font-size:9px;color:var(--muted);}
.brief{padding:14px 16px;flex:1;} .brief .bt{font-family:'Orbitron';font-size:14px;font-weight:700;margin-bottom:8px;} .brief p{font-size:13px;color:var(--text2);line-height:1.55;} .brief .bk{display:flex;gap:7px;margin-top:10px;flex-wrap:wrap;} .bk-i{font-family:'JetBrains Mono';font-size:9px;background:var(--surface2);border:1px solid var(--border2);padding:3px 8px;border-radius:6px;color:var(--text2);} .brief .by{font-family:'JetBrains Mono';font-size:9px;color:var(--muted);margin-top:10px;}
.crew{padding:12px 14px;display:grid;grid-template-columns:repeat(5,1fr);gap:8px;flex:1;}
.crew-c{aspect-ratio:1;border-radius:11px;background:var(--surface);border:1px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:.16s;position:relative;}
.crew-c:hover{border-color:var(--cyan);transform:translateY(-2px);} .crew-c .em{font-size:17px;} .crew-c .cn{font-family:'JetBrains Mono';font-size:7.5px;color:var(--text2);letter-spacing:.4px;}
.crew-c .st{position:absolute;top:6px;right:6px;width:5px;height:5px;border-radius:50%;} .crew-c .st.on{background:var(--green);box-shadow:0 0 6px var(--green);} .crew-c .st.off{background:var(--muted);}
.spend{padding:14px 16px;display:flex;align-items:center;gap:16px;flex:1;}
.gauge{--p:25;width:88px;height:88px;border-radius:50%;flex-shrink:0;position:relative;background:conic-gradient(var(--cyan) calc(var(--p)*1%),var(--border) 0);display:grid;place-items:center;} .gauge::before{content:'';position:absolute;inset:10px;border-radius:50%;background:var(--card);} .gauge .gi{position:relative;text-align:center;} .gauge .gi .pct{font-family:'Orbitron';font-weight:700;font-size:17px;color:var(--cyan);} .gauge .gi .lb{font-family:'JetBrains Mono';font-size:7px;letter-spacing:1px;color:var(--muted);}
.spend-info{flex:1;} .spend-info .si{display:flex;justify-content:space-between;font-size:12.5px;padding:4px 0;border-bottom:1px solid var(--border);} .spend-info .si:last-child{border:none;} .spend-info .si span:first-child{color:var(--text2);} .spend-info .si span:last-child{font-family:'JetBrains Mono';font-weight:600;}
.ct-sync{display:flex;align-items:center;gap:8px;font-family:'JetBrains Mono';font-size:9px;color:var(--green);margin:0 12px 10px;padding:7px 10px;background:rgba(0,255,156,.06);border:1px solid rgba(0,255,156,.18);border-radius:8px;}
.ct-sync .g{width:14px;height:14px;border-radius:3px;background:linear-gradient(135deg,#4285f4,#34a853);display:grid;place-items:center;font-size:8px;color:#fff;font-weight:700;}
.ct-row{display:flex;align-items:center;gap:10px;padding:7px 12px;cursor:pointer;transition:.16s;} .ct-row:hover{background:var(--surface2);}
.ct-av{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:12px;color:#06101a;flex-shrink:0;} .ct-row .cn{font-weight:600;font-size:13px;} .ct-row .ce{font-family:'JetBrains Mono';font-size:9px;color:var(--muted);} .ct-row .cact{margin-left:auto;color:var(--text2);} .ct-row:hover .cact{color:var(--cyan);}

/* ===== PROJECTS LIST ===== */
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.pcard{background:linear-gradient(160deg,var(--card),var(--surface));border:1px solid var(--border);border-radius:16px;padding:20px;cursor:pointer;transition:.18s;position:relative;overflow:hidden;}
.pcard:hover{border-color:var(--cyan);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.4),0 0 0 1px var(--cyan-dim);}
.pcard::after{content:'';position:absolute;right:-30px;top:-30px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,var(--pc,var(--cyan)),transparent 70%);opacity:.08;}
.pcard .picon{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;font-size:22px;background:var(--surface2);border:1px solid var(--border2);margin-bottom:14px;}
.pcard .ptitle{font-family:'Orbitron';font-weight:700;font-size:17px;margin-bottom:5px;}
.pcard .pdesc{font-size:13px;color:var(--text2);line-height:1.5;margin-bottom:16px;min-height:38px;}
.pcard .pstats{display:flex;gap:16px;padding-top:14px;border-top:1px solid var(--border);}
.pcard .pstat{display:flex;flex-direction:column;} .pcard .pstat .pv{font-family:'Orbitron';font-weight:700;font-size:16px;} .pcard .pstat .pl2{font-family:'JetBrains Mono';font-size:8px;letter-spacing:1px;color:var(--muted);text-transform:uppercase;margin-top:2px;}
.pcard .pactive{position:absolute;top:18px;right:18px;font-family:'JetBrains Mono';font-size:8.5px;color:var(--green);display:flex;align-items:center;gap:5px;} .pcard .pactive::before{content:'●';animation:blink 1.8s infinite;}
.pcard.new{border-style:dashed;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--muted);min-height:230px;} .pcard.new:hover{color:var(--cyan);} .pcard.new .big{font-size:40px;margin-bottom:8px;}

/* ===== PROJECT CONTROL ROOM ===== */
.crumb{display:flex;align-items:center;gap:8px;font-family:'JetBrains Mono';font-size:11px;color:var(--text2);margin-bottom:14px;cursor:pointer;} .crumb:hover{color:var(--cyan);}
.pr-hero{background:linear-gradient(135deg,var(--surface2),var(--card));border:1px solid var(--border2);border-radius:16px;padding:22px;margin-bottom:18px;display:flex;align-items:center;gap:18px;position:relative;overflow:hidden;}
.pr-hero::after{content:'';position:absolute;right:-40px;top:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,var(--cyan),transparent 70%);opacity:.1;}
.pr-hero .pricon{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;font-size:28px;background:var(--surface);border:1px solid var(--cyan);box-shadow:inset 0 0 16px rgba(0,229,255,.15);}
.pr-hero h1{font-family:'Orbitron';font-size:23px;font-weight:700;} .pr-hero .pd{color:var(--text2);font-size:13.5px;margin-top:4px;}
.pr-hero .prmeta{display:flex;gap:20px;margin-left:auto;} .prmeta .pm{text-align:center;} .prmeta .pm .v{font-family:'Orbitron';font-weight:700;font-size:20px;color:var(--cyan);} .prmeta .pm .l{font-family:'JetBrains Mono';font-size:8px;letter-spacing:1px;color:var(--muted);text-transform:uppercase;}
.pr-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}

/* ===== CHATS (two-pane) ===== */
.chat-shell{display:grid;grid-template-columns:300px 1fr;gap:0;height:calc(100vh - 130px);border:1px solid var(--border);border-radius:16px;overflow:hidden;background:var(--card);}
.chat-list{border-right:1px solid var(--border);background:var(--bg2);display:flex;flex-direction:column;}
.cl-head{padding:14px 14px 10px;border-bottom:1px solid var(--border);}
.cl-search{width:100%;background:var(--surface);border:1px solid var(--border2);border-radius:9px;padding:8px 12px;color:var(--text);font-family:'Rajdhani';font-size:13px;outline:none;} .cl-search::placeholder{color:var(--muted);} .cl-search:focus{border-color:var(--cyan);}
.cl-scroll{overflow-y:auto;flex:1;} .cl-scroll::-webkit-scrollbar{width:5px;} .cl-scroll::-webkit-scrollbar-thumb{background:var(--border2);border-radius:5px;}
.cl-item{display:grid;grid-template-columns:34px 1fr;gap:10px;padding:12px 14px;cursor:pointer;border-left:3px solid transparent;transition:.14s;}
.cl-item:hover{background:var(--surface);} .cl-item.active{background:var(--surface2);border-left-color:var(--cyan);}
.cl-av{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-size:15px;background:var(--surface);border:1px solid var(--border2);}
.cl-item.active .cl-av{border-color:var(--cyan);}
.cl-mid{min-width:0;} .cl-mid .ct{font-weight:700;font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;} .cl-mid .cp{font-size:11.5px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px;} .cl-mid .cm{font-family:'JetBrains Mono';font-size:8.5px;color:var(--muted);margin-top:3px;}
.cl-item .cbadge{margin-left:auto;width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 6px var(--cyan-glow);align-self:start;margin-top:4px;}
/* convo pane */
.convo{display:flex;flex-direction:column;background:linear-gradient(180deg,var(--card),var(--surface));}
.convo-head{padding:13px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;}
.convo-head .ch-av{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-size:17px;background:var(--surface);border:1px solid var(--cyan);}
.convo-head .ch-t{font-family:'Orbitron';font-size:14px;font-weight:700;} .convo-head .ch-s{font-family:'JetBrains Mono';font-size:9.5px;color:var(--text2);margin-top:2px;}
.convo-head .ch-act{margin-left:auto;display:flex;gap:8px;}
.msgs{flex:1;overflow-y:auto;overflow-x:hidden;padding:20px 18px;display:flex;flex-direction:column;gap:14px;} .msgs::-webkit-scrollbar{width:5px;} .msgs::-webkit-scrollbar-thumb{background:var(--border2);border-radius:5px;}
.msg{max-width:78%;display:flex;gap:10px;}
.msg.me{align-self:flex-end;flex-direction:row-reverse;}
.msg .mav{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-size:13px;flex-shrink:0;background:var(--surface);border:1px solid var(--border2);}
.msg.me .mav{background:linear-gradient(135deg,var(--violet),var(--cyan));color:#06101a;border:none;}
.msg .bubble{background:var(--surface2);border:1px solid var(--border);border-radius:13px;padding:11px 14px;font-size:13.5px;line-height:1.55;overflow-wrap:anywhere;}
.msg.me .bubble{background:var(--cyan-dim);border-color:var(--cyan2);}
.msg .mname{font-family:'JetBrains Mono';font-size:9px;color:var(--cyan);margin-bottom:4px;letter-spacing:.5px;}
.composer{padding:14px 18px;border-top:1px solid var(--border);display:flex;gap:10px;align-items:center;}
.composer .cbox{flex:1;background:var(--surface);border:1px solid var(--border2);border-radius:12px;padding:11px 14px;color:var(--text);font-family:'Rajdhani';font-size:14px;outline:none;} .composer .cbox:focus{border-color:var(--cyan);}
.composer .send{width:42px;height:42px;border-radius:12px;border:none;background:linear-gradient(135deg,var(--cyan),var(--cyan2));color:#04121a;font-size:17px;cursor:pointer;box-shadow:0 0 16px rgba(0,229,255,.3);}
/* v17.12.32 in-flight status — base hidden in stylesheet (v17.12.30 lesson); .tool-spinner reuses @keyframes spin at line 32. */
.composer-status{display:none;padding:4px 18px;font-family:'JetBrains Mono',monospace;font-size:8px;color:var(--cyan);letter-spacing:2px;border-top:1px solid var(--border);align-items:center;gap:6px;}
.composer-status.active{display:flex;}
.tool-spinner{width:7px;height:7px;border:1px solid var(--cyan);border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0;}

/* ===== AUTOMATIONS (full) ===== */
.auto-list{display:flex;flex-direction:column;gap:12px;}
.auto-card{background:linear-gradient(160deg,var(--card),var(--surface));border:1px solid var(--border);border-radius:14px;padding:16px 18px;display:grid;grid-template-columns:48px 1fr auto;gap:15px;align-items:center;transition:.16s;cursor:pointer;}
.auto-card:hover{border-color:var(--cyan);}
.auto-card .aico{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;font-size:20px;background:var(--surface);border:1px solid var(--border2);} .auto-card .aico.on{border-color:var(--cyan);color:var(--cyan);box-shadow:inset 0 0 12px rgba(0,229,255,.15);} .auto-card .aico.idle{color:var(--muted);}
.auto-card .an{font-weight:700;font-size:16px;} .auto-card .am{font-family:'JetBrains Mono';font-size:10.5px;color:var(--text2);margin-top:5px;display:flex;gap:9px;flex-wrap:wrap;} .auto-card .am .src{color:var(--cyan);} .auto-card .am .fire{color:var(--green);}
.chip{font-family:'JetBrains Mono';font-size:9px;padding:2px 7px;border-radius:6px;letter-spacing:.5px;} .chip.gmail{background:rgba(255,77,109,.12);color:#ff8da3;} .chip.bot{background:var(--cyan-dim);color:var(--cyan);}
.auto-right{display:flex;align-items:center;gap:14px;} .auto-right .ar-stat{text-align:right;} .auto-right .ar-stat .v{font-family:'Orbitron';font-weight:700;font-size:15px;} .auto-right .ar-stat .l{font-family:'JetBrains Mono';font-size:8px;color:var(--muted);text-transform:uppercase;}

/* ===== TASKS ===== */
.kanban{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.kcol{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:14px;}
.kcol .kh{font-family:'JetBrains Mono';font-size:10px;letter-spacing:1.5px;text-transform:uppercase;display:flex;align-items:center;gap:7px;margin-bottom:12px;}
.kcol .kh .n{margin-left:auto;background:var(--surface2);padding:1px 8px;border-radius:20px;color:var(--text2);}
.kh.q{color:var(--amber);} .kh.r{color:var(--cyan);} .kh.d{color:var(--green);}
.ktask{background:var(--card);border:1px solid var(--border2);border-radius:11px;padding:13px;margin-bottom:10px;cursor:pointer;transition:.16s;} .ktask:hover{border-color:var(--cyan);transform:translateY(-1px);} .ktask.live{border-color:var(--cyan);box-shadow:inset 0 0 14px rgba(0,229,255,.1);}
.ktask .kt{font-weight:700;font-size:14px;display:flex;align-items:center;gap:7px;} .ktask .kbot{font-family:'JetBrains Mono';font-size:8.5px;background:var(--cyan-dim);color:var(--cyan);padding:1px 6px;border-radius:5px;}
.ktask .km{font-family:'JetBrains Mono';font-size:9.5px;color:var(--text2);margin-top:6px;} .ktask .ktrig{font-family:'JetBrains Mono';font-size:8.5px;color:var(--violet);margin-top:6px;} .ktask .prog{height:3px;background:var(--border2);border-radius:3px;margin-top:10px;overflow:hidden;} .ktask .prog i{display:block;height:100%;background:linear-gradient(90deg,var(--cyan2),var(--cyan));animation:flow 1.5s ease-in-out infinite;}

/* ===== BRIEFINGS ===== */
.brief-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:16px;}
.brief-feat{background:linear-gradient(160deg,var(--surface2),var(--card));border:1px solid var(--border2);border-radius:16px;padding:24px;}
.brief-feat .bf-tag{font-family:'JetBrains Mono';font-size:9px;letter-spacing:1.5px;color:var(--cyan);background:var(--cyan-dim);padding:3px 9px;border-radius:20px;display:inline-block;margin-bottom:14px;}
.brief-feat h2{font-family:'Orbitron';font-size:21px;font-weight:700;margin-bottom:14px;}
.brief-feat p{font-size:14px;color:var(--text2);line-height:1.65;margin-bottom:12px;}
.brief-feat .bf-meta{display:flex;gap:10px;margin-top:18px;padding-top:16px;border-top:1px solid var(--border);}
.brief-mini{background:linear-gradient(160deg,var(--card),var(--surface));border:1px solid var(--border);border-radius:13px;padding:15px 17px;margin-bottom:12px;cursor:pointer;transition:.16s;} .brief-mini:hover{border-color:var(--cyan);}
.brief-mini .bm-t{font-family:'Orbitron';font-size:14px;font-weight:700;} .brief-mini .bm-p{font-size:12.5px;color:var(--text2);margin-top:5px;line-height:1.5;} .brief-mini .bm-d{font-family:'JetBrains Mono';font-size:9px;color:var(--muted);margin-top:8px;}

/* ===== CREW PAGE ===== */
.crew-page{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.crew-big{background:linear-gradient(160deg,var(--card),var(--surface));border:1px solid var(--border);border-radius:15px;padding:18px;text-align:center;cursor:pointer;transition:.16s;position:relative;} .crew-big:hover{border-color:var(--cyan);transform:translateY(-3px);}
.crew-big .cb-av{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;font-size:26px;background:var(--surface2);border:1px solid var(--border2);margin:0 auto 12px;}
.crew-big .cb-n{font-family:'Orbitron';font-size:14px;font-weight:700;} .crew-big .cb-r{font-family:'JetBrains Mono';font-size:9px;color:var(--text2);margin-top:3px;} .crew-big .cb-stat{display:flex;justify-content:center;gap:14px;margin-top:13px;padding-top:12px;border-top:1px solid var(--border);} .crew-big .cb-stat .v{font-family:'Orbitron';font-weight:700;font-size:14px;color:var(--cyan);} .crew-big .cb-stat .l{font-family:'JetBrains Mono';font-size:7.5px;color:var(--muted);}
.crew-big .cb-st{position:absolute;top:12px;right:12px;width:7px;height:7px;border-radius:50%;} .crew-big .cb-st.on{background:var(--green);box-shadow:0 0 6px var(--green);} .crew-big .cb-st.off{background:var(--muted);}

.section-title{font-family:'Orbitron';font-weight:700;font-size:12px;letter-spacing:1px;color:var(--text2);margin:24px 4px 14px;display:flex;align-items:center;gap:10px;} .section-title::after{content:'';flex:1;height:1px;background:var(--border);}

@media (max-width:1180px){.metrics{grid-template-columns:repeat(3,1fr);}.bento,.pr-grid,.brief-grid{grid-template-columns:1fr;}.span2{grid-column:span 1;}.proj-grid{grid-template-columns:repeat(2,1fr);}.crew-page{grid-template-columns:repeat(3,1fr);}}

/* ── W2b additions ─ .auto-banner + .auto-toggle ─────────────────────
   Additive only. Does NOT redefine .auto-list, .auto-card, .aico,
   .an, .am, .chip, .fire, .auto-right, or .sw (all preserved above).
   .auto-banner clones the .ct-sync soft-tint pattern with --amber for
   warning palette. .auto-toggle inherits the .sw on/off color story
   (cyan-glow for on, muted/surface for off) but renders as a text
   pill ("ARMED" / "IDLE") rather than a sliding-dot pill, because
   the W2b button is text-bearing. */
.auto-banner{font-family:'JetBrains Mono';font-size:11px;letter-spacing:.4px;color:var(--amber);background:rgba(255,184,48,.08);border:1px solid rgba(255,184,48,.22);border-radius:11px;padding:10px 14px;margin-bottom:12px;}
.auto-toggle{font-family:'JetBrains Mono';font-size:10px;letter-spacing:1.2px;text-transform:uppercase;font-weight:700;color:var(--text2);background:var(--surface);border:1px solid var(--border2);border-radius:20px;padding:6px 14px;cursor:pointer;transition:.16s;flex-shrink:0;}
.auto-toggle:hover{border-color:var(--cyan);color:var(--cyan);}
.auto-toggle.on{background:linear-gradient(90deg,var(--cyan2),var(--cyan));color:#04121a;border-color:var(--cyan);box-shadow:0 0 12px var(--cyan-glow);}
.auto-toggle.on:hover{box-shadow:0 0 16px var(--cyan-glow);}
.auto-toggle:disabled{opacity:.55;cursor:wait;}

/* ── W3 additions ─ projects view (live CRUD) ────────────────────────
   Additive only. Does NOT redefine .proj-grid, .pcard, .pcard.new,
   .pcard .picon, .pcard .ptitle, .pcard .pdesc, .pcard .pactive,
   .pcard .pstats, .pcard.new .big (all preserved above).
   .proj-banner clones .auto-banner amber-tint pattern; .info variant
   for the post-archive notice uses the cyan tint. */
.proj-banner{font-family:'JetBrains Mono';font-size:11px;letter-spacing:.4px;color:var(--amber);background:rgba(255,184,48,.08);border:1px solid rgba(255,184,48,.22);border-radius:11px;padding:10px 14px;margin-bottom:12px;}
.proj-banner.info{color:var(--cyan);background:rgba(0,229,255,.06);border-color:rgba(0,229,255,.22);}
.pdefault-tag{font-family:'JetBrains Mono';font-size:8.5px;letter-spacing:1px;color:var(--green);background:rgba(0,255,156,.1);border:1px solid rgba(0,255,156,.25);padding:2px 6px;border-radius:6px;margin-left:8px;vertical-align:middle;font-weight:600;}
.pcard-menu-btn{position:absolute;top:14px;right:14px;width:28px;height:28px;border-radius:8px;border:1px solid var(--border2);background:var(--surface);color:var(--text2);font-size:14px;cursor:pointer;display:grid;place-items:center;transition:.14s;z-index:2;font-family:'Orbitron';line-height:1;}
.pcard-menu-btn:hover{border-color:var(--cyan);color:var(--cyan);}
.pcard-menu{position:absolute;top:48px;right:14px;min-width:170px;background:var(--surface);border:1px solid var(--border2);border-radius:11px;padding:5px;z-index:3;box-shadow:0 8px 24px rgba(0,0,0,.45);}
.pcard-menu-item{padding:8px 11px;border-radius:7px;cursor:pointer;font-size:13px;color:var(--text2);font-family:'Rajdhani';font-weight:600;}
.pcard-menu-item:hover{background:var(--surface2);color:var(--text);}
.pcard-menu-item.danger:hover{color:var(--red);}
.pcard.creating{border-style:solid;border-color:var(--cyan);box-shadow:0 0 0 1px var(--cyan-dim) inset;min-height:230px;display:flex;flex-direction:column;}
.pcard-form{display:flex;flex-direction:column;gap:12px;flex:1;}
.pcard-form-label{font-family:'JetBrains Mono';font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--cyan);}
.pcard-form-name{background:var(--surface);border:1px solid var(--border2);border-radius:9px;padding:9px 12px;color:var(--text);font-family:'Rajdhani';font-size:14px;outline:none;font-weight:600;width:100%;}
.pcard-form-name:focus{border-color:var(--cyan);}
.pcard-form-name:disabled{opacity:.55;cursor:wait;}
.pcard-form-row{display:flex;align-items:center;gap:10px;}
.pcard-form-mini{font-family:'JetBrains Mono';font-size:9px;letter-spacing:1px;color:var(--muted);text-transform:uppercase;}
.pcard-form-swatches{display:flex;gap:7px;flex-wrap:wrap;}
.pcard-swatch{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;transition:.14s;opacity:.55;}
.pcard-swatch:hover{opacity:1;transform:scale(1.08);}
.pcard-swatch.active{opacity:1;border-color:var(--text);box-shadow:0 0 0 2px var(--bg);}
.pcard-form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:auto;}
.pcard-form-actions .btn-primary,.pcard-form-actions .btn-ghost{height:34px;font-size:12.5px;padding:0 14px;}
.pcard-form-actions .btn-primary:disabled,.pcard-form-actions .btn-ghost:disabled{opacity:.55;cursor:wait;}
.pcard.inflight{opacity:.6;pointer-events:none;}
/* -- W8a: configure modal (cfgm-) -- JS-created overlay, see shell-crew.js -- */
#cfgm-overlay{display:none;position:fixed;inset:0;z-index:300;background:rgba(4,6,10,.72);backdrop-filter:blur(4px);align-items:center;justify-content:center;padding:18px;}
#cfgm-overlay.show{display:flex;}
.cfgm{width:min(560px,100%);max-height:92vh;display:flex;flex-direction:column;background:linear-gradient(160deg,var(--card),var(--surface));border:1px solid var(--border2);border-radius:15px;box-shadow:0 18px 60px rgba(0,0,0,.55);overflow:hidden;}
.cfgm-head{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 18px 12px;border-bottom:1px solid var(--border);}
.cfgm-title{font-family:'Orbitron';font-size:15px;font-weight:700;letter-spacing:.5px;}
.cfgm-sub{font-family:'JetBrains Mono';font-size:9px;color:var(--text2);margin-top:3px;letter-spacing:.5px;}
.cfgm-x{background:none;border:none;color:var(--text2);font-family:'JetBrains Mono';font-size:14px;cursor:pointer;padding:2px 6px;}
.cfgm-x:hover{color:var(--text);}
.cfgm-body{padding:14px 18px;display:flex;flex-direction:column;gap:8px;overflow-y:auto;}
.cfgm-l{font-family:'JetBrains Mono';font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--cyan);margin-top:4px;}
.cfgm-hint{color:var(--muted);text-transform:none;letter-spacing:.5px;}
.cfgm-i,.cfgm-t{background:var(--surface);border:1px solid var(--border2);border-radius:9px;padding:8px 11px;color:var(--text);font-family:'Rajdhani';font-size:14px;font-weight:600;outline:none;width:100%;}
.cfgm-i:focus,.cfgm-t:focus{border-color:var(--cyan);}
.cfgm-i:disabled,.cfgm-t:disabled{opacity:.5;}
.cfgm-t{font-family:'JetBrains Mono';font-size:11.5px;font-weight:400;line-height:1.5;resize:vertical;min-height:110px;}
.cfgm-row{display:flex;gap:10px;align-items:flex-end;}
.cfgm-col{display:flex;flex-direction:column;gap:4px;}
.cfgm-grow{flex:1;}
.cfgm-icon{width:64px;text-align:center;font-size:18px;}
.cfgm-c{width:46px;height:36px;padding:2px;border:1px solid var(--border2);border-radius:9px;background:var(--surface);cursor:pointer;}
.cfgm-tog{display:flex;align-items:center;gap:6px;font-family:'JetBrains Mono';font-size:9px;letter-spacing:1px;color:var(--text2);white-space:nowrap;padding-bottom:9px;cursor:pointer;}
.cfgm-err{font-family:'JetBrains Mono';font-size:10px;color:var(--red,#ff4d6d);min-height:14px;}
.cfgm-foot{display:flex;align-items:center;gap:8px;padding:12px 18px 16px;border-top:1px solid var(--border);}
.cfgm-spacer{flex:1;}
.cfgm-danger{color:var(--red,#ff4d6d);border-color:var(--red,#ff4d6d);}

/* v17.12.2 chats scroll fix: flex/grid descendants default to min-height:auto which lets .msgs push the composer off-screen; min-height:0 lets the scroll container activate */
.chat-shell > *{min-height:0;min-width:0;}
.convo{min-height:0;}
.msgs{min-height:0;}

/* W10/B4 -- dashboard head: notifications bell, search dropdown, CAP-> tap-through (cfgm-adjacent visual vocab, ntf-/dsr- prefixes) */
#v-dashboard .vhead{position:relative;}
.ntf-dropdown,.dsr-dropdown{position:absolute;top:54px;right:0;width:min(420px,92vw);max-height:540px;background:var(--surface);border:1px solid var(--border2);border-radius:11px;z-index:60;box-shadow:0 14px 36px rgba(0,0,0,.55);display:flex;flex-direction:column;overflow:hidden;}
.ntf-head,.dsr-head{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border);}
.ntf-title{font-family:'Orbitron';font-size:11px;letter-spacing:1.5px;font-weight:700;color:var(--text);}
.ntf-spacer{flex:1;}
.ntf-mark-all{background:none;border:1px solid var(--border2);color:var(--cyan);font-family:'JetBrains Mono';font-size:9px;letter-spacing:1px;padding:4px 8px;border-radius:7px;cursor:pointer;}
.ntf-mark-all:hover{border-color:var(--cyan);}
.ntf-x{background:none;border:none;color:var(--text2);font-family:'JetBrains Mono';font-size:18px;line-height:1;cursor:pointer;padding:2px 8px;}
.ntf-x:hover{color:var(--text);}
.ntf-list,.dsr-list{overflow-y:auto;max-height:460px;padding:6px;}
.ntf-row{display:flex;gap:10px;padding:8px 10px;border-radius:9px;cursor:pointer;align-items:flex-start;}
.ntf-row:hover{background:var(--surface2);}
.ntf-row.unread{background:var(--cyan-dim);}
.ntf-row-icon{width:24px;text-align:center;font-size:14px;color:var(--cyan);padding-top:2px;}
.ntf-row-mid{flex:1;min-width:0;}
.ntf-row-title{font-family:'Rajdhani';font-weight:700;font-size:13px;color:var(--text);overflow:hidden;text-overflow:ellipsis;}
.ntf-row-body{font-family:'JetBrains Mono';font-size:10.5px;color:var(--text2);margin-top:3px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.ntf-row-meta{display:flex;gap:8px;align-items:center;margin-top:4px;font-family:'JetBrains Mono';font-size:9px;letter-spacing:.5px;color:var(--muted);}
.ntf-bot{color:var(--cyan);}
.ntf-row-act{display:flex;align-items:flex-start;}
.ntf-act-btn{background:none;border:1px solid var(--cyan);color:var(--cyan);font-family:'JetBrains Mono';font-size:9px;letter-spacing:1px;padding:4px 7px;border-radius:6px;cursor:pointer;}
.ntf-act-btn.ghost{border-color:var(--border2);color:var(--text2);}
.ntf-act-btn:hover{background:var(--cyan-dim);}
.ntf-empty{padding:18px 14px;text-align:center;color:var(--muted);font-family:'JetBrains Mono';font-size:10.5px;letter-spacing:.5px;}
.dsr-input{flex:1;background:var(--surface2);border:1px solid var(--border2);border-radius:9px;padding:7px 11px;color:var(--text);font-family:'Rajdhani';font-size:13px;font-weight:600;outline:none;}
.dsr-input:focus{border-color:var(--cyan);}
.dsr-row{display:flex;gap:10px;padding:8px 10px;border-radius:9px;cursor:pointer;align-items:center;}
.dsr-row:hover{background:var(--surface2);}
.dsr-row-icon{width:24px;text-align:center;color:var(--cyan);}
.dsr-row-mid{flex:1;min-width:0;}
.dsr-row-title{font-family:'Rajdhani';font-weight:700;font-size:13px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dsr-row-meta{font-family:'JetBrains Mono';font-size:9px;letter-spacing:.5px;color:var(--muted);margin-top:2px;}

/* ===== v17.12.14 Batch 5 -- chats rich rendering ===== */
/* Assistant messages uncap to full row width (interpretation b); the inner
   wrapper grows so the bubble flows free. User messages keep the 78% cap
   and bubble chrome via .msg.me. /app fmt() output styles scoped to
   .msg:not(.me) so user bubbles stay visually unchanged. */
.msg:not(.me){max-width:100%;width:100%;}
.msg:not(.me) > div + div{flex:1;min-width:0;}
.msg:not(.me) .bubble{background:transparent;border-color:transparent;padding:6px 0;font-size:14px;line-height:1.65;color:var(--text);position:relative;}
.msg:not(.me) .bubble p{margin:0 0 8px;} .msg:not(.me) .bubble p:last-child{margin-bottom:0;}
.msg:not(.me) .bubble strong{color:var(--cyan);font-weight:700;}
.msg:not(.me) .bubble em{color:var(--text);font-style:italic;}
.msg:not(.me) .bubble code{background:rgba(0,229,255,.08);border:1px solid rgba(0,229,255,.20);padding:1px 6px;border-radius:5px;font-family:JetBrains Mono,monospace;font-size:12.5px;color:var(--cyan);}
.msg:not(.me) .bubble ul, .msg:not(.me) .bubble ol{padding-left:20px;margin:4px 0 10px;}
.msg:not(.me) .bubble li{margin-bottom:4px;}
.msg:not(.me) .bubble h3{font-family:Orbitron,monospace;font-size:13px;color:var(--cyan);margin:12px 0 6px;letter-spacing:1px;font-weight:700;}
.msg:not(.me) .bubble h4{color:var(--amber);font-size:11px;margin:10px 0 4px;font-family:JetBrains Mono,monospace;letter-spacing:1px;}
.msg:not(.me) .bubble hr{border:none;border-top:1px solid var(--border);margin:12px 0;}
.msg:not(.me) .bubble blockquote{border-left:2px solid var(--cyan);padding-left:12px;color:var(--text2);margin:10px 0;font-style:italic;}
.msg:not(.me) .bubble a{color:var(--cyan);text-decoration:underline;text-underline-offset:2px;word-break:break-all;}
.msg:not(.me) .bubble a:hover{color:var(--cyan2);}

/* COPY button -- lifted from /app:195-206, scoped to assistant bubbles */
.msg-copy{position:absolute;top:0;right:0;background:rgba(0,229,255,.06);border:1px solid rgba(0,229,255,.22);color:var(--cyan);font-family:JetBrains Mono,monospace;font-size:8.5px;letter-spacing:1px;padding:3px 8px;border-radius:6px;cursor:pointer;opacity:0;transition:opacity .15s,background .15s,color .15s;z-index:2;}
.msg:not(.me) .bubble:hover .msg-copy{opacity:1;}
.msg-copy:hover{background:rgba(0,229,255,.18);color:var(--cyan2);}
.msg-copy.copied{background:rgba(0,255,156,.18);border-color:rgba(0,255,156,.45);color:var(--green);opacity:1;}
@media (hover:none){.msg-copy{opacity:.55;}}

/* cht- chrome -- tier select + action buttons + search input header */
.cht-tier{background:var(--surface);border:1px solid var(--border2);color:var(--text);font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:1.2px;font-weight:700;padding:6px 10px;border-radius:8px;cursor:pointer;outline:none;}
.cht-tier:focus{border-color:var(--cyan);}
.cht-act-btn{background:var(--surface);border:1px solid var(--border2);color:var(--text2);font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:1.2px;font-weight:700;padding:6px 10px;border-radius:8px;cursor:pointer;}
.cht-act-btn:hover{border-color:var(--cyan);color:var(--cyan);}
.cht-act-btn.danger:hover{border-color:var(--red);color:var(--red);}
.cl-head{padding:12px 14px;border-bottom:1px solid var(--border);}
.cl-head .cl-search{margin:0;}

/* ── v17.12.21 Batch 1 — off-canvas mobile rail + 4 stack fixes ──────
   Additive only. Base rules below keep .menu-btn + .menu-bd at
   display:none above the 768px breakpoint, so desktop (>768px) is
   layout-byte-identical to v17.12.18. The new @media block sits AFTER
   the existing @media(max-width:1180px) at :231 so where rules overlap
   (metrics, crew-page, proj-grid) the 768 declaration wins by source
   order at <=768px. Neither block conflicts with .rail / .app at any
   width — 1180 leaves both alone, 768 owns the off-canvas transform. */
.menu-btn{display:none;position:fixed;top:12px;left:12px;z-index:210;width:40px;height:40px;border-radius:10px;border:1px solid var(--border2);background:var(--surface);color:var(--text);font-family:'Orbitron';font-size:18px;cursor:pointer;place-items:center;}
.menu-btn:hover{border-color:var(--cyan);color:var(--cyan);}
.menu-bd{display:none;position:fixed;inset:0;background:rgba(4,6,10,.55);backdrop-filter:blur(2px);z-index:190;}
body.menu-open{overflow:hidden;}
body.menu-open .menu-btn{display:none;}
/* v17.12.23 Batch 2 -- chats single-pane: .cht-back base hidden everywhere,
   flipped on only inside the @media below when .chat-shell carries
   data-pane="convo". Desktop >768px never sees the button. */
.cht-back{display:none;background:var(--surface);border:1px solid var(--border2);color:var(--text2);font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:1.2px;font-weight:700;padding:6px 10px;border-radius:8px;cursor:pointer;}
.cht-back:hover{border-color:var(--cyan);color:var(--cyan);}
@media (max-width:768px){
  .app{grid-template-columns:1fr;}
  .rail{position:fixed;left:0;top:0;width:84vw;max-width:300px;height:100vh;height:100dvh;z-index:200;transform:translateX(-100%);transition:transform .22s ease;}
  .rail.open{transform:translateX(0);box-shadow:0 0 40px rgba(0,0,0,.6);}
  .menu-btn{display:grid;}
  .menu-bd.show{display:block;}
  .main{padding:60px 16px 40px;}
  .metrics{grid-template-columns:repeat(2,1fr);}
  .kanban{grid-template-columns:1fr;}
  .crew-page{grid-template-columns:repeat(2,1fr);}
  .proj-grid{grid-template-columns:1fr;}
  .chat-shell{grid-template-columns:1fr;}
  .chat-shell .convo{display:none;}
  .chat-shell[data-pane="convo"] .chat-list{display:none;}
  .chat-shell[data-pane="convo"] .convo{display:flex;}
  .chat-shell[data-pane="convo"] .cht-back{display:inline-flex;}
  .convo-head{flex-wrap:wrap;gap:8px;padding:11px 12px;}
  .convo-head .ch-title-block{flex:1 1 100%;order:0;min-width:0;}
  .convo-head .ch-t,.convo-head .ch-s{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .convo-head .ch-av{display:none;}
  .convo-head .cht-back,.convo-head .ch-act{order:1;}
  .ch-act{gap:4px;}
  .cht-act-btn,.cht-tier{padding:5px 6px;font-size:9px;}
  .cht-back{padding:6px 8px;}
  .msg-copy{position:static;display:block;opacity:.7;margin-top:8px;}
}

/* ── v17.12.39 — Attachments port (mirrored from index.html:258-328).
   @keyframes spin already defined at :32 (used by .spin / .tool-spinner /
   brand mark) — .attach-chip-spinner reuses it. ─────────────────────── */
.attach-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;min-height:0}
.attach-chips:empty{display:none}
.attach-chip{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--card);border:1px solid var(--border2);
  border-radius:14px;padding:4px 10px 4px 6px;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  color:var(--text2);letter-spacing:.4px;
  max-width:240px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  transition:border-color .12s;
}
.attach-chip.uploading{opacity:.7}
.attach-chip.ready{border-color:rgba(0,212,255,0.35)}
.attach-chip.failed{border-color:var(--red);color:var(--red)}
.attach-chip-thumb{width:20px;height:20px;border-radius:3px;object-fit:cover;flex-shrink:0;border:1px solid var(--border);}
.attach-chip-glyph{flex-shrink:0;font-size:13px;width:20px;text-align:center}
.attach-chip-spinner{
  width:12px;height:12px;border:1.5px solid var(--cyan);border-top-color:transparent;
  border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0;margin-left:4px;
}
.attach-chip-label{flex:1;overflow:hidden;text-overflow:ellipsis}
.attach-chip-x{flex-shrink:0;background:none;border:none;color:var(--muted);font-size:13px;cursor:pointer;padding:0 2px;line-height:1;}
.attach-chip-x:hover{color:var(--red)}

.attach-btn{
  width:30px;height:30px;background:transparent;border:1px solid var(--border2);
  border-radius:2px;cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:14px;transition:all .15s;flex-shrink:0;color:var(--muted);
  align-self:flex-end;margin-bottom:2px;
}
.attach-btn:hover{border-color:var(--cyan);color:var(--cyan)}

.input-area{position:relative}
.input-area.drag-over{
  outline:2px dashed var(--cyan);outline-offset:-6px;
  background:linear-gradient(0deg,rgba(0,212,255,0.08) 0%,transparent 100%);
}
.input-area.drag-over::after{
  content:'DROP TO ATTACH';
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:3px;
  color:var(--cyan);pointer-events:none;text-shadow:0 0 12px rgba(0,212,255,0.6);
}

.msg-attachments{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}
.msg-attach{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--card);border:1px solid var(--border);
  border-radius:10px;padding:3px 8px 3px 4px;
  font-family:'JetBrains Mono',monospace;font-size:9px;
  color:var(--muted);letter-spacing:.3px;
  max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.msg-attach-thumb{width:16px;height:16px;border-radius:2px;object-fit:cover;flex-shrink:0}
.msg-attach-glyph{flex-shrink:0;font-size:11px;width:16px;text-align:center}
.msg-attach-name{flex:1;overflow:hidden;text-overflow:ellipsis}
