/* solenthos-ui.css
 * Single allowed CSS file for Jarvis UI contract.
 * Contains the mobile Jarvis frontend styles.
 */

:root{--bg:#fff;--surface:#fff;--soft:#f7f7f8;--soft2:#f1f1f3;--text:#171717;--muted:#737373;--border:#e7e7e8;--accent:#111;--green:#10a37f;--danger:#d92d20;--warn:#8a5a00;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}*{box-sizing:border-box}body{margin:0;background:#ececee;color:var(--text);min-height:100vh;display:grid;place-items:center}.phone{width:min(430px,100vw);height:min(932px,100vh);background:var(--bg);overflow:hidden;position:relative;display:grid;grid-template-rows:auto 1fr auto;box-shadow:0 10px 30px rgba(0,0,0,.08)}.topbar{height:calc(58px + env(safe-area-inset-top));padding:env(safe-area-inset-top) 14px 0;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.92);backdrop-filter:blur(18px);z-index:5}.icon-btn{width:38px;height:38px;border:0;background:transparent;border-radius:12px;display:grid;place-items:center;color:var(--text);padding:0;cursor:pointer}.title{display:flex;flex-direction:column;align-items:center;line-height:1.15;font-weight:650;letter-spacing:-.01em}.title small{color:var(--muted);font-size:12px;font-weight:500;display:flex;align-items:center;gap:5px;margin-top:2px}.dot{width:7px;height:7px;border-radius:50%;background:var(--green)}.dot.off{background:var(--danger)}.auto-toggle{border:1px solid var(--border);background:var(--soft);color:var(--muted);border-radius:999px;padding:7px 10px;font-size:11px;font-weight:800;letter-spacing:.02em;cursor:pointer;white-space:nowrap}.auto-toggle.on{background:#ddf7ed;color:#087443;border-color:#bdebd9}.auto-toggle.off{background:#fee4e2;color:var(--danger);border-color:#ffd0cc}
.avatar{width:31px;height:31px;border-radius:50%;background:#111;color:#fff;display:grid;place-items:center;font-size:13px;font-weight:700;cursor:pointer;user-select:none}.avatar:hover{filter:brightness(1.18)}.chat{overflow-y:auto;padding:18px 14px;background:var(--surface)}.welcome{min-height:32%;display:grid;place-items:end center;padding-bottom:26px;text-align:center}.mark{width:42px;height:42px;border-radius:14px;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:760;margin:0 auto 14px}h1{margin:0;font-size:25px;letter-spacing:-.045em;line-height:1.06;font-weight:720}.message-row{display:flex;margin:18px 0;gap:10px;align-items:flex-start}.message-row.user{justify-content:flex-end}.bubble{max-width:82%;border-radius:22px;padding:12px 14px;font-size:15px;line-height:1.43;white-space:pre-wrap;word-wrap:break-word}.user .bubble{background:var(--soft2);border-top-right-radius:7px}.assistant .bubble{background:transparent;padding-left:2px;max-width:100%}.agent-icon{width:28px;height:28px;border-radius:9px;background:#111;color:#fff;display:grid;place-items:center;font-size:12px;font-weight:750;flex:0 0 auto;margin-top:4px}.task-card{border:1px solid var(--border);border-radius:18px;background:var(--soft);padding:12px;margin-top:10px}.task-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;font-size:13px;font-weight:650}.status{font-size:11px;color:var(--warn);background:#fff3d7;border-radius:999px;padding:4px 8px;white-space:nowrap}.status.completed{color:#087443;background:#ddf7ed}.status.failed,.status.cancelled{color:var(--danger);background:#fee4e2}.steps{margin-top:10px;display:grid;gap:7px;color:var(--muted);font-size:12px}.step{display:flex;gap:8px;align-items:flex-start}.step-dot{width:6px;height:6px;border-radius:50%;background:var(--green);flex:0 0 auto;margin-top:6px}.composer-wrap{padding:10px 10px calc(10px + env(safe-area-inset-bottom));background:rgba(255,255,255,.94);backdrop-filter:blur(18px);border-top:1px solid var(--border)}.composer{min-height:52px;border:1px solid var(--border);background:#fff;border-radius:26px;display:grid;grid-template-columns:42px 1fr 42px 42px;align-items:end;padding:5px;box-shadow:0 2px 16px rgba(0,0,0,.04)}.composer button{width:42px;height:42px;border:0;border-radius:50%;display:grid;place-items:center;background:transparent;color:var(--text);padding:0;cursor:pointer}.composer button.send{background:#111;color:#fff;width:36px;height:36px;margin:3px}.composer button:disabled{opacity:.35;cursor:not-allowed}textarea{border:0;outline:0;resize:none;min-height:40px;max-height:132px;padding:10px 4px 8px;font:inherit;font-size:16px;line-height:1.35;background:transparent}.ai-note{margin-top:7px;text-align:center;color:var(--muted);font-size:11px;line-height:1.25}.drawer{position:absolute;inset:0 auto 0 0;width:82%;max-width:340px;background:#fff;z-index:20;transform:translateX(-102%);transition:transform .22s ease;border-right:1px solid var(--border);padding:calc(18px + env(safe-area-inset-top)) 14px 14px;box-shadow:20px 0 50px rgba(0,0,0,.12);overflow:auto}.drawer.open{transform:translateX(0)}.drawer h2{font-size:18px;margin:0 0 14px;letter-spacing:-.03em}.thread{width:100%;border:0;background:transparent;color:var(--text);text-align:left;padding:12px;border-radius:14px;margin-bottom:6px;font:inherit;font-size:14px;cursor:pointer}.thread.active{background:var(--soft)}.thread small{display:block;color:var(--muted);margin-top:3px}.scrim{position:absolute;inset:0;background:rgba(0,0,0,.18);z-index:15;display:none}.scrim.show{display:block}.file-fab{position:absolute;right:16px;bottom:calc(92px + env(safe-area-inset-bottom));z-index:8;width:48px;height:48px;border:1px solid var(--border);border-radius:50%;background:#fff;box-shadow:0 8px 24px rgba(0,0,0,.12);display:grid;place-items:center;color:var(--text);cursor:pointer}.file-badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:var(--green);color:#fff;border:2px solid #fff;font-size:11px;font-weight:800;display:none;place-items:center;line-height:1}.file-badge.show{display:grid}.file-sheet{position:absolute;left:0;right:0;bottom:0;z-index:30;background:#fff;border-radius:26px 26px 0 0;border-top:1px solid var(--border);box-shadow:0 -20px 60px rgba(0,0,0,.18);padding:12px 14px max(42px,calc(18px + env(safe-area-inset-bottom)));transform:translateY(105%);transition:transform .24s ease;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.file-sheet.open{transform:translateY(0)}.sheet-handle{width:42px;height:5px;border-radius:999px;background:#d9d9dc;margin:0 auto 14px}.sheet-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.sheet-head h2{margin:0;font-size:20px;letter-spacing:-.035em}.sheet-head p{margin:4px 0 0;color:var(--muted);font-size:13px}.file-list{display:grid;gap:8px;padding-bottom:10px}.file-item{border:1px solid var(--border);border-radius:16px;padding:11px 12px;display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:13px}.file-item small{display:block;color:var(--muted);margin-top:2px}.upload-dropzone{border:1.5px dashed #cfcfd3;border-radius:20px;background:var(--soft);padding:18px;display:grid;place-items:center;text-align:center;min-height:132px;margin-bottom:14px;cursor:pointer}.upload-dropzone strong{display:block;margin:10px 0 4px;font-size:15px}.upload-dropzone span{color:var(--muted);font-size:13px}input[type=file]{display:none}.empty{color:var(--muted);text-align:center;padding:18px;font-size:14px}.error{color:var(--danger)}@media(min-width:700px){.phone{border-radius:34px;height:min(900px,calc(100vh - 32px))}}

/* Artifact preview sheet */
.file-sheet{max-height:78vh;overflow:auto}.file-sheet.preview-mode{max-height:92vh}.file-preview{display:none;border:1px solid var(--border);border-radius:18px;background:var(--soft);overflow:hidden}.file-preview.open{display:block}.artifact-list-view.hidden{display:none}.file-preview-head{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:11px 12px;border-bottom:1px solid var(--border);font-size:13px;font-weight:650}.file-preview-head span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-preview-head button,.file-preview-head a,.file-item button{border:0;background:transparent;color:var(--text);font:inherit;font-size:13px;cursor:pointer;padding:6px 4px;text-decoration:none}.file-preview-body{padding:12px 12px 34px;max-height:66vh;overflow:auto;white-space:pre-wrap;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;line-height:1.45;color:#303030;background:#fff}.file-item .open-artifact{font-weight:650}.file-meta{max-width:75%;overflow:hidden}.file-meta div{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.file-item.unseen .file-meta div{font-weight:760}.file-item.seen .file-meta div{font-weight:400}.load-more{width:100%;border:1px solid var(--border);background:var(--soft);border-radius:14px;padding:11px 12px;margin-top:10px;font:inherit;font-size:13px;cursor:pointer}.file-preview-body.markdown{font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:14px;line-height:1.55;white-space:normal}.file-preview-body.markdown h1{font-size:20px;margin:4px 0 12px;letter-spacing:-.03em}.file-preview-body.markdown h2{font-size:17px;margin:14px 0 8px;letter-spacing:-.02em}.file-preview-body.markdown h3{font-size:15px;margin:12px 0 7px}.file-preview-body.markdown code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;background:var(--soft);border:1px solid var(--border);border-radius:6px;padding:1px 4px}.file-preview-body.markdown .md-li{margin:4px 0}


/* Chat rendering fixes */
.message-row.task-message .bubble{width:100%;max-width:100%;padding-right:0}.task-card{width:100%;min-height:0}.task-card .steps{max-height:none;overflow:visible}.task-card .step{white-space:normal;overflow:visible;text-overflow:clip}.final-response .bubble{white-space:normal}.final-response .bubble h1{font-size:20px;margin:4px 0 12px;letter-spacing:-.03em}.final-response .bubble h2{font-size:17px;margin:14px 0 8px;letter-spacing:-.02em}.final-response .bubble h3{font-size:15px;margin:12px 0 7px}.final-response .bubble .md-li{margin:4px 0}.final-response .bubble code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;background:var(--soft);border:1px solid var(--border);border-radius:6px;padding:1px 4px}.file-meta div{white-space:normal}.file-preview-head span{white-space:normal}.bubble{overflow:visible;text-overflow:clip}

/* Mobile stability fixes: no horizontal drift, fixed app chrome, calmer updates */
html,body{height:100%;width:100%;overflow:hidden;overscroll-behavior:none}
body{display:block;background:#fff}
.phone{width:100vw;max-width:430px;height:100dvh;max-height:100dvh;margin:0 auto;overflow:hidden;grid-template-rows:auto minmax(0,1fr) auto;box-shadow:none}
.topbar{position:sticky;top:0;z-index:40;flex:0 0 auto}
.composer-wrap{position:sticky;bottom:0;z-index:35;flex:0 0 auto}
.chat{min-width:0;width:100%;overflow-x:hidden;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding-left:14px;padding-right:14px}
.message-row{width:100%;min-width:0;max-width:100%;overflow:visible}
.message-row.user .bubble{max-width:min(82%,calc(100% - 44px))}
.message-row.assistant .bubble{max-width:calc(100% - 38px);min-width:0}
.message-row.task-message .bubble{max-width:calc(100% - 38px);width:auto;min-width:0;padding-right:0}
.bubble,.task-card,.steps,.step,.file-preview-body{min-width:0;max-width:100%;overflow-wrap:anywhere;word-break:normal}
.task-head{min-width:0}.task-head span:first-child{min-width:0;overflow-wrap:anywhere}
.file-fab{z-index:36}.file-badge{z-index:37;pointer-events:none}
@media(min-width:700px){body{display:grid;place-items:center;background:#ececee}.phone{height:min(900px,calc(100dvh - 32px));max-height:calc(100dvh - 32px);box-shadow:0 10px 30px rgba(0,0,0,.08)}}

/* Mobile viewport hardening */
:root{--app-height:100dvh;--app-top:0px}
@media(max-width:699px){html,body{width:100%;height:100%;margin:0;padding:0!important;overflow:hidden;background:#fff!important}body{display:block!important;place-items:initial!important}.phone{position:fixed!important;left:50%!important;top:var(--app-top)!important;transform:translateX(-50%)!important;width:100vw!important;max-width:430px!important;height:var(--app-height)!important;max-height:var(--app-height)!important;margin:0!important;box-shadow:none!important;display:grid!important;grid-template-rows:58px minmax(0,1fr) auto!important;overflow:hidden!important}.topbar{position:relative!important;top:auto!important;height:58px!important;min-height:58px!important;padding:0 14px!important;flex:0 0 58px!important}.chat{min-height:0!important;height:auto!important;overflow-y:auto!important;overflow-x:hidden!important;padding-top:18px!important;padding-bottom:18px!important}.composer-wrap{position:relative!important;bottom:auto!important;padding:10px 10px max(10px,env(safe-area-inset-bottom))!important;flex:0 0 auto!important}.file-fab{bottom:calc(92px + max(0px,env(safe-area-inset-bottom)))!important}.file-sheet{max-height:min(78vh,calc(var(--app-height) - 24px))!important;padding-bottom:max(46px,calc(22px + env(safe-area-inset-bottom)))!important}.file-sheet.preview-mode{max-height:min(92vh,calc(var(--app-height) - 12px))!important;padding-bottom:max(46px,calc(22px + env(safe-area-inset-bottom)))!important}}


/* Bottom-sheet layering fix: sheets sit above composer and own the bottom viewport. */
.phone.sheet-open .composer-wrap{display:none!important}
.phone.sheet-open .file-fab{display:none!important}
.phone.sheet-open .chat{pointer-events:none}
.scrim{z-index:70!important}
.drawer{z-index:80!important}
.file-sheet{z-index:120!important;bottom:0!important;max-height:calc(var(--app-height, 100dvh) - 64px)!important;overflow-y:auto!important;padding-bottom:max(72px,calc(32px + env(safe-area-inset-bottom)))!important}
.file-sheet.preview-mode{max-height:calc(var(--app-height, 100dvh) - 24px)!important;padding-bottom:max(72px,calc(32px + env(safe-area-inset-bottom)))!important}
.file-preview-body{max-height:calc(var(--app-height, 100dvh) - 180px)!important;padding-bottom:72px!important}
@media(max-width:699px){
  .file-sheet{max-height:calc(var(--app-height, 100dvh) - 64px)!important;padding-bottom:max(72px,calc(32px + env(safe-area-inset-bottom)))!important}
  .file-sheet.preview-mode{max-height:calc(var(--app-height, 100dvh) - 24px)!important;padding-bottom:max(72px,calc(32px + env(safe-area-inset-bottom)))!important}
}

/* Desktop layout: keep the phone-grade mobile UI, but stop scaling it up on laptops. */
@media (min-width: 900px){
  :root{--desktop-sidebar:288px;--desktop-header:64px;--desktop-composer:92px}
  html,body{width:100%;height:100%;margin:0;overflow:hidden;background:#f7f7f8!important}
  body{display:block!important;place-items:initial!important}
  .phone{
    position:relative!important;
    inset:auto!important;
    transform:none!important;
    width:100vw!important;
    max-width:none!important;
    height:100dvh!important;
    max-height:100dvh!important;
    margin:0!important;
    border-radius:0!important;
    box-shadow:none!important;
    display:grid!important;
    grid-template-columns:var(--desktop-sidebar) minmax(0,1fr)!important;
    grid-template-rows:var(--desktop-header) minmax(0,1fr) auto!important;
    background:var(--surface)!important;
    overflow:hidden!important;
  }
  .drawer{
    position:relative!important;
    grid-column:1!important;
    grid-row:1 / 4!important;
    width:100%!important;
    max-width:none!important;
    height:100%!important;
    transform:none!important;
    z-index:2!important;
    border-right:1px solid var(--border)!important;
    box-shadow:none!important;
    padding:22px 14px!important;
    background:#f7f7f8!important;
    overflow-y:auto!important;
  }
  .drawer h2{font-size:17px;margin-bottom:16px}
  .thread{border-radius:12px;padding:11px 12px}
  .thread.active{background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.03)}
  .topbar{
    grid-column:2!important;
    grid-row:1!important;
    position:relative!important;
    top:auto!important;
    height:var(--desktop-header)!important;
    min-height:var(--desktop-header)!important;
    padding:0 28px!important;
    border-bottom:1px solid var(--border)!important;
    background:rgba(255,255,255,.88)!important;
    z-index:5!important;
  }
  #menuBtn{visibility:hidden;pointer-events:none}
  .title{align-items:flex-start;margin-right:auto;margin-left:0;text-align:left}
  .title span{font-size:15px}
  .chat{
    grid-column:2!important;
    grid-row:2!important;
    width:100%!important;
    height:auto!important;
    min-height:0!important;
    overflow-y:auto!important;
    overflow-x:hidden!important;
    padding:28px max(32px,calc((100vw - var(--desktop-sidebar) - 860px)/2)) 36px!important;
    background:#fff!important;
  }
  .welcome{min-height:42%;place-items:center;padding-bottom:0}
  .message-row{max-width:860px;margin-left:auto;margin-right:auto}
  .message-row.user .bubble{max-width:min(68%,680px)}
  .message-row.assistant .bubble{max-width:min(100%,820px)}
  .message-row.task-message .bubble{max-width:min(100%,820px)}
  .bubble{font-size:15px;line-height:1.5}
  .task-card{background:#fafafa}
  .composer-wrap{
    grid-column:2!important;
    grid-row:3!important;
    position:relative!important;
    bottom:auto!important;
    z-index:6!important;
    padding:14px max(32px,calc((100vw - var(--desktop-sidebar) - 860px)/2)) 14px!important;
    border-top:1px solid var(--border)!important;
    background:rgba(255,255,255,.92)!important;
  }
  .composer{max-width:860px;margin:0 auto;border-radius:24px;box-shadow:0 2px 18px rgba(0,0,0,.045)}
  .ai-note{max-width:860px;margin-left:auto;margin-right:auto}
  .file-fab{
    position:absolute!important;
    right:28px!important;
    bottom:112px!important;
    z-index:25!important;
  }
  .scrim{position:absolute!important;left:var(--desktop-sidebar)!important;right:0!important;top:0!important;bottom:0!important;inset:0 0 0 var(--desktop-sidebar)!important;background:rgba(0,0,0,.12)!important;z-index:70!important}
  .scrim.show{display:block!important}
  .file-sheet{
    left:auto!important;
    right:24px!important;
    top:80px!important;
    bottom:24px!important;
    width:min(520px,calc(100vw - var(--desktop-sidebar) - 48px))!important;
    max-height:none!important;
    height:auto!important;
    border:1px solid var(--border)!important;
    border-radius:24px!important;
    box-shadow:0 24px 80px rgba(0,0,0,.18)!important;
    padding:14px 16px 18px!important;
    transform:translateX(calc(100% + 40px))!important;
    overflow-y:auto!important;
    z-index:120!important;
  }
  .file-sheet.open{transform:translateX(0)!important}
  .sheet-handle{display:none}
  .file-sheet.preview-mode{max-height:none!important;height:auto!important;padding-bottom:18px!important}
  .file-preview-body{max-height:calc(100dvh - 230px)!important;padding-bottom:28px!important}
  .phone.sheet-open .composer-wrap{display:block!important}
  .phone.sheet-open .file-fab{display:none!important}
  .phone.sheet-open .chat{pointer-events:auto!important}
}

@media (min-width: 1200px){
  :root{--desktop-sidebar:320px}
  .chat{padding-left:max(48px,calc((100vw - var(--desktop-sidebar) - 920px)/2))!important;padding-right:max(48px,calc((100vw - var(--desktop-sidebar) - 920px)/2))!important}
  .composer-wrap{padding-left:max(48px,calc((100vw - var(--desktop-sidebar) - 920px)/2))!important;padding-right:max(48px,calc((100vw - var(--desktop-sidebar) - 920px)/2))!important}
  .message-row,.composer,.ai-note{max-width:920px}
}

/* v2.4.2: Markdown artifact preview with real GFM-style tables */
.file-preview-body.markdown{overflow:auto!important;overflow-x:auto!important;white-space:normal!important;word-break:normal!important}
.file-preview-body.markdown p{margin:0 0 12px}.file-preview-body.markdown ul{margin:8px 0 12px 20px;padding:0}.file-preview-body.markdown li{margin:4px 0}.file-preview-body.markdown pre{overflow:auto;background:var(--soft);border:1px solid var(--border);border-radius:10px;padding:10px;margin:10px 0;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;line-height:1.45}.file-preview-body.markdown .md-table-wrap{width:100%;overflow-x:auto;margin:12px 0 18px;border:1px solid var(--border);border-radius:12px;background:#fff}.file-preview-body.markdown table{width:100%;min-width:560px;border-collapse:collapse;font-size:13px;line-height:1.4}.file-preview-body.markdown th,.file-preview-body.markdown td{border-bottom:1px solid var(--border);border-right:1px solid var(--border);padding:8px 10px;text-align:left;vertical-align:top;white-space:normal}.file-preview-body.markdown th:last-child,.file-preview-body.markdown td:last-child{border-right:0}.file-preview-body.markdown tr:last-child td{border-bottom:0}.file-preview-body.markdown th{background:var(--soft);font-weight:700}.file-preview-body.markdown tbody tr:nth-child(even){background:#fafafa}

/* v2.4.3: stabilize task cards while progress/tool calls stream in. */
.message-row.task-message{align-items:flex-start!important}
.message-row.task-message .bubble{white-space:normal!important;display:block!important}
.message-row.task-message .task-card{white-space:normal!important;display:block!important;height:auto!important;min-height:0!important;margin:0!important}
.message-row.task-message .steps{white-space:normal!important;align-content:start!important;max-height:180px!important;overflow-y:auto!important;overscroll-behavior:contain!important;padding-right:4px!important}
.message-row.task-message .step{white-space:normal!important;line-height:1.35!important}
.message-row.task-message + .message-row{margin-top:18px!important}
@media (min-width:900px){.message-row.task-message .steps{max-height:160px!important}.message-row.task-message .task-card{padding:14px 16px!important}}

/* v2.4.6 deterministic autonomy floating control
   Same geometry as .file-fab; center shifted upward by 1.5 button heights (72px). */
.autonomy-fab{
  position:absolute;
  right:16px;
  bottom:calc(164px + env(safe-area-inset-bottom));
  z-index:36;
  width:48px;
  height:48px;
  min-width:48px;
  min-height:48px;
  max-width:48px;
  max-height:48px;
  border:1px solid var(--danger);
  border-radius:50%;
  background:#fff;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
  display:grid;
  place-items:center;
  color:var(--danger);
  cursor:pointer;
  padding:0;
  margin:0;
  appearance:none;
  -webkit-appearance:none;
  line-height:0;
  overflow:visible;
}
.autonomy-fab:hover{filter:brightness(.98)}
.autonomy-fab.on{border-color:var(--green);color:var(--green);background:#fff}
.autonomy-fab.off{border-color:var(--danger);color:var(--danger);background:#fff}
.autonomy-fab svg{display:block;width:22px;height:22px;flex:0 0 22px}
.phone.sheet-open .autonomy-fab{display:none!important}
@media(max-width:699px){.autonomy-fab{bottom:calc(164px + max(0px,env(safe-area-inset-bottom)))!important}}


/* v2.4.10: cleaner task timeline UX.
   Only the currently running task is expanded; completed/cancelled/failed/pending tasks stay compact. */
.message-row.task-message .task-card.compact{
  padding:10px 12px!important;
  background:#fff!important;
}
.message-row.task-message .task-card.compact .task-head{
  align-items:center!important;
}
.message-row.task-message .task-card.compact .steps,
.message-row.task-message .task-card.compact .error{
  display:none!important;
}
.message-row.task-message .task-card.running{
  border-color:rgba(17,17,17,.18)!important;
  background:#fafafa!important;
}
.message-row.task-message .task-card.running .task-head span:first-child{
  font-weight:720!important;
}
.message-row.task-message .task-card.done .task-head span:first-child{
  color:var(--muted)!important;
  font-weight:600!important;
}
.message-row.task-message .task-card.compact .status{
  transform:scale(.94);
  transform-origin:right center;
}

/* v2.4.12: accordion task cards + explicit running-task stop control */
.message-row.task-message .task-card{transition:border-color .16s ease,background .16s ease,box-shadow .16s ease!important}
.message-row.task-message .task-card.running{box-shadow:0 10px 28px rgba(0,0,0,.055)!important}
.task-accordion{display:block;width:100%}
.task-accordion summary{list-style:none;cursor:pointer;user-select:none}
.task-accordion summary::-webkit-details-marker{display:none}
.task-accordion summary.task-head{position:relative;padding-left:18px!important;align-items:center!important}
.task-accordion summary.task-head::before{content:'›';position:absolute;left:0;top:50%;transform:translateY(-50%) rotate(0deg);font-size:18px;line-height:1;color:var(--muted);transition:transform .16s ease}
.task-accordion[open] summary.task-head::before{transform:translateY(-50%) rotate(90deg)}
.task-title{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}
.task-actions{display:inline-flex;align-items:center;gap:7px;flex:0 0 auto}
.task-body{padding-top:10px}
.task-stop{border:1px solid #ffd0cc;background:#fff;color:var(--danger);border-radius:999px;padding:4px 9px;font-size:11px;font-weight:800;cursor:pointer;line-height:1.2}
.task-stop:hover{background:#fee4e2}
.message-row.task-message .task-card.compact .steps,.message-row.task-message .task-card.compact .error{display:grid!important}
.message-row.task-message .task-card.compact:not(:has(details[open])) .task-body{display:none!important}
.message-row.task-message .task-card.done{border-color:#efeff0!important;background:#fff!important}
.message-row.task-message .task-card.done details[open]{background:#fff!important}
@supports not selector(:has(*)){
  .message-row.task-message .task-card.compact .task-body{display:none!important}
  .message-row.task-message .task-card.compact details[open] .task-body{display:block!important}
}



/* v2.4.20: clean right-side FAB rail; stable spacing, no visual drift. */
.fab-rail{
  position:absolute;
  right:16px;
  bottom:calc(92px + env(safe-area-inset-bottom));
  z-index:36;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  pointer-events:none;
}
.fab-rail > button{
  position:relative!important;
  right:auto!important;
  bottom:auto!important;
  margin:0!important;
  flex:0 0 48px;
  width:48px!important;
  height:48px!important;
  min-width:48px!important;
  min-height:48px!important;
  pointer-events:auto;
  transform:none!important;
}
.phone.sheet-open .fab-rail{display:none!important}
@media(max-width:699px){
  .fab-rail{bottom:calc(92px + max(0px,env(safe-area-inset-bottom)))!important}
}


/* v2.4.25 Plugin Admin Mode switch */
.switch{width:48px;height:28px;border:1px solid var(--border);border-radius:999px;background:#e9e9ec;position:relative;padding:0;cursor:pointer;flex:0 0 auto;transition:background .18s ease,border-color .18s ease}
.switch span{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.18);transition:transform .18s ease}
.switch.on{background:var(--green);border-color:var(--green)}
.switch.on span{transform:translateX(20px)}
.switch.off{background:#e9e9ec;border-color:var(--border)}

/* v2.4.34 Push-to-talk dictation: no VAD, no wakeword. */
.composer button.mic{color:var(--text);background:#fff;border:1px solid transparent}
.composer button.mic:hover{background:var(--soft)}
.composer button.mic.recording{background:#fff!important;color:var(--green)!important;border-color:var(--green)!important;box-shadow:0 0 0 4px rgba(20,184,166,.14)}
.composer button.mic.busy{background:var(--soft)!important;color:var(--muted)!important}

/* v2.4.41: task cards are fixed-width, collapsed by default, and show the current step in the header. */
.message-row.task-message .bubble{
  width:min(100%,520px)!important;
  max-width:min(100%,520px)!important;
  flex:0 1 520px!important;
}
.message-row.task-message .task-card{
  width:100%!important;
  max-width:520px!important;
  box-sizing:border-box!important;
}
.task-title{
  min-width:0!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  white-space:nowrap!important;
  font-weight:720!important;
}
.task-full-title{
  margin:0 0 8px!important;
  color:var(--muted)!important;
  font-size:12px!important;
  line-height:1.3!important;
  overflow-wrap:anywhere!important;
}
.message-row.task-message .task-card.compact .task-body{
  display:none!important;
}
.message-row.task-message .task-card.compact details[open] .task-body{
  display:block!important;
}
.message-row.task-message .task-card.compact .steps,
.message-row.task-message .task-card.compact .error{
  display:grid!important;
}
.message-row.task-message .task-card.running .task-head span:first-child{
  color:var(--text)!important;
}

/* v2.4.42 Project Workspace MVP */
.project-select{
  margin-top:4px;
  max-width:190px;
  height:24px;
  border:1px solid var(--border);
  border-radius:999px;
  background:#fff;
  color:var(--text);
  font-size:11px;
  font-weight:650;
  padding:0 8px;
  outline:0;
}
.project-select:focus{border-color:#bbb;box-shadow:0 0 0 3px rgba(0,0,0,.05)}
@media(max-width:699px){.project-select{max-width:150px;height:22px;font-size:10px}.title{max-width:240px}}
