﻿*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f5f3ee;--surf:#fff;--surf2:#eeebe3;--surf3:#e4e0d6;
  --bdr:#ddd8cc;--bdr2:#ccc7b8;
  --txt:#1a1710;--txt2:#6b6354;--txt3:#a09880;
  --grn:#1a6b3a;--grn-bg:#e5f4ec;--grn-mid:#2d9e58;
  --red:#b03a2e;--red-bg:#fbeeed;--red-mid:#d95a46;
  --blu:#1a4a8a;--blu-bg:#edf2fb;--blu-mid:#3a7ad4;
  --pur:#5b2d8e;--pur-bg:#f0eafa;--pur-mid:#8b5cf6;
  --amb:#7a4a0a;--amb-bg:#fdf2e0;--amb-mid:#d4901a;
  --acc:#2a5498;--acc2:#edf2fb;--acc-lt:#5a80c8;
  --user-bg:#2a5498;--user-txt:#fff;
  --r:14px;--rs:9px;--rsm:6px;
  font-family:'DM Sans',sans-serif;font-size:14px;color:var(--txt);
}
@media(prefers-color-scheme:dark){:root{
  --bg:#111009;--surf:#1a1814;--surf2:#221f18;--surf3:#2c2820;
  --bdr:#332e24;--bdr2:#44403a;
  --txt:#f0ece2;--txt2:#a09880;--txt3:#6b6456;
  --grn:#2d9e58;--grn-bg:#0d2219;--grn-mid:#1a6b3a;
  --red:#d95a46;--red-bg:#280f0c;--red-mid:#b03a2e;
  --blu:#3a7ad4;--blu-bg:#0d1e3a;--blu-mid:#1a4a8a;
  --pur:#8b5cf6;--pur-bg:#1e1230;--pur-mid:#5b2d8e;
  --amb:#d4901a;--amb-bg:#271a06;--amb-mid:#7a4a0a;
  --acc:#5a8fd4;--acc2:#162040;--acc-lt:#7aaae8;
  --user-bg:#1e3a6a;--user-txt:#f0ece2;
}}
html,body{height:100%;overflow:hidden;max-width:100vw}
body{background:var(--bg);display:flex;flex-direction:column}

