/* ===== VARIABLES ===== */
:root{--brand-500:#6366f1;--brand-400:#818cf8;--brand-600:#4f46e5;--brand-700:#4338ca;--success:#10b981;--success-bg:rgba(16,185,129,0.12);--warning:#f59e0b;--warning-bg:rgba(245,158,11,0.12);--error:#ef4444;--error-bg:rgba(239,68,68,0.12);--font-h:'Space Grotesk','Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;--font-b:'DM Sans','Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;--font-m:'JetBrains Mono','SF Mono','Menlo','Consolas',monospace}
[data-theme="dark"]{--bg-app:#16161f;--bg-page:#1a1a26;--bg-card:#202032;--bg-card2:#26263a;--bg-el:#2a2a42;--bg-hover:rgba(255,255,255,0.06);--bg-active:rgba(99,102,241,0.14);--bg-glass:rgba(26,26,40,0.82);--bg-sidebar:rgba(16,16,26,0.92);--bg-inp:#1a1a26;--text-pri:#ededf5;--text-sec:#a8a8c0;--text-ter:#6e6e88;--text-dis:#44445a;--border-def:#2d2d48;--border-str:#383858;--border-brand:rgba(99,102,241,0.4);--sh-xs:0 1px 2px rgba(0,0,0,0.3);--sh-sm:0 2px 4px rgba(0,0,0,0.35);--sh-md:0 4px 16px rgba(0,0,0,0.4);--sh-lg:0 8px 32px rgba(0,0,0,0.5);--sh-xl:0 16px 48px rgba(0,0,0,0.55);--glow-brand:0 0 20px rgba(99,102,241,0.15);--sk-from:rgba(255,255,255,0.05);--sk-to:rgba(255,255,255,0.1);--accent-cyan:#00d4ff;--accent-cyan-bg:rgba(0,212,255,0.08);--accent-cyan-border:rgba(0,212,255,0.25);--accent-magenta:#ff0088;--accent-magenta-bg:rgba(255,0,136,0.08);--accent-teal:#00ff88;--accent-teal-bg:rgba(0,255,136,0.08)}
[data-theme="light"]{--bg-app:#f5f5f8;--bg-page:#fafafc;--bg-card:#fff;--bg-card2:#f5f5fa;--bg-el:#eeeef4;--bg-hover:rgba(0,0,0,0.04);--bg-active:rgba(99,102,241,0.08);--bg-glass:rgba(255,255,255,0.7);--bg-sidebar:rgba(255,255,255,0.85);--bg-inp:#fafafc;--text-pri:#0f0f1a;--text-sec:#3d3d54;--text-ter:#6a6a80;--text-dis:#c5c5d4;--border-def:#e2e2ee;--border-str:#d0d0e0;--border-brand:rgba(99,102,241,0.25);--sh-xs:0 1px 2px rgba(0,0,0,0.04);--sh-sm:0 2px 4px rgba(0,0,0,0.05);--sh-md:0 4px 16px rgba(0,0,0,0.08);--sh-lg:0 8px 32px rgba(0,0,0,0.1);--sh-xl:0 16px 48px rgba(0,0,0,0.12);--glow-brand:0 0 16px rgba(99,102,241,0.1);--sk-from:rgba(0,0,0,0.04);--sk-to:rgba(0,0,0,0.08);--accent-cyan:var(--brand-400);--accent-cyan-bg:rgba(99,102,241,0.08);--accent-cyan-border:rgba(99,102,241,0.2);--accent-magenta:#ec4899;--accent-magenta-bg:rgba(236,72,153,0.08);--accent-teal:#10b981;--accent-teal-bg:rgba(16,185,129,0.08)}

/* ===== BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{height:100%}
body{font-family:var(--font-b);background:var(--bg-app);color:var(--text-pri);line-height:1.6;height:100%;-webkit-font-smoothing:antialiased;overflow:hidden}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-thumb{background:var(--border-str);border-radius:3px}
a{color:inherit;text-decoration:none}

/* ===== APP SHELL ===== */
.app{display:flex;height:100dvh;overflow:hidden}
.sidebar{width:240px;flex-shrink:0;background:var(--bg-sidebar);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-right:1px solid var(--border-def);display:flex;flex-direction:column;padding:1rem 0.625rem;gap:0.125rem;overflow-y:auto;overscroll-behavior:contain}
.sd-logo{font-family:var(--font-h);font-size:1.375rem;font-weight:700;padding:0.25rem 0.75rem 1rem;background:linear-gradient(135deg,#818cf8,#6366f1,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-0.03em}
.sd-label{font-size:0.625rem;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--text-ter);padding:0.75rem 0.75rem 0.25rem}
.sd-item{display:flex;align-items:center;gap:0.5rem;padding:0.5rem 0.75rem;border-radius:8px;font-size:0.8125rem;font-weight:450;color:var(--text-sec);cursor:pointer;touch-action:manipulation;transition:all 0.12s;border:none;background:none;width:100%;text-align:left;font-family:inherit}
.sd-item:hover{background:var(--bg-hover);color:var(--text-pri)}
.sd-item.active{background:rgba(99,102,241,0.18);color:var(--brand-400);font-weight:500;border-left:2px solid var(--brand-400)}
.sd-item svg{width:16px;height:16px;flex-shrink:0;opacity:0.6}
.sd-item.active svg{opacity:1}
.sd-spacer{flex:1}
.sd-footer{padding:0.25rem 0.75rem;font-size:0.6875rem;color:var(--text-ter);display:flex;align-items:center;gap:0.5rem}
.sd-footer-dot{width:6px;height:6px;border-radius:50%;background:var(--text-dis);flex-shrink:0}
.sd-footer-dot.ok{background:var(--success);box-shadow:0 0 6px rgba(16,185,129,0.5)}
.sd-footer-dot.err{background:var(--error);box-shadow:0 0 6px rgba(239,68,68,0.5)}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.header{display:flex;align-items:center;justify-content:space-between;padding:0.5rem 1.5rem;gap:1rem;border-bottom:1px solid var(--border-def);background:var(--bg-glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);flex-shrink:0;min-height:48px}
.hl{display:flex;align-items:center;gap:0.75rem;flex:1}
.hr{display:flex;align-items:center;gap:0.5rem;flex-shrink:0}
.search{display:flex;align-items:center;gap:0.5rem;background:var(--bg-card);border:1px solid var(--border-def);border-radius:8px;padding:0.375rem 0.75rem;width:240px;transition:all 0.2s}
.search:focus-within{border-color:var(--brand-400);box-shadow:var(--glow-brand);width:280px}
.search svg{width:14px;height:14px;color:var(--text-ter);flex-shrink:0}
.search input{border:none;background:none;outline:none;color:var(--text-pri);font-size:0.8125rem;font-family:inherit;width:100%}
.search input::placeholder{color:var(--text-ter)}
.search-kbd{font-size:0.625rem;font-family:var(--font-m);color:var(--text-ter);background:var(--bg-hover);padding:0.125rem 0.375rem;border-radius:4px;border:1px solid var(--border-def);flex-shrink:0}
.hbtn{width:34px;height:34px;border-radius:8px;border:1px solid var(--border-def);background:var(--bg-card);color:var(--text-sec);cursor:pointer;touch-action:manipulation;display:flex;align-items:center;justify-content:center;transition:all 0.12s}
.hbtn:hover{border-color:var(--border-str);color:var(--text-pri);background:var(--bg-hover)}
.hbtn svg{width:16px;height:16px}
.avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--brand-500),var(--brand-700));color:#fff;display:flex;align-items:center;justify-content:center;font-size:0.75rem;font-weight:600;cursor:pointer;touch-action:manipulation;position:relative;flex-shrink:0}
.avatar-dot{width:8px;height:8px;border-radius:50%;background:var(--success);border:2px solid var(--bg-card);position:absolute;bottom:-2px;right:-2px;animation:pdot 2s ease-in-out infinite}
@keyframes pdot{0%,100%{box-shadow:0 0 0 0 rgba(16,185,129,0.4)}50%{box-shadow:0 0 0 4px rgba(16,185,129,0)}}
.content{flex:1;overflow-y:auto;padding:1.5rem}

/* ===== ANIMATIONS ===== */
@keyframes fUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes mIn{from{opacity:0;transform:scale(0.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}
@keyframes tIn{from{opacity:0;transform:translateX(1.5rem) scale(0.95)}to{opacity:1;transform:translateX(0) scale(1)}}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ===== COMPONENTS ===== */
.ph{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;gap:1rem}
.ph h1{font-family:var(--font-h);font-size:1.5rem;font-weight:600;letter-spacing:-0.02em;line-height:1.3}
.ph p{font-size:0.8125rem;color:var(--text-ter);margin-top:0.25rem}
.pha{display:flex;gap:0.5rem;flex-shrink:0}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0.75rem;margin-bottom:1.5rem}
.stat{background:var(--bg-card);border:1px solid var(--border-def);border-radius:12px;padding:1rem 1.25rem;transition:all 0.2s}
.stat:hover{border-color:var(--border-str);box-shadow:var(--sh-md);transform:translateY(-1px)}
.stat-ico{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:0.5rem}
.stat-ico svg{width:16px;height:16px}
.stat-lbl{font-size:0.6875rem;font-weight:500;color:var(--text-ter);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:0.25rem}
.stat-val{font-family:var(--font-h);font-size:1.5rem;font-weight:600;line-height:1.2}
.ntw{display:flex;align-items:center;gap:0.125rem;background:var(--bg-el);border-radius:10px;padding:0.25rem;margin-bottom:1.5rem}
.nt{display:inline-flex;align-items:center;gap:0.5rem;padding:0.5rem 1rem;border-radius:8px;font-size:0.8125rem;font-weight:500;color:var(--text-ter);border:none;background:transparent;cursor:pointer;transition:all 0.12s;font-family:inherit;white-space:nowrap}
.nt:hover{color:var(--text-pri);background:var(--bg-hover)}
.nt.active{color:var(--text-pri);background:var(--bg-card);box-shadow:var(--sh-xs)}
.nt svg{width:15px;height:15px}
.sc{background:var(--bg-card);border:1px solid var(--border-def);border-radius:12px;padding:1.25rem;transition:all 0.2s}
.sc:hover{border-color:var(--border-str)}
.sc--int{cursor:pointer}
.sc--int:hover{border-color:var(--brand-400);box-shadow:var(--glow-brand),var(--sh-md);transform:translateY(-2px)}
.sc--acc{position:relative;overflow:hidden}
.sc--acc::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--brand-500),#a5b4fc);border-radius:2px 2px 0 0}
.btn{display:inline-flex;align-items:center;gap:0.5rem;padding:0.5rem 1rem;border-radius:8px;font-size:0.8125rem;font-weight:500;font-family:inherit;border:1px solid transparent;cursor:pointer;touch-action:manipulation;transition:all 0.12s;white-space:nowrap}
.btn svg{width:15px;height:15px}
.btn-pr{background:var(--brand-600);color:#fff;border-color:var(--brand-600)}
.btn-pr:hover{background:var(--brand-700);box-shadow:0 0 16px rgba(99,102,241,0.3)}
.btn-sc{background:transparent;color:var(--text-pri);border-color:var(--border-str)}
.btn-sc:hover{background:var(--bg-hover);border-color:var(--text-ter)}
.btn-gh{background:transparent;color:var(--text-sec);border-color:transparent}
.btn-gh:hover{background:var(--bg-hover);color:var(--text-pri)}
.btn-sm{padding:0.375rem 0.75rem;font-size:0.75rem}.btn-sm svg{width:13px;height:13px}
.badge{display:inline-flex;align-items:center;gap:0.25rem;padding:0.125rem 0.5rem;border-radius:6px;font-size:0.6875rem;font-weight:500;border:1px solid}
.badge-b{background:var(--bg-active);border-color:rgba(99,102,241,0.2);color:var(--brand-400)}
.badge-s{background:var(--success-bg);border-color:rgba(16,185,129,0.2);color:var(--success)}
.badge-w{background:var(--warning-bg);border-color:rgba(245,158,11,0.2);color:var(--warning)}
.badge-e{background:var(--error-bg);border-color:rgba(239,68,68,0.2);color:var(--error)}
.badge-n{background:var(--bg-el);border-color:var(--border-def);color:var(--text-ter)}
.fi{width:100%;padding:0.5rem 0.75rem;border-radius:8px;border:1px solid var(--border-def);background:var(--bg-inp);color:var(--text-pri);font-size:0.8125rem;font-family:inherit;transition:all 0.15s;outline:none}
.fi::placeholder{color:var(--text-ter)}
.fi:focus{border-color:var(--brand-400);box-shadow:var(--glow-brand)}
.sel{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 16 16'%3E%3Cpath fill='%236e6e88' d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 0.625rem center;padding-right:2rem}
.toggle{display:inline-flex;align-items:center;gap:0.5rem;cursor:pointer;font-size:0.8125rem;color:var(--text-sec)}
.toggle input{display:none}
.toggle-tr{width:36px;height:20px;background:var(--border-str);border-radius:10px;position:relative;transition:all 0.2s;flex-shrink:0}
.toggle input:checked+.toggle-tr{background:var(--brand-500)}
.toggle-th{width:16px;height:16px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:left 0.2s cubic-bezier(0.34,1.56,0.64,1)}
.toggle input:checked+.toggle-tr .toggle-th{left:18px}
.tw{background:var(--bg-card);border:1px solid var(--border-def);border-radius:12px;overflow:hidden}
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:0.6875rem;font-weight:600;color:var(--text-ter);text-transform:uppercase;letter-spacing:0.06em;padding:0.75rem 1rem;border-bottom:1px solid var(--border-def);background:var(--bg-hover)}
td{padding:0.75rem 1rem;font-size:0.8125rem;border-bottom:1px solid var(--border-def)}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--bg-hover)}
.pvd{background:var(--bg-card);border:1px solid var(--border-def);border-radius:12px;overflow:hidden;transition:all 0.2s}
.pvd:hover{border-color:var(--border-str);box-shadow:var(--sh-md)}
.pvd-hd{display:flex;align-items:center;justify-content:space-between;padding:0.875rem 1.25rem;gap:0.75rem;border-bottom:1px solid var(--border-def)}
.pvd-info{display:flex;align-items:center;gap:0.75rem;min-width:0}
.pvd-ico{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}
.pvd-ico svg{width:18px;height:18px}
.pvd-name{font-size:0.875rem;font-weight:600}
.pvd-bd{display:flex;align-items:center;justify-content:space-between;padding:0.75rem 1.25rem;gap:0.75rem}
.pvd-meta{font-size:0.75rem;color:var(--text-sec);display:flex;flex-direction:column;gap:0.125rem}
.pvd-meta strong{color:var(--text-pri);font-weight:500;font-size:0.8125rem}
.sdot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.sdot.ok{background:var(--success);box-shadow:0 0 6px rgba(16,185,129,0.5)}
.sdot.err{background:var(--error);box-shadow:0 0 6px rgba(239,68,68,0.5)}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:0.75rem}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:0.75rem}
.shd{display:flex;align-items:center;justify-content:space-between;margin-bottom:0.75rem}
.stl{font-family:var(--font-h);font-size:0.9375rem;font-weight:600}
.sac{font-size:0.75rem;color:var(--brand-400);cursor:pointer;background:none;border:none;font-family:inherit;padding:0.25rem 0.5rem;border-radius:6px;transition:all 0.12s;display:flex;align-items:center;gap:0.375rem}
.sac:hover{background:var(--bg-active)}
.skel{background:linear-gradient(90deg,var(--sk-from) 25%,var(--sk-to) 50%,var(--sk-from) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:6px}
.sk-l{height:10px;margin-bottom:6px;width:100%}
.sk-block{height:60px;width:100%}
.emp{display:flex;flex-direction:column;align-items:center;padding:2.5rem 2rem;text-align:center}
.emp-ill{width:80px;height:80px;border-radius:50%;background:var(--bg-el);border:1px solid var(--border-def);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:var(--text-ter)}
.emp-ill svg{width:36px;height:36px}
.emp h3{font-family:var(--font-h);font-size:0.9375rem;font-weight:600;margin-bottom:0.25rem}
.emp p{font-size:0.8125rem;color:var(--text-ter);max-width:300px;margin-bottom:1rem}.mov{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1000;align-items:center;justify-content:center}
.mov.show{display:flex}
.mod{background:var(--bg-card);border:1px solid var(--border-str);border-radius:16px;padding:1.5rem;min-width:420px;max-width:90vw;max-height:85dvh;overflow-y:auto;overscroll-behavior:contain;box-shadow:var(--sh-xl);animation:mIn 0.2s ease-out}
.mod-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}
.mod-tl{font-family:var(--font-h);font-size:1.0625rem;font-weight:600}
.mod-cl{background:none;border:none;color:var(--text-ter);cursor:pointer;padding:0.25rem;border-radius:6px;transition:all 0.12s}
.mod-cl:hover{background:var(--bg-hover);color:var(--text-pri)}
.mod-ft{display:flex;gap:0.5rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-def)}
.msg{display:flex;gap:0.75rem;margin-bottom:1rem;animation:fUp 0.3s ease-out}
.msg-av{width:32px;height:32px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:0.6875rem;font-weight:600;color:#fff}
.msg-bd{flex:1;min-width:0}
.msg-meta{display:flex;align-items:center;gap:0.5rem;margin-bottom:0.25rem}
.msg-author{font-size:0.75rem;font-weight:600}
.msg-time{font-size:0.625rem;color:var(--text-ter)}
.msg-bub{background:var(--bg-card);border:1px solid var(--border-def);border-radius:12px;padding:0.75rem 1rem;font-size:0.8125rem;line-height:1.6}
.msg--usr .msg-bub{background:var(--bg-active);border-color:var(--border-brand)}
.msg-bub code{font-family:var(--font-m);font-size:0.75rem;background:var(--bg-el);padding:0.125rem 0.375rem;border-radius:4px}
.chat-inp{position:sticky;bottom:0;background:var(--bg-glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--border-def);padding:0.75rem 1.5rem}
.chat-row{display:flex;gap:0.5rem;max-width:800px;margin:0 auto}
.chat-row .fi{border-radius:10px;padding:0.625rem 1rem;font-size:0.875rem}
.pg-pick{display:flex;gap:0.25rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border-def);padding-bottom:0.75rem}
.pg-p{display:flex;align-items:center;gap:0.375rem;padding:0.375rem 0.75rem;border-radius:8px;font-size:0.75rem;font-weight:500;color:var(--text-ter);cursor:pointer;border:none;background:none;font-family:inherit;transition:all 0.12s}
.pg-p:hover{color:var(--text-pri);background:var(--bg-hover)}
.pg-p.active{color:var(--brand-400);background:var(--bg-active)}
.pg-p svg{width:14px;height:14px}
.tc{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:0.5rem;z-index:2000;pointer-events:none}
.toast{display:flex;align-items:center;gap:0.625rem;padding:0.75rem 1rem;border-radius:10px;background:var(--bg-card);border:1px solid var(--border-def);box-shadow:var(--sh-lg);font-size:0.8125rem;pointer-events:auto;animation:tIn 0.25s ease-out}
.toast--s{border-left:3px solid var(--success)}.toast--s svg{color:var(--success)}
.toast--e{border-left:3px solid var(--error)}.toast--e svg{color:var(--error)}
.toast svg{width:16px;height:16px;flex-shrink:0}
.dv{border:none;border-top:1px solid var(--border-def);margin:2rem 0}
.tbtn{position:fixed;top:1rem;right:1rem;z-index:100;width:36px;height:36px;border-radius:10px;background:var(--bg-card);border:1px solid var(--border-def);cursor:pointer;color:var(--text-pri);box-shadow:var(--sh-md);display:flex;align-items:center;justify-content:center;transition:all 0.12s}
.tbtn:hover{border-color:var(--brand-400);box-shadow:var(--glow-brand)}.tbtn svg{width:18px;height:18px}

