
/* ── RESET & VARIÁVEIS ─────────────────────────────────────────────── */
:root{--font:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;--mono:'JetBrains Mono','Fira Code',monospace;--sidebar-w:240px;--r:10px;--r-sm:7px}
[data-theme="dark"]{--bg:#0d0d0f;--bg2:#161618;--surface:#1a1a1e;--surface2:#222226;--sidebar:#111113;--border:rgba(255,255,255,.07);--border2:rgba(255,255,255,.1);--text:#ececec;--text2:#9b9ba4;--text3:#555560;--red:#CC0000;--green:#4caf7d;--blue:#5b8def;--amber:#e8a838;--purple:#a78bfa}
[data-theme="light"]{--bg:#f5f5f7;--bg2:#eaeaec;--surface:#fff;--surface2:#f0f0f2;--sidebar:#fff;--border:rgba(0,0,0,.08);--border2:rgba(0,0,0,.12);--text:#111;--text2:#555;--text3:#999;--red:#CC0000;--green:#2e7d46;--blue:#1a56db;--amber:#b45309;--purple:#6d28d9}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden;font-family:var(--font);background:var(--bg);color:var(--text);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}

/* ── LOGIN ──────────────────────────────────────────────────────────── */
.login-wrap{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.login-card{background:var(--surface);border:1px solid var(--border2);border-radius:16px;padding:36px 40px;width:380px;box-shadow:0 8px 40px rgba(0,0,0,.3)}
.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:24px}
.login-mark{width:36px;height:36px;border-radius:10px;background:var(--red);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff}
.login-name{font-size:18px;font-weight:700;color:var(--text)}
.login-h{font-size:18px;font-weight:700;margin-bottom:6px;letter-spacing:-.02em}
.login-sub{font-size:13px;color:var(--text2);margin-bottom:24px}
.login-lbl{font-size:12px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:6px}
.login-inp{width:100%;background:var(--surface2);border:1px solid var(--border2);border-radius:8px;padding:10px 14px;font-size:14px;color:var(--text);outline:none;transition:.15s;margin-bottom:14px}
.login-inp:focus{border-color:var(--blue)}
.login-btn{width:100%;padding:11px;background:var(--red);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:.12s;margin-bottom:12px}
.login-btn:hover{background:#aa0000}
.login-err{font-size:13px;color:var(--red);text-align:center;min-height:20px}

/* ── APP WRAPPER ────────────────────────────────────────────────────── */
.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}

/* ── TOOLBAR ────────────────────────────────────────────────────────── */
.tb{display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:48px;flex-shrink:0;background:var(--sidebar);border-bottom:1px solid var(--border);gap:8px}
.tb-l{display:flex;align-items:center;gap:8px;flex:1;min-width:0}
.tb-r{display:flex;align-items:center;gap:6px;flex-shrink:0}
.tb-logo{display:flex;align-items:center;gap:7px;flex-shrink:0;text-decoration:none}
.tb-logo-mark{width:28px;height:28px;border-radius:8px;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;letter-spacing:-.02em}
.tb-logo-name{font-size:14px;font-weight:700;color:var(--text)}
.tb-sep{width:1px;height:16px;background:var(--border);flex-shrink:0}
.tb-title{font-size:13px;font-weight:500;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tb-btn,.sb-col{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--text3);cursor:pointer;transition:.12s;border:none;background:none}
.tb-btn:hover,.sb-col:hover{background:var(--surface);color:var(--text)}

/* ── APP BODY ───────────────────────────────────────────────────────── */
.app-body{display:flex;flex:1;overflow:hidden}

/* ── SIDEBAR ────────────────────────────────────────────────────────── */
.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;transition:width .2s ease}
.sidebar.collapsed{width:0}
.sb-new{display:flex;align-items:center;gap:8px;padding:9px 14px;margin:8px 10px 4px;border-radius:8px;border:1px solid var(--border2);background:none;color:var(--text2);font-size:13px;font-weight:500;cursor:pointer;transition:.12s;width:calc(100% - 20px)}
.sb-new:hover{background:var(--surface);color:var(--text)}
.sb-hist{flex:1;overflow-y:auto;padding:0 6px 8px}
.sb-hist::-webkit-scrollbar{width:3px}
.sb-hist::-webkit-scrollbar-thumb{background:var(--surface2);border-radius:3px}
.sb-hist-lbl{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;padding:8px 14px 4px;display:block}
.hg-lbl{font-size:10px;font-weight:600;color:var(--text3);padding:6px 8px 2px;display:block}
.hi{display:flex;align-items:center;gap:7px;padding:6px 8px;cursor:pointer;border-radius:7px;transition:.12s;position:relative}
.hi:hover{background:var(--surface)}
.hi.active{background:var(--surface)}
.hi svg{flex-shrink:0;color:var(--text3);opacity:.6}
.hi-t{flex:1;font-size:12px;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hi.active .hi-t{color:var(--text)}
.hi-del{display:none;background:none;border:none;cursor:pointer;color:var(--text3);padding:2px 3px;border-radius:3px;flex-shrink:0;line-height:0;transition:.12s}
.hi-del:hover{color:var(--red)}
.hi:hover .hi-del{display:flex}
.sb-ft{padding:6px 8px 10px;border-top:1px solid var(--border)}
.sb-usr{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:7px;margin-bottom:4px}
.sb-av{width:28px;height:28px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}
.sb-user-info{min-width:0}
.sb-user-name{font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sb-user-role{font-size:11px;color:var(--text3)}
.sb-ni{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:7px;cursor:pointer;transition:.12s;color:var(--text2);font-size:13px;width:100%}
.sb-ni:hover{background:var(--surface);color:var(--text)}
.sb-ni.active{background:var(--surface);color:var(--blue)}
.sb-nl{font-size:13px}
.sb-sep{height:1px;background:var(--border);margin:4px 10px}

/* ── MAIN ───────────────────────────────────────────────────────────── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}/* CORTEX-DEV: position:relative — page-dev-console fica contida no main e não cobre a sidebar */

/* ── CHAT AREA ──────────────────────────────────────────────────────── */
.chat-area{flex:1;position:relative;display:flex;flex-direction:column;overflow:hidden}
.chat-msgs{flex:1;overflow-y:auto;overflow-x:hidden;padding:16px 0;scroll-behavior:smooth;min-height:0}/* CORTEX-DEV v1.2.82: sem scroll horizontal */
.chat-msgs::-webkit-scrollbar{width:4px}
.chat-msgs::-webkit-scrollbar-thumb{background:var(--surface2);border-radius:4px}

/* ── CHAT EMPTY (ecrã inicial) ──────────────────────────────────────── */
.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 24px;text-align:center}
.ce-logo{width:52px;height:52px;border-radius:14px;background:var(--red);display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:800;color:#fff;letter-spacing:-.02em}
.chat-empty h2{font-size:22px;font-weight:700;letter-spacing:-.03em;color:var(--text)}
.chat-empty p{font-size:14px;color:var(--text2);max-width:480px;line-height:1.6}
.suggs{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:620px;margin-top:4px}
.sg{background:var(--surface);border:1px solid var(--border2);border-radius:20px;padding:7px 16px;font-size:13px;color:var(--text2);cursor:pointer;transition:.12s;white-space:nowrap}
.sg:hover{background:var(--surface2);color:var(--text)}

/* ── PAGES (overlay absoluto sobre o chat) ──────────────────────────── */
.page{display:none;position:absolute;inset:0;z-index:10;background:var(--bg);overflow-y:auto;padding:24px 28px 32px;flex-direction:column;-webkit-overflow-scrolling:touch}
.page.active{display:flex}
.page-hd{margin-bottom:20px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-shrink:0}
.page-hd h1{font-size:22px;font-weight:700;letter-spacing:-.03em;color:var(--text)}
.page-hd p{font-size:13px;color:var(--text2);margin-top:4px}
.page-hd-right{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* ── INPUT AREA (fora do chat-area, sempre visível) ─────────────────── */
.inp-area{padding:8px 20px 14px;flex-shrink:0;background:var(--bg);position:relative;z-index:20}
/* CORTEX-DEV v1.2.58 — Anexos */
.inp-files{display:none;flex-wrap:wrap;gap:5px;padding:6px 12px 0;max-width:760px;margin:0 auto}
.inp-files.show{display:flex}
.fchip{display:flex;align-items:center;gap:5px;padding:3px 8px 3px 6px;border-radius:20px;font-size:11px;font-weight:500;border:1px solid var(--border2);background:var(--surface2);color:var(--text2);max-width:180px;cursor:default}
.fchip.img{border-color:rgba(91,141,239,.35);background:rgba(91,141,239,.08);color:var(--blue)}
.fchip.zip{border-color:rgba(232,168,56,.35);background:rgba(232,168,56,.08);color:var(--amber)}
.fchip.txt{border-color:rgba(76,175,125,.35);background:rgba(76,175,125,.08);color:var(--green)}
/* CORTEX-DEV v1.2.59: paste text block */
.fchip.paste{display:flex;align-items:flex-start;gap:7px;padding:7px 10px 7px 9px;border-radius:10px;border-color:rgba(161,139,250,.3);background:rgba(161,139,250,.07);color:var(--text);max-width:320px;cursor:default}
.fchip.paste .fchip-ico{font-size:16px;flex-shrink:0;margin-top:1px}
.fchip.paste .fchip-body{flex:1;min-width:0}
.fchip.paste .fchip-name{display:block;font-size:12px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fchip.paste .fchip-prev{display:block;font-size:11px;color:var(--text3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:1px;font-style:italic}
.fchip.paste .fchip-meta{display:block;font-size:10px;color:var(--purple);margin-top:2px;opacity:.8}
.fchip.paste .fchip-rm{margin-top:2px}
.fchip-thumb{width:18px;height:18px;border-radius:3px;object-fit:cover;flex-shrink:0}
.fchip.img-lg{display:flex;flex-direction:column;align-items:center;gap:4px;padding:4px 8px 4px 6px;border-radius:10px;max-width:none;border-color:rgba(91,141,239,.3);background:rgba(91,141,239,.06)}
.fchip.img-lg img{border-radius:6px;max-width:140px;max-height:100px;object-fit:cover}
.fchip.img-lg .fchip-name{font-size:10px;color:var(--text3);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fchip-ico{flex-shrink:0;font-size:13px;line-height:1}
.fchip-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.fchip-rm{flex-shrink:0;cursor:pointer;color:var(--text3);padding:0 2px;font-size:14px;line-height:1;transition:.1s}
.fchip-rm:hover{color:var(--red)}
/* drop zone highlight on inp-area */
.inp-area.drag-over{background:rgba(91,141,239,.06);outline:2px dashed rgba(91,141,239,.4);outline-offset:-2px;border-radius:12px}
.btn-attach{width:32px;height:32px;border-radius:8px;background:none;border:1px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text3);transition:.12s;flex-shrink:0}
.btn-attach:hover{background:var(--surface2);color:var(--text)}
.btn-attach.active{color:var(--blue);border-color:rgba(91,141,239,.45);background:rgba(91,141,239,.07)}
.inp-box{max-width:760px;margin:0 auto;background:var(--surface);border:1px solid var(--border2);border-radius:14px;overflow:hidden;transition:border-color .15s;box-shadow:0 1px 6px rgba(0,0,0,.12)}
.inp-box:focus-within{border-color:rgba(204,0,0,.35)}
.inp-row{display:flex;align-items:flex-end;padding:10px 12px 10px 16px;gap:8px}
.chat-ta{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:15px;line-height:1.6;resize:none;min-height:24px;max-height:180px;font-family:var(--font)}
.chat-ta::placeholder{color:var(--text3)}
.btn-send{width:34px;height:34px;border-radius:9px;background:var(--red);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.12s}
.btn-send:hover{background:#aa0000}
.btn-send:disabled{opacity:.4;cursor:not-allowed}
.inp-ft{padding:0 16px 8px;display:flex;align-items:center;justify-content:space-between}
.inp-hint{font-size:11px;color:var(--text3)}
.inp-cost{font-size:11px;color:var(--text3)}
@keyframes inpPulse{0%,100%{border-color:var(--border2)}50%{border-color:rgba(204,0,0,.4)}}
.inp-ready{animation:inpPulse .6s ease}

/* ── MENSAGENS ──────────────────────────────────────────────────────── */
.mr{max-width:760px;margin:0 auto;padding:10px 24px;display:flex;gap:12px;align-items:flex-start}
.mr.user{flex-direction:row-reverse;padding-left:80px}
.mr.ai{padding-right:80px}
.mav{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;margin-top:3px}
.mr.user .mav{background:var(--red);color:#fff}
.mr.ai .mav{background:var(--surface2);border:1px solid var(--border2);color:var(--text2)}
.mb{flex:1;font-size:15px;line-height:1.7;color:var(--text);min-width:0}
.mr.user .mb{background:var(--surface);border:1px solid var(--border2);border-radius:18px 18px 4px 18px;padding:10px 16px;font-size:15px;max-width:72%}
.mb p{margin:0 0 8px}
.mb p:last-child{margin-bottom:0}
.mb h1{font-size:19px;font-weight:700;margin:14px 0 7px;letter-spacing:-.02em}
.mb h2{font-size:17px;font-weight:700;margin:12px 0 6px}
.mb h3{font-size:15px;font-weight:600;margin:10px 0 4px}
.mb ul,.mb ol{padding-left:22px;margin:6px 0}
.mb li{margin:3px 0;line-height:1.65}
.mb strong{font-weight:600}
.mb em{font-style:italic}
.mb a{color:var(--blue);text-decoration:none}
.mb a:hover{text-decoration:underline}
.mb blockquote{border-left:3px solid var(--border2);padding:4px 0 4px 14px;color:var(--text2);margin:8px 0;font-style:italic}
.mb table{border-collapse:collapse;width:100%;margin:10px 0;font-size:13px}
.mb th{background:var(--surface2);padding:7px 12px;text-align:left;font-weight:600;border:1px solid var(--border)}
.mb td{padding:6px 12px;border:1px solid var(--border)}
.mb pre{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:14px;overflow-x:auto;font-size:13px;margin:10px 0;line-height:1.5;position:relative}
.mb code:not(pre code){background:var(--surface2);padding:2px 6px;border-radius:4px;font-size:13px;font-family:var(--mono)}
.mb pre code{font-family:var(--mono);display:block;color:var(--text)}
/* Acções mensagem */
.mac{display:none;gap:4px;margin-top:6px}
.mr.ai:hover .mac{display:flex}
.mab{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:6px;color:var(--text3);cursor:pointer;transition:.12s;border:none;background:none}
.mab:hover{background:var(--surface);color:var(--text2)}
/* Code block com copiar */

.cb-lang{position:absolute;top:8px;left:12px;font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em}
.cb-copy{position:absolute;top:6px;right:8px;font-size:11px;font-weight:600;color:var(--text3);background:var(--surface);border:1px solid var(--border);border-radius:5px;padding:3px 8px;cursor:pointer;transition:.12s}
.cb-copy:hover{color:var(--text);border-color:var(--border2)}
.cb pre{padding-top:28px!important}

/* ── THINK BLOCK ────────────────────────────────────────────────────── */
.think-block{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);margin-bottom:8px;overflow:hidden}
.think-hd{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;user-select:none}
.think-hd:hover{background:rgba(255,255,255,.03)}
.think-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.think-dot.running{background:var(--blue);animation:tPulse 1.2s ease-in-out infinite}
.think-dot.done{background:var(--green)}
@keyframes tPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
.think-lbl{font-size:12px;font-weight:600;color:var(--text2);flex:1}
.think-dur{font-size:11px;color:var(--text3)}
.think-chev{font-size:9px;color:var(--text3);transition:transform .2s}
.think-chev.open{transform:rotate(180deg)}
.think-body{padding:8px 12px 12px;border-top:1px solid var(--border)}
.think-body:not(.open){display:none}
.think-steps{display:flex;flex-direction:column;gap:6px}
.think-step{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text2);padding:4px 8px;border-radius:6px;background:var(--bg2)}
.think-step.running{color:var(--purple)}
.think-step.done{color:var(--text3)}
.think-cube{width:16px;height:16px;flex-shrink:0}
.think-step-txt{flex:1}
.think-step-badge{font-size:10px;font-weight:700;color:var(--text3);background:var(--surface);padding:1px 6px;border-radius:10px}
.think-summary{font-size:11px;color:var(--text3);margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}

/* ── MOTOR SELECTOR ─────────────────────────────────────────────────── */
.mm-wrap{position:relative}
.motor-btn{display:flex;align-items:center;gap:6px;padding:5px 10px;border-radius:8px;background:var(--surface2);border:1px solid var(--border);cursor:pointer;font-size:12px;font-weight:600;color:var(--text2);transition:.12s;min-width:100px}
.motor-btn:hover{border-color:var(--border2);color:var(--text)}
.mdot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.mm{position:absolute;top:calc(100% + 6px);right:0;background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:6px;min-width:220px;z-index:200;display:none;box-shadow:0 8px 32px rgba(0,0,0,.4)}
.mm.open{display:block}
.mo{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:.12s}
.mo:hover{background:var(--surface)}
.mo.active{background:rgba(91,141,239,.12)}
.mo-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:4px}
.mo-n{font-size:13px;font-weight:600;color:var(--text);display:block}
.mo-d{font-size:11px;color:var(--text3);display:block;margin-top:1px}

/* ── ARTIFACT PANEL ─────────────────────────────────────────────────── */
.artifact-panel{width:0;flex-shrink:0;background:var(--bg2);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;transition:width .22s cubic-bezier(.4,0,.2,1);position:relative}
.artifact-panel.open{width:46%;min-width:300px}
.ap-resize{position:absolute;left:0;top:0;bottom:0;width:5px;cursor:ew-resize;z-index:5;transition:.12s;background:var(--border)}
.ap-resize:hover,.ap-resize.dragging{background:var(--blue);opacity:.7}
/* ── Cartão de ficheiro no chat (estilo Claude.ai) ── */
.msg-file-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border2);border-radius:12px;padding:10px 14px;cursor:pointer;transition:.15s;max-width:340px;margin-top:4px}
.msg-file-card:hover{background:var(--surface2);border-color:var(--border)}
.mfc-icon{width:40px;height:40px;border-radius:9px;background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--amber);flex-shrink:0}
.mfc-info{flex:1;min-width:0}
.mfc-name{display:block;font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mfc-meta{display:block;font-size:11px;color:var(--text3);margin-top:2px}
.mfc-dl{display:flex;align-items:center;gap:5px;padding:6px 12px;background:var(--blue);color:#fff;border:none;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;flex-shrink:0;transition:.12s}
.mfc-dl:hover{filter:brightness(1.1)}
.ap-hd{display:flex;align-items:center;gap:8px;padding:0 12px;height:48px;border-bottom:1px solid var(--border);flex-shrink:0}
.ap-title{flex:1;font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ap-tabs{display:flex;gap:2px;background:var(--surface2);border-radius:7px;padding:3px}
.ap-tab{padding:4px 12px;border-radius:5px;font-size:12px;font-weight:600;color:var(--text3);cursor:pointer;transition:.12s;border:none;background:none}
.ap-tab.active{background:var(--surface);color:var(--text)}
.ap-btns{display:flex;gap:4px;margin-left:auto}
.ap-btn{width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text3);cursor:pointer;transition:.12s;border:none;background:none}
.ap-btn:hover{background:var(--surface);color:var(--text)}
.ap-body{flex:1;overflow:hidden;display:flex;flex-direction:column}
.ap-preview{flex:1;overflow:auto;padding:16px;background:var(--bg2)}
.ap-code{flex:1;overflow:auto;font-family:var(--mono);font-size:13px;line-height:1.6;counter-reset:line;padding:0}
.ap-line-wrap{display:flex}
.ap-line-num{min-width:40px;padding:0 12px 0 16px;color:var(--text3);text-align:right;user-select:none;border-right:1px solid var(--border);background:var(--bg2);flex-shrink:0}
.ap-line{padding:0 16px;flex:1;white-space:pre;color:var(--text)}

/* ── TOAST ──────────────────────────────────────────────────────────── */
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(8px);background:var(--surface2);color:var(--text);padding:9px 18px;border-radius:8px;font-size:13px;font-weight:500;opacity:0;transition:opacity .2s,transform .2s;pointer-events:none;z-index:1000;border:1px solid var(--border);box-shadow:0 4px 16px rgba(0,0,0,.3);white-space:nowrap}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.err{border-color:rgba(204,0,0,.4);color:var(--red)}
#toast.ok{border-color:rgba(76,175,125,.4);color:var(--green)}

/* ── ADMIN PAGE ─────────────────────────────────────────────────────── */
.admin-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.admin-kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px 18px;display:flex;flex-direction:column}
.admin-kpi-lbl{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;display:block}
.admin-kpi-val{font-size:22px;font-weight:700;color:var(--text);display:block}
.admin-kpi-val.blue{color:var(--blue)}
.admin-kpi-val.green{color:var(--green)}
.admin-kpi-val.red{color:var(--red)}
.admin-kpi-sub{font-size:11px;color:var(--text3);margin-top:3px;display:block}
.admin-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.admin-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.admin-panel-hd{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}
.admin-panel-title{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em}
.admin-panel-actions{display:flex;gap:4px}
.btn-backup-run{display:flex;align-items:center;gap:6px;padding:7px 14px;background:var(--red);color:#fff;border:none;border-radius:7px;font-size:12px;font-weight:700;cursor:pointer;transition:.12s}
.btn-backup-run:hover{background:#aa0000}
.btn-backup-run:disabled{opacity:.5;cursor:not-allowed}
.bk-auto-toggle{display:flex;align-items:center;gap:7px;cursor:pointer;font-size:12px;color:var(--text2)}
.bk-running{display:none;align-items:center;gap:10px;padding:12px 16px;font-size:13px;color:var(--text2)}
.bk-running.show{display:flex}
.bk-spinner{width:16px;height:16px;border:2px solid var(--border2);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.bk-tl-header{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;padding:10px 16px 6px}
.bk-timeline{overflow:visible}
.bk-tl-entry{border-bottom:1px solid var(--border);padding:10px 16px}
.bk-tl-entry:last-child{border-bottom:none}
.bk-tl-hd{display:flex;align-items:center;gap:8px;margin-bottom:3px}
.bk-tl-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.bk-tl-name{font-size:13px;font-weight:700;color:var(--text);flex:1}
.bk-tl-status{font-size:11px;font-weight:700;color:var(--green)}
.bk-tl-meta{font-size:11px;color:var(--text3);margin:2px 0 8px 18px}
.bk-tl-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:2px 8px;border-radius:10px;background:var(--amber);color:#000}
.bk-tl-actions{display:flex;gap:5px;flex-wrap:wrap;margin-left:18px}
.bk-action-btn{font-size:11px;font-weight:600;padding:4px 10px;border-radius:6px;border:1px solid var(--border);background:var(--surface2);color:var(--text2);cursor:pointer;transition:.12s}
.bk-action-btn:hover{background:var(--surface);color:var(--text);border-color:var(--border2)}
/* Patcher */
.pt-dropzone{border:2px dashed var(--border2);border-radius:10px;padding:24px 16px;text-align:center;cursor:pointer;transition:.15s;position:relative;margin-bottom:12px}
.pt-dropzone:hover,.pt-dropzone.drag-over{border-color:var(--blue);background:rgba(91,141,239,.04)}
.pt-dropzone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.pt-dropzone p{font-size:13px;font-weight:500;color:var(--text2);margin:8px 0 4px}
.pt-dropzone span{font-size:11px;color:var(--text3)}
.pt-installing{display:none;align-items:center;gap:10px;padding:10px 0;font-size:13px;color:var(--text2)}
.pt-installing.show{display:flex}
.pt-confirm-panel{background:var(--surface2);border:2px solid var(--amber);border-radius:var(--r);padding:16px;margin:12px 0;display:none}
.pt-confirm-panel.show{display:block}
.pt-confirm-hd{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.pt-confirm-icon{font-size:20px}
.pt-confirm-title{font-size:14px;font-weight:700;color:var(--text)}
.pt-confirm-sub{font-size:12px;color:var(--text2);margin-top:2px}
.pt-timer-wrap{display:flex;align-items:center;gap:16px;margin-bottom:14px}
.pt-timer-ring{position:relative;flex-shrink:0}
.pt-timer-bg{fill:none;stroke:var(--surface);stroke-width:3}
.pt-timer-fg{fill:none;stroke:var(--amber);stroke-width:3;stroke-linecap:round;transform-origin:26px 26px;transform:rotate(-90deg);transition:stroke-dashoffset .5s linear}
.pt-timer-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--text)}
.pt-timer-desc{font-size:12px;color:var(--text2);line-height:1.5}
.pt-confirm-btns{display:flex;gap:8px}
.btn-pt-ok{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--green);color:#fff;border:none;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;transition:.12s}
.btn-pt-ok:hover{filter:brightness(1.1)}
.btn-pt-undo{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--surface);color:var(--text2);border:1px solid var(--border);border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;transition:.12s}
.btn-pt-undo:hover{color:var(--text)}
.pt-empty{padding:16px;text-align:center;color:var(--text3);font-size:13px}
.btn-pt-preset{padding:4px 10px;border:1px solid var(--border2);border-radius:6px;background:var(--bg2);color:var(--text2);font-size:11px;font-weight:600;cursor:pointer;transition:.12s}
.btn-pt-preset:hover{background:var(--surface);color:var(--text)}
.btn-pt-preset.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.pt-history{display:flex;flex-direction:column;gap:6px;padding:0 16px 16px}
.pt-hist-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:7px;background:var(--bg2);border:1px solid var(--border);font-size:12px;flex-wrap:wrap}
.pt-hist-name{font-weight:600;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pt-hist-date{font-size:11px;color:var(--text3)}
.pt-badge-confirmed{background:rgba(76,175,125,.15);color:var(--green);border:1px solid rgba(76,175,125,.2);padding:2px 8px;border-radius:10px;font-size:10px;font-weight:700;text-transform:uppercase}
.pt-badge-reverted,.pt-badge-auto-rollback{background:rgba(204,0,0,.12);color:var(--red);border:1px solid rgba(204,0,0,.2);padding:2px 8px;border-radius:10px;font-size:10px;font-weight:700;text-transform:uppercase}
.pt-hist-undo{font-size:11px;font-weight:600;color:var(--text3);background:none;border:1px solid var(--border);border-radius:5px;padding:2px 8px;cursor:pointer;transition:.12s}
.pt-hist-undo:hover{color:var(--text)}

/* ── CONFIGURAÇÕES PAGE ─────────────────────────────────────────────── */
.cfg-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:12px}
.cfg-panel.purple{border-color:rgba(167,139,250,.3)}
.cfg-panel.danger{border-color:rgba(204,0,0,.25)}
.cfg-hd{padding:13px 16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);border-bottom:1px solid var(--border);background:var(--bg2)}
.cfg-hd.purple{color:var(--purple);background:rgba(167,139,250,.06)}
.cfg-hd.danger{color:var(--red);background:rgba(204,0,0,.05)}
.cfg-body{padding:16px}
.cfg-group{margin-bottom:14px}
.cfg-group:last-child{margin-bottom:0}
.cfg-group label{display:block;font-size:12px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px}
.cfg-input,.cfg-select{width:100%;background:var(--surface2);border:1px solid var(--border2);border-radius:8px;padding:9px 12px;font-size:14px;color:var(--text);outline:none;transition:.15s;font-family:var(--font)}
.cfg-input:focus,.cfg-select:focus{border-color:var(--blue);box-shadow:0 0 0 2px rgba(91,141,239,.15)}
.cfg-save-row{display:flex;align-items:center;gap:10px;margin-top:14px}
.btn-cfg-save{padding:7px 18px;background:var(--blue);color:#fff;border:none;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;transition:.12s}
.btn-cfg-save:hover{filter:brightness(1.1)}
.cfg-status{font-size:12px;color:var(--green)}
.cfg-hint{font-size:12px;color:var(--text3);line-height:1.5;margin-bottom:10px}
.cfg-admin-note{font-size:12px;color:var(--text3);font-style:italic;margin-top:10px}
.cfg-row{display:flex;gap:8px;align-items:center}
.cfg-range-row{display:flex;align-items:center;gap:10px}
.cfg-range-row input[type=range]{flex:1;accent-color:var(--blue)}
.btn-cfg-danger{padding:8px 18px;background:rgba(204,0,0,.12);color:var(--red);border:1px solid rgba(204,0,0,.2);border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;transition:.12s}
.btn-cfg-danger:hover{background:rgba(204,0,0,.2)}
.tone-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.tone-btn{padding:6px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:20px;font-size:12px;color:var(--text2);cursor:pointer;transition:.12s}
.tone-btn:hover{border-color:var(--border2);color:var(--text)}
.tone-btn.active{background:rgba(91,141,239,.12);border-color:var(--blue);color:var(--blue)}

/* ── MEMÓRIA PAGE ───────────────────────────────────────────────────── */
.mem-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.mem-kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:14px 16px}
.mem-kpi-lbl{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:6px}
.mem-kpi-val{font-size:22px;font-weight:700}
.mem-kpi-val.blue{color:var(--blue)}
.mem-kpi-val.purple{color:var(--purple)}
.mem-kpi-val.white{color:var(--text)}
.mem-kpi-val.green{color:var(--green)}
.mem-search{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border2);border-radius:9px;padding:8px 14px;margin-bottom:14px}
.mem-search input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:14px;font-family:var(--font)}
.mem-search input::placeholder{color:var(--text3)}
.mem-list{flex:1;display:flex;flex-direction:column;gap:8px}
.mem-loading{text-align:center;color:var(--text3);font-size:13px;padding:24px}
.mem-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px}
.mem-item-text{font-size:13px;color:var(--text);line-height:1.6;margin-bottom:6px}
.mem-item-meta{font-size:11px;color:var(--text3);display:flex;gap:10px;align-items:center}
.mem-item-motor{font-weight:600}
.mem-item-actions{display:flex;gap:6px;margin-left:auto}
.mem-rate-btn,.mem-del-btn{background:none;border:none;cursor:pointer;color:var(--text3);font-size:12px;padding:2px 6px;border-radius:4px;transition:.12s}
.mem-rate-btn:hover{color:var(--amber)}
.mem-del-btn:hover{color:var(--red)}
.mem-pagination{display:flex;align-items:center;justify-content:center;gap:16px;padding-top:12px;margin-top:auto}
.mem-pg-btn{padding:6px 14px;background:var(--surface);border:1px solid var(--border);border-radius:7px;font-size:12px;font-weight:600;color:var(--text2);cursor:pointer;transition:.12s}
.mem-pg-btn:hover{color:var(--text)}
.mem-pg-info{font-size:12px;color:var(--text3)}

