:root{
  --bg:#0c0e13; --panel:#13161d; --panel2:#191d27; --inset:#0f1219;
  --line:rgba(255,255,255,.07); --line2:rgba(255,255,255,.13);
  --txt:#e7eaf0; --mut:#9aa3b2; --dim:#5d6678;
  --acc:#5b8cff; --accbg:rgba(91,140,255,.13);
  --grn:#3dd68c; --grnbg:rgba(61,214,140,.12);
  --red:#ff6b6b; --redbg:rgba(255,107,107,.10);
  --amb:#f5b14d; --ambbg:rgba(245,177,77,.13);
  --pur:#b18cff; --teal:#39c5cf;
  --mono:'JetBrains Mono',ui-monospace,monospace;
}
[data-theme="light"]{
  --bg:#f4f5f8; --panel:#ffffff; --panel2:#f0f2f6; --inset:#e9ebf1;
  --line:rgba(20,24,40,.09); --line2:rgba(20,24,40,.16);
  --txt:#1b2030; --mut:#5a6376; --dim:#9aa1b2;
  --accbg:rgba(91,140,255,.12); --grnbg:rgba(22,160,90,.12); --redbg:rgba(220,60,60,.09); --ambbg:rgba(200,140,30,.13);
  --teal:#0d9488; --grn:#16a05a;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:var(--bg);color:var(--txt);font:13.5px/1.55 'Inter',system-ui,sans-serif;-webkit-font-smoothing:antialiased;overflow:hidden}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
input,textarea,select{font:inherit;color:var(--txt);background:var(--inset);border:1px solid var(--line2);border-radius:9px;padding:8px 12px;outline:none}
input:focus,textarea:focus{border-color:rgba(91,140,255,.5)}
::placeholder{color:var(--dim)}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:rgba(140,150,170,.22);border-radius:6px;border:2px solid transparent;background-clip:content-box}
::-webkit-scrollbar-track{background:transparent}