/* ===== AGGRESSIVE PAGE OVERRIDES ===== */
/* Force all page containers, cards, panels to use design system colors */
[class*="container"],[class*="panel"],[class*="card"],[class*="section"],[class*="pane"],
[class*="sidebar"],[class*="toolbar"],[class*="editor"],[class*="viewer"],[class*="wrapper"],
[class*="content"],[class*="body"],[class*="header"],[class*="footer"],[class*="tab"],
[class*="modal"],[class*="dialog"],[class*="overlay"],[class*="dropdown"],[class*="menu"] {
    color:var(--text-pri)!important
}
/* Override dark backgrounds on legacy elements */
[class*="graph"],[class*="knowledge"],[class*="settings"],[class*="editor"],
[class*="chat"],[class*="ingest"],[class*="watcher"],[class*="project"],[class*="admin"],
[class*="schema"],[class*="template"],[class*="budget"],[class*="status"],[class*="model"],
[class*="analytics"],[class*="dashboard"],[class*="profile"],[class*="config"] {
    background:transparent!important
}
/* Card-like surfaces get proper background */
.card,.surface-card,.project-card,.provider-card,.agent-card,.credential-card,
.watcher-card,.type-pick-card,.template-card,.model-card,.schema-card,.status-card,
.budget-card,.analytics-card,.config-section,.settings-panel,.config-panel,
.results-panel,.summary-card,.source-card,.graph-controls,.graph-canvas,
.edit-pane,.preview-pane,.knowledge-sidebar,.knowledge-toolbar,.file-tree,
.query-panel,.pipeline-step,.models-container,.admin-panel {
    background:var(--bg-card)!important;
    border:1px solid var(--border-def)!important;
    border-radius:12px!important
}
/* Code/monospace blocks */
code,pre,.code-block,.monospace,.terminal,.log-viewer,.json-viewer,.yaml-viewer {
    background:var(--bg-el)!important;color:var(--text-sec)!important;
    border:1px solid var(--border-def)!important;border-radius:8px!important;
    font-family:var(--font-m)!important
}
/* Inputs */
input:not([type="checkbox"]):not([type="radio"]):not([type="range"]),
textarea,select,.search-input,.text-input,.form-input {
    background:var(--bg-inp)!important;border:1px solid var(--border-def)!important;
    color:var(--text-pri)!important;border-radius:8px!important
}
input:focus,textarea:focus,select:focus,.search-input:focus,.form-input:focus {
    border-color:var(--brand-400)!important;box-shadow:var(--glow-brand)!important;outline:none!important
}
/* Tab/nav bars */
.tabs,.nav-tabs,.tab-bar,.tab-nav,.settings-nav,.gs-nav,.config-tabs,
.nav-pills,.segmented-control,.tab-container {
    background:var(--bg-el)!important;border-radius:10px!important;padding:0.25rem!important
}
.tab,.nav-tab,.tab-item,.pill,.segmented-item,.config-tab {
    border-radius:8px!important;color:var(--text-ter)!important;
    font-size:0.8125rem!important;font-weight:500!important;padding:0.5rem 1rem!important;
    background:transparent!important;border:none!important
}
.tab.active,.tab:hover,.nav-tab.active,.nav-tab:hover,.pill.active,.config-tab.active {
    background:var(--bg-card)!important;color:var(--text-pri)!important
}
/* Headings */
h1,h2,h3,h4,.page-title,.section-title,.panel-title,.card-title {
    font-family:var(--font-h)!important;color:var(--text-pri)!important
}
h1{font-size:1.5rem!important;font-weight:600!important;letter-spacing:-0.02em!important}
h2{font-size:1.125rem!important;font-weight:600!important}
h3{font-size:0.9375rem!important;font-weight:600!important}
/* Buttons */
button:not(.nav-tab):not(.tab):not(.sd-item):not(.pg-p):not(.hbtn):not(.theme-toggle),
.btn:not(.nav-tab):not(.tab) {
    border-radius:8px!important;font-weight:500!important;transition:all 0.12s!important;
    cursor:pointer!important;font-family:inherit!important
}
/* SVG icons */
svg:not([width]):not([height]){width:16px!important;height:16px!important}
/* Tables */
table{border-collapse:collapse!important}
th{color:var(--text-ter)!important;font-size:0.6875rem!important;text-transform:uppercase!important;
  letter-spacing:0.06em!important;font-weight:600!important;
  background:var(--bg-hover)!important;padding:0.75rem 1rem!important}