/* ── CONTA PAGE ─────────────────────────────────────────────────────── */
.acc-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.acc-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px}
.acc-card.acc-full{grid-column:1/-1}
.acc-card-title{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}
.acc-identity{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.acc-avatar{width:44px;height:44px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:700;color:#fff;flex-shrink:0}
.acc-identity-info h2{font-size:16px;font-weight:700;color:var(--text)}
.acc-identity-info p{font-size:13px;color:var(--text2);margin-top:2px}
.acc-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}
.acc-row:last-child{border-bottom:none}
.acc-lbl{color:var(--text2)}
.acc-val{color:var(--text);font-weight:500}
.acc-val.blue{color:var(--blue)}
.acc-val.green{color:var(--green)}
.acc-plan-badge{padding:3px 10px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.acc-plan-badge.pro{background:rgba(167,139,250,.15);color:var(--purple);border:1px solid rgba(167,139,250,.25)}
.acc-plan-badge.free{background:var(--surface2);color:var(--text3)}
.acc-bar-wrap{height:4px;background:var(--surface2);border-radius:4px;margin-top:12px;overflow:hidden}
.acc-bar{height:100%;background:var(--blue);border-radius:4px;transition:width .5s}
.acc-skeleton{background:var(--surface2);border-radius:6px;animation:skeleton 1.4s ease-in-out infinite}
@keyframes skeleton{0%,100%{opacity:1}50%{opacity:.5}}


/* ── ARTIFACT PANEL extra ───────────────────────────────────────────── */
.ap-badge{font-size:10px;font-weight:700;background:var(--surface2);color:var(--text3);padding:2px 8px;border-radius:10px;border:1px solid var(--border)}
.ap-frame{width:100%;height:100%;border:none;background:var(--bg)}
.ap-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--text3);font-size:13px}
.ap-ft{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;border-top:1px solid var(--border);flex-shrink:0;min-height:36px}
.ap-ft-info{font-size:11px;color:var(--text3)}
.ap-btn.primary{background:var(--blue);color:#fff;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600;border:none;cursor:pointer;display:flex;align-items:center;gap:5px;transition:.12s}
.ap-btn.primary:hover{filter:brightness(1.1)}

/* ── MEMÓRIA — episódios ────────────────────────────────────────────── */
.mem-empty{text-align:center;color:var(--text3);font-size:13px;padding:32px;flex:1;display:flex;align-items:center;justify-content:center}
.mem-ep{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:0;margin-bottom:8px;overflow:hidden}
.mem-ep-hd{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;cursor:pointer;transition:.12s}
.mem-ep-hd:hover{background:var(--surface2)}
.mem-ep-prompt{font-size:13px;font-weight:600;color:var(--text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mem-ep-meta{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:10px}
.mem-ep-motor{font-size:10px;font-weight:700;color:var(--text3);background:var(--surface2);padding:2px 7px;border-radius:10px}
.mem-ep-date{font-size:11px;color:var(--text3)}
.mem-ep-actions{display:flex;gap:4px}
.mem-ep-btn{background:none;border:none;cursor:pointer;color:var(--text3);padding:3px 6px;border-radius:5px;font-size:12px;transition:.12s}
.mem-ep-btn:hover{background:var(--surface2);color:var(--text2)}
.mem-ep-body{padding:10px 14px;border-top:1px solid var(--border);background:var(--bg2);display:none}
.mem-ep-body.open{display:block}
.mem-ep-reply{font-size:13px;color:var(--text2);line-height:1.6;margin-top:6px}

/* ── PATCHER extra ──────────────────────────────────────────────────── */
.pt-progress{background:var(--surface2);border-radius:4px;height:4px;overflow:hidden;margin:8px 0;display:none}
.pt-progress.show{display:block}
.pt-progress-bar{height:100%;background:var(--blue);border-radius:4px;transition:width .3s}
.pt-entry{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border-radius:7px;background:var(--bg2);border:1px solid var(--border);font-size:12px;margin-bottom:6px}
.pt-entry-name{font-weight:600;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pt-entry-meta{font-size:11px;color:var(--text3);display:flex;gap:6px;align-items:center;margin-top:3px}
.pt-entry-info{font-size:11px;color:var(--text3);flex-shrink:0}
/* CORTEX-DEV v1.2.56 — Patch Preview Panel */
.pt-preview{display:none;margin-top:12px}
.pt-preview.show{display:block}
.pt-preview-hd{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:8px 8px 0 0;border-bottom:none}
.pt-preview-name{font-size:13px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}
.pt-preview-total{font-size:11px;font-weight:700;color:var(--text3);background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:2px 10px}
.pt-preview-sections{border:1px solid var(--border);border-radius:0 0 8px 8px;overflow:hidden;margin-bottom:12px;max-height:280px;overflow-y:auto}
.pt-preview-sections::-webkit-scrollbar{width:3px}
.pt-preview-sections::-webkit-scrollbar-thumb{background:var(--border2)}
.pt-section-lbl{display:flex;align-items:center;gap:7px;padding:6px 12px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:var(--surface2);border-bottom:1px solid var(--border);color:var(--text3);position:sticky;top:0;z-index:1}
.pt-section-lbl.replace{color:var(--amber)}
.pt-section-lbl.new{color:var(--green)}
.pt-section-lbl.delete{color:var(--red)}
.pt-section-lbl .cnt{font-size:10px;font-weight:700;padding:1px 7px;border-radius:10px;margin-left:auto}
.pt-section-lbl.replace .cnt{background:rgba(232,168,56,.15);color:var(--amber)}
.pt-section-lbl.new .cnt{background:rgba(76,175,125,.15);color:var(--green)}
.pt-section-lbl.delete .cnt{background:rgba(204,0,0,.12);color:var(--red)}
.pt-frow{display:flex;align-items:center;gap:8px;padding:6px 12px;border-bottom:1px solid rgba(255,255,255,.03);font-size:12px;transition:.1s}
.pt-frow:last-child{border-bottom:none}
.pt-frow:hover{background:var(--surface2)}
.pt-frow-icon{flex-shrink:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;border-radius:3px}
.pt-frow-icon.r{background:rgba(232,168,56,.15);color:var(--amber)}
.pt-frow-icon.n{background:rgba(76,175,125,.15);color:var(--green)}
.pt-frow-icon.d{background:rgba(204,0,0,.12);color:var(--red)}
.pt-frow-path{flex:1;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pt-frow-path span{color:var(--text3);font-size:11px}
.pt-frow-meta{flex-shrink:0;font-size:11px;color:var(--text3);text-align:right}
.pt-frow-meta .diff-up{color:var(--green)}
.pt-frow-meta .diff-dn{color:var(--red)}
.pt-preview-warn{display:flex;align-items:flex-start;gap:8px;padding:9px 12px;background:rgba(204,0,0,.07);border:1px solid rgba(204,0,0,.2);border-radius:7px;margin-bottom:12px;font-size:12px;color:var(--red);line-height:1.4}
.pt-preview-actions{display:flex;gap:8px}
.btn-pt-install{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;background:var(--red);color:#fff;border:none;border-radius:7px;font-size:13px;font-weight:700;cursor:pointer;transition:.12s;letter-spacing:.02em}
.btn-pt-install:hover{filter:brightness(1.15)}
.btn-pt-install:disabled{opacity:.5;cursor:not-allowed}
.btn-pt-cancel{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 14px;background:none;color:var(--text3);border:1px solid var(--border);border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;transition:.12s}
.btn-pt-cancel:hover{color:var(--text);border-color:var(--border2)}
/* Confirm panel — lista de ficheiros */
.pt-confirm-files{margin:10px 0 14px;border:1px solid var(--border);border-radius:7px;overflow:hidden;max-height:160px;overflow-y:auto}
.pt-confirm-files::-webkit-scrollbar{width:3px}
.pt-confirm-files::-webkit-scrollbar-thumb{background:var(--border2)}
.btn-pt-revert{font-size:11px;font-weight:600;color:var(--text3);background:none;border:1px solid var(--border);border-radius:5px;padding:2px 8px;cursor:pointer;transition:.12s;flex-shrink:0}
.btn-pt-revert:hover{color:var(--red);border-color:rgba(204,0,0,.3)}

/* ── BACKUP extra ───────────────────────────────────────────────────── */
.bk-item{display:flex;align-items:flex-start;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border)}
.bk-item:last-child{border-bottom:none}
.bk-info{flex:1;min-width:0}
.bk-id{font-size:13px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:3px}
.bk-meta{font-size:11px;color:var(--text3);margin:2px 0 8px 18px}
.bk-line{display:none}
.bk-actions{display:flex;gap:5px;flex-wrap:wrap;margin-left:18px}

/* ── SIDEBAR extra ──────────────────────────────────────────────────── */
.sb-uname{font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sb-urole{font-size:11px;color:var(--text3)}
.hi-empty{text-align:center;color:var(--text3);font-size:12px;padding:16px 8px}

/* ── PAGE header-left ───────────────────────────────────────────────── */
.page-hd-left{flex:1;min-width:0}
.page-hd-left h1{font-size:22px;font-weight:700;letter-spacing:-.03em;color:var(--text)}
.page-hd-left p{font-size:13px;color:var(--text2);margin-top:4px}

/* ── LOGIN extra ────────────────────────────────────────────────────── */
.login-field{margin-bottom:14px}

/* ── CODE BLOCK extra ───────────────────────────────────────────────── */


/* ── AVATAR CX ──────────────────────────────────────────────────────── */
.mav-cx{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}

/* ── BACKUP/PATCHER banner de topo ──────────────────────────────────── */
.pt-banner{background:rgba(232,168,56,.1);border:1px solid rgba(232,168,56,.25);border-radius:8px;padding:10px 16px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:13px;color:var(--amber)}
.pt-banner-btns{display:flex;gap:8px}
.acc-sessions{display:flex;flex-direction:column;gap:8px}.acc-sess-item{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}.acc-sess-item:last-child{border-bottom:none}.acc-sess-title{color:var(--text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.acc-sess-meta{font-size:11px;color:var(--text3);flex-shrink:0;margin-left:12px}

/* Conta — identity info */
.acc-identity-info{min-width:0;flex:1}
.acc-identity-info h2{font-size:16px;font-weight:700;color:var(--text);margin-bottom:2px}
.acc-identity-info p{font-size:13px;color:var(--text2)}

/* Page header descriptions */
.page-hd p{font-size:13px;color:var(--text2);margin-top:4px;line-height:1.5}
.page-hd-left{flex:1;min-width:0}
.page-hd-left h1{font-size:22px;font-weight:700;letter-spacing:-.03em;color:var(--text)}
.mr.ai:hover{background:rgba(255,255,255,.015);border-radius:8px}
/* ── CONFIGURAÇÕES — redesign completo ──────────────────────────────── */
.cfg-section{display:flex;flex-direction:column;gap:12px}
.cfg-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.cfg-panel--purple{border-color:rgba(167,139,250,.3)}
.cfg-panel--danger{border-color:rgba(204,0,0,.25)}
.cfg-panel-hd{padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg2)}
.cfg-panel-title{font-size:12px;font-weight:700;color:var(--text2);letter-spacing:.01em}
.cfg-panel-title--purple{color:var(--purple)}
.cfg-panel-title--danger{color:var(--red)}
.cfg-panel-body{padding:16px;display:flex;flex-direction:column;gap:14px}
.cfg-field{display:flex;flex-direction:column;gap:6px}
.cfg-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cfg-label{font-size:12px;font-weight:500;color:var(--text2)}
.cfg-input-row{display:flex;gap:8px;align-items:center}
.cfg-input-row .cfg-input{flex:1}
.cfg-actions{display:flex;align-items:center;gap:10px;padding-top:2px}
.cfg-note{font-size:12px;color:var(--text3);font-style:italic}
/* Manter os antigos para compatibilidade JS */
.cfg-group{display:flex;flex-direction:column;gap:6px}
.cfg-group label{font-size:12px;font-weight:500;color:var(--text2)}
.cfg-save-row{display:flex;align-items:center;gap:10px}

/* Admin extras */
.admin-icon-btn{width:26px;height:26px;border-radius:6px;border:none;background:none;color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.12s;flex-shrink:0}
.admin-icon-btn:hover{background:var(--surface2);color:var(--text)}
.admin-panel-body{padding:14px 16px;display:flex;flex-direction:column;gap:12px}
.bk-loading{padding:20px;text-align:center;color:var(--text3);font-size:13px}
.pt-hist-section{margin-top:4px}
.pt-hist-header{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;padding:8px 0 8px}
.bk-auto-toggle input[type=checkbox]{width:14px;height:14px;accent-color:var(--blue);cursor:pointer}

/* ── BACKUP TIMELINE ────────────────────────────────────────────────── */
/* bk-kpi-val = alias de admin-kpi-val (JS sobrescreve className) */
.bk-kpi-val{font-size:22px;font-weight:700;color:var(--text);display:block}
.bk-kpi-val.blue,.bk-kpi-val.blue{color:var(--blue)}
.bk-kpi-val.green{color:var(--green)}
.bk-kpi-val.red{color:var(--red)}

/* Cabeçalho da timeline */
.bk-tl-header{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;padding:10px 16px 6px;border-bottom:1px solid var(--border)}

/* Item da timeline */
.bk-item{display:flex;align-items:flex-start;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border);position:relative}
.bk-item:last-child{border-bottom:none}

/* Linha vertical entre dots */
.bk-line{width:2px;background:var(--border);flex-shrink:0;align-self:stretch;margin-top:6px}

/* Dot colorido */
.bk-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;margin-top:5px}
.bk-dot.recent{background:var(--blue)}
.bk-dot.ok{background:var(--green)}
.bk-dot.err{background:var(--red)}

/* Informação do backup */
.bk-info{flex:1;min-width:0}
.bk-id{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--text);margin-bottom:3px;flex-wrap:wrap}

/* Badge "Mais Recente" */
.bk-badge{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:10px;flex-shrink:0}
.bk-badge.recent{background:rgba(91,141,239,.15);color:var(--blue);border:1px solid rgba(91,141,239,.25)}

/* Meta info (data, tamanho) */
.bk-meta{font-size:11px;color:var(--text3);margin-bottom:7px}

/* Botões de acção */
.bk-actions{display:flex;gap:5px;flex-wrap:wrap}
.bk-btn{font-size:11px;font-weight:600;padding:4px 9px;border-radius:5px;border:1px solid var(--border);background:var(--surface2);color:var(--text2);cursor:pointer;transition:.12s;white-space:nowrap}
.bk-btn:hover{background:var(--surface);color:var(--text);border-color:var(--border2)}
.bk-btn.files:hover{color:var(--blue);border-color:rgba(91,141,239,.3)}
.bk-btn.db:hover{color:var(--amber);border-color:rgba(232,168,56,.3)}
.bk-btn.all:hover{color:var(--green);border-color:rgba(76,175,125,.3)}
.bk-btn.del{color:var(--text3)}
.bk-btn.del:hover{color:var(--red);border-color:rgba(204,0,0,.3);background:rgba(204,0,0,.05)}

/* Status (✓ OK / ✗ Erro) */
.bk-status{font-size:11px;font-weight:700;flex-shrink:0;white-space:nowrap;margin-top:4px}
.bk-status.ok{color:var(--green)}
.bk-status.err{color:var(--red)}

/* Linha connector da timeline (via pseudo-elemento) */


/* Patch history entries */
.pt-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:3px}
.pt-dot.confirmed{background:var(--green)}
.pt-dot.reverted,.pt-dot.auto-rollback{background:var(--red)}
.pt-dot.pending{background:var(--amber)}
.pt-entry-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:10px}
.pt-entry-badge.confirmed{background:rgba(76,175,125,.15);color:var(--green);border:1px solid rgba(76,175,125,.25)}
.pt-entry-badge.reverted,.pt-entry-badge.auto-rollback{background:rgba(204,0,0,.12);color:var(--red);border:1px solid rgba(204,0,0,.2)}
.pt-entry-badge.pending{background:rgba(232,168,56,.15);color:var(--amber);border:1px solid rgba(232,168,56,.3)}

/* ── MEMÓRIA — episódios redesenhados ───────────────────────────────── */
.mem-ep{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:8px;transition:.15s}
.mem-ep:hover{border-color:var(--border2)}
.mem-ep-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 14px;cursor:pointer;user-select:none;transition:.12s}
.mem-ep-hd:hover{background:var(--surface2)}
.mem-ep-hd.open{background:var(--surface2)}
.mem-ep-prompt-summary{font-size:13px;font-weight:500;color:var(--text);flex:1;line-height:1.5;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mem-ep-meta{display:flex;align-items:center;gap:8px;flex-shrink:0}
.mem-ep-qubit-badge{font-size:10px;font-weight:700;background:rgba(167,139,250,.12);color:var(--purple);padding:2px 8px;border-radius:10px;border:1px solid rgba(167,139,250,.2);white-space:nowrap;letter-spacing:.02em}
.mem-ep-cost{font-size:10px;color:var(--text3);white-space:nowrap}
.mem-ep-date{font-size:11px;color:var(--text3);white-space:nowrap}
/* Body — colapsável */
.mem-ep-body{display:none;border-top:1px solid var(--border);background:var(--bg2)}
.mem-ep-body.open{display:block}
/* Log entries */
.mem-log-entry{padding:10px 14px;border-bottom:1px solid var(--border)}
.mem-log-entry:last-of-type{border-bottom:none}
.mem-log-user{background:rgba(91,141,239,.04)}
.mem-log-cortex{background:transparent}
.mem-log-who{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);display:block;margin-bottom:5px}
.mem-log-user .mem-log-who{color:var(--blue)}
.mem-log-cortex .mem-log-who{color:var(--purple)}
.mem-log-text{font-size:13px;color:var(--text);line-height:1.6;margin:0;white-space:pre-wrap;word-break:break-word}
/* Acções */
.mem-ep-actions{display:flex;align-items:center;gap:6px;padding:8px 14px;border-top:1px solid var(--border);background:var(--bg2)}
.mem-action-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:6px;border:1px solid var(--border);background:none;color:var(--text3);font-size:12px;font-weight:500;cursor:pointer;transition:.12s}
.mem-action-btn:hover{background:var(--surface);color:var(--text);border-color:var(--border2)}
.mem-action-btn.mem-btn-up{color:var(--green);border-color:rgba(76,175,125,.3);background:rgba(76,175,125,.06)}
.mem-action-btn.mem-btn-down{color:var(--amber);border-color:rgba(232,168,56,.3);background:rgba(232,168,56,.06)}
.mem-action-del:hover{color:var(--red)!important;border-color:rgba(204,0,0,.3)!important;background:rgba(204,0,0,.05)!important}
.mem-empty{padding:32px;text-align:center;color:var(--text3);font-size:13px;flex:1;display:flex;align-items:center;justify-content:center}
.mem-loading{padding:20px;text-align:center;color:var(--text3);font-size:13px}