.btn{display:inline-flex;align-items:center;gap:6px;font:500 12.5px 'Inter';color:var(--mut);background:transparent;border:1px solid var(--line2);border-radius:8px;padding:5px 12px}
.btn:hover{color:var(--txt);background:var(--panel2)}
.btn-acc{background:var(--acc);border-color:var(--acc);color:#fff}
.btn-acc:hover{background:#6c98ff;color:#fff}
.btn-run{background:var(--grn);border-color:var(--grn);color:#06351f}
.btn-stop{background:var(--redbg);border-color:rgba(255,107,107,.4);color:var(--red)}
.btn-sm{padding:3px 9px;font-size:11.5px;border-radius:7px}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:var(--mut);background:var(--inset);border:1px solid var(--line);border-radius:999px;padding:2px 10px;white-space:nowrap}
.chip .ti{font-size:13px}
.chip-live{color:var(--grn)}
.chip-acc{color:var(--acc);background:var(--accbg);border-color:rgba(91,140,255,.3)}
.chip-warn{color:var(--amb);background:var(--ambbg);border-color:rgba(245,177,77,.3)}
.dot{width:6px;height:6px;border-radius:50%;display:inline-block;background:var(--dim)}
.dot-g{background:var(--grn)}.dot-a{background:var(--amb)}.dot-r{background:var(--red)}
.spin{display:inline-block;width:14px;height:14px;border:2px solid var(--line2);border-top-color:var(--acc);border-radius:50%;animation:spin .8s linear infinite;vertical-align:-2px}
@keyframes spin{to{transform:rotate(360deg)}}
.fade{animation:fadein .2s ease}
@keyframes fadein{from{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}

#genesis{position:fixed;inset:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:60;padding:0 24px}
#genesis .glogo{font-size:30px;color:var(--pur)}
#genesis h1{font-size:24px;font-weight:600}
#genesis .gin{width:min(620px,90vw);font-size:14.5px;padding:14px 18px;border-radius:13px}
.chiprow{display:flex;flex-wrap:wrap;gap:7px;justify-content:center}
.hint{font-size:12px;color:var(--dim)}

#workspace{display:none;height:100vh;height:100dvh}
#workspace.on{display:flex}
.rail{width:46px;flex:none;border-right:1px solid var(--line);display:flex;flex-direction:column;align-items:center;gap:10px;padding:12px 0;background:var(--panel)}
.rail .home{width:27px;height:27px;border-radius:9px;background:var(--accbg);color:var(--acc);display:flex;align-items:center;justify-content:center;font-size:15px}
.rail>i,.rail>button{color:var(--dim);font-size:17px}
.rail .dg{width:27px;height:27px;border-radius:9px;background:var(--panel2);display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--dim)}
.rail .grow{flex:1}
#railProjects{display:flex;flex-direction:column;gap:8px;align-items:center}
.pavatar{width:30px;height:30px;border-radius:9px;background:var(--panel2);border:1px solid var(--line2);color:var(--mut);font:600 13px 'Inter';display:flex;align-items:center;justify-content:center;position:relative;flex:none}
.pavatar:hover{color:var(--txt);border-color:var(--line2)}
.pavatar.on{background:var(--accbg);color:var(--acc);border-color:var(--acc)}
.pavatar.shared{border-style:dashed} /* a project shared WITH me (collaborator), vs my own */
.pavatar.live::after{content:'';position:absolute;bottom:-2px;right:-2px;width:8px;height:8px;border-radius:50%;background:var(--grn);border:2px solid var(--panel)}
.pavatar.busy::after{content:'';position:absolute;bottom:-2px;right:-2px;width:8px;height:8px;border-radius:50%;background:var(--acc);border:2px solid var(--panel);animation:pulse 1.2s ease infinite}
.railadd{width:30px;height:30px;border-radius:9px;color:var(--dim);font-size:16px;display:flex;align-items:center;justify-content:center;flex:none}
.railadd:hover{color:var(--txt);background:var(--panel2)}
.chatlist{display:flex;flex-wrap:wrap;gap:6px;padding:9px 14px 2px;flex:none}
.chatchip{font:500 11.5px 'Inter';color:var(--mut);background:var(--panel2);border:1px solid var(--line);border-radius:999px;padding:3px 11px;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:none}
.chatchip:hover{color:var(--txt)}
.chatchip.on{background:var(--accbg);color:var(--acc);border-color:rgba(91,140,255,.35)}

#agentcol{width:470px;flex:none;min-width:320px;max-width:720px;border-right:1px solid var(--line);display:flex;flex-direction:column;background:var(--panel);position:relative}
.dragbar{position:absolute;top:0;right:-6px;width:12px;height:100%;cursor:col-resize;z-index:5;display:flex;justify-content:center}
.dragbar::after{content:'';width:3px;height:100%;border-radius:2px;background:transparent;transition:background .12s}
.dragbar:hover::after,.dragbar.dragging::after{background:var(--acc)}

/* file drawer — a persistent, toggleable left panel (the project's files), separate from the
   editor/preview panes. Toggle with ⌘⇧L or the topbar button. */
#filedrawer{width:230px;flex:none;border-left:1px solid var(--line);background:var(--panel);display:flex;flex-direction:column;overflow:hidden}
body.fileshidden #filedrawer{display:none}
#filedrawer .fdhead{display:flex;align-items:center;gap:8px;padding:10px 12px;flex:none}
#filedrawer .fdhead b{font-size:12px;flex:1}
#filedrawer .fdhead button{color:var(--dim);font-size:14px;display:flex}
#filedrawer .fdhead button:hover{color:var(--txt)}
#filedrawer .fdsearch{flex:none;padding:0 10px 8px}
#filedrawer .fdsearch input{width:100%;font-size:12px;padding:6px 9px;border-radius:8px;background:var(--inset);border:1px solid var(--line);color:var(--txt)}
#filedrawer .tree{flex:1;min-height:0;overflow:auto}
#btnFiles.on{color:var(--acc);border-color:rgba(91,140,255,.4)}

#maincol{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--panel)}
#topbar{display:flex;align-items:center;gap:10px;height:46px;padding:0 12px;border-bottom:1px solid var(--line);flex-wrap:nowrap;overflow:hidden}
#topbar .pname{font-size:13px;font-weight:600;margin-right:4px}
#tabstrip{display:flex;align-items:center;gap:4px;overflow-x:auto;flex:1;min-width:0;scrollbar-width:none}
#tabstrip::-webkit-scrollbar{display:none}
.ttab{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--mut);border:1px solid transparent;border-radius:9px;padding:5px 11px;cursor:pointer;white-space:nowrap;flex:none}
.ttab:hover{color:var(--txt)}
.ttab.on{background:var(--panel2);color:var(--txt);border-color:var(--line)}
.ttab .x{color:var(--dim);font-size:11px;border-radius:4px;padding:1px}
.ttab .x:hover{color:var(--txt);background:var(--inset)}
.ttab .ti{font-size:14px}
#midrow{flex:1;min-height:0;display:flex}
#panes{flex:1;min-width:0;position:relative;background:var(--panel)}

/* ---- unified shell: "home" is the same workspace, just with no project focused ---- */
/* The main area stays the normal tabbed panel area (New tab is the default) — same mental model as
   in-project. We only hide the chrome that needs a project: share/publish/files/cost. */
body.homeview #btnShare,
body.homeview #btnPublish,
body.homeview #btnFiles,
body.homeview #costChip{display:none}
body.homeview #filedrawer{display:none}
/* view-only collaborator: no publish (editor+ only); the agent composer is replaced in agent_panel.js */
body.roleviewer #btnPublish{display:none}
.viewonly{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--amb,#e0a458);background:var(--inset);border:1px solid var(--line2);border-radius:6px;padding:2px 7px}

/* start composer — agent panel's "no project yet" mode (the one constant surface) */
.startwrap{display:flex;flex-direction:column;height:100%;min-height:0}
.starttop{display:flex;align-items:center;gap:8px;padding:14px 16px;font-size:14px;font-weight:600;color:var(--txt);flex:none}
.starttop i{color:var(--pur);font-size:16px}
.startbody{flex:1;display:flex;flex-direction:column;justify-content:center;gap:14px;padding:0 18px 8px;min-height:0;overflow:auto}
.starth{font-size:19px;font-weight:600;line-height:1.32}
.startcomposer{position:relative}
.startcomposer textarea{width:100%;resize:none;font-size:14px;line-height:1.45;padding:12px 44px 12px 14px;border-radius:13px;background:var(--inset);border:1px solid var(--line2)}
.startcomposer .sendbtn{position:absolute;right:8px;bottom:8px}
.startchips{display:flex;flex-wrap:wrap;gap:7px}
.startfoot{display:flex;align-items:center;gap:8px;padding:11px 16px;border-top:1px solid var(--line);flex:none}

/* GitHub panel */
.ghwrap{height:100%;overflow:auto}
.ghhero{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:24px}
.ghhero i{font-size:30px;color:var(--txt)}
.ghhero h3{font-size:17px;font-weight:600}
.ghhero .hint{max-width:340px}
.ghrepo{display:flex;align-items:center;gap:9px;width:100%;text-align:left;padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--panel2);cursor:pointer;font-size:13px;margin-bottom:6px}
.ghrepo:hover{border-color:var(--line2);background:var(--inset)}
.ghout{margin-top:12px;padding:9px 11px;background:var(--inset);border:1px solid var(--line);border-radius:8px;font:11.5px var(--mono);white-space:pre-wrap;max-height:200px;overflow:auto}

.pane{position:absolute;inset:0;display:none;overflow:hidden}
.pane.on{display:flex;flex-direction:column}
#statusbar{display:flex;align-items:center;gap:12px;height:30px;padding:0 12px;border-top:1px solid var(--line);font-size:11.5px;color:var(--mut);background:var(--panel)}
#statusbar .sp{flex:1}
#statusbar .sbtn{color:var(--dim);font-size:11.5px}
#statusbar .sbtn:hover{color:var(--txt)}

.tree{padding:10px 8px;font-size:12.5px}
.tree .dir{color:var(--mut);font-weight:500;padding:3px 8px;display:flex;gap:7px;align-items:center;cursor:pointer}
.tree .fil{color:var(--mut);padding:3px 8px 3px 26px;display:flex;gap:7px;align-items:center;cursor:pointer;border-radius:7px}
.tree .fil:hover{background:var(--panel2);color:var(--txt)}
.tree .fil.on{background:var(--accbg);color:var(--acc)}
.tree .ti{font-size:13px}

.toolhead{display:flex;align-items:center;gap:10px;padding:9px 14px;border-bottom:1px solid var(--line);flex:none}
.toolhead b{font-size:12.5px;font-weight:600}
.toolhead .sp{flex:1}
.toolbody{flex:1;min-height:0;overflow:auto}
.pad{padding:14px 16px}

.ntwrap{width:min(580px,86%);margin:0 auto;padding-top:30px}
.ntlabel{font-size:12.5px;color:var(--dim);margin:14px 0 4px}
.titem{display:flex;align-items:center;gap:13px;padding:7px 10px;border-radius:10px;cursor:pointer}
.titem:hover,.titem.sel{background:var(--panel2)}
.titem .tile{width:36px;height:36px;flex:none;border-radius:10px;background:var(--panel2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--mut)}
.titem h5{font-size:13.5px;font-weight:500}
.titem p{font-size:12px;color:var(--mut)}
.titem.flat{gap:9px;padding:4.5px 10px}
.titem.flat>.ti{font-size:14px;color:var(--dim);flex:none}
.titem.flat h5{font-size:12.5px;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.titem.flat p{margin-left:auto;font:11px var(--mono);color:var(--dim)}

.clog{font:12px/1.75 var(--mono);padding:8px 0}
.clog .row{padding:0 16px;white-space:pre-wrap;word-break:break-word}
.clog .cmd{color:var(--mut)}
.clog .out{color:var(--txt)}
.clog .err{color:var(--red)}
.clog .ok{color:var(--grn)}
.clog .sys{color:var(--dim);font-style:italic}
.clog .sep{color:var(--dim);padding:6px 16px 2px;font-style:normal}
.askai{font-size:10.5px;color:var(--acc);border:1px solid rgba(91,140,255,.35);border-radius:6px;padding:0 7px;margin-left:8px;cursor:pointer}

.tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.tbl th{font:500 11px 'Inter';text-transform:uppercase;letter-spacing:.05em;color:var(--dim);text-align:left;padding:7px 12px;border-bottom:1px solid var(--line2)}
.tbl td{padding:7px 12px;border-bottom:1px solid var(--line);color:var(--mut)}
.tbl td:first-child,.tbl th:first-child{padding-left:16px}
.tbl tr:hover td{background:var(--panel2)}
.mono{font-family:var(--mono);font-size:12px}

.seg{display:flex;gap:3px;background:var(--inset);border:1px solid var(--line);border-radius:9px;padding:3px}
.seg button{font:500 12px 'Inter';color:var(--mut);border-radius:6px;padding:3px 11px}
.seg button.on{background:var(--panel2);color:var(--txt)}

#toasts{position:fixed;bottom:42px;right:16px;z-index:90;display:flex;flex-direction:column;gap:8px}
.toast{display:flex;align-items:center;gap:9px;max-width:calc(100vw - 32px);background:var(--panel2);border:1px solid var(--line2);border-radius:11px;padding:10px 14px;font-size:12.5px;box-shadow:0 14px 40px rgba(0,0,0,.45);animation:fadein .18s ease}
.toast .ti{font-size:15px}
.toast-ok .ti{color:var(--grn)}.toast-err .ti{color:var(--red)}.toast-info .ti{color:var(--acc)}

#cmdk{position:fixed;inset:0;background:rgba(5,7,12,.55);z-index:80;display:none;align-items:flex-start;justify-content:center;padding-top:12vh}
#cmdk.on{display:flex}
.cmdkbox{width:min(640px,92vw);background:var(--panel2);border:1px solid var(--line2);border-radius:14px;overflow:hidden;box-shadow:0 30px 90px rgba(0,0,0,.6)}
.cmdkbox .cin{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--line)}
.cmdkbox .cin input{flex:1;background:none;border:0;padding:0;font-size:14px}
.cmdkbox .list{max-height:46vh;overflow:auto;padding:6px}

.thread{flex:1;min-height:0;overflow-y:auto;padding:14px 14px 6px;display:flex;flex-direction:column;gap:10px}
.msg-user{align-self:flex-end;max-width:78%;background:var(--accbg);border:1px solid rgba(91,140,255,.25);color:var(--txt);border-radius:13px 13px 4px 13px;padding:8px 13px;font-size:13px}
.msg-agent{max-width:92%;font-size:13px;color:var(--txt)}
.msg-agent p{margin:0 0 8px}
.msg-agent code{font:11.5px var(--mono);background:var(--inset);border:1px solid var(--line);border-radius:5px;padding:1px 6px;color:var(--amb)}
.acard{background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:11px 13px}
.evline{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--dim);padding:1px 2px}
.evline .ti{font-size:13px}
.cpcard{display:flex;flex-direction:column;gap:7px;background:var(--panel2);border:1px solid var(--line2);border-radius:11px;padding:9px 12px;font-size:12.5px;min-width:0}
.cpcard .cptop{display:flex;align-items:center;gap:8px;min-width:0}
.cpcard .cptop b{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}
.cpcard .ti-flag{color:var(--teal);flex:none}
.cpcard .cpmeta{display:flex;align-items:center;gap:9px;color:var(--mut);white-space:nowrap;min-width:0}
.cpcard .cpmeta .mono{min-width:0;overflow:hidden;text-overflow:ellipsis}
.cpcard .cpmeta .btn{flex:none}
.planrow{display:flex;align-items:center;gap:9px;font-size:12.5px;padding:2.5px 0}
.planrow .ti{font-size:14px}
.planrow.done .ti{color:var(--grn)}
.planrow.doing .ti{color:var(--acc);animation:spin 1.2s linear infinite}
/* per-edit + per-command stream cards (Agent Stream v2) */
.fecard,.cmdcard{background:var(--panel2);border:1px solid var(--line2);border-radius:11px;overflow:hidden;min-width:0;flex:none}
.fehead,.cmdhead{display:flex;align-items:center;gap:8px;padding:8px 11px;font-size:12.5px;cursor:pointer;min-width:0}
.fehead:hover,.cmdhead:hover{background:var(--panel)}
.fehead>.ti,.cmdhead>.ti{flex:none;font-size:14px;color:var(--dim)}
.fehead .fepath{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;direction:rtl;text-align:left}
.cmdhead .cmdtext{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px;color:var(--txt)}
.feplus{color:var(--grn);font-family:var(--mono);font-size:11px;flex:none}
.feminus{color:var(--red);font-family:var(--mono);font-size:11px;flex:none}
.cmdexit{font-family:var(--mono);font-size:11px;flex:none}
.cmdexit.ok{color:var(--grn)} .cmdexit.bad{color:var(--red)}
.fechev{transition:transform .15s;color:var(--dim);font-size:14px;flex:none}
.fecard.open .fechev,.cmdcard.open .fechev{transform:rotate(180deg)}
.febody,.cmdbody{display:none;padding:8px 11px;border-top:1px solid var(--line);max-height:260px;overflow:auto}
.fecard.open .febody,.cmdcard.open .cmdbody{display:block}
.febody .dl2{white-space:pre-wrap;word-break:break-word;padding:0 6px;border-radius:4px;font-family:var(--mono);font-size:11.5px;line-height:1.55}
.febody .add2{background:var(--grnbg);color:var(--grn)}
.febody .del2{background:var(--redbg);color:var(--red)}
.cmdbody{white-space:pre-wrap;word-break:break-word;font-size:11.5px;line-height:1.5;color:var(--mut)}
.composer{margin:8px 12px 12px;border:1px solid var(--line2);border-radius:13px;background:var(--inset);flex:none}
.composer textarea{width:100%;background:none;border:0;resize:none;padding:11px 13px 2px;font-size:13px;max-height:120px}
.composer .crow{display:flex;align-items:center;gap:10px;padding:8px 11px}
.composer .crow .ti{color:var(--dim);font-size:16px;cursor:pointer}
.pillbtn{display:inline-flex;align-items:center;gap:6px;font:500 12px 'Inter';color:var(--mut);background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:4px 10px;cursor:pointer}
.pillbtn.on{background:var(--accbg);color:var(--acc);border-color:rgba(91,140,255,.35)}
.sendbtn{width:28px;height:28px;border-radius:9px;background:var(--acc);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;cursor:pointer;transition:background .12s}
.sendbtn.stop{background:var(--red,#e5484d)}

/* auth overlay (login / signup) */
#authoverlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:var(--bg);background-image:radial-gradient(60% 50% at 50% 0%, rgba(91,140,255,.10), transparent 70%)}
#authoverlay .authcard{width:340px;max-width:92vw;background:var(--panel);border:1px solid var(--line2);border-radius:16px;padding:26px 24px;display:flex;flex-direction:column;gap:12px;box-shadow:0 24px 60px rgba(0,0,0,.45)}
#authoverlay .authbrand{display:flex;align-items:center;gap:8px;font-size:18px}
#authoverlay .authbrand .ti{color:var(--acc);font-size:20px}
#authoverlay .authsub{color:var(--mut);font-size:13px;margin-bottom:4px}
#authoverlay .authtabs{display:flex;gap:6px;background:var(--inset);border-radius:10px;padding:4px;margin-bottom:4px}
#authoverlay .authtabs button{flex:1;border:0;background:none;color:var(--mut);font:500 12.5px 'Inter';padding:7px;border-radius:7px;cursor:pointer}
#authoverlay .authtabs button.on{background:var(--panel2);color:var(--txt)}
#authoverlay input{background:var(--inset);border:1px solid var(--line);border-radius:10px;padding:11px 13px;font-size:13.5px;color:var(--txt);outline:none}
#authoverlay input:focus{border-color:var(--acc)}
#authoverlay .autherr{color:var(--red);font-size:12px;min-height:14px}
#authoverlay .authgo{background:var(--acc);color:#fff;border:0;border-radius:10px;padding:11px;font:600 13.5px 'Inter';cursor:pointer}
#authoverlay .authgo:disabled{opacity:.6;cursor:default}
.sugg{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}

.urlbar{display:flex;align-items:center;gap:9px;padding:8px 12px;border-bottom:1px solid var(--line);color:var(--dim);flex:none}
.urlbar .ti{font-size:15px;cursor:pointer}
.urlbar .ti:hover{color:var(--mut)}
.urlpill{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;font:12px var(--mono);color:var(--mut);background:var(--inset);border:1px solid var(--line);border-radius:8px;padding:5px 12px;min-width:0;overflow:hidden}
.pvframe{flex:1;min-height:0;border:0;width:100%;background:#fff}
.pvdead{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--dim);font-size:13px}
.pvbuild{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:24px;background:var(--inset)}
.pvbuild-head{display:flex;align-items:center;gap:10px;font-size:15px;color:var(--txt)}
.pvbuild-head .spin{width:15px;height:15px}
.pvbuild-steps{display:flex;flex-direction:column;gap:9px;min-width:240px}
.pvbuild-step{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--dim)}
.pvbuild-step .ti{font-size:16px}
.pvbuild-step.done{color:var(--mut)}.pvbuild-step.done .ti{color:var(--grn)}
.pvbuild-step.now{color:var(--txt)}.pvbuild-step.now .ti{color:var(--acc);animation:spin 1.1s linear infinite}
.pvbuild-sub{font:11.5px var(--mono);color:var(--dim);max-width:80%;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pvbuild-foot{font-size:11.5px;color:var(--dim);opacity:.7;margin-top:4px}
.devtools{flex:none;height:0;border-top:1px solid var(--line2);display:flex;flex-direction:column;overflow:hidden;transition:height .15s ease}
.devtools.on{height:180px}

.term{flex:1;min-height:0;overflow-y:auto;font:12px/1.7 var(--mono);padding:10px 14px}
.term .tin{display:flex;gap:8px}
.term input{background:none;border:0;padding:0;flex:1;font:inherit;color:var(--txt)}
.term .ps1{color:var(--grn)}

.kvrow{display:flex;align-items:center;gap:10px;padding:9px 14px;border-bottom:1px solid var(--line)}
.kvrow .k{font-family:var(--mono);font-size:12.5px;min-width:200px}
.kvrow .v{font-family:var(--mono);font-size:12px;color:var(--dim);flex:1}

.stage{display:flex;align-items:center;gap:10px;padding:7px 0;font-size:12.5px;color:var(--mut)}
.stage .ti{font-size:15px}
.stage.done{color:var(--txt)}
.stage.done .ti{color:var(--grn)}
.stage.doing .ti{color:var(--acc);animation:spin 1s linear infinite}

.uimenu{position:fixed;z-index:120;min-width:190px;max-width:calc(100vw - 16px);background:var(--panel2);border:1px solid var(--line2);border-radius:11px;padding:5px;box-shadow:0 18px 50px rgba(0,0,0,.5);animation:fadein .12s ease}
.uimenu-it{display:flex;align-items:center;gap:9px;width:100%;text-align:left;font:13px 'Inter';color:var(--txt);border-radius:7px;padding:7px 10px}
.uimenu-it>span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.uimenu-it:hover{background:var(--accbg)}
.uimenu-it .ti{font-size:15px;color:var(--mut)}
.uimenu-it .chk{margin-left:auto;color:var(--acc)}
.uimenu-it.dim{color:var(--dim);cursor:default}
.uimenu-it.dim:hover{background:none}
.uimenu-sep{height:1px;background:var(--line);margin:5px 4px}
.uimodal-back{position:fixed;inset:0;background:rgba(5,7,12,.55);z-index:110;display:flex;align-items:flex-start;justify-content:center;padding-top:14vh}
.uimodal{width:min(440px,92vw);background:var(--panel2);border:1px solid var(--line2);border-radius:14px;overflow:hidden;box-shadow:0 30px 90px rgba(0,0,0,.6);animation:fadein .15s ease}
.uimodal-head{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--line);font-size:14px}
.uimodal-x{color:var(--dim);font-size:15px;padding:3px 6px;border-radius:7px}
.uimodal-x:hover{color:var(--txt);background:var(--inset)}
.uimodal-body{padding:14px 16px}
.cchip{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;color:var(--acc);background:var(--accbg);border:1px solid rgba(91,140,255,.3);border-radius:999px;padding:2px 10px;margin:6px 0 0 12px}
.cchip .ti{font-size:12px;cursor:pointer}
.selhint{display:flex;align-items:center;gap:9px;padding:7px 14px;background:var(--accbg);border-bottom:1px solid rgba(91,140,255,.3);color:var(--acc);font-size:12px;flex:none}

#panes{display:flex}
#panesMain{flex:1;min-width:0;position:relative}
#paneSide{display:none;flex:none;width:46%;min-width:280px;border-left:1px solid var(--line2);flex-direction:column;background:var(--panel)}
#paneSide.on{display:flex}
#paneSide .sidehead{display:flex;align-items:center;gap:8px;padding:6px 12px;border-bottom:1px solid var(--line);font-size:12px;color:var(--mut);flex:none}
#paneSide .sidehead .ti{font-size:14px}
#paneSide .sidehead button{color:var(--dim);display:flex;padding:2px;border-radius:5px}
#paneSide .sidehead button:hover{color:var(--txt);background:var(--inset)}
#paneSide .sidebody{flex:1;min-height:0;position:relative}
#paneSide .sidebody>.pane{display:flex;flex-direction:column}
.tbadge{width:7px;height:7px;border-radius:50%;flex:none}

#phoneWrap{position:fixed;right:18px;bottom:42px;z-index:70;width:292px;height:580px;background:var(--panel);border:1px solid var(--line2);border-radius:30px;box-shadow:0 30px 90px rgba(0,0,0,.65);display:none;flex-direction:column;overflow:hidden;animation:fadein .2s ease}
#phoneWrap.on{display:flex}
.phnotch{display:flex;align-items:center;justify-content:space-between;padding:10px 18px 4px;font:500 10.5px 'Inter';color:var(--dim);flex:none}
.phnotch .pill{width:64px;height:16px;border-radius:999px;background:#000}
.phbody{flex:1;min-height:0;overflow-y:auto;padding:10px 12px}
.phtabs{display:flex;justify-content:space-around;align-items:center;padding:9px 8px 13px;border-top:1px solid var(--line);flex:none}
.phtabs button{color:var(--dim);font-size:18px;display:flex;padding:4px 10px;border-radius:9px}
.phtabs button.on{color:var(--acc);background:var(--accbg)}
.phblk{background:var(--panel2);border:1px solid var(--line);border-radius:11px;padding:9px 11px;margin-bottom:8px;font-size:12px}
.phblk p{color:var(--mut);font-size:11px;margin-top:2px}
.phmsg-u{margin-left:auto;width:fit-content;max-width:88%;background:var(--accbg);border:1px solid rgba(91,140,255,.25);border-radius:11px 11px 3px 11px;padding:6px 10px;font-size:11.5px;margin-bottom:7px}
.phmsg-a{max-width:94%;font-size:11.5px;margin-bottom:7px;color:var(--txt)}
.phmsg-a code{font:10px var(--mono);background:var(--inset);border:1px solid var(--line);border-radius:4px;padding:0 4px;color:var(--amb)}
.phev{display:flex;align-items:center;gap:6px;font-size:10.5px;color:var(--dim);margin-bottom:6px}
.phcomposer{display:flex;gap:7px;padding:8px 10px;border-top:1px solid var(--line);flex:none}
.phcomposer input{flex:1;font-size:11.5px;padding:6px 10px;border-radius:9px}
.phcomposer button{width:28px;height:28px;border-radius:9px;background:var(--acc);color:#fff;display:flex;align-items:center;justify-content:center;flex:none}
.phframe{width:100%;height:330px;border:1px solid var(--line);border-radius:11px;background:#0d1117}
.diffwrap{max-height:46vh;overflow:auto;font:11.5px/1.7 var(--mono)}
.diffwrap .dfile{font:500 12px 'Inter';color:var(--mut);padding:8px 2px 4px;border-bottom:1px solid var(--line);margin-bottom:4px;display:flex;gap:8px;align-items:center}
.diffwrap .dl2{white-space:pre-wrap;word-break:break-word;padding:0 6px;border-radius:4px}
.diffwrap .add2{background:var(--grnbg);color:var(--grn)}
.diffwrap .del2{background:var(--redbg);color:var(--red)}

/* ── responsive tiers — keep LAST so overrides win specificity ties ── */
@media (max-width:1000px){.pubtxt{display:none}}
@media (max-width:900px){.urlbar .seg{display:none}}
/* Responsive tiers — phone (≤640): two full-width surfaces + bottom bar;
   tablet (641–880): agent panel is a slide-over; desktop (>880): side-by-side,
   panel collapsible. One body class drives narrow visibility: .agentopen. */
#btnAgent{display:none;position:relative}
body.agentopen #btnAgent{color:var(--acc);border-color:rgba(91,140,255,.4)}
body.agentbusy:not(.agentopen) #btnAgent::after{content:'';position:absolute;top:-3px;right:-3px;width:8px;height:8px;border-radius:50%;background:var(--grn);animation:pulse 1.2s ease infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
#agentScrim{display:none;position:fixed;inset:0;background:rgba(5,7,12,.5);z-index:35}
/* docked widths (>560): agent is a permanent left panel; collapse cleanly hides it
   (no popup) and the sparkles button restores it — exactly the Replit two-pane model */
@media (min-width:561px){
  body.agentcollapsed #agentcol{display:none}
  body.agentcollapsed #btnAgent{display:inline-flex}
}
#mobilebar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:45;background:var(--panel);border-top:1px solid var(--line2);height:calc(56px + env(safe-area-inset-bottom,0px));padding:0 10px env(safe-area-inset-bottom,0px);align-items:center;justify-content:space-around}
#mobilebar>button{display:flex;flex-direction:column;align-items:center;gap:1px;font:500 10.5px 'Inter';color:var(--dim);padding:4px 22px;border-radius:11px;position:relative}
#mobilebar>button .ti{font-size:20px}
#mobilebar>button.on{color:var(--acc)}
#mobilebar .mbdot{position:absolute;top:1px;right:14px;width:8px;height:8px;border-radius:50%;background:var(--grn);display:none}
body.agentbusy:not(.agentopen) #mobilebar .mbdot{display:block;animation:pulse 1.2s ease infinite}
/* docked-but-narrow (561–900): keep BOTH panes; shrink the agent so the workspace keeps room */
@media (max-width:900px){
  #agentcol{width:clamp(280px,40vw,470px)}
}
@media (max-width:820px){#tabstrip .ttab:not(.on) .tlabel{display:none}#costChip{display:none !important}}
/* Phone (≤560): agent + workspace are two full-width surfaces switched by the bottom bar */
@media (max-width:560px){
  .rail{display:none}
  #filedrawer{display:none !important} /* the file drawer isn't a phone surface */
  #btnFiles{display:none}
  #btnAgent{display:none}
  #btnSearch{display:none}
  #mobilebar{display:flex}
  #maincol{padding-bottom:calc(56px + env(safe-area-inset-bottom,0px))}
  #agentcol{position:fixed;top:0;left:0;width:100vw !important;bottom:calc(56px + env(safe-area-inset-bottom,0px));z-index:40;transform:translateX(-102%);transition:transform .18s ease;box-shadow:none;border-right:0}
  body.agentopen #agentcol{transform:none}
  body.agentopen #agentScrim{display:none}
  input,textarea,select{font-size:16px !important} /* sub-16px focus zooms the page on iOS; !important beats inline styles */
  .toolhead{flex-wrap:wrap;row-gap:6px}
  body.kbopen #mobilebar{display:none}
  body.kbopen #agentcol{bottom:var(--kb,0px)}
  body.kbopen #maincol{padding-bottom:var(--kb,0px)}
  #genesis h1{font-size:20px}
  .msg-user{max-width:88%}
  #toasts{bottom:calc(64px + env(safe-area-inset-bottom,0px))}
}
/* Touch: larger hit targets, fatter drag handle */
@media (pointer:coarse){
  .ttab{padding:8px 12px}
  .titem.flat{padding:8px 10px}
  .btn-sm{padding:6px 11px;font-size:12px}
  .titem{padding:9px 10px}
  .dragbar{width:22px;right:-11px}
  .urlbar .ti{font-size:17px}
  .composer .crow .ti{font-size:19px}
}
