@font-face{font-family:"Söhne";font-weight:100 900;font-display:swap;src:url("assets/fonts/soehne.ttf") format("truetype")}
:root{
  --bg:#FFFFFF; --card:#FFFFFF; --card2:#F7F7F7; --line:rgba(0,0,0,.10);
  --txt:#0D0D0D; --sub:#3D3D3D; --ter:#6E6E6E; --accent:#0D0D0D; --bubble:#F4F4F4;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
body{background:#e9e9ec;font-family:"Söhne",-apple-system,"PingFang SC",system-ui,sans-serif;
  display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;gap:30px;flex-wrap:wrap}
.wrap{display:flex;flex-direction:column;align-items:center;gap:12px}
.label{color:#5D5D5D;font-size:13px;letter-spacing:.5px}
.phone{width:390px;height:844px;background:var(--bg);border-radius:46px;
  border:11px solid #1a1d24;box-shadow:0 0 0 2px #000,0 30px 80px rgba(0,0,0,.6);
  overflow:hidden;position:relative;display:flex;flex-direction:column}
.notch{position:absolute;top:0;left:50%;transform:translateX(-50%);width:130px;height:30px;
  background:#000;border-radius:0 0 18px 18px;z-index:100}
.statusbar{height:50px;display:flex;align-items:flex-end;justify-content:space-between;
  padding:0 26px 6px;color:var(--txt);font-size:13px;font-weight:600;flex-shrink:0}
.statusbar .si-icons{display:flex;align-items:center;gap:6px}
.statusbar svg{display:block}
.screen{flex:1;overflow:hidden;position:relative}
.page{position:absolute;inset:0;overflow-y:auto;padding:8px 0 90px;display:none;scrollbar-width:none}
#p1.active{padding-bottom:150px}
.page::-webkit-scrollbar{display:none}
.page.active{display:block}
.tabbar{position:absolute;bottom:0;left:0;right:0;height:82px;background:rgba(255,255,255,.92);
  backdrop-filter:blur(20px);border-top:1px solid var(--line);display:flex;padding-bottom:18px;z-index:50}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  color:var(--sub);cursor:pointer;font-size:10px;transition:.2s}
.tab.active{color:#0D0D0D}
.tab svg{width:24px;height:24px}
.hd{padding:10px 20px 14px;display:flex;align-items:center;justify-content:space-between}
.hd h1{font-size:24px;color:var(--txt);font-weight:700}
.hd .r{display:flex;gap:14px;color:var(--sub);align-items:center}
.hd .r svg{display:block;cursor:pointer}
.dev-status{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--txt);border:2px solid var(--ter);transition:border-color .15s,transform .1s}
.dev-status:active{transform:scale(.92)}
.dev-status.online{border-color:#1aa251}
.dev-status svg{width:17px;height:17px}
.sec{font-size:12px;color:var(--sub);padding:14px 20px 8px;font-weight:600;letter-spacing:.5px;
  display:flex;align-items:center;justify-content:space-between}
.sec a{color:#5D5D5D;font-size:12px;font-weight:500}

/* cards */
.card{background:var(--bg);margin:9px 16px;border-radius:20px;padding:16px;border:1px solid var(--line)}
.card.tap{cursor:pointer;transition:.15s}
.card.tap:active{transform:scale(.98);background:#fafafa}
.pushcard{background:var(--bg);border-color:var(--line)}
.crow{display:flex;align-items:center;gap:11px}
.ico{width:34px;height:34px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--txt);background:var(--bg);border:1px solid var(--line)}
.ico svg{display:block}
.ctitle{font-size:15px;color:var(--txt);font-weight:600;display:inline-flex;align-items:center;gap:7px}
.csub{font-size:12.5px;color:var(--txt);margin-top:3px;line-height:1.5}
.csub svg{display:inline-block;vertical-align:-3px;margin-right:4px}
.badge{font-size:10px;padding:0 9px;height:18px;display:inline-flex;align-items:center;border-radius:100px;font-weight:600;background:transparent;border:1px solid var(--line);color:var(--sub)}
.prog{height:5px;background:rgba(0,0,0,.10);border-radius:3px;margin-top:10px;overflow:hidden}
.prog i{display:block;height:100%;background:#0D0D0D;border-radius:3px}

/* chat */
.chat{padding:6px 16px}
.msg{margin:14px 0;display:flex;gap:8px;max-width:88%}
.msg.me{margin-left:auto;flex-direction:row-reverse;max-width:85%}
.msg.ai{max-width:100%;width:100%}
.msg.ai .bubble{width:100%;max-width:100%}
.bubble{padding:10px 14px;border-radius:16px;font-size:14.5px;line-height:1.55;color:var(--txt)}
.msg.ai .bubble{background:transparent;padding:2px 0 0}
.msg.me .bubble{background:var(--bubble);color:var(--txt);border-bottom-right-radius:5px}
.av{display:none}
.divtime{text-align:center;color:var(--ter);font-size:11px;margin:14px 0}

/* memory / kb tabs */
.subtab{display:flex;gap:8px;padding:6px 16px 4px}
.pill{padding:7px 16px;border-radius:100px;font-size:13px;background:var(--bg);color:var(--sub);cursor:pointer;border:1px solid var(--line)}
.pill.on{background:#0D0D0D;color:#fff;border-color:#0D0D0D}
.memitem{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--line);margin:0 8px}
.memitem .t{flex:1}
.memitem svg{color:var(--ter)}
.dot{width:7px;height:7px;border-radius:50%;background:#5D5D5D;flex-shrink:0}

/* explore */
.reco{display:flex;gap:12px;overflow-x:auto;padding:4px 16px 10px;scrollbar-width:none;scroll-snap-type:x proximity}
.reco::-webkit-scrollbar{display:none}
.rcard{min-width:140px;flex:0 0 42%;background:var(--bg);border:1px solid var(--line);
  border-radius:18px;padding:15px;cursor:pointer}
.rcard .e{color:var(--sub)}.rcard .e svg{display:block}
.rcard .t{font-size:14px;color:var(--txt);font-weight:600;margin-top:8px}
.rcard .d{font-size:11.5px;color:var(--sub);margin-top:3px;line-height:1.4}

/* me */
.devscroll{display:flex;gap:10px;overflow-x:auto;padding:2px 16px 4px;scrollbar-width:none}
.devscroll::-webkit-scrollbar{display:none}
.devbox{flex:0 0 116px;background:var(--bg);border:1px solid var(--line);border-radius:18px;padding:14px;display:flex;flex-direction:column;gap:8px;cursor:pointer;transition:transform .1s,background .12s}
.devbox:active{transform:scale(.97);background:rgba(0,0,0,.02)}
.devimg{width:42px;height:42px;border-radius:12px;background:var(--bg);border:1px solid var(--line);color:var(--txt);display:flex;align-items:center;justify-content:center}
.devimg svg{display:block}
.devname{font-size:14px;font-weight:600;color:var(--txt)}
.devmeta{font-size:11.5px;color:var(--sub);display:flex;align-items:center;gap:5px}
.ddot{width:7px;height:7px;border-radius:50%}
.ddot.on{background:#1aa251}
.ddot.off{background:transparent;border:1.5px solid var(--ter)}
.devbox.add{align-items:center;justify-content:center;border-style:dashed;color:var(--sub)}
.devbox.add .addico{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--txt)}
.list{margin:9px 16px;background:var(--bg);border-radius:18px;border:1px solid var(--line);overflow:hidden}
.li{display:flex;align-items:center;gap:12px;padding:14px 15px;border-bottom:1px solid var(--line);cursor:pointer;font-size:14.5px;color:var(--txt)}
.li:last-child{border-bottom:none}
.li:active{background:#fafafa}
.li .ar{margin-left:auto;color:var(--ter);font-size:12px;font-weight:600}
.li .e{width:24px;display:flex;align-items:center;justify-content:center;color:var(--sub)}
.li .e svg{display:block}

/* timeline (情景记忆) */
.timeline{margin:9px 16px;padding:4px 0 4px 6px;position:relative}
.tl-item{position:relative;padding:0 0 18px 22px}
.tl-item:last-child{padding-bottom:2px}
.tl-item::before{content:"";position:absolute;left:4px;top:13px;bottom:-5px;width:1.5px;background:var(--line)}
.tl-item:last-child::before{display:none}
.tl-dot{position:absolute;left:0;top:4px;width:9px;height:9px;border-radius:50%;background:var(--bg);border:2px solid var(--txt)}
.tl-title{font-size:14px;color:var(--txt);line-height:1.4}
.tl-date{font-size:12px;color:var(--ter);margin-top:2px}

/* detail overlay */
.overlay{position:absolute;inset:0;background:var(--bg);z-index:200;transform:translateX(100%);transition:.3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.overlay.show{transform:translateX(0)}
.obar{height:54px;display:flex;align-items:center;gap:6px;padding:0 8px;border-bottom:1px solid var(--line);flex-shrink:0}
.obar .bk{width:40px;height:40px;border:none;background:transparent;color:#0D0D0D;border-radius:100px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,transform .1s}
.obar .bk:active{background:rgba(0,0,0,.05);transform:scale(.92)}
.obar .ti{font-size:16px;font-weight:600;color:var(--txt)}
.obody{flex:1;overflow-y:auto;padding:14px 16px 30px;scrollbar-width:none}
.obody::-webkit-scrollbar{display:none}
.screenview{background:#0D0D0D;border:1px solid var(--line);border-radius:14px;height:300px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.screenview .mock{text-align:center;color:#fff;font-size:13px}
.screenview .mock svg{display:block;margin:0 auto 8px}
.hl{position:absolute;border:2px solid #fff;border-radius:8px;box-shadow:0 0 0 4px rgba(255,255,255,.25);animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.step{display:flex;gap:11px;padding:11px 0;align-items:flex-start}
.step .si{width:22px;height:22px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
.si.ok{background:#0D0D0D;color:#fff}.si.cur{background:#0D0D0D;color:#fff}
.si.wait{background:var(--bg);color:var(--txt);border:1px solid var(--line)}
.si svg{display:block}
.step .st{font-size:14px;color:var(--txt)}.step .ss{font-size:12px;color:var(--txt)}
.actbtns{display:flex;gap:10px;margin-top:18px}
.btn{flex:1;padding:13px;border-radius:100px;border:none;font-size:14px;font-weight:600;cursor:pointer}
.btn.takeover{background:#0D0D0D;color:#fff}
.btn.pause{background:var(--bg);color:var(--txt);border:1px solid var(--line)}
.btn.stop{background:var(--bg);color:var(--txt);border:1px solid var(--line)}
.confirm-banner{background:var(--bg);border:1px solid var(--line);margin:9px 16px;border-radius:20px;padding:16px}
.hint{position:fixed;bottom:14px;left:50%;transform:translateX(-50%);background:#0D0D0D;color:#fff;
  font-size:12px;padding:8px 16px;border-radius:20px;z-index:999;box-shadow:0 10px 30px rgba(0,0,0,.3)}

/* sticky composer (matches assistant) */
.composer{position:absolute;bottom:82px;left:0;right:0;padding:8px 12px 12px;background:linear-gradient(to top,var(--bg) 62%,rgba(255,255,255,0));z-index:48;display:none}
.composer .plus-tray{display:flex;gap:10px;max-height:0;overflow:hidden;padding:0 2px;opacity:0;transition:max-height .25s cubic-bezier(.3,0,0,1),margin .25s cubic-bezier(.3,0,0,1),opacity .2s}
.composer .plus-tray.open{max-height:92px;margin-bottom:10px;opacity:1}
.composer .tray-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:7px;padding:12px 4px;background:var(--bg);border:1px solid var(--line);border-radius:18px;color:var(--sub);cursor:pointer;font-size:11.5px;transition:background .12s,transform .1s}
.composer .tray-item:active{background:rgba(0,0,0,.05);transform:scale(.95)}
.composer .tray-item .ti-ico{color:var(--txt)}
.composer .input-row{display:flex;align-items:flex-end;gap:8px;background:var(--bg);border:1px solid var(--line);border-radius:28px;padding:6px 6px 6px 8px;min-height:52px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.composer .rnd{width:38px;height:38px;flex-shrink:0;border:none;background:transparent;color:var(--txt);border-radius:100px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .12s,transform .1s}
.composer .rnd:active{background:rgba(0,0,0,.08);transform:scale(.9)}
.composer .input-field{flex:1;border:none;background:transparent;color:var(--txt);font-size:16px;font-weight:400;font-family:-apple-system,"PingFang SC",system-ui,sans-serif;resize:none;outline:none;padding:9px 2px;max-height:100px;line-height:1.4}
.composer .input-field::placeholder{color:var(--ter);font-weight:400}
.composer .send-btn{width:38px;height:38px;flex-shrink:0;border:none;border-radius:100px;background:#0D0D0D;color:#fff;display:none;align-items:center;justify-content:center;cursor:pointer;transition:transform .1s}
.composer .send-btn:active{transform:scale(.9)}
.composer.typing #cMic,.composer.typing #cPlus{display:none}
.composer.typing .send-btn{display:flex}
/* task-card inside companion (reuse assistant styles) */
.task-card{background:var(--bg);border:1px solid var(--line);border-radius:20px;padding:16px;margin-top:8px}
.task-card .tc-head{display:flex;align-items:flex-start;gap:11px;margin-bottom:12px}
.task-card .tc-ico{width:34px;height:34px;flex-shrink:0;border-radius:11px;background:var(--bg);border:1px solid var(--line);color:var(--txt);display:flex;align-items:center;justify-content:center}
.task-card .tc-title{font-size:15px;font-weight:600;color:var(--txt);line-height:1.35}
.task-card .tc-sub{font-size:12.5px;color:var(--txt);margin-top:3px}
.task-card .tc-status{margin-left:auto;flex-shrink:0;font-size:11px;font-weight:600;color:var(--txt);display:flex;align-items:center;gap:5px}
.task-card .tc-status .pulse{width:7px;height:7px;border-radius:50%;background:var(--txt);animation:pulse 1.4s ease-in-out infinite}
.progress-wrap{margin:6px 0 14px}
.progress-row{display:flex;justify-content:space-between;font-size:12px;color:var(--txt);margin-bottom:7px}
.progress-track{height:6px;border-radius:100px;background:rgba(0,0,0,.10);overflow:hidden}
.progress-fill{height:100%;border-radius:100px;background:#0D0D0D;transition:width .6s}
.task-steps{list-style:none;margin:0 0 14px;display:flex;flex-direction:column;gap:9px}
.task-steps li{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--txt)}
.task-steps li.done{color:var(--ter)}
.step-ico{width:16px;height:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.step-ico.done{color:var(--txt)}
.step-ico.run{color:var(--txt)}
.step-ico.run .spin{animation:spin 1s linear infinite;transform-origin:center}
@keyframes spin{to{transform:rotate(360deg)}}
.step-ico.wait{color:var(--ter)}
.tc-actions{display:flex;gap:10px}
.tc-actions .btn{flex:1;padding:12px;border-radius:100px}