.msg-inner{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}

/* ── CODE BLOCKS — numerados, 10 linhas ─────────────────────────────── */
.cb{background:var(--surface2);border:1px solid var(--border);border-radius:8px;margin:10px 0;overflow:hidden;font-family:var(--mono)}
.cb-hd{display:flex;align-items:center;gap:8px;padding:6px 12px;border-bottom:1px solid var(--border);background:var(--bg2)}
.cb-lang-badge{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;flex:1}
.cb-lines-info{font-size:10px;color:var(--text3)}
.cb-copy-btn{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:var(--text3);background:none;border:1px solid var(--border);border-radius:5px;padding:3px 8px;cursor:pointer;transition:.12s;font-family:var(--font)}
.cb-copy-btn:hover{color:var(--text);border-color:var(--border2)}
.cb-body{display:flex;max-height:calc(15 * 1.6em + 24px);overflow-y:auto}
.cb-body::-webkit-scrollbar{width:4px;height:4px}
.cb-body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
.cb-nums{padding:12px 8px 12px 12px;text-align:right;user-select:none;border-right:1px solid var(--border);background:var(--bg2);flex-shrink:0;min-width:36px}
.cb-ln{display:block;font-size:12px;line-height:1.6;color:var(--text3);font-family:var(--mono)}
.cb-code{flex:1;padding:12px;font-size:13px;line-height:1.6;overflow-x:auto;color:var(--text);white-space:pre}
.cb-row{display:block;line-height:1.6}
/* PATCH B4 v3.0.9 — md tables e blockquotes */
.md-tbl{border-collapse:collapse;margin:10px 0;font-size:13px;display:block;overflow-x:auto;max-width:100%;border:1px solid var(--border2);border-radius:6px}
.md-tbl thead{background:var(--surface2)}
.md-tbl th{padding:8px 12px;text-align:left;font-weight:600;color:var(--text);border-bottom:1px solid var(--border2);white-space:nowrap}
.md-tbl td{padding:7px 12px;border-bottom:1px solid var(--border);color:var(--text)}
.md-tbl tbody tr:last-child td{border-bottom:none}
.md-tbl tbody tr:hover{background:rgba(255,255,255,.02)}
[data-theme="light"] .md-tbl tbody tr:hover{background:rgba(0,0,0,.02)}
.md-bq{border-left:3px solid var(--blue);padding:6px 0 6px 14px;margin:10px 0;color:var(--text2);font-style:italic}
.md-link{color:var(--blue);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px;cursor:pointer;word-break:break-all}
.md-link:hover{opacity:.85;text-decoration-thickness:2px}
/* Inline code */
.ic{font-family:var(--mono);font-size:13px;background:var(--surface2);padding:2px 6px;border-radius:4px;color:var(--text);border:1px solid var(--border)}
/* Think cube animation */
.think-cube-svg{animation:cubeSpin 3s linear infinite;flex-shrink:0}
@keyframes cubeSpin{0%{opacity:.6}50%{opacity:1}100%{opacity:.6}}
.think-step.done .think-cube-svg{animation:none;opacity:.4}
.think-step.done{color:var(--text3)}
.think-step.running{color:var(--purple)}