td{color:var(--text-sec)!important;font-size:0.8125rem!important;padding:0.75rem 1rem!important;
  border-bottom:1px solid var(--border-def)!important}
tr:hover td{background:var(--bg-hover)!important}
/* Links */
a:not(.btn):not(.sd-item):not(.admin-menu-item):not(.user-dropdown-item):not(.pg-p) {
    color:var(--brand-400)!important
}
/* Footer */
.footer,.page-footer{color:var(--text-ter)!important;font-size:0.75rem!important}
/* Sidebar page-specific */
.config-section,.settings-tab-content,.provider-section,.agent-section,
.credential-section,.budget-section,.project-section,.watcher-section,
.ingest-section,.graph-section,.knowledge-section,.analytics-section,
.admin-section,.status-section {
    background:transparent!important
}
/* Landing page hero */
.landing-hero,.landing-container,.hero-section{background:transparent!important}
/* Feature cards get proper card style */
.feature-card,.value-card,.product-card{background:var(--bg-card)!important;
  border:1px solid var(--border-def)!important;border-radius:12px!important}

/* ===== HAMBURGER + MOBILE NAV ===== */
.hamburger{display:none}
.hamburger-icon{font-size:1.25rem;line-height:1}
.mobile-nav{position:fixed;top:0;left:-280px;width:280px;max-width:85vw;height:100dvh;background:var(--bg-sidebar);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-right:1px solid var(--border-def);z-index:1002;padding:1rem 0.625rem;overflow-y:auto;overscroll-behavior:contain;transition:left 0.25s cubic-bezier(0.4,0,0.2,1);display:flex;flex-direction:column;gap:0.125rem;-webkit-overflow-scrolling:touch}
.mobile-nav.open{left:0}
.mobile-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:999;display:none;touch-action:manipulation}
.mobile-backdrop.active{display:block}
[data-theme="light"] .mobile-nav{background:rgba(255,255,255,0.96)}
[data-theme="light"] .mobile-backdrop{background:rgba(0,0,0,0.3)}
body.menu-open{overflow:hidden;position:fixed;width:100%;height:100%}