/* ── INTELLIGENCE LAYER ── */
.confidence-bar{display:flex;align-items:center;gap:6px;margin-top:6px;padding:4px 0;flex-wrap:wrap}
.conf-tag{display:inline-flex;align-items:center;gap:3px;font-size:10px;padding:2px 7px;border-radius:20px;font-weight:500;opacity:.85}
.conf-live{background:var(--grn-bg);color:var(--grn)}
.conf-memory{background:var(--pur-bg);color:var(--pur-mid)}
.conf-training{background:var(--amb-bg);color:var(--amb-mid)}
.conf-stale{background:var(--red-bg);color:var(--red)}
.pattern-nudge{margin-top:8px;padding:8px 11px;background:var(--acc2);border:1px solid rgba(90,143,212,.2);border-radius:var(--rs);font-size:11px;color:var(--acc);display:flex;align-items:flex-start;gap:7px;line-height:1.5}
.pattern-nudge button{background:var(--acc);color:#fff;border:none;border-radius:var(--rsm);padding:3px 9px;font-size:10px;cursor:pointer;font-family:"DM Sans",sans-serif;white-space:nowrap;flex-shrink:0;margin-top:1px}
.pattern-nudge-dismiss{background:none!important;color:var(--acc)!important;border:1px solid rgba(90,143,212,.3)!important;margin-left:4px}
.pushback-notice{margin-bottom:8px;padding:7px 10px;background:var(--amb-bg);border-left:3px solid var(--amb-mid);border-radius:0 var(--rs) var(--rs) 0;font-size:12px;color:var(--amb);line-height:1.5}
.loki-nudge{display:flex;align-items:flex-start;gap:8px;line-height:1.5}
.math-block{overflow-x:auto;margin:12px 0}
.bubble.ai sup{font-size:0.72em;vertical-align:super;line-height:0}
.bubble.ai sub{font-size:0.72em;vertical-align:sub;line-height:0}
.bubble.ai .math-block span{font-family:Georgia,serif}
/* ── CLOUD MEMORY ── */
.cloud-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;background:var(--blu-bg);color:var(--blu-mid);border:1px solid rgba(58,122,212,.2);border-radius:20px;padding:2px 8px;margin-bottom:6px}
.passphrase-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:9999;display:none;align-items:center;justify-content:center;padding:16px}
.passphrase-overlay.show{display:flex}
.passphrase-box{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:24px;width:100%;max-width:380px}
.passphrase-box h3{font-family:"DM Serif Display",serif;font-size:18px;margin-bottom:8px}
.passphrase-box p{font-size:12px;color:var(--txt2);margin-bottom:14px;line-height:1.6}
.pp-input{width:100%;padding:10px 12px;border:1px solid var(--bdr);border-radius:var(--rs);background:var(--surf2);color:var(--txt);font-size:14px;font-family:"DM Sans",sans-serif;outline:none;margin-bottom:10px}
.pp-input:focus{border-color:var(--acc)}
.pp-btns{display:flex;gap:8px}
.pp-btns button{flex:1;padding:9px;border-radius:var(--rs);font-size:13px;font-weight:500;cursor:pointer;font-family:"DM Sans",sans-serif;border:none}
.pp-ok{background:var(--acc);color:#fff}.pp-ok:hover{opacity:.88}
.pp-skip{background:var(--surf2);color:var(--txt2);border:1px solid var(--bdr)!important}
/* ── OFFLINE ── */
.offline-bar{display:none;background:var(--amb-mid);color:#fff;font-size:12px;text-align:center;padding:6px;flex-shrink:0}
.offline-bar.show{display:block}

/* ── PROVIDER BAR ── */
.provider-bar{display:none;padding:7px 16px;font-size:12px;font-weight:500;text-align:center;flex-shrink:0;align-items:center;justify-content:center;gap:10px}
.provider-bar.show{display:flex}
.provider-bar.groq{background:var(--grn-bg);color:var(--grn);border-bottom:1px solid rgba(45,158,88,.2)}
.provider-bar.gemini{background:var(--red-bg);color:var(--red);border-bottom:1px solid rgba(217,90,70,.2)}
.provider-bar button{background:none;border:none;cursor:pointer;color:inherit;font-size:16px;opacity:.7;line-height:1}

/* ── SETUP ── */
.setup-wrap{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:20px;overflow-y:auto}
.setup-box{background:var(--surf);border-radius:20px;padding:28px;width:100%;max-width:420px;margin:auto;box-shadow:0 4px 24px rgba(0,0,0,.1),0 1px 6px rgba(0,0,0,.06)}
.setup-logo{text-align:center;margin-bottom:22px}
.setup-icon{width:60px;height:60px;background:linear-gradient(135deg,var(--acc),var(--acc-lt));border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 12px;box-shadow:0 4px 16px rgba(42,84,152,.35)}
.setup-logo h1{font-family:'DM Serif Display',serif;font-size:28px}
.setup-logo p{font-size:12px;color:var(--txt3);margin-top:4px;line-height:1.5}
.fld{margin-bottom:11px}
.fld label{display:block;font-size:12px;font-weight:500;color:var(--txt2);margin-bottom:4px}
.fld input,.fld select,.fld textarea{width:100%;padding:9px 11px;border:none;border-radius:var(--r);background:var(--surf2);color:var(--txt);font-size:13px;font-family:'DM Sans',sans-serif;outline:none;transition:box-shadow .15s;box-shadow:0 1px 4px rgba(0,0,0,.07),0 2px 8px rgba(0,0,0,.04)}
.fld input:focus,.fld select:focus,.fld textarea:focus{box-shadow:0 1px 4px rgba(42,84,152,.15),0 0 0 2px var(--acc2)}
.fld textarea{resize:vertical;min-height:72px;line-height:1.5}
.key-row{display:flex;gap:6px}
.key-row input{flex:1}
.key-row button{padding:9px 12px;border:none;border-radius:var(--r);background:var(--surf2);color:var(--txt2);cursor:pointer;font-size:12px;font-family:'DM Sans',sans-serif;white-space:nowrap;transition:all .15s;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.key-row button:hover{color:var(--acc);background:var(--acc2)}
.btn-full{width:100%;padding:11px;background:linear-gradient(135deg,var(--acc),var(--acc-lt));color:#fff;border:none;border-radius:var(--rs);font-size:14px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;margin-top:6px;box-shadow:0 2px 8px rgba(42,84,152,.3);transition:opacity .15s}
.btn-full:hover{opacity:.9}
.info-box{border-radius:var(--rs);padding:12px 13px;margin-bottom:12px;font-size:12px;line-height:1.7}
.info-box a{color:var(--acc)}
.info-box strong{color:var(--txt)}
.info-box.grn{background:var(--grn-bg);border:1px solid rgba(45,158,88,.3)}
.info-box.amb{background:var(--amb-bg);border:1px solid rgba(212,144,26,.3)}
.smsg{font-size:12px;padding:9px 11px;border-radius:var(--rs);margin-top:10px;display:none}
.smsg.err{background:var(--red-bg);color:var(--red);display:block}
.smsg.ok{background:var(--grn-bg);color:var(--grn);display:block}
.install-btn{display:none;width:100%;padding:9px;background:var(--grn-bg);color:var(--grn);border:1px solid rgba(45,158,88,.4);border-radius:var(--rs);font-size:13px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;margin-top:8px}
.install-btn.show{display:block}

/* ── TOPBAR ── */
.topbar{background:var(--surf);box-shadow:0 1px 0 var(--bdr),0 2px 10px rgba(0,0,0,.04);padding:10px 16px;display:flex;align-items:center;justify-content:space-between;gap:8px;flex-shrink:0;flex-wrap:wrap}
.topbar-l{display:flex;align-items:center;gap:9px}
.app-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--acc),var(--acc-lt));border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;box-shadow:0 2px 8px rgba(42,84,152,.3)}
.app-name{font-family:'DM Serif Display',serif;font-size:17px;line-height:1}
.app-sub{font-size:10px;color:var(--txt3)}
.topbar-r{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.model-chip{display:flex;align-items:center;gap:5px;background:var(--surf2);border-radius:20px;padding:5px 11px;font-size:11px;color:var(--txt2);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.model-dot{width:7px;height:7px;border-radius:50%;background:var(--grn-mid);flex-shrink:0;animation:pulse 2.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.top-btn{background:var(--surf2);border:none;padding:5px 10px;border-radius:var(--rs);font-size:11px;cursor:pointer;color:var(--txt2);font-family:'DM Sans',sans-serif;transition:all .15s;white-space:nowrap;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.top-btn:hover{color:var(--acc);background:var(--acc2)}
.top-btn.qwen-active{background:var(--pur-bg);border-color:var(--pur-mid);color:var(--pur-mid);font-weight:600}
.top-btn.danger:hover{border-color:var(--red);color:var(--red);background:var(--red-bg)}
.sidebar-toggle{display:none;background:none;border:none;padding:4px 6px;cursor:pointer;color:var(--txt2);font-size:18px;line-height:1}

/* ── MAIN LAYOUT ── */
.main{flex:1;display:flex;overflow:hidden}
.mobile-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:50;display:none}
.mobile-overlay.open{display:block}

/* ── SIDEBAR ── */
.sidebar{width:240px;background:var(--surf);box-shadow:2px 0 12px rgba(0,0,0,.06);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}
.sidebar-hdr{padding:16px 14px 10px;display:flex;align-items:center;justify-content:space-between;gap:6px}
.sidebar-title{font-family:'DM Serif Display',serif;font-size:16px;color:var(--txt);line-height:1}
.new-btn{background:linear-gradient(135deg,var(--acc),var(--acc-lt));color:#fff;border:none;border-radius:var(--r);padding:6px 12px;font-size:11px;cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:500;box-shadow:0 2px 6px rgba(42,84,152,.25);transition:opacity .15s}
.new-btn:hover{opacity:.88}
.sidebar-tabs{display:flex;background:var(--surf2);border-radius:20px;padding:3px;gap:3px;margin:4px 10px 10px}
.stab{flex:1;text-align:center;padding:6px;border-radius:16px;font-size:11px;cursor:pointer;border:none;background:none;color:var(--txt2);font-family:'DM Sans',sans-serif;transition:all .15s;font-weight:500}
.stab.active{background:var(--surf);color:var(--txt);box-shadow:0 1px 4px rgba(0,0,0,.1)}
.sidebar-body{flex:1;overflow-y:auto;padding:6px}
.conv-item{padding:9px 10px;border-radius:var(--r);cursor:pointer;margin-bottom:2px;transition:all .15s;position:relative}
.conv-item:hover{background:var(--surf2);transform:translateX(2px)}
.conv-item.active{background:var(--acc2);box-shadow:0 1px 4px rgba(90,143,212,.12)}
.conv-title{font-size:12px;font-weight:500;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:18px}
.conv-meta{font-size:10px;color:var(--txt3);margin-top:2px}
.conv-del{position:absolute;right:7px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--txt3);cursor:pointer;font-size:16px;padding:2px 4px;line-height:1;display:none}
.conv-item:hover .conv-del{display:block}
.conv-del:hover{color:var(--red)}
.no-items{font-size:12px;color:var(--txt3);text-align:center;padding:20px 10px;line-height:1.6}

/* ── MEMORY PANEL (sidebar trigger) ── */
.mem-open-btn{padding:9px 20px;background:var(--acc);color:#fff;border:none;border-radius:var(--rs);font-size:13px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;transition:opacity .15s}
.mem-open-btn:hover{opacity:.88}
.mem-stats{font-size:11px;color:var(--txt3);padding:6px 10px 10px;text-align:center}

/* ── MEMORY MANAGER POPUP ── */
.mem-modal{position:fixed;top:80px;left:50%;transform:translateX(-50%);width:640px;min-width:300px;max-width:94vw;height:520px;min-height:120px;max-height:88vh;background:var(--surf);border:1px solid var(--bdr2);border-radius:14px;box-shadow:0 8px 40px rgba(0,0,0,.22);z-index:9900;display:flex;flex-direction:column;overflow:hidden;resize:both}
.mem-modal.minimised{height:46px!important;min-height:46px;resize:none}
.mem-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:0 14px;height:46px;flex-shrink:0;background:var(--surf2);border-bottom:1px solid var(--bdr);border-radius:14px 14px 0 0;cursor:grab;font-weight:600;font-size:13px;user-select:none}
.mem-modal-hdr:active{cursor:grabbing}
.mem-modal-btns{display:flex;gap:6px}
.mem-modal-btns button{background:none;border:1px solid var(--bdr);border-radius:6px;width:26px;height:26px;cursor:pointer;color:var(--txt2);font-size:14px;display:flex;align-items:center;justify-content:center}
.mem-modal-btns button:hover{background:var(--bdr2)}
.mem-modal-body{flex:1;overflow:hidden;display:flex;flex-direction:column}
.mem-modal-toolbar{display:flex;gap:8px;align-items:center;padding:10px 14px;border-bottom:1px solid var(--bdr);flex-shrink:0}
.mem-add-btn{padding:6px 13px;background:var(--acc);color:#fff;border:none;border-radius:var(--rs);font-size:12px;font-family:'DM Sans',sans-serif;cursor:pointer;white-space:nowrap;transition:opacity .15s}
.mem-add-btn:hover{opacity:.88}
.mem-search-inp{flex:1;padding:6px 10px;border:1px solid var(--bdr);border-radius:var(--rs);background:var(--surf2);color:var(--txt);font-size:12px;font-family:'DM Sans',sans-serif;outline:none}
.mem-search-inp:focus{border-color:var(--acc)}
.mem-modal-list{flex:1;overflow-y:auto;padding:10px 14px}
.mem-modal-list::-webkit-scrollbar{width:3px}
.mem-modal-list::-webkit-scrollbar-thumb{background:rgba(0,0,0,0.07);border-radius:2px}
.mem-modal-list::-webkit-scrollbar-track{background:transparent}
.mem-card{background:var(--surf2);border:1px solid var(--bdr);border-radius:var(--r);padding:11px 13px;margin-bottom:8px}
.mem-card-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--txt3);margin-bottom:5px}
.mem-card-text{font-size:13px;color:var(--txt);line-height:1.55;word-break:break-word;white-space:pre-wrap}
.mem-card-text[contenteditable=true]{outline:1px solid var(--acc);border-radius:4px;padding:2px 4px;background:var(--surf)}
.mem-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:9px}
.mem-card-ts{font-size:10px;color:var(--txt3)}
.mem-card-actions{display:flex;gap:5px}
.mem-card-actions button{padding:3px 9px;border-radius:var(--rs);font-size:11px;font-family:'DM Sans',sans-serif;cursor:pointer;border:1px solid var(--bdr);background:var(--surf);color:var(--txt2);transition:all .15s}
.btn-save{background:var(--acc)!important;color:#fff!important;border-color:var(--acc)!important;display:none}
.btn-del:hover{color:var(--red)!important;border-color:var(--red)!important}
.btn-edit:hover{background:var(--surf2)!important}

/* ── CHAT ── */
.chat-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;max-width:100%;position:relative}
.top-fade-mask{position:fixed;top:0;left:0;right:0;height:72px;background:linear-gradient(to bottom,var(--bg) 50%,transparent 100%);z-index:150;pointer-events:none}
#particleBg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0}
.messages{flex:1;overflow-y:auto;overflow-x:hidden;padding:56px 16px 100px;display:flex;flex-direction:column;gap:3px;scroll-behavior:smooth;max-width:100%;position:relative;z-index:1}
.messages::-webkit-scrollbar{width:3px}
.messages::-webkit-scrollbar-thumb{background:rgba(0,0,0,0.07);border-radius:2px}
.messages::-webkit-scrollbar-track{background:transparent}

/* ── BUBBLES ── */
.msg-wrap{display:flex;gap:9px;align-items:flex-end;animation:fadeUp .18s ease;padding:0 2px}
@keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.msg-wrap.user{flex-direction:row-reverse}
.msg-wrap.user+.msg-wrap.ai,.msg-wrap.ai+.msg-wrap.user{margin-top:8px}
.avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;box-shadow:0 1px 4px rgba(0,0,0,.12)}
.avatar.ai{background:linear-gradient(135deg,var(--acc),var(--acc-lt));color:#fff;font-size:14px}
.avatar.user{background:var(--surf3);color:var(--txt2)}
.msg-col{display:flex;flex-direction:column;align-items:flex-start;max-width:78%;min-width:0;overflow:visible}
.msg-wrap.user .msg-col{align-items:flex-end}
.bubble{padding:11px 15px;font-size:13px;line-height:1.7;word-break:break-word;min-width:0}
.bubble.ai{background:var(--surf);border-radius:18px 18px 18px 4px;color:var(--txt);box-shadow:0 1px 4px rgba(0,0,0,.07),0 2px 12px rgba(0,0,0,.04);max-width:100%;overflow-wrap:break-word;word-break:break-word;min-width:0}
.bubble.user{background:var(--user-bg);color:var(--user-txt);border-radius:18px 18px 4px 18px;box-shadow:0 1px 4px rgba(0,0,0,.1)}
.bubble-meta{display:flex;align-items:center;gap:7px;margin-top:4px;padding:0 2px;flex-wrap:wrap}
.msg-wrap.user .bubble-meta{flex-direction:row-reverse}
.bubble-time{font-size:10px;color:var(--txt3)}

/* AI bubble markdown */
.bubble.ai p{margin-bottom:9px;line-height:1.7}.bubble.ai p:last-child{margin-bottom:0}
.bubble.ai strong{font-weight:600}.bubble.ai em{font-style:italic;color:var(--txt2)}
.bubble.ai code{background:var(--surf2);border-radius:6px;padding:2px 6px;font-size:11.5px;font-family:'Courier New',monospace;color:var(--acc);word-break:break-all;box-shadow:inset 0 1px 2px rgba(0,0,0,.04)}
.bubble.ai pre{background:var(--surf2);border-radius:12px;padding:14px 16px;overflow-x:auto;margin:10px 0;position:relative;max-width:100%;white-space:pre;box-shadow:0 1px 6px rgba(0,0,0,.06)}
.bubble.ai pre code{background:none;padding:0;font-size:12px;color:var(--txt);display:block;box-shadow:none}
.bubble.ai ul{list-style:none;padding-left:0;margin:8px 0}
.bubble.ai ul li{padding-left:15px;position:relative;margin-bottom:4px}
.bubble.ai ul li::before{content:'•';position:absolute;left:0;color:var(--acc);font-weight:700}
.bubble.ai ol{padding-left:18px;margin:8px 0}
.bubble.ai ol li{margin-bottom:4px}
.bubble.ai h1,.bubble.ai h2,.bubble.ai h3{font-family:'DM Serif Display',serif;margin:14px 0 6px;line-height:1.3}
.bubble.ai h1{font-size:18px;border-bottom:1px solid var(--bdr);padding-bottom:6px}
.bubble.ai h2{font-size:15px}.bubble.ai h3{font-size:14px;color:var(--txt2)}
.bubble.ai blockquote{border-left:3px solid var(--acc);padding:6px 10px;color:var(--txt2);margin:8px 0;background:var(--surf2);border-radius:0 6px 6px 0;font-style:italic}
.bubble.ai hr{border:none;border-top:1px solid var(--bdr);margin:12px 0}
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:10px 0;border-radius:10px;box-shadow:0 1px 4px rgba(0,0,0,.07),0 2px 8px rgba(0,0,0,.04)}
.bubble.ai table{border-collapse:collapse;min-width:100%;font-size:12px;border:none;margin:0}
.bubble.ai th{background:var(--surf2);padding:7px 10px;text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--txt2);white-space:nowrap}
.bubble.ai td{padding:7px 10px;border-top:1px solid var(--bdr)}
.bubble.ai tr:hover td{background:var(--surf2)}
.bubble.ai a{color:var(--acc);text-decoration:underline;text-underline-offset:2px}