/* ── Barra de processamento estilo Claude ────────────────────────── */
.cw-proc{display:flex;align-items:center;gap:8px;padding:6px 0;min-height:28px}
.cw-dots{display:flex;gap:4px;align-items:center}
.cw-dots span{width:6px;height:6px;border-radius:50%;background:var(--text3);display:inline-block}
.cw-dots span:nth-child(1){animation:cwDot 1.2s ease-in-out infinite}
.cw-dots span:nth-child(2){animation:cwDot 1.2s ease-in-out .2s infinite}
.cw-dots span:nth-child(3){animation:cwDot 1.2s ease-in-out .4s infinite}
@keyframes cwDot{0%,80%,100%{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}
.cw-proc-lbl{font-size:11px;color:var(--text3)}
.cw-motor-tag{font-size:11px;color:var(--text3);padding:2px 0 6px;display:flex;align-items:center;gap:4px}

/* ── Artifact panel melhorado ───────────────────────────────────── */
.artifact-panel.full{width:100%!important;position:absolute;inset:0;z-index:50}
.ap-nav{display:flex;align-items:center;gap:4px;margin-right:4px}
.ap-nav-btn{width:22px;height:22px;border-radius:4px;border:none;background:none;color:var(--text3);cursor:pointer;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center;transition:.12s}
.ap-nav-btn:hover{background:var(--surface);color:var(--text)}
.ap-nav-btn:disabled{opacity:.3;cursor:not-allowed}
.ap-nav-info{font-size:11px;color:var(--text3);min-width:32px;text-align:center}
/* Pill inline — substitui bloco de código no chat */
.ap-pill{display:inline-flex;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border2);border-radius:8px;padding:8px 14px;cursor:pointer;transition:.15s;margin:8px 0;font-size:13px;color:var(--text2)}
.ap-pill:hover{background:var(--surface);border-color:rgba(204,0,0,.3);color:var(--text)}
.ap-pill-lang{font-weight:700;font-size:11px;letter-spacing:.08em;color:var(--red)}
.ap-pill-info{color:var(--text3);font-size:12px}
.ap-pill-open{font-size:11px;color:var(--text3);margin-left:auto}
.ap-pill:hover .ap-pill-open{color:var(--text2)}
/* Code panel — numerado todas as linguagens */
.ap-code{flex:1;overflow:auto;display:flex;background:var(--bg2)}
.ap-ln-col{padding:12px 8px 12px 14px;text-align:right;user-select:none;border-right:1px solid var(--border);background:var(--bg2);flex-shrink:0;min-width:44px}
.ap-ln{display:block;font-size:12px;line-height:1.6;color:var(--text3);font-family:var(--mono)}
.ap-code-col{flex:1;padding:12px 16px;overflow-x:auto}
.ap-row{display:block;font-size:12px;line-height:1.6;font-family:var(--mono);color:var(--text);white-space:pre}
/* Frame preview */
.ap-frame{width:100%;height:100%;border:none;background:#fff;flex:1}

/* ── Artifact panel v2 ──────────────────────────────────────────── */
.artifact-panel.full{width:100%!important}
.ap-nav{display:flex;align-items:center;gap:3px;margin-right:6px}
.ap-nav-btn{width:22px;height:22px;border-radius:4px;border:none;background:none;color:var(--text3);cursor:pointer;font-size:15px;line-height:1;display:flex;align-items:center;justify-content:center;transition:.12s}
.ap-nav-btn:hover{background:var(--surface);color:var(--text)}
.ap-nav-btn:disabled{opacity:.3;cursor:not-allowed}
.ap-nav-info{font-size:11px;color:var(--text3);min-width:32px;text-align:center;font-variant-numeric:tabular-nums}
/* Pill inline */
.ap-pill{display:inline-flex;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border2);border-radius:8px;padding:9px 14px;cursor:pointer;transition:.15s;margin:8px 0;font-size:13px;color:var(--text2);width:100%;max-width:460px}
.ap-pill:hover{background:var(--surface);border-color:rgba(204,0,0,.35);color:var(--text)}
.ap-pill svg{flex-shrink:0;color:var(--red);opacity:.8}
.ap-pill-lang{font-weight:700;font-size:11px;letter-spacing:.07em;color:var(--text);background:var(--surface);padding:2px 7px;border-radius:5px;border:1px solid var(--border)}
.ap-pill-sep{color:var(--border2)}
.ap-pill-info{font-size:12px;color:var(--text3);flex:1}
.ap-pill-open{font-size:11px;color:var(--text3);margin-left:auto;white-space:nowrap}
.ap-pill:hover .ap-pill-open{color:var(--blue)}
/* Code view */
.ap-code{flex:1;overflow:auto;display:flex;background:var(--bg2);min-height:0}
.ap-ln-col{padding:12px 8px 12px 14px;text-align:right;user-select:none;border-right:1px solid var(--border);background:var(--bg2);flex-shrink:0;min-width:44px;font-variant-numeric:tabular-nums}
.ap-ln{display:block;font-size:12px;line-height:1.6;color:var(--text3);font-family:var(--mono)}
.ap-code-col{flex:1;padding:12px 16px;overflow-x:auto}
.ap-row{display:block;font-size:12px;line-height:1.6;font-family:var(--mono);color:var(--text);white-space:pre}
.ap-frame{width:100%;height:100%;border:none;background:#fff;flex:1;display:block}

.ap-body{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}

.mo{position:relative}
.mo-q{font-size:10px;font-weight:800;color:var(--text3);background:var(--surface);border:1px solid var(--border);padding:2px 6px;border-radius:6px;flex-shrink:0;letter-spacing:.04em;margin-left:auto}
.mo-q--max{color:var(--red);border-color:rgba(204,0,0,.3);background:rgba(204,0,0,.06)}

.cw-motor-tag{font-size:11px;color:var(--text3);padding:3px 0 8px;display:flex;align-items:center;gap:6px}
.cw-motor-tag strong{font-weight:600;color:var(--text2)}
.mt-tier{font-size:10px;font-weight:700;color:var(--purple);background:rgba(167,139,250,.1);padding:1px 6px;border-radius:8px}
.mt-dur{color:var(--text3);margin-left:2px}

.ap-btn-dev{color:var(--red)!important;border:1px solid rgba(204,0,0,.25);border-radius:5px}
.ap-btn-dev:hover{background:rgba(204,0,0,.1)!important;border-color:rgba(204,0,0,.4)!important}

.sb-ni-dev{color:var(--purple)!important;opacity:.8}
.sb-ni-dev:hover{background:rgba(167,139,250,.08)!important;color:var(--purple)!important;opacity:1}

/* ── Server Access Section ────────────────────────────────────────── */
.srv-section{margin-top:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.srv-section-hd{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg2)}
.srv-section-title{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text3)}
.srv-status-row{display:flex;align-items:center;gap:7px}
.srv-status-dot{width:8px;height:8px;border-radius:50%;background:var(--border2);animation:tp 2s ease-in-out infinite;flex-shrink:0}
.srv-status-lbl{font-size:11px;color:var(--text3)}
.srv-hint{font-size:12px;color:var(--text3);margin-bottom:14px;line-height:1.5}
.srv-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);background:var(--bg2)}
.srv-tab{display:flex;align-items:center;gap:7px;padding:10px 18px;font-size:12px;font-weight:600;color:var(--text3);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;transition:.15s;letter-spacing:.04em}
.srv-tab:hover{color:var(--text2)}
.srv-tab.active{color:var(--blue);border-bottom-color:var(--blue);background:var(--surface)}
.srv-panel{display:none}
.srv-panel.active{display:block}
.srv-panel-body{padding:16px;display:flex;flex-direction:column;gap:12px}
.srv-actions{display:flex;align-items:center;gap:10px;padding-top:4px}
.btn-srv-save{padding:7px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;font-size:12px;font-weight:600;color:var(--text2);cursor:pointer;transition:.12s}
.btn-srv-save:hover{background:var(--surface);color:var(--text)}