/* Mobile nav user section */
.mn-user{padding:0.75rem;border-top:1px solid var(--border-def)}
.mn-user-info{display:flex;align-items:center;gap:0.625rem;margin-bottom:0.5rem}
.mn-user-avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--brand-500),var(--brand-700));color:#fff;display:flex;align-items:center;justify-content:center;font-size:0.6875rem;font-weight:600;flex-shrink:0}
.mn-user-details{flex:1;min-width:0}
.mn-user-name{font-size:0.8125rem;font-weight:600;color:var(--text-pri)}
.mn-user-role{font-size:0.6875rem;color:var(--text-ter);text-transform:capitalize}
.mn-user .sd-item{padding:0.375rem 0.5rem}

/* ===== RESPONSIVE BREAKPOINTS ===== */
@media(max-width:1024px){
    .stats{grid-template-columns:repeat(2,1fr)}
    .g3{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
    .hamburger{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:var(--bg-card);border:1px solid var(--border-def);border-radius:8px;color:var(--text-sec);cursor:pointer;flex-shrink:0;transition:all 0.12s}
    .hamburger:hover{background:var(--bg-hover);color:var(--text-pri)}
    .sidebar{display:none}
    .g2{grid-template-columns:1fr}
}
@media(max-width:600px){
    .stats,.g3,.g2{grid-template-columns:1fr}
    .mod{min-width:auto;width:95vw}
    .header{padding:0.5rem 0.75rem}
    .hl{gap:0.5rem}
    .hr{gap:0.375rem}
}
@media(max-width:480px){
    .content{padding:0.75rem}
    .header{padding:0.375rem 0.5rem}
    .hl{gap:0.375rem}
    .hr{gap:0.5rem}
    .hamburger{width:44px;height:44px;min-width:44px;min-height:44px}
    .hamburger-icon{font-size:1.25rem}
    #projectSelect{width:140px!important;font-size:0.875rem!important;padding:0.375rem 0.5rem!important}
    .hbtn{width:44px;height:44px;min-width:44px;min-height:44px}
    .avatar{width:44px;height:44px;min-width:44px;min-height:44px;font-size:0.8125rem}
    .cost-indicator{padding:0.375rem 0.625rem;font-size:0.75rem;min-height:36px}
    .btn,.btn-pr,.btn-sc,.btn-gh{min-height:44px;padding:0.625rem 1rem}
    .fi,textarea.fi,select.fi{font-size:1rem;min-height:44px}
    .mod{border-radius:12px}
    .sd-item{min-height:44px;padding:0.625rem 0.75rem}
}

/* ===== GLOBAL MOBILE OVERRIDES (target page-specific patterns) ===== */
@media(max-width:480px){
    /* Collapse multi-column grids to single */
    [class*="grid"]:not(.stats):not(.g3):not(.g2),
    [class*="cards"]:not(.stats),
    [class*="row"][class*="agent"],
    [class*="type"][class*="grid"],
    [class*="wizard"][class*="grid"],
    [class*="toggle"][class*="schema"],
    [class*="options"][class*="web"],
    [class*="results"][class*="grid"],
    [class*="metrics"] {
        grid-template-columns:1fr!important
    }
    /* History panel full screen on mobile */
    .history-panel{
        width:100%!important;max-width:100vw!important;
        position:fixed!important;inset:0!important;
        z-index:1000!important
    }
    /* Admin modals: ensure width fits */
    .admin-panel .modal-content,
    [class*="admin"] .modal-content {
        max-width:90vw!important;width:90vw!important
    }
    /* Tables: horizontal scroll */
    table.wide,.data-table,.call-table,#usersTable,#groupsTable {
        display:block;overflow-x:auto
    }
    /* Fix message max-width on mobile */
    .message,.msg-bub{
        max-width:100%!important
    }
    /* Chat input full width */
    .chat-inp{padding:0.5rem 0.75rem}
    .chat-row{max-width:100%}
}
@media(max-width:600px){
    /* Two-column grids collapse at smaller sizes */
    .charts-grid,[class*="charts"]{grid-template-columns:1fr!important}
}