/* ── TOKEN BADGE (above bubble) ── */
.tkn-badge{display:inline-flex;align-items:center;gap:5px;margin-bottom:5px;opacity:.5;transition:opacity .15s}
.tkn-badge:hover{opacity:1}
.tkn-count{font-size:10px;color:var(--txt3);cursor:pointer;letter-spacing:.01em}
.tkn-sep{font-size:9px;color:var(--bdr2)}
.quota-pill{display:inline-flex;align-items:center;gap:2px;cursor:pointer}
.quota-pct-txt{font-size:9px;font-weight:700;line-height:1}
/* ── TOKEN / QUOTA POPUPS ── */
.tkn-popup{background:var(--surf);border:1px solid var(--bdr2);border-radius:10px;padding:13px 15px;min-width:210px;box-shadow:0 6px 24px rgba(0,0,0,.18);font-size:12px}
.tpop-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--txt3);margin-bottom:9px}
.tpop-row{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:3px 0;color:var(--txt2)}
.tpop-row span:last-child{color:var(--txt);font-weight:500;white-space:nowrap;font-variant-numeric:tabular-nums}
.tpop-hr{border:none;border-top:1px solid var(--bdr);margin:7px 0}
.tpop-total span{font-weight:700!important;color:var(--txt)!important}
.qsec{margin-bottom:11px}.qsec:last-child{margin-bottom:0}
.qsec-lbl{font-size:11px;font-weight:500;color:var(--txt2);margin-bottom:5px}
.qbar-bg{height:5px;background:var(--bdr2);border-radius:3px;overflow:hidden;margin-bottom:3px}
.qbar-fill{height:100%;border-radius:3px;transition:width .3s}
.qbar-nums{font-size:10px;color:var(--txt3);text-align:right;font-variant-numeric:tabular-nums}