/* ── Dev Console 256³ ────────────────────────────────────────────── */
.dev-version-badge{font-size:11px;font-weight:700;color:var(--purple);background:rgba(167,139,250,.12);padding:4px 10px;border-radius:10px;border:1px solid rgba(167,139,250,.25)}
.dev-file-row{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;border-radius:7px;border:1px solid var(--border);background:var(--bg2);margin-bottom:6px;flex-wrap:wrap}
.dev-file-row.dev-file-has-issues{border-color:rgba(232,168,56,.3);background:rgba(232,168,56,.04)}
.dev-file-info{flex:1;min-width:0}
.dev-file-path{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--text);display:block}
.dev-file-meta{font-size:11px;color:var(--text3);display:block;margin-top:2px}
.dev-file-issues{width:100%;margin-top:6px;display:flex;flex-direction:column;gap:3px}
.dev-issue{font-size:11px;line-height:1.5}
.dev-btn-read{font-size:11px;font-weight:600;padding:4px 10px;border-radius:5px;border:1px solid var(--border);background:var(--surface);color:var(--text2);cursor:pointer;flex-shrink:0;transition:.12s}
.dev-btn-read:hover{color:var(--blue);border-color:rgba(91,141,239,.3)}
.dev-suggestion{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:0;margin-bottom:8px;overflow:hidden}
.dev-sug-hd{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--bg2)}
.dev-sug-icon{font-size:14px;flex-shrink:0;width:18px;text-align:center}
.dev-sug-info{flex:1;min-width:0}
.dev-sug-title{font-size:13px;font-weight:600;color:var(--text);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dev-sug-file{font-size:11px;color:var(--text3);font-family:var(--mono);display:block;margin-top:1px}
.dev-sug-actions{display:flex;gap:6px;flex-shrink:0}
.dev-sug-desc{font-size:12px;color:var(--text2);padding:8px 14px;line-height:1.6}
.dev-sug-status{font-size:11px;color:var(--text3);padding:0 14px 8px;min-height:0}
.dev-sug-status:not(:empty){display:block}
.dev-btn-install-auto{font-size:12px;font-weight:700;padding:5px 12px;border-radius:6px;background:var(--red);color:#fff;border:none;cursor:pointer;transition:.12s}
.dev-btn-install-auto:hover{background:#aa0000}
.dev-btn-install-auto:disabled{opacity:.5;cursor:not-allowed}
.dev-btn-generate{font-size:12px;font-weight:600;padding:5px 12px;border-radius:6px;background:rgba(167,139,250,.12);color:var(--purple);border:1px solid rgba(167,139,250,.25);cursor:pointer;transition:.12s}
.dev-btn-generate:hover{background:rgba(167,139,250,.2)}
.dev-firewall-bar{display:flex;align-items:center;gap:8px;padding:8px 14px;background:rgba(204,0,0,.06);border:1px solid rgba(204,0,0,.2);border-radius:8px;margin-top:12px;font-size:12px;color:var(--red);font-weight:500}
.dev-empty{padding:16px;text-align:center;color:var(--text3);font-size:13px}
/* Dev Auto-Repair */
.dar-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-top:16px}
.dar-hd{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg2)}
.dar-title{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em}
.dar-empty{padding:20px;text-align:center;color:var(--text3);font-size:13px}
.dar-err{border-bottom:1px solid var(--border);padding:12px 16px;display:flex;flex-direction:column;gap:6px}
.dar-err:last-child{border-bottom:none}
.dar-err-hd{display:flex;align-items:flex-start;gap:10px}
.dar-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;text-transform:uppercase;white-space:nowrap;flex-shrink:0}
.dar-badge.fatal,.dar-badge.parse{background:rgba(204,0,0,.12);color:var(--red)}
.dar-badge.warning{background:rgba(232,168,56,.12);color:var(--amber)}
.dar-badge.notice,.dar-badge.deprecated{background:rgba(91,141,239,.12);color:var(--blue)}
.dar-badge.cerberus{background:rgba(167,139,250,.12);color:var(--purple)}
.dar-msg{font-family:var(--mono);font-size:11px;color:var(--text2);flex:1;line-height:1.5;word-break:break-word}
.dar-meta{font-size:11px;color:var(--text3);display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.dar-file{font-family:var(--mono);font-size:10px;color:var(--blue);cursor:pointer;text-decoration:underline;text-decoration-color:rgba(91,141,239,.3)}
.dar-actions{display:flex;gap:6px;margin-top:4px}
.dar-repair-btn{font-size:11px;font-weight:700;padding:4px 12px;border-radius:6px;background:var(--red);color:#fff;border:none;cursor:pointer;transition:.12s}
.dar-repair-btn:hover{filter:brightness(1.2)}
.dar-repair-btn:disabled{opacity:.5;cursor:not-allowed}
.dar-suggestion{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 14px;margin-top:8px;display:none}
.dar-sug-pre{font-family:var(--mono);font-size:11px;line-height:1.6;color:var(--text2);white-space:pre-wrap;word-break:break-word;max-height:200px;overflow:auto}
.dar-sug-actions{display:flex;gap:8px;margin-top:10px;align-items:center}
.dar-sug-status{font-size:11px;color:var(--text3);flex:1}
/* Memória Activa */
.cx-mem-bar{display:flex;align-items:center;gap:8px;padding:6px 14px;background:rgba(167,139,250,.06);border-bottom:1px solid rgba(167,139,250,.15);font-size:11px;color:var(--purple);flex-shrink:0;flex-wrap:wrap}
.cx-mem-bar svg{flex-shrink:0;opacity:.7}
.cx-mem-sess{display:inline-flex;align-items:center;gap:5px;background:rgba(167,139,250,.1);border:1px solid rgba(167,139,250,.2);border-radius:10px;padding:2px 8px;cursor:pointer;transition:.12s;max-width:180px}
.cx-mem-sess:hover{background:rgba(167,139,250,.2)}
.cx-mem-sess-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:10px}
.cx-mem-clear{background:none;border:none;cursor:pointer;color:var(--purple);opacity:.6;padding:0;line-height:0;margin-left:auto}
.cx-mem-clear:hover{opacity:1}
/* Dev Runner */
.dev-run-wrap{display:flex;flex-direction:column;height:100%}
.dev-run-toolbar{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--bg2);flex-shrink:0;flex-wrap:wrap}
.dev-run-timeout{width:64px;background:var(--surface);border:1px solid var(--border2);border-radius:5px;color:var(--text);font-size:12px;font-family:var(--mono);padding:4px 7px;outline:none;text-align:center}
.dev-run-cols{display:grid;grid-template-columns:1fr 1fr;gap:0;flex:1;min-height:0;overflow:hidden}
.dev-run-col{display:flex;flex-direction:column;min-height:0;overflow:hidden}
.dev-run-col+.dev-run-col{border-left:1px solid var(--border)}
.dev-run-col-hd{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:var(--bg2);border-bottom:1px solid var(--border);font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;flex-shrink:0}
.dev-run-input{flex:1;padding:10px 14px;font-family:var(--mono);font-size:12px;line-height:1.6;color:var(--text);background:var(--bg);border:none;outline:none;resize:none;overflow:auto;tab-size:2;white-space:pre}
.dev-run-output{flex:1;padding:10px 14px;font-family:var(--mono);font-size:12px;line-height:1.6;color:var(--text2);background:var(--bg);overflow:auto;white-space:pre-wrap;word-break:break-all}
.dev-run-output.has-error{color:var(--red)}
.dev-run-output.empty{color:var(--text3);font-style:italic}
.dev-run-footer{display:flex;align-items:center;justify-content:space-between;padding:6px 14px;border-top:1px solid var(--border);background:var(--bg2);font-size:11px;color:var(--text3);flex-shrink:0}
.dev-run-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;text-transform:uppercase}
.dev-run-badge.ok{background:rgba(34,197,94,.12);color:#22c55e}
.dev-run-badge.err{background:rgba(239,68,68,.12);color:#ef4444}
.dev-run-badge.warn{background:rgba(232,168,56,.12);color:var(--amber)}
.dev-run-badge.run{background:rgba(91,141,239,.12);color:var(--blue)}
.dev-run-spinner{display:inline-block;width:10px;height:10px;border:2px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
/* Dev Editor */
.dev-ed-wrap{display:flex;flex-direction:column;height:100%;min-height:0}
.dev-ed-toolbar{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--bg2);flex-shrink:0;flex-wrap:wrap}
.dev-ed-file-sel{flex:1;min-width:180px;max-width:340px;background:var(--surface);border:1px solid var(--border2);border-radius:6px;color:var(--text);font-size:12px;font-family:var(--mono);padding:5px 8px;outline:none}
.dev-ed-btn{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:5px 12px;border-radius:6px;border:1px solid var(--border2);background:var(--surface);color:var(--text2);cursor:pointer;transition:.12s;white-space:nowrap}
.dev-ed-btn:hover{color:var(--text);border-color:var(--border)}
.dev-ed-btn.primary{background:var(--blue);color:#fff;border-color:var(--blue)}
.dev-ed-btn.primary:hover{filter:brightness(1.1)}
.dev-ed-btn.danger{background:rgba(204,0,0,.1);color:var(--red);border-color:rgba(204,0,0,.25)}
.dev-ed-btn:disabled{opacity:.45;cursor:not-allowed;filter:none}
.dev-ed-status{font-size:11px;color:var(--text3);flex:1;text-align:right;font-family:var(--mono)}
.dev-ed-status.ok{color:var(--green)}.dev-ed-status.err{color:var(--red)}
.dev-ed-body{flex:1;display:flex;min-height:0;overflow:hidden}
.dev-ed-lines{width:44px;background:var(--bg2);border-right:1px solid var(--border);padding:10px 0;text-align:right;font-family:var(--mono);font-size:12px;line-height:1.6;color:var(--text3);overflow:hidden;flex-shrink:0;user-select:none}
.dev-ed-lines span{display:block;padding-right:8px}
.dev-ed-lines span.changed{color:var(--amber);font-weight:700}
.dev-ed-code{flex:1;padding:10px 14px;font-family:var(--mono);font-size:12px;line-height:1.6;color:var(--text);background:var(--bg);border:none;outline:none;resize:none;overflow:auto;tab-size:2;white-space:pre}
.dev-ed-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;border-top:1px solid var(--border);background:var(--bg2);font-size:11px;color:var(--text3);flex-shrink:0}
.dev-ed-diff{background:var(--bg2);border-top:1px solid var(--border);max-height:160px;overflow:auto;flex-shrink:0}
.dev-ed-diff-hd{padding:6px 14px;font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border)}
.dev-ed-diff-line{display:block;font-family:var(--mono);font-size:11px;line-height:1.6;padding:0 14px;white-space:pre}
.dev-ed-diff-line.add{background:rgba(34,197,94,.08);color:#22c55e}
.dev-ed-diff-line.rem{background:rgba(239,68,68,.08);color:#ef4444}
.dev-ed-diff-line.ctx{color:var(--text3)}
.dev-ed-confirm-bar{display:flex;align-items:center;gap:10px;padding:8px 14px;background:rgba(34,197,94,.08);border-top:1px solid rgba(34,197,94,.25);font-size:12px;color:var(--green);flex-shrink:0}
.dev-ed-rollback-bar{display:flex;align-items:center;gap:10px;padding:8px 14px;background:rgba(232,168,56,.08);border-top:1px solid rgba(232,168,56,.25);font-size:12px;color:var(--amber);flex-shrink:0}

/* ── Admin tabs ─────────────────────────────────────────────────── */
.adm-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:20px}
.adm-tab{display:flex;align-items:center;gap:7px;padding:10px 20px;font-family:var(--font);font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--text3);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:.15s;position:relative}
.adm-tab:hover{color:var(--text2)}
.adm-tab.active{color:var(--text);border-bottom-color:var(--red)}
.adm-tab-badge{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--red);color:#fff;font-size:9px;font-weight:800;margin-left:2px}
.adm-tab-dot{width:7px;height:7px;border-radius:50%;background:var(--green);margin-left:2px}
.adm-panel{display:none;flex-direction:column;gap:16px}
.adm-panel.active{display:flex}
.adm-actions-bar{display:flex;align-items:center;gap:12px;padding:8px 0}
.srv-status-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:4px;font-size:12px;color:var(--text2)}
/* PATCH B2 v3.0.9 — Syntax highlighting custom */
.cb-row .hljs-keyword,.cb-row .hljs-built_in{color:#c678dd;font-weight:500}
.cb-row .hljs-string,.cb-row .hljs-attr{color:#98c379}
.cb-row .hljs-number,.cb-row .hljs-literal{color:#d19a66}
.cb-row .hljs-comment{color:#5c6370;font-style:italic}
.cb-row .hljs-function,.cb-row .hljs-title{color:#61afef}
.cb-row .hljs-variable,.cb-row .hljs-params{color:#e06c75}
.cb-row .hljs-tag,.cb-row .hljs-name{color:#e06c75}
.cb-row .hljs-attribute{color:#d19a66}
.cb-row .hljs-meta,.cb-row .hljs-doctag{color:#56b6c2}
.cb-row .hljs-type,.cb-row .hljs-class{color:#e5c07b}
[data-theme="light"] .cb-row .hljs-keyword,[data-theme="light"] .cb-row .hljs-built_in{color:#a626a4}
[data-theme="light"] .cb-row .hljs-string,[data-theme="light"] .cb-row .hljs-attr{color:#50a14f}
[data-theme="light"] .cb-row .hljs-number,[data-theme="light"] .cb-row .hljs-literal{color:#986801}
[data-theme="light"] .cb-row .hljs-comment{color:#a0a1a7}
[data-theme="light"] .cb-row .hljs-function,[data-theme="light"] .cb-row .hljs-title{color:#4078f2}
[data-theme="light"] .cb-row .hljs-variable,[data-theme="light"] .cb-row .hljs-params{color:#e45649}

/* ══ CENTRO HOSPITALAR ═══════════════════════════════════════════════ */
.health-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.health-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:16px}
@media(max-width:900px){.health-grid,.health-grid-3{grid-template-columns:1fr}}
.hc-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px 18px;position:relative;overflow:hidden}
.hc-card.ok{border-color:rgba(76,175,125,.3)}
.hc-card.warn{border-color:rgba(232,168,56,.3)}
.hc-card.err{border-color:rgba(204,0,0,.3)}
.hc-card-title{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.hc-card-title .hc-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.hc-dot.green{background:var(--green)}
.hc-dot.amber{background:var(--amber)}
.hc-dot.red{background:var(--red)}
.hc-dot.pulse{animation:tPulse 1.4s ease-in-out infinite}
/* ECG */
.hc-ecg-wrap{height:56px;position:relative;overflow:hidden;margin:4px 0 8px}
.hc-ecg-canvas{width:100%;height:100%;display:block}
.hc-ecg-flatline{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--red);font-weight:700;letter-spacing:.1em;display:none}
.hc-ecg-wrap.flatline .hc-ecg-flatline{display:flex}
.hc-ecg-wrap.flatline .hc-ecg-canvas{opacity:.2}
/* Métricas */
.hc-metric-row{display:flex;align-items:baseline;gap:6px;margin-bottom:4px}
.hc-metric-val{font-size:28px;font-weight:700;letter-spacing:-.03em;color:var(--text);line-height:1}
.hc-metric-unit{font-size:12px;color:var(--text3)}
.hc-metric-sub{font-size:11px;color:var(--text3);margin-top:2px}
.hc-metric-delta{font-size:11px;font-weight:600;padding:1px 6px;border-radius:8px}
.hc-metric-delta.up{background:rgba(76,175,125,.15);color:var(--green)}
.hc-metric-delta.down{background:rgba(204,0,0,.12);color:var(--red)}
.hc-metric-delta.neutral{background:var(--surface2);color:var(--text3)}
/* Tensor mini sphere */
#hc-tensor-canvas{width:100%;height:180px;display:block;border-radius:8px;background:var(--bg)}
/* Ficheiros RX */
.hc-file-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--border);font-size:12px}
.hc-file-row:last-child{border-bottom:none}
.hc-file-name{flex:1;color:var(--text2);font-family:var(--mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hc-file-size{color:var(--text3);font-size:11px;flex-shrink:0}
.hc-file-ok{width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;flex-shrink:0}
.hc-file-ok.ok{background:rgba(76,175,125,.15);color:var(--green)}
.hc-file-ok.err{background:rgba(204,0,0,.12);color:var(--red)}
/* DB table */
.hc-db-row{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:12px;border-bottom:1px solid var(--border)}
.hc-db-row:last-child{border-bottom:none}
.hc-db-name{font-family:var(--mono);color:var(--text2);flex:1}
.hc-db-count{font-weight:600;color:var(--text);font-size:13px;min-width:60px;text-align:right}
.hc-db-delta{font-size:10px;color:var(--green);min-width:40px;text-align:right}
/* Log */
.hc-log{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:10px 12px;font-family:var(--mono);font-size:11px;color:var(--text3);max-height:140px;overflow-y:auto;line-height:1.6}
.hc-log .hc-log-err{color:var(--red)}
.hc-log .hc-log-ok{color:var(--green)}
.hc-log .hc-log-warn{color:var(--amber)}
/* Ambulatório — botões de acção */
.hc-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.hc-action-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:7px;border:1px solid var(--border2);background:var(--surface2);color:var(--text2);font-size:12px;font-weight:600;cursor:pointer;transition:.12s}
.hc-action-btn:hover{background:var(--surface);color:var(--text)}
.hc-action-btn.danger{border-color:rgba(204,0,0,.3);color:var(--red)}
.hc-action-btn.danger:hover{background:rgba(204,0,0,.08)}
.hc-action-btn:disabled{opacity:.4;cursor:not-allowed}
/* Score geral */
.hc-score-wrap{display:flex;align-items:center;gap:14px;padding:10px 0}
.hc-score-circle{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;flex-shrink:0;border:3px solid var(--green)}
.hc-score-circle.warn{border-color:var(--amber);color:var(--amber)}
.hc-score-circle.err{border-color:var(--red);color:var(--red)}
.hc-score-label{font-size:13px;color:var(--text2);line-height:1.5}
.hc-score-label strong{display:block;font-size:15px;color:var(--text)}
/* Refresh timer */
.hc-refresh-bar{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text3);margin-bottom:16px}
.hc-refresh-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:tPulse 2s ease-in-out infinite}
/* Nav item saúde */
.sb-ni-health{color:var(--green)!important;opacity:.85}
.sb-ni-health:hover{background:rgba(76,175,125,.08)!important;color:var(--green)!important;opacity:1}


/* ══ CENTRO HOSPITALAR — DARK OVERRIDE ══════════════════════════════════ */
#page-health,
#page-health .page-hd,
#page-health .page-hd h1,
#page-health .page-hd p {
  background: #060810 !important;
  color: #c8d8f0 !important;
  font-family: 'DM Sans', var(--font), sans-serif !important;
}
#page-health { padding: 0 !important; }
#page-health .page-hd { display: none !important; } /* header substituído pelo ch-hd */

/* Cards */
#page-health .hc-card {
  background: #0c0f1a !important;
  border-color: #1e2a3a !important;
  border-radius: 0 !important;
}
#page-health .hc-card-title {
  font-family: 'Space Mono', monospace !important;
  color: #4a6080 !important;
  letter-spacing: .12em !important;
}
#page-health .hc-dot.green { background: #00d4aa !important; }
#page-health .hc-dot.amber { background: #f0a030 !important; }
#page-health .hc-dot.red   { background: #f04060 !important; }

/* Grid */
#page-health .health-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 1px !important;
  background: #1e2a3a !important;
  margin-bottom: 1px !important;
  border-radius: 0 !important;
}

/* Score */
#page-health .hc-score-circle {
  background: transparent !important;
  border: 3px solid #00d4aa !important;
  color: #00d4aa !important;
  font-family: 'Space Mono', monospace !important;
  font-size: 14px !important;
  width: 64px !important; height: 64px !important;
}
#page-health .hc-score-circle.warn { border-color: #f0a030 !important; color: #f0a030 !important; }
#page-health .hc-score-circle.err  { border-color: #f04060 !important; color: #f04060 !important; }
#page-health .hc-score-label strong { color: #c8d8f0 !important; font-size: 14px !important; }
#page-health .hc-score-label span   { color: #4a6080 !important; }

/* Badges */
#page-health #hc-badges { display: flex !important; flex-wrap: wrap !important; gap: 5px !important; }
#page-health .ch-badge {
  padding: 3px 8px !important;
  border-radius: 3px !important;
  font-family: 'Space Mono', monospace !important;
  font-size: 10px !important;
  border: 1px solid !important;
}
#page-health .ch-badge.ok   { border-color: #00d4aa !important; color: #00d4aa !important; background: rgba(0,212,170,.06) !important; }
#page-health .ch-badge.warn { border-color: #f0a030 !important; color: #f0a030 !important; background: rgba(240,160,48,.06) !important; }
#page-health .ch-badge.err  { border-color: #f04060 !important; color: #f04060 !important; background: rgba(240,64,96,.06) !important; }

/* Tensor Canvas */
#hc-tensor-canvas {
  width: 100% !important;
  height: 200px !important;
  display: block !important;
  background: #000 !important;
  border-radius: 4px !important;
}

/* Memória */
#page-health .hc-metric-val {
  color: #c8d8f0 !important;
  font-family: 'Space Mono', monospace !important;
  font-size: 30px !important;
}
#page-health #hc-autonomy { color: #00d4aa !important; }
#page-health #hc-mem-24h  { color: #00d4aa !important; }
#page-health .hc-metric-sub { color: #4a6080 !important; }
#page-health #hc-last-episode {
  background: #111827 !important;
  border-left: 2px solid #00c8ff !important;
  border-radius: 4px !important;
  padding: 10px 12px !important;
  font-family: 'Space Mono', monospace !important;
  font-size: 11px !important;
  color: #4a6080 !important;
}

/* DB */
#page-health .ch-dbr  { display: flex !important; align-items: center !important; padding: 6px 0 !important; border-bottom: 1px solid #111827 !important; gap: 8px !important; }
#page-health .ch-dbn  { flex: 1 !important; font-size: 11px !important; color: #4a6080 !important; }
#page-health .ch-dbc  { font-family: 'Space Mono', monospace !important; font-size: 12px !important; color: #c8d8f0 !important; min-width: 40px !important; text-align: right !important; }
#page-health .ch-dbd  { font-family: 'Space Mono', monospace !important; font-size: 10px !important; color: #00d4aa !important; min-width: 55px !important; text-align: right !important; }

/* RX */
#page-health .ch-rxr  { display: flex !important; align-items: center !important; padding: 5px 0 !important; border-bottom: 1px solid #111827 !important; gap: 8px !important; }
#page-health .ch-rxok { font-size: 11px !important; color: #00d4aa !important; min-width: 14px !important; }
#page-health .ch-rxok.err { color: #f04060 !important; }
#page-health .ch-rxn  { flex: 1 !important; font-size: 11px !important; color: #4a6080 !important; }
#page-health .ch-rxs  { font-family: 'Space Mono', monospace !important; font-size: 10px !important; color: #1e2a3a !important; }

/* Camadas */
#page-health .ch-row1 { display: grid !important; grid-template-columns: 1fr !important; gap: 1px !important; background: #1e2a3a !important; margin-bottom: 1px !important; }
#page-health .ch-layers { display: grid !important; grid-template-columns: repeat(5,1fr) !important; gap: 8px !important; }
#page-health .ch-layer { padding: 10px 12px !important; background: #111827 !important; border-radius: 4px !important; border: 1px solid #1e2a3a !important; border-bottom: 2px solid #00d4aa !important; }
#page-health .ch-layer.dim { opacity: .4 !important; border-bottom-color: #1e2a3a !important; }
#page-health .ch-lc { font-family: 'Space Mono', monospace !important; font-size: 10px !important; color: #00c8ff !important; text-transform: uppercase !important; letter-spacing: .08em !important; }
#page-health .ch-lr { font-size: 10px !important; color: #4a6080 !important; margin-top: 2px !important; }
#page-health .ch-ls { font-family: 'Space Mono', monospace !important; font-size: 11px !important; color: #c8d8f0 !important; margin-top: 6px !important; }

/* Domínios */
#page-health .ch-row  { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 1px !important; background: #1e2a3a !important; margin-bottom: 1px !important; }
#page-health .ch-cell { background: #0c0f1a !important; padding: 18px 20px !important; }
#page-health .ch-ttl  { font-family: 'Space Mono', monospace !important; font-size: 10px !important; letter-spacing: .12em !important; color: #4a6080 !important; text-transform: uppercase !important; margin-bottom: 14px !important; display: flex !important; align-items: center !important; gap: 7px !important; }
#page-health .ch-ttl::before { content: '' !important; width: 4px !important; height: 4px !important; border-radius: 50% !important; background: #00c8ff !important; flex-shrink: 0 !important; }
#page-health .ch-domr { display: flex !important; align-items: center !important; gap: 8px !important; margin-bottom: 6px !important; }
#page-health .ch-domn { font-family: 'Space Mono', monospace !important; font-size: 10px !important; color: #4a6080 !important; min-width: 90px !important; text-align: right !important; }
#page-health .ch-domt { flex: 1 !important; height: 4px !important; background: #1e2a3a !important; border-radius: 2px !important; overflow: hidden !important; }
#page-health .ch-domf { height: 100% !important; border-radius: 2px !important; transition: width .6s !important; }
#page-health .ch-domc { font-family: 'Space Mono', monospace !important; font-size: 10px !important; color: #4a6080 !important; min-width: 28px !important; text-align: right !important; }

/* Providers */
#page-health .ch-pr   { display: flex !important; align-items: center !important; gap: 8px !important; padding: 6px 0 !important; border-bottom: 1px solid #111827 !important; }
#page-health .ch-prd  { width: 7px !important; height: 7px !important; border-radius: 50% !important; background: #4a6080 !important; flex-shrink: 0 !important; }
#page-health .ch-prd.on { background: #00d4aa !important; }
#page-health .ch-prn  { flex: 1 !important; font-size: 12px !important; color: #c8d8f0 !important; }
#page-health .ch-prm  { font-family: 'Space Mono', monospace !important; font-size: 10px !important; padding: 2px 6px !important; border: 1px solid #1e2a3a !important; border-radius: 3px !important; color: #4a6080 !important; }
#page-health .ch-prm.pulse { color: #3080ff !important; border-color: rgba(48,128,255,.3) !important; }
#page-health .ch-prm.forge { color: #00d4aa !important; border-color: rgba(0,212,170,.3) !important; }
#page-health .ch-prm.apex  { color: #f0a030 !important; border-color: rgba(240,160,48,.3) !important; }
#page-health .ch-prc  { font-family: 'Space Mono', monospace !important; font-size: 10px !important; color: #4a6080 !important; }

/* Log */
#page-health .ch-log  { font-family: 'Space Mono', monospace !important; font-size: 11px !important; background: #060810 !important; border: 1px solid #1e2a3a !important; border-radius: 4px !important; padding: 10px !important; max-height: 140px !important; overflow-y: auto !important; color: #4a6080 !important; }
#page-health .ch-lok  { color: #00d4aa !important; }
#page-health .ch-lerr { color: #f04060 !important; }
#page-health .ch-lwrn { color: #f0a030 !important; }

/* Acções */
#page-health .ch-acts { display: flex !important; flex-wrap: wrap !important; gap: 8px !important; }
#page-health .ch-act  { display: flex !important; align-items: center !important; gap: 6px !important; padding: 7px 12px !important; background: #111827 !important; border: 1px solid #1e2a3a !important; border-radius: 4px !important; color: #c8d8f0 !important; font-size: 11px !important; cursor: pointer !important; }
#page-health .ch-act:hover { background: #1e2a3a !important; }
#page-health .ch-act.danger { border-color: rgba(240,64,96,.3) !important; color: #f04060 !important; }
#page-health .ch-act.danger:hover { background: rgba(240,64,96,.1) !important; }

/* Header CH */
#page-health .ch-hd { display: flex !important; align-items: center !important; padding: 14px 24px !important; background: #0c0f1a !important; border-bottom: 1px solid #1e2a3a !important; gap: 16px !important; }
#page-health .ch-hd-title { font-family: 'Space Mono', monospace !important; font-size: 11px !important; color: #00c8ff !important; letter-spacing: .1em !important; text-transform: uppercase !important; }
#page-health .ch-hd-sub   { font-size: 11px !important; color: #4a6080 !important; }
#page-health .ch-hd-right { display: flex !important; align-items: center !important; gap: 8px !important; margin-left: auto !important; }
#page-health .ch-hd-time  { font-family: 'Space Mono', monospace !important; font-size: 11px !important; color: #4a6080 !important; }
#page-health .ch-hd-btn   { display: flex !important; align-items: center !important; gap: 5px !important; padding: 5px 12px !important; background: #111827 !important; border: 1px solid #1e2a3a !important; color: #c8d8f0 !important; font-size: 11px !important; border-radius: 4px !important; cursor: pointer !important; }
#page-health .ch-hd-btn:hover { background: #1e2a3a !important; }
#page-health .ch-pulse { width: 6px !important; height: 6px !important; border-radius: 50% !important; background: #00d4aa !important; animation: chPulse 2s ease-in-out infinite !important; }
@keyframes chPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.8)} }