/* ===== BUDGET ALERT TOAST ===== */
.budget-alert{
    position:fixed;
    top:calc(58px + env(safe-area-inset-top,0px));
    right:1rem;
    z-index:2100;
    width:min(420px,calc(100vw - 2rem));
    display:none;
    padding:0;
    border:1px solid rgba(245,158,11,0.35);
    border-radius:10px;
    background:rgba(17,24,39,0.96);
    box-shadow:0 18px 50px rgba(0,0,0,0.35),0 0 0 1px rgba(255,255,255,0.04) inset;
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    animation:budgetAlertIn 0.18s ease-out;
}
.budget-alert-content{display:grid;grid-template-columns:auto 1fr auto;gap:0.75rem;align-items:center;padding:0.75rem}
.budget-alert-icon{width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(245,158,11,0.16);color:#f59e0b;font-size:0.85rem;font-weight:700;flex-shrink:0}
.budget-alert-message{font-size:0.78rem;line-height:1.4;color:var(--text-sec);min-width:0}
.budget-alert-message strong{color:var(--text-pri);font-weight:700}
.budget-alert-actions{display:flex;gap:0.375rem;align-items:center;flex-shrink:0}
.budget-alert-link,.budget-alert-dismiss{min-height:32px;border-radius:7px;padding:0.35rem 0.55rem;font-size:0.72rem;font-weight:600;white-space:nowrap}
.budget-alert-link{background:rgba(99,102,241,0.16);border:1px solid rgba(99,102,241,0.35);color:var(--brand-300)!important;text-decoration:none}
.budget-alert-dismiss{background:transparent;border:1px solid var(--border-def);color:var(--text-ter)}
.budget-alert-link:hover,.budget-alert-dismiss:hover{background:var(--bg-hover);color:var(--text-pri)!important}
body.modal-open .budget-alert{display:none!important}
@keyframes budgetAlertIn{from{transform:translateY(-8px);opacity:0}to{transform:translateY(0);opacity:1}}
[data-theme="light"] .budget-alert{background:rgba(255,255,255,0.97);border-color:rgba(217,119,6,0.28);box-shadow:0 18px 50px rgba(15,23,42,0.14)}
[data-theme="light"] .budget-alert-message{color:var(--text-sec)}
@media(max-width:480px){
    .budget-alert{top:calc(54px + env(safe-area-inset-top,0px));right:0.5rem;left:0.5rem;width:auto;border-radius:8px}
    .budget-alert-content{grid-template-columns:auto minmax(0,1fr) auto;gap:0.5rem;padding:0.5rem 0.55rem}
    .budget-alert-icon{width:22px;height:22px;font-size:0.72rem}
    .budget-alert-message{font-size:0.72rem;line-height:1.25}
    .budget-alert-actions{grid-column:auto;justify-content:flex-end}
    .budget-alert-link{display:none}
    .budget-alert-dismiss{min-height:28px;padding:0.25rem 0.45rem;font-size:0.68rem}
}