/* source cards */
/* ── SOURCES DROPDOWN ── */
.sources-drop{margin-top:5px;border-radius:10px;border:1px solid var(--bdr);background:var(--surf2);overflow:hidden;font-size:12px;width:100%}
.sources-toggle{display:flex;align-items:center;gap:7px;padding:8px 12px;cursor:pointer;list-style:none;user-select:none;color:var(--txt2);font-weight:500}
.sources-toggle::-webkit-details-marker{display:none}
.sources-toggle::marker{display:none}
.sources-toggle:hover{background:var(--bdr)}
.sources-ico{font-size:13px;flex-shrink:0}
.sources-chev{margin-left:auto;color:var(--txt3);font-size:15px;transition:transform .2s;line-height:1}
.sources-drop[open] .sources-chev{transform:rotate(90deg)}
.sources-list{display:flex;flex-direction:column;gap:0;padding:0 8px 8px}
.source-card{display:flex;align-items:center;gap:8px;border-radius:var(--r);padding:8px 10px;text-decoration:none;color:var(--txt);transition:background .12s;cursor:pointer}
.source-card:hover{background:var(--bdr)}
.source-ico{font-size:15px;flex-shrink:0}
.source-info{flex:1;min-width:0}
.source-title{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--txt)}
.source-url{font-size:10px;color:var(--txt3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.source-arr{font-size:10px;color:var(--acc);flex-shrink:0}
.source-dl{font-size:11px;background:var(--acc);color:#fff;padding:3px 8px;border-radius:var(--rsm);white-space:nowrap;flex-shrink:0}

/* memory recall badge */
.mem-recall{display:inline-flex;align-items:center;gap:4px;font-size:10px;background:var(--pur-bg);color:var(--pur-mid);border-radius:20px;padding:2px 8px;margin-bottom:6px;box-shadow:0 1px 3px rgba(91,45,142,.1)}

/* copy / action buttons */
.copy-btn{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--rsm);font-size:10px;color:var(--txt3);background:var(--surf2);border:none;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.copy-btn:hover{color:var(--acc);background:var(--acc2)}
.copy-btn.copied{color:var(--grn)}

/* attach */
.attach-img{max-width:min(220px,100%);max-height:160px;border-radius:10px;display:block;margin-bottom:8px;border:1px solid rgba(255,255,255,.15)}
.attach-img.ai-img{border-color:var(--bdr)}
.attach-file{display:flex;align-items:center;gap:7px;border-radius:10px;padding:7px 10px;margin-bottom:8px;font-size:12px;background:rgba(255,255,255,.15)}
.attach-file.ai-att{background:var(--surf2)}
.attach-fname{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}

/* typing */
.typing-wrap{display:flex;gap:9px;align-items:flex-end;padding:0 2px;margin-top:8px}
.typing-bub{background:var(--surf);border-radius:18px 18px 18px 4px;padding:13px 15px;display:flex;gap:5px;align-items:center;box-shadow:0 1px 4px rgba(0,0,0,.07),0 2px 12px rgba(0,0,0,.04)}
.typing-dot{width:7px;height:7px;border-radius:50%;background:var(--txt3);animation:tdot .9s infinite}
.typing-dot:nth-child(2){animation-delay:.15s}.typing-dot:nth-child(3){animation-delay:.3s}
@keyframes tdot{0%,80%,100%{transform:translateY(0)}40%{transform:translateY(-5px)}}

/* tool status */
.tool-status{font-size:11px;color:var(--txt3);display:flex;align-items:center;gap:5px;padding:4px 0 2px 38px;animation:fadeUp .2s ease}
.tool-status-dot{width:5px;height:5px;border-radius:50%;background:var(--amb-mid);animation:pulse 1s infinite}

/* welcome — redefined in HOME WIDGETS section below */
/* ── INPUT ── */
.input-area{padding:12px 16px 16px;background:transparent;flex-shrink:0;box-shadow:none;position:relative;z-index:1}
.file-strip{display:none;gap:7px;padding:6px 10px;flex-wrap:wrap;align-items:center;margin-bottom:6px}
.file-strip.show{display:flex}
.file-chip{display:flex;align-items:center;gap:5px;background:var(--surf2);border-radius:20px;padding:4px 9px;font-size:11px;color:var(--txt2);box-shadow:0 1px 3px rgba(0,0,0,.06)}
.chip-thumb{width:20px;height:20px;border-radius:3px;object-fit:cover}
.chip-name{max-width:110px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chip-del{background:none;border:none;cursor:pointer;color:var(--txt3);font-size:14px;line-height:1;padding:0 1px}
.chip-del:hover{color:var(--red)}
.input-row{display:flex;gap:7px;align-items:flex-end;background:var(--surf2);border-radius:var(--r);padding:8px 8px 8px 13px;transition:box-shadow .15s}
.input-row:focus-within{box-shadow:0 2px 16px rgba(42,84,152,.14),0 0 0 2px var(--acc2)}
#chatInput{flex:1;background:none;border:none;outline:none;font-size:13px;font-family:'DM Sans',sans-serif;color:var(--txt);resize:none;max-height:150px;line-height:1.6;padding:3px 0}
#chatInput::placeholder{color:var(--txt3)}
.input-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}
.attach-label{cursor:pointer;padding:6px;border-radius:var(--rs);color:var(--txt3);transition:all .15s;font-size:17px;line-height:1}
.attach-label:hover{background:var(--acc2);color:var(--acc)}
.send-btn{width:36px;height:36px;background:linear-gradient(135deg,var(--acc),var(--acc-lt));border:none;border-radius:var(--r);cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;transition:all .15s;box-shadow:0 2px 8px rgba(42,84,152,.35);flex-shrink:0}
.send-btn:hover{transform:scale(1.06);box-shadow:0 4px 12px rgba(42,84,152,.45)}
.send-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.input-meta{display:flex;align-items:center;justify-content:space-between;margin-top:6px;padding:0 2px}
.input-hint{font-size:10px;color:var(--txt3)}
.stop-btn-old{display:none;background:var(--surf2);border:none;padding:3px 9px;border-radius:var(--r);font-size:11px;cursor:pointer;color:var(--txt2);font-family:'DM Sans',sans-serif}
.stop-btn-old.vis{display:inline-block}
.stop-btn-old:hover{color:var(--red);background:var(--red-bg)}

/* ── SETTINGS DRAWER ── */
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);z-index:100;display:none}
.drawer-overlay.open{display:block}
.drawer{position:fixed;right:50%;top:20px;bottom:20px;width:calc(100% - 40px);max-width:580px;background:var(--surf);z-index:101;display:flex;flex-direction:column;transform:translateX(50%) translateY(30px);opacity:0;pointer-events:none;transition:transform .28s ease,opacity .25s ease;box-shadow:0 20px 60px rgba(0,0,0,.2);border-radius:16px;overflow:hidden;isolation:isolate;contain:layout}
.drawer.open{transform:translateX(50%) translateY(0);opacity:1;pointer-events:auto}
.drawer-hdr{padding:22px 22px 16px;display:flex;align-items:center;justify-content:space-between}
.drawer-title{font-family:'DM Serif Display',serif;font-size:20px}
.drawer-close{background:var(--surf2);border:none;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--txt2);font-size:18px;line-height:1;box-shadow:0 1px 3px rgba(0,0,0,.07);transition:all .15s}
.drawer-body{flex:1;overflow-y:auto;padding:4px 22px 22px;will-change:scroll-position;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.sg{margin-bottom:20px}
.sg-label{font-size:11px;font-weight:600;color:var(--txt3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px}
.sg input,.sg select,.sg textarea{width:100%;padding:9px 11px;border:none;border-radius:var(--r);background:var(--surf2);color:var(--txt);font-size:13px;font-family:'DM Sans',sans-serif;outline:none;transition:box-shadow .15s;box-shadow:0 1px 4px rgba(0,0,0,.07),0 2px 8px rgba(0,0,0,.04)}
.sg input:focus,.sg select:focus,.sg textarea:focus{box-shadow:0 1px 4px rgba(42,84,152,.15),0 0 0 2px var(--acc2)}
.sg textarea{min-height:90px;resize:vertical;line-height:1.5}
.sg-note{font-size:11px;color:var(--txt3);margin-top:5px;line-height:1.5}
.sg-note a{color:var(--acc)}
.drawer-save{width:100%;padding:11px;background:linear-gradient(135deg,var(--acc),var(--acc-lt));color:#fff;border:none;border-radius:var(--r);font-size:13px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;margin-top:6px;box-shadow:0 2px 8px rgba(42,84,152,.25);transition:opacity .15s,transform .15s}
.drawer-save:hover{opacity:.9;transform:translateY(-1px)}
.save-ok{font-size:12px;color:var(--grn);text-align:center;margin-top:6px;display:none}

/* ── PRIVACY MODAL ── */
.priv-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:300;display:none;align-items:center;justify-content:center;padding:16px}
.priv-overlay.show{display:flex}
.priv-box{background:var(--surf);border:2px solid var(--red-mid);border-radius:var(--r);padding:22px;width:100%;max-width:420px}
.priv-box h3{font-family:'DM Serif Display',serif;font-size:18px;color:var(--red);margin-bottom:10px}
.priv-box p{font-size:13px;color:var(--txt2);line-height:1.6;margin-bottom:8px}
.priv-box ul{font-size:12px;color:var(--txt2);padding-left:16px;margin-bottom:14px;line-height:1.9}
.priv-btns{display:flex;gap:7px;flex-wrap:wrap}
.priv-btns button{flex:1;padding:9px;border-radius:var(--rs);font-size:12px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;border:none;min-width:120px}
.pb-deny{background:var(--surf2);color:var(--txt2);border:1px solid var(--bdr)!important}
.pb-allow{background:var(--red-mid);color:#fff}
.pb-always{background:none;color:var(--txt3);border:1px solid var(--bdr)!important;font-size:11px!important;width:100%;margin-top:5px}

/* ── MEMORY EXPORT MODAL ── */
.mem-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;display:none;align-items:center;justify-content:center;padding:16px}
.mem-modal-overlay.show{display:flex}
.mem-modal{background:var(--surf);border-radius:var(--r);border:1px solid var(--bdr);padding:22px;width:100%;max-width:400px}
.mem-modal h3{font-family:'DM Serif Display',serif;font-size:18px;margin-bottom:12px}

@media(max-width:640px){
  .sidebar{position:fixed;left:0;top:0;bottom:0;z-index:51;transform:translateX(-100%);transition:transform .25s ease;width:260px}
  .sidebar.open{transform:none}
  .sidebar-toggle{display:block}
  .model-chip{display:none}
  .top-btn{padding:5px 8px;font-size:10px}

  /* Mobile: tighter bubbles, no horizontal bleed */
  .msg-col{max-width:88%}
  .bubble{max-width:100%;padding:9px 12px}
  .bubble.ai pre{font-size:11px;padding:10px 11px;border-radius:8px}
  .bubble.ai pre code{font-size:11px}
  .messages{padding:12px 10px;overflow-x:hidden}
  .input-area{padding:8px 10px 12px}
  .topbar{padding:8px 10px}
  .drawer{width:100%;max-width:340px}
  .attach-img{max-width:min(180px,80vw)}
}

/* -- UI REVAMP -- */
.provider-bar,.provider-bar.show{display:none!important}
.input-meta{display:none!important}
.icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--surf2);border:none;border-radius:var(--r);cursor:pointer;color:var(--txt2);font-size:16px;line-height:1;transition:all .15s;flex-shrink:0;font-family:'DM Sans',sans-serif;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.icon-btn:hover{color:var(--acc);background:var(--acc2);box-shadow:0 2px 8px rgba(42,84,152,.15);transform:translateY(-1px)}.icon-btn:active{transform:scale(.95)}
.qwen-pill{display:flex;align-items:center;justify-content:center;width:30px;height:30px;background:var(--surf);border:none;border-radius:50%;cursor:pointer;color:var(--txt3);font-size:12px;line-height:1;transition:all .15s;flex-shrink:0;font-family:'DM Sans',sans-serif;box-shadow:0 1px 3px rgba(0,0,0,.08)}
.qwen-pill:hover{color:var(--pur-mid);background:var(--pur-bg);box-shadow:0 2px 6px rgba(91,45,142,.15)}
.qwen-pill.qwen-active{background:var(--pur-bg);color:var(--pur-mid);box-shadow:0 2px 6px rgba(91,45,142,.2)}
.stop-btn{width:36px;height:36px;background:var(--surf);border:none;border-radius:var(--r);cursor:pointer;display:none;align-items:center;justify-content:center;color:var(--red);font-size:12px;transition:all .15s;flex-shrink:0;box-shadow:0 1px 4px rgba(0,0,0,.08)}
.stop-btn:hover{background:var(--red-bg);box-shadow:0 2px 8px rgba(176,58,46,.15)}
.sidebar-footer{padding:10px 10px 12px;display:flex;gap:5px;flex-shrink:0}
.sidebar-footer button{flex:1;padding:7px 8px;background:var(--surf2);border:none;border-radius:var(--r);cursor:pointer;font-size:11px;color:var(--txt3);font-family:'DM Sans',sans-serif;transition:all .15s;box-shadow:0 1px 3px rgba(0,0,0,.05)}
.sidebar-footer button:hover{color:var(--acc);background:var(--acc2)}
.sidebar-footer button.sf-danger:hover{color:var(--red);background:var(--red-bg)}
.input-row{border-radius:20px!important;border:none!important;box-shadow:0 4px 24px rgba(0,0,0,.13),0 1px 6px rgba(0,0,0,.07)!important}
.input-row:focus-within{box-shadow:0 4px 28px rgba(42,84,152,.22),0 0 0 2px rgba(90,143,212,.15)!important}
.sidebar-title{font-family:'DM Serif Display',serif!important;font-size:16px!important;color:var(--txt)!important;text-transform:none!important;letter-spacing:0!important}
/* HOME WIDGETS — new design */
.welcome{flex:1;display:flex;flex-direction:column;align-items:center;padding:32px 20px 24px;overflow-y:auto;gap:0}
.hw-hero{text-align:center;margin-bottom:32px}
.hw-hero-icon{font-size:38px;margin-bottom:10px;display:block;line-height:1}
.hw-hero-title{font-family:'DM Serif Display',serif;font-size:26px;color:var(--txt);margin-bottom:6px}
.hw-hero-sub{font-size:13px;color:var(--txt3);line-height:1.6;max-width:360px;margin:0 auto}
.hw-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%;max-width:600px}
.hw-card{background:var(--surf);border-radius:18px;overflow:hidden;cursor:pointer;display:flex;flex-direction:column;box-shadow:0 1px 3px rgba(0,0,0,.07),0 4px 14px rgba(0,0,0,.05);transition:transform .2s ease,box-shadow .2s ease}
.hw-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.11),0 2px 6px rgba(0,0,0,.07)}
.hw-card:active{transform:scale(.97)}
.hw-card-accent{height:6px;flex-shrink:0}
.hw-card-weather .hw-card-accent{background:linear-gradient(90deg,#3a7ad4,#5aa8e0)}
.hw-card-news .hw-card-accent{background:linear-gradient(90deg,#c87f0e,#e0a030)}
.hw-card-trip .hw-card-accent{background:linear-gradient(90deg,#257a46,#3db068)}
.hw-card-lpt .hw-card-accent{background:linear-gradient(90deg,#7340d4,#9d70f0)}
.hw-card-body{padding:18px 20px 12px;display:flex;flex-direction:column;gap:5px}
.hw-card-ico{font-size:30px;line-height:1;margin-bottom:6px}
.hw-card-title{font-family:'DM Serif Display',serif;font-size:17px;color:var(--txt)}
.hw-card-desc{font-size:12px;color:var(--txt3);line-height:1.5}
.hw-card-foot{margin-top:auto;padding:8px 20px 14px;font-size:11px;color:var(--txt3);text-align:right;transition:color .15s}
.hw-card:hover .hw-card-foot{color:var(--acc)}
.hw-card-hidden{display:none}
.hw-chat-hint{margin-top:22px;font-size:12px;color:var(--txt3);cursor:pointer;transition:color .15s;user-select:none}
.hw-chat-hint:hover{color:var(--acc)}
.hw-chat-hint span{color:var(--acc)}
/* fullscreen mode */
.welcome.hw-fullscreen{padding:0!important;overflow:hidden}
.welcome.hw-fullscreen .hw-hero{display:none}
.welcome.hw-fullscreen .hw-chat-hint{display:none}
.welcome.hw-fullscreen .hw-grid{display:flex;flex-direction:column;max-width:100%;width:100%;flex:1;overflow:hidden;gap:0}
.welcome.hw-fullscreen .hw-card{display:none;border-radius:0;box-shadow:none;cursor:default}
.welcome.hw-fullscreen .hw-card.hw-expanded{display:flex;flex:1;flex-direction:column;overflow-y:auto;animation:fadeUp .2s ease}
.welcome.hw-fullscreen .hw-card.hw-expanded .hw-card-accent{height:4px}
.welcome.hw-fullscreen .hw-card.hw-expanded .hw-card-body{padding:26px 32px 16px;flex-direction:row;align-items:flex-start;gap:16px;flex-shrink:0;border-bottom:1px solid var(--bdr)}
.welcome.hw-fullscreen .hw-card.hw-expanded .hw-card-ico{font-size:40px;flex-shrink:0;margin-bottom:0}
.welcome.hw-fullscreen .hw-card.hw-expanded .hw-card-title{font-size:22px}
.welcome.hw-fullscreen .hw-card.hw-expanded .hw-card-desc{font-size:13px;margin-top:2px}
.welcome.hw-fullscreen .hw-card.hw-expanded .hw-card-foot{display:none}
.welcome.hw-fullscreen .hw-card.hw-expanded .hw-card-hidden{display:flex;flex-direction:column;gap:12px;padding:24px 32px;flex:1}
/* inputs & buttons (fullscreen only) */
.hw-input{width:100%;padding:10px 13px;border:1px solid var(--bdr);border-radius:var(--rs);background:var(--surf2);color:var(--txt);font-size:13px;font-family:'DM Sans',sans-serif;outline:none;transition:border .15s,box-shadow .15s}
.hw-input:focus{border-color:var(--acc);box-shadow:0 0 0 3px rgba(90,143,212,.1)}
.hw-btns{display:flex;gap:8px;flex-wrap:wrap}
.hw-btn{padding:7px 14px;border:1px solid var(--bdr);border-radius:var(--rsm);background:var(--surf2);color:var(--txt2);font-size:12px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s;white-space:nowrap}
.hw-btn:hover,.hw-btn.hw-active{border-color:var(--acc);color:var(--acc);background:var(--acc2)}
.hw-btn-go{background:var(--acc)!important;color:#fff!important;border-color:var(--acc)!important;font-weight:500}
.hw-btn-go:hover{opacity:.88!important}
.hw-result{font-size:12px;color:var(--txt2);line-height:1.6}
.hw-spinner{display:flex;align-items:center;gap:7px;color:var(--txt3);font-size:12px;padding:6px 0}
/* weather result */
.hw-w-top{display:flex;align-items:center;gap:14px;margin-bottom:12px}
.hw-w-icon{font-size:48px;line-height:1}
.hw-w-temp{font-size:36px;font-weight:700;color:var(--txt)}
.hw-w-loc{font-size:13px;font-weight:500;color:var(--txt)}
.hw-w-cond{font-size:12px;color:var(--txt3);margin-top:2px}
.hw-w-meta{font-size:11px;color:var(--txt3);padding:8px 0;border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);margin-bottom:12px}
.hw-w-forecast{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}
.hw-w-day{background:var(--surf2);border:1px solid var(--bdr);border-radius:var(--rs);padding:10px 12px;text-align:center;flex:1;min-width:64px}
.hw-w-day-name{font-size:10px;font-weight:600;color:var(--txt2);margin-bottom:4px;text-transform:uppercase}
.hw-w-day-icon{font-size:20px;margin-bottom:4px}
.hw-w-day-temp{font-size:11px;color:var(--txt);font-weight:500}
.hw-w-day-rain{font-size:10px;color:var(--blu-mid);margin-top:3px}
/* news result */
.hw-news-list{display:flex;flex-direction:column;gap:10px}
.hw-news-item{padding-bottom:10px;border-bottom:1px solid var(--bdr)}
.hw-news-item:last-child{border-bottom:none}
.hw-news-item a{display:block;font-size:13px;font-weight:500;color:var(--acc);text-decoration:none;line-height:1.4;margin-bottom:3px}
.hw-news-item a:hover{text-decoration:underline}
.hw-news-snippet{font-size:11px;color:var(--txt2);line-height:1.5;margin-bottom:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.hw-news-meta{font-size:10px;color:var(--txt3)}
/* trip result */
.hw-trip-link{display:flex;align-items:center;gap:8px;padding:10px 13px;background:var(--acc2);border:1px solid rgba(90,143,212,.25);border-radius:var(--rs);color:var(--acc);font-size:12px;font-weight:500;text-decoration:none;margin-bottom:10px}
.hw-trip-link:hover{background:var(--acc);color:#fff}
.hw-trip-tips{font-size:12px;color:var(--txt2);line-height:1.7;white-space:pre-wrap}
/* lpt result */
.hw-lpt-title{font-size:14px;font-weight:600;color:var(--txt);margin-bottom:6px;line-height:1.4}
.hw-lpt-body{font-size:12px;color:var(--txt2);line-height:1.65;margin-bottom:8px}
.hw-lpt-link{font-size:11px;color:var(--txt3);text-decoration:none}
.hw-lpt-link:hover{color:var(--acc);text-decoration:underline}
/* fullscreen nav — segmented pill tabs */
.sidebar-toggle{display:flex!important;align-items:center;justify-content:center;transition:color .15s;border-radius:var(--rsm)}
.sidebar-toggle:hover{color:var(--acc)!important}
.sidebar{transition:width .25s ease,transform .25s ease}
.sidebar.desktop-collapsed{width:0!important;min-width:0!important;overflow:hidden!important;border-right:none!important}
.hw-nav{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--surf);border-bottom:1px solid var(--bdr);flex-shrink:0}
.hw-nav-back{background:none;border:none;cursor:pointer;color:var(--txt2);font-size:12px;padding:5px 9px;border-radius:var(--rsm);font-family:'DM Sans',sans-serif;transition:all .15s;flex-shrink:0}
.hw-nav-back:hover{background:var(--surf2);color:var(--txt)}
.hw-nav-tabs{display:flex;gap:3px;background:var(--surf2);border-radius:20px;padding:3px;flex:1;justify-content:center;max-width:400px}
.hw-tab{flex:1;padding:5px 8px;border-radius:16px;border:none;background:transparent;cursor:pointer;font-size:11px;font-weight:500;color:var(--txt3);font-family:'DM Sans',sans-serif;transition:all .15s;white-space:nowrap}
.hw-tab.hw-tab-active{background:var(--surf);color:var(--txt);box-shadow:0 1px 4px rgba(0,0,0,.1)}
.hw-tab:hover:not(.hw-tab-active){color:var(--txt2)}
.hw-nav-chat{background:var(--acc);color:#fff;border:none;border-radius:var(--rs);padding:6px 12px;font-size:11px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;transition:opacity .15s;flex-shrink:0}
.hw-nav-chat:hover{opacity:.88}
@media(max-width:640px){
  .hw-grid{grid-template-columns:1fr}
  .hw-nav-tabs{max-width:none}
  .hw-tab{font-size:10px;padding:4px 6px}
  .welcome.hw-fullscreen .hw-card.hw-expanded .hw-card-body{padding:18px 18px 14px}
  .welcome.hw-fullscreen .hw-card.hw-expanded .hw-card-hidden{padding:16px 18px}
}

/* ══════════════════════════════════════════
   NEW FLOATING CHROME
══════════════════════════════════════════ */

/* Global minimal scrollbar */
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-thumb{background:rgba(0,0,0,0.07);border-radius:2px}
::-webkit-scrollbar-track{background:transparent}
*{scrollbar-width:thin;scrollbar-color:rgba(0,0,0,0.08) transparent}

/* Aria label (inline next to icon) */
.aria-label{
  font-family:'DM Serif Display',serif;font-size:17px;color:var(--txt);
  white-space:nowrap;pointer-events:none;
  transition:opacity .18s ease,max-width .2s ease;
  max-width:80px;overflow:hidden;
}
.aria-label--hidden{opacity:0;max-width:0;pointer-events:none}

/* Aria icon orb button */
.aria-anchor{position:fixed;top:14px;left:14px;z-index:200;display:flex;align-items:center;gap:10px;overflow:visible}
.aria-btn{
  width:38px;height:38px;border-radius:50%;background:none;border:none;
  font-size:20px;color:var(--acc);cursor:pointer;display:flex;
  align-items:center;justify-content:center;flex-shrink:0;
  filter:drop-shadow(0 0 8px rgba(42,84,152,.4));
  transition:filter .2s ease;
}
.aria-btn:hover{filter:drop-shadow(0 0 14px rgba(42,84,152,.65))}
.aria-btn.spinning{animation:ariaSpin .4s cubic-bezier(.34,1.56,.64,1) forwards}
.aria-btn.spinning-back{animation:ariaSpinBack .35s ease forwards}
@keyframes ariaSpin{from{transform:rotate(0deg) scale(1)}to{transform:rotate(90deg) scale(1.08)}}
@keyframes ariaSpinBack{from{transform:rotate(90deg) scale(1.08)}to{transform:rotate(0deg) scale(1)}}

/* Floating orb cluster */
.aria-cluster{
  display:flex;align-items:center;gap:8px;
  pointer-events:none;opacity:0;transform:translateX(-10px) scale(0.88);
  transition:opacity .2s ease,transform .25s cubic-bezier(.34,1.56,.64,1);
}
.aria-cluster.open{pointer-events:auto;opacity:1;transform:translateX(0) scale(1)}
.aria-cluster .aria-orb:nth-child(1){transition-delay:.03s}
.aria-cluster .aria-orb:nth-child(2){transition-delay:.07s}
.aria-cluster .aria-orb:nth-child(3){transition-delay:.11s}
.aria-cluster .aria-orb:nth-child(4){transition-delay:.15s}
.aria-orb{
  width:38px;height:38px;border-radius:50%;
  background:var(--surf);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;color:var(--txt2);
  box-shadow:0 2px 12px rgba(0,0,0,.12);
  transition:transform .15s ease,box-shadow .15s ease,color .15s ease,background .15s ease;
}
.aria-orb:hover{transform:translateY(-2px) scale(1.08);box-shadow:0 4px 16px rgba(0,0,0,.16);color:var(--acc)}
.aria-orb.active{background:var(--acc2);color:var(--acc)}

/* Conversation carousel — lives inside .aria-anchor as absolute child */
.conv-carousel{
  position:absolute;top:50%;left:100%;margin-left:8px;
  transform:translateY(-50%) translateX(-10px);
  opacity:0;pointer-events:none;
  display:flex;align-items:center;
  max-width:calc(100vw - 140px);
  transition:opacity .2s ease,transform .25s cubic-bezier(.34,1.56,.64,1);
  z-index:199;
}
.conv-carousel.open{opacity:1;transform:translateY(-50%) translateX(0);pointer-events:auto}
.conv-carousel-inner{display:flex;gap:14px;align-items:center;overflow-x:auto;padding:4px 2px;scrollbar-width:none}
.conv-carousel-inner::-webkit-scrollbar{display:none}

/* Pill + delete group */
.conv-pill-grp{display:flex;align-items:center;flex-shrink:0}
.conv-pill{
  padding:7px 13px;background:var(--surf);border:none;border-radius:20px 6px 6px 20px;
  font-size:11px;color:var(--txt2);cursor:pointer;white-space:nowrap;
  max-width:130px;overflow:hidden;text-overflow:ellipsis;flex-shrink:0;
  box-shadow:0 2px 8px rgba(0,0,0,.09);font-family:'DM Sans',sans-serif;
  transition:background .12s ease,color .12s ease;
}
.conv-pill:hover{background:var(--acc2);color:var(--acc)}
.conv-pill.active-pill{background:var(--acc);color:#fff}
.conv-pill-del{
  width:22px;height:22px;border-radius:50%;border:none;
  background:var(--surf2);color:var(--txt3);font-size:11px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;margin-left:4px;
  box-shadow:0 1px 4px rgba(0,0,0,.08);
  transition:background .12s ease,color .12s ease;
}
.conv-pill-del:hover{background:var(--red-bg);color:var(--red)}

/* Conv-mode: collapse other orbs so conversations orb slides left */
.aria-cluster.conv-mode{gap:0}
.aria-cluster.conv-mode .aria-orb:not(.aria-orb-convs){
  opacity:0;transform:scale(0.5);pointer-events:none;
  width:0;height:0;padding:0;margin:0;overflow:hidden;box-shadow:none;
  transition:opacity .18s ease,transform .18s ease,width .2s ease,height .2s ease,margin .2s ease;
}
.aria-cluster.conv-mode .aria-orb-convs{background:var(--acc2);color:var(--acc)}

/* Encryption indicator */
.encrypt-indicator{
  position:fixed;top:14px;right:14px;z-index:200;
  width:36px;height:36px;border-radius:50%;
  background:var(--blu-bg);border:1.5px solid rgba(58,122,212,.25);
  color:var(--blu-mid);font-size:14px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 1px 6px rgba(42,84,152,.12);transition:all .15s ease;
}
.encrypt-indicator:hover{box-shadow:0 2px 12px rgba(42,84,152,.25);transform:scale(1.06)}
.encrypt-indicator.encrypt-error{background:var(--red-bg);border-color:rgba(176,58,46,.3);color:var(--red);box-shadow:0 1px 6px rgba(176,58,46,.18)}

/* Model pill inside input row */
.model-pill-inp{
  display:flex;align-items:center;gap:5px;
  background:var(--surf);border:none;border-radius:20px;
  padding:4px 9px 4px 7px;font-size:11px;color:var(--txt2);
  cursor:pointer;flex-shrink:0;font-family:'DM Sans',sans-serif;
  transition:background .15s ease;white-space:nowrap;
  box-shadow:0 1px 3px rgba(0,0,0,.07);
}
.model-pill-inp:hover{background:var(--surf2)}
.model-pill-inp .model-dot{width:6px;height:6px;border-radius:50%;background:var(--grn-mid);animation:pulse 2.5s infinite;flex-shrink:0}
.model-pill-chevron{font-size:8px;opacity:.5;transition:transform .2s ease}
.model-pill-inp[aria-expanded="true"] .model-pill-chevron{transform:rotate(180deg)}

/* Model dropdown */
.model-dropdown{
  position:absolute;bottom:calc(100% + 6px);right:16px;left:auto;
  background:var(--surf);border:1px solid var(--bdr2);border-radius:14px;
  padding:6px;box-shadow:0 8px 32px rgba(0,0,0,.16);z-index:50;
  min-width:240px;display:none;flex-direction:column;gap:2px;
  transform-origin:bottom right;
}
.model-dropdown.open{display:flex;animation:dropUp .18s cubic-bezier(.34,1.56,.64,1) forwards}
@keyframes dropUp{from{opacity:0;transform:translateY(6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.model-opt{
  display:flex;align-items:center;justify-content:space-between;
  padding:9px 12px;border-radius:10px;border:none;background:none;
  font-size:12px;color:var(--txt);cursor:pointer;font-family:'DM Sans',sans-serif;
  text-align:left;transition:background .12s ease;gap:8px;
}
.model-opt:hover{background:var(--surf2)}
.model-opt.active{background:var(--acc2);color:var(--acc);font-weight:500}
.model-opt-badge{font-size:9px;padding:2px 6px;border-radius:10px;background:var(--grn-bg);color:var(--grn);font-weight:500;white-space:nowrap;flex-shrink:0}
.model-opt-badge-tpm{background:var(--blu-bg);color:var(--blu-mid)}
.model-opt-badge-smart{background:var(--pur-bg);color:var(--pur-mid)}
.model-opt-badge-fast{background:var(--amb-bg);color:var(--amb-mid)}

/* Mobile overrides */
@media(max-width:640px){
  .messages{padding:50px 10px 90px;overflow-x:hidden}
  .conv-carousel{max-width:calc(100vw - 110px)}
  .drawer{width:calc(100% - 24px);max-width:100%;border-radius:12px;top:12px;bottom:12px}
  .aria-label{font-size:15px}
}

/* ══════════════════════════════════════════
   PLANNER DRAWER
══════════════════════════════════════════ */
.planner-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);z-index:100;display:none}
.planner-overlay.open{display:block}
.planner-drawer{position:fixed;right:50%;top:20px;bottom:20px;width:calc(100% - 40px);max-width:480px;background:var(--surf);z-index:101;display:flex;flex-direction:column;transform:translateX(50%) translateY(30px);opacity:0;pointer-events:none;transition:transform .28s ease,opacity .25s ease;box-shadow:0 20px 60px rgba(0,0,0,.2);border-radius:16px;overflow:hidden;isolation:isolate}
.planner-drawer.open{transform:translateX(50%) translateY(0);opacity:1;pointer-events:auto}
.planner-hdr{padding:20px 22px 16px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;border-bottom:1px solid var(--bdr)}
.planner-title{font-family:'DM Serif Display',serif;font-size:20px;color:var(--txt)}

/* Tabs */
.planner-tabs-bar{display:flex;gap:2px;padding:10px 14px 0;background:var(--surf);flex-shrink:0}
.ptab{flex:1;padding:7px 6px;border-radius:var(--rs) var(--rs) 0 0;border:none;background:none;cursor:pointer;font-size:11px;font-weight:500;color:var(--txt3);font-family:'DM Sans',sans-serif;transition:all .15s;white-space:nowrap}
.ptab.ptab-active{background:var(--surf2);color:var(--txt);box-shadow:inset 0 -2px 0 var(--acc)}
.ptab:hover:not(.ptab-active){color:var(--txt2);background:var(--surf2)}

/* Task list */
.planner-list{flex:1;overflow-y:auto;padding:8px 12px;display:flex;flex-direction:column;gap:2px;background:var(--surf2)}
.planner-list::-webkit-scrollbar{width:3px}
.planner-list::-webkit-scrollbar-thumb{background:rgba(0,0,0,.07);border-radius:2px}
.plan-empty{font-size:12px;color:var(--txt3);text-align:center;padding:28px 10px;line-height:1.6}

/* Task items */
.plan-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r);background:var(--surf);border:1px solid var(--bdr);transition:background .12s,border-color .12s}
.plan-item:hover{border-color:var(--bdr2)}
.plan-item.plan-overdue{border-color:rgba(176,58,46,.3);background:var(--red-bg)}
.plan-item.plan-done{opacity:.5}
.plan-check{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--bdr2);background:none;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;color:transparent;transition:all .15s;font-family:'DM Sans',sans-serif}
.plan-check:hover{border-color:var(--grn-mid);color:var(--grn-mid)}
.plan-check.plan-checked{background:var(--grn-mid);border-color:var(--grn-mid);color:#fff}
.plan-info{flex:1;min-width:0}
.plan-text{font-size:13px;color:var(--txt);line-height:1.4;word-break:break-word}
.plan-done .plan-text{text-decoration:line-through;color:var(--txt3)}
.plan-due{font-size:10px;color:var(--txt3);margin-top:3px}
.plan-overdue .plan-due{color:var(--red);font-weight:600}
.plan-actions{display:flex;gap:3px;flex-shrink:0;opacity:0;transition:opacity .12s}
.plan-item:hover .plan-actions{opacity:1}
.plan-del,.plan-edit-btn{background:none;border:none;cursor:pointer;color:var(--txt3);font-size:16px;line-height:1;padding:3px 5px;border-radius:var(--rsm);transition:color .12s,background .12s}
.plan-del:hover{color:var(--red);background:var(--red-bg)}
.plan-edit-btn:hover{color:var(--acc);background:var(--acc2)}

/* Inline task edit */
.plan-edit-wrap{flex:1;display:flex;flex-direction:column;gap:6px}
.plan-edit-row{display:flex;gap:6px;align-items:center}
.plan-edit-inp{flex:1;padding:7px 10px;border:1.5px solid var(--acc);border-radius:var(--rs);background:var(--surf);color:var(--txt);font-size:13px;font-family:'DM Sans',sans-serif;outline:none}
.plan-edit-date{width:38px}
.plan-edit-actions{display:flex;gap:6px}
.plan-save-btn{padding:5px 14px;background:var(--acc);color:#fff;border:none;border-radius:var(--rs);font-size:11px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;transition:opacity .15s}
.plan-save-btn:hover{opacity:.88}
.plan-cancel-btn{padding:5px 10px;background:none;border:1px solid var(--bdr);border-radius:var(--rs);font-size:11px;cursor:pointer;color:var(--txt3);font-family:'DM Sans',sans-serif;transition:all .15s}
.plan-cancel-btn:hover{color:var(--txt);background:var(--surf2)}

/* Quick-pick time buttons (follow-up bubble) */
.plan-quick-btns{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.plan-quick-btn{padding:5px 12px;border-radius:20px;border:1px solid var(--bdr);background:var(--surf2);font-size:11px;cursor:pointer;color:var(--txt2);font-family:'DM Sans',sans-serif;transition:all .15s}
.plan-quick-btn:hover{border-color:var(--acc);color:var(--acc);background:var(--acc2)}
.plan-quick-skip{color:var(--txt3)}
.plan-quick-skip:hover{color:var(--txt2);border-color:var(--bdr2)}

/* Add area */
.planner-add-area{padding:12px 14px;border-top:1px solid var(--bdr);display:flex;gap:7px;flex-shrink:0;align-items:center;background:var(--surf)}
.planner-add-inp{flex:1;padding:9px 11px;border:1px solid var(--bdr);border-radius:var(--rs);background:var(--surf2);color:var(--txt);font-size:13px;font-family:'DM Sans',sans-serif;outline:none;transition:border .15s,box-shadow .15s}
.planner-add-inp:focus{border-color:var(--acc);box-shadow:0 0 0 3px rgba(90,143,212,.1)}
.planner-add-date{padding:8px 6px;border:1px solid var(--bdr);border-radius:var(--rs);background:var(--surf2);color:var(--txt);font-size:11px;font-family:'DM Sans',sans-serif;outline:none;cursor:pointer;width:38px;overflow:hidden;transition:width .25s ease,border-color .15s;color-scheme:dark light}
.planner-add-date:focus,.planner-add-date:hover{width:170px;border-color:var(--acc)}
.planner-add-btn{width:34px;height:34px;background:linear-gradient(135deg,var(--acc),var(--acc-lt));border:none;border-radius:var(--rs);cursor:pointer;color:#fff;font-size:22px;line-height:1;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .15s,transform .15s;box-shadow:0 2px 8px rgba(42,84,152,.3)}
.planner-add-btn:hover{opacity:.9;transform:scale(1.05)}

/* Notification pulse on planner orb */
@keyframes notifPing{0%{box-shadow:0 0 0 0 rgba(212,144,26,.8)}70%{box-shadow:0 0 0 9px rgba(212,144,26,0)}100%{box-shadow:0 0 0 0 rgba(212,144,26,0)}}
.notif-ping{animation:notifPing .9s ease 3}

/* Mobile planner overrides */
@media(max-width:640px){
  .planner-drawer{top:12px;bottom:12px;width:calc(100% - 24px);max-width:100%;border-radius:12px}
  .planner-add-date{display:none}
  .ptab{font-size:10px;padding:6px 4px}
}