/* ═══ Mick Bot Dashboard — Styles ═══ */
:root {
  --bg: #0f1115;
  --bg2: #13161c;
  --panel: #181b22;
  --panel2: #1c2029;
  --accent: #63f5c6;
  --accent-dim: rgba(99,245,198,0.1);
  --gold: #f5c463;
  --gold-dim: rgba(245,196,99,0.12);
  --text: #e4e6eb;
  --muted: #6b7080;
  --muted2: #8b8f99;
  --green: #34d399;
  --green-dim: rgba(52,211,153,0.1);
  --red: #f87171;
  --red-dim: rgba(248,113,113,0.12);
  --orange: #fb923c;
  --blue: #60a5fa;
  --purple: #a78bfa;
  --bubble-out: #005c4b;
  --bubble-in: #1f2c33;
  --border: rgba(255,255,255,0.06);
  --border2: rgba(255,255,255,0.1);
  --radius: 14px;
  --radius-sm: 8px;
  --transition: all .15s ease;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{background:var(--bg);color:var(--text);font-family:'Inter',system-ui,sans-serif;line-height:1.5;height:100vh;overflow:hidden;display:flex;flex-direction:column;}
a{color:var(--accent);text-decoration:none;overflow-wrap:anywhere;}
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}

/* ═══ AUTH ═══ */
#auth-screen{display:flex;align-items:center;justify-content:center;height:100vh;}
.auth-box{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:40px;max-width:360px;width:90%;text-align:center;}
.auth-box h1{font-size:1.3rem;margin-bottom:4px;display:flex;align-items:center;justify-content:center;gap:8px;}
.auth-box p{font-size:0.8rem;color:var(--muted);margin-bottom:20px;}
.auth-box input{width:100%;padding:10px 14px;border:1px solid var(--border2);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);font-size:0.85rem;outline:none;font-family:inherit;margin-bottom:10px;}
.auth-box input:focus{border-color:var(--accent);}
.auth-box button{width:100%;padding:10px;background:var(--accent);color:var(--bg);border:none;border-radius:var(--radius-sm);font-weight:600;font-size:0.85rem;cursor:pointer;font-family:inherit;margin-top:4px;}
.auth-box button:hover{opacity:0.85;}
.auth-error{color:var(--red);font-size:0.78rem;margin-top:8px;}

/* ═══ APP ═══ */
#app{display:none;flex:1;overflow:hidden;flex-direction:column;}
#app.show{display:flex;}

/* ═══ TOP BAR ═══ */
.topbar{display:flex;align-items:center;height:46px;padding:0 16px;background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0;}
.topbar-logo{font-weight:700;font-size:0.95rem;color:var(--gold);margin-right:24px;display:flex;align-items:center;gap:6px;white-space:nowrap;}
.topbar-nav{display:flex;gap:2px;height:100%;}
.topbar-nav button{background:none;border:none;color:var(--muted);padding:0 14px;font-size:0.78rem;font-weight:500;cursor:pointer;font-family:inherit;height:100%;border-bottom:2px solid transparent;transition:var(--transition);}
.topbar-nav button:hover{color:var(--text);}
.topbar-nav button.active{color:var(--gold);border-bottom-color:var(--gold);}
.topbar-spacer{flex:1;}
.topbar-user{font-size:0.75rem;color:var(--muted2);margin-right:12px;}
.topbar-badge{padding:2px 10px;border-radius:4px;font-size:0.65rem;font-weight:600;text-transform:uppercase;background:var(--green-dim);color:var(--green);}
.topbar-dot{width:7px;height:7px;border-radius:50%;background:var(--green);margin-left:8px;animation:pulse 2s infinite;}
.topbar-link{font-size:0.75rem;color:var(--muted2);transition:var(--transition);}
.topbar-link:hover{color:var(--accent);}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.3;}}

/* ═══ PAGES ═══ */
.page-wrap{flex:1;overflow:hidden;}
.page{display:none;height:100%;}
.page.active{display:flex;flex-direction:column;}

/* ═══ OVERVIEW ═══ */
.overview-scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding:28px 36px 60px;}

.dashboard-shortcuts{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px;margin-bottom:20px;}
.shortcut-card{background:linear-gradient(135deg,rgba(255,255,255,.02),rgba(255,255,255,.01));border:1px solid color-mix(in srgb, var(--shortcut-accent) 28%, transparent);border-radius:16px;padding:18px;box-shadow:0 10px 28px rgba(0,0,0,.18);cursor:pointer;transition:var(--transition);position:relative;overflow:hidden;}
.shortcut-card.active{box-shadow:0 0 0 1px color-mix(in srgb, var(--shortcut-accent) 60%, transparent),0 12px 30px rgba(0,0,0,.25);}
.shortcut-card.active::before{height:4px;}
 .shortcut-card::before{content:'';position:absolute;left:0;right:0;top:0;height:3px;background:var(--shortcut-accent);opacity:.95;}
 .shortcut-card:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(0,0,0,.25);}
 .shortcut-top{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px;}
 .shortcut-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;background:color-mix(in srgb, var(--shortcut-accent) 16%, transparent);flex-shrink:0;}
 .shortcut-head{flex:1;min-width:0;}
 .shortcut-title{font-size:1rem;font-weight:700;color:var(--text);}
 .shortcut-subtitle{font-size:.76rem;color:var(--muted2);margin-top:2px;}
 .shortcut-badge{font-size:.65rem;font-weight:700;padding:6px 10px;border-radius:999px;border:1px solid var(--border2);flex-shrink:0;}
 .shortcut-badge.live{color:var(--green);background:var(--green-dim);}
 .shortcut-badge.missing{color:var(--red);background:var(--red-dim);}
 .shortcut-desc{font-size:.84rem;color:var(--muted2);line-height:1.5;margin-bottom:10px;}
 .shortcut-meta{font-size:.74rem;color:var(--muted);margin-bottom:14px;}
 .shortcut-actions{display:flex;flex-wrap:wrap;gap:10px;}
 .shortcut-btn{appearance:none;border:1px solid var(--border2);background:transparent;color:var(--text);padding:10px 14px;border-radius:10px;cursor:pointer;font-size:.82rem;font-weight:600;text-decoration:none;font-family:inherit;}
 .shortcut-btn.primary{background:color-mix(in srgb, var(--shortcut-accent) 14%, transparent);border-color:color-mix(in srgb, var(--shortcut-accent) 30%, transparent);color:var(--shortcut-accent);}
 .shortcut-btn:hover{border-color:var(--shortcut-accent);color:var(--shortcut-accent);}

.dashboard-live-sheet{margin-bottom:28px;}
.live-sheet-card{background:linear-gradient(135deg,rgba(255,255,255,.02),rgba(255,255,255,.01));border:1px solid color-mix(in srgb, var(--shortcut-accent) 28%, transparent);border-radius:18px;padding:20px;box-shadow:0 14px 40px rgba(0,0,0,.22);position:relative;overflow:hidden;}
.morgan-chat-panel{margin-top:18px;background:linear-gradient(135deg,rgba(245,196,99,.05),rgba(255,255,255,.015));border:1px solid rgba(245,196,99,.18);border-radius:18px;padding:20px;box-shadow:0 10px 28px rgba(0,0,0,.18);}
.morgan-edit-toolbar{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:14px;padding:12px 14px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:14px;}
.morgan-edit-status{font-size:.82rem;color:var(--muted2);}
.morgan-chat-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px;}
.morgan-chat-kicker{font-size:.68rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:6px;}
.morgan-chat-header h3{font-size:1.06rem;color:var(--text);margin-bottom:4px;}
.morgan-chat-header p{font-size:.84rem;color:var(--muted2);max-width:720px;}
.morgan-chat-compose textarea{width:100%;background:var(--bg2);border:1px solid var(--border2);color:var(--text);border-radius:14px;padding:12px 14px;font-size:.86rem;font-family:inherit;resize:vertical;min-height:92px;outline:none;}
.morgan-chat-compose textarea:focus{border-color:var(--gold);}
.morgan-chat-actions{display:flex;justify-content:flex-end;margin-top:10px;}
.morgan-chat-status{margin-top:10px;font-size:.78rem;color:var(--muted2);}
.live-sheet-card::before{content:'';position:absolute;left:0;right:0;top:0;height:4px;background:var(--shortcut-accent);}
.live-sheet-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:10px;}
.live-sheet-kicker{font-size:.68rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--shortcut-accent);margin-bottom:6px;}
.live-sheet-header h3{font-size:1.2rem;color:var(--text);margin-bottom:4px;}
.live-sheet-header p{font-size:.84rem;color:var(--muted2);max-width:760px;}
.live-sheet-header-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;}
.live-sheet-meta{font-size:.74rem;color:var(--muted);margin-bottom:14px;}
.live-sheet-content{background:rgba(0,0,0,.2);border:1px solid var(--border);border-radius:14px;overflow:hidden;min-height:720px;}
.live-sheet-loading,.live-sheet-empty{display:flex;align-items:center;justify-content:center;min-height:240px;color:var(--muted2);font-size:.88rem;padding:24px;text-align:center;}
.sheet-tabs{display:flex;gap:8px;flex-wrap:wrap;padding:14px 14px 0;border-bottom:1px solid var(--border);background:rgba(255,255,255,.01);}
.sheet-tab{appearance:none;border:1px solid var(--border2);background:transparent;color:var(--muted2);padding:8px 12px;border-radius:10px 10px 0 0;cursor:pointer;font-size:.78rem;font-weight:600;font-family:inherit;}
.sheet-tab.active{background:color-mix(in srgb, var(--shortcut-accent) 10%, transparent);color:var(--shortcut-accent);border-color:color-mix(in srgb, var(--shortcut-accent) 28%, transparent);}
.sheet-panels{padding:0;}
.sheet-panel{display:none;}
.sheet-panel.active{display:block;}
.sheet-table-wrap{overflow:auto;max-height:720px;}
.sheet-table{width:max-content;min-width:100%;border-collapse:collapse;font-size:.78rem;background:rgba(0,0,0,.08);}
.sheet-table tr:nth-child(odd) td{background:rgba(255,255,255,.01);}
.sheet-table td,.sheet-table th{border:1px solid var(--border);padding:8px 10px;vertical-align:top;min-width:120px;max-width:320px;white-space:pre-wrap;word-break:break-word;}
.sheet-table td.editable-cell{background:rgba(99,245,198,.04);cursor:text;}
.sheet-table td.dirty{background:rgba(245,196,99,.12);}
.sheet-inline-input{width:100%;border:none;outline:none;background:rgba(99,245,198,.08);color:var(--text);font:inherit;padding:0;margin:0;}
.sheet-table td.saving{background:rgba(245,196,99,.12);}
.sheet-table td.saved{background:rgba(52,211,153,.14);}
.sheet-table td.save-error{background:rgba(248,113,113,.16);}
.sheet-table th{background:rgba(255,255,255,.04);font-weight:700;color:var(--text);position:sticky;top:0;z-index:1;}
.sheet-table .row-index{min-width:52px;width:52px;text-align:right;color:var(--muted);background:rgba(255,255,255,.02);font-variant-numeric:tabular-nums;position:sticky;left:0;z-index:2;}
.shortcut-card::before{content:'';position:absolute;left:0;right:0;top:0;height:3px;background:var(--shortcut-accent);opacity:.95;}
.shortcut-card:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(0,0,0,.25);}
.shortcut-top{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px;}
.shortcut-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;background:color-mix(in srgb, var(--shortcut-accent) 16%, transparent);flex-shrink:0;}
.shortcut-head{flex:1;min-width:0;}
.shortcut-title{font-size:1rem;font-weight:700;color:var(--text);}
.shortcut-subtitle{font-size:.76rem;color:var(--muted2);margin-top:2px;}
.shortcut-badge{font-size:.65rem;font-weight:700;padding:6px 10px;border-radius:999px;border:1px solid var(--border2);flex-shrink:0;}
.shortcut-badge.live{color:var(--green);background:var(--green-dim);}
.shortcut-badge.missing{color:var(--red);background:var(--red-dim);}
.shortcut-desc{font-size:.84rem;color:var(--muted2);line-height:1.5;margin-bottom:10px;}
.shortcut-meta{font-size:.74rem;color:var(--muted);margin-bottom:14px;}
.shortcut-actions{display:flex;flex-wrap:wrap;gap:10px;}
.shortcut-btn{appearance:none;border:1px solid var(--border2);background:transparent;color:var(--text);padding:10px 14px;border-radius:10px;cursor:pointer;font-size:.82rem;font-weight:600;text-decoration:none;font-family:inherit;}
.shortcut-btn.primary{background:color-mix(in srgb, var(--shortcut-accent) 14%, transparent);border-color:color-mix(in srgb, var(--shortcut-accent) 30%, transparent);color:var(--shortcut-accent);}
.shortcut-btn:hover{border-color:var(--shortcut-accent);color:var(--shortcut-accent);}

/* Stats */
.stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:36px;}
.stat{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:18px 16px;text-align:center;position:relative;overflow:hidden;transition:var(--transition);}
.stat:hover{border-color:var(--border2);transform:translateY(-1px);}
.stat::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;}
.stat:nth-child(1)::before{background:var(--gold);}
.stat:nth-child(2)::before{background:var(--green);}
.stat:nth-child(3)::before{background:var(--accent);}
.stat:nth-child(4)::before{background:var(--blue);}
.stat:nth-child(5)::before{background:var(--red);}
.stat .stat-icon{font-size:0.85rem;margin-bottom:4px;}
.stat .v{font-size:2.2rem;font-weight:800;}
.stat .l{font-size:0.72rem;color:var(--muted);margin-top:2px;letter-spacing:0.02em;}

/* ═══ ORG CHART — Professional Layout ═══ */
.org-chart{display:flex;flex-direction:column;align-items:center;padding-bottom:40px;}

/* Orchestrator card */
.org-orchestrator{position:relative;margin-bottom:0;}
.orch-glow{position:absolute;inset:-20px;background:radial-gradient(ellipse at center,rgba(245,196,99,0.06) 0%,transparent 70%);pointer-events:none;border-radius:50%;}
.orch-card{position:relative;background:linear-gradient(135deg,rgba(245,196,99,0.06),rgba(99,245,198,0.03));border:1.5px solid rgba(245,196,99,0.25);border-radius:16px;padding:24px 32px;display:flex;align-items:center;gap:20px;min-width:500px;transition:var(--transition);box-shadow:0 8px 40px rgba(0,0,0,0.4);}
.orch-card:hover{box-shadow:0 8px 50px rgba(245,196,99,0.1);}
.orch-avatar{font-size:2.8rem;filter:drop-shadow(0 0 12px rgba(245,196,99,0.3));}
.orch-info{flex:1;}
.orch-label{font-size:0.6rem;color:var(--gold);text-transform:uppercase;letter-spacing:0.14em;font-weight:700;margin-bottom:2px;}
.orch-name{font-size:1.3rem;font-weight:800;}
.orch-scope{font-size:0.78rem;color:var(--muted);margin-top:2px;}
.orch-tags{display:flex;gap:6px;flex-shrink:0;}
.otag{padding:4px 10px;border-radius:6px;font-size:0.6rem;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;}
.otag-live{background:var(--green-dim);color:var(--green);animation:pulse 2s infinite;}
.otag-model{background:var(--gold-dim);color:var(--gold);}

/* Org chart wrapper — centers everything */
#org-chart{display:flex;flex-direction:column;align-items:center;width:100%;}

/* Orchestrator card */
.org-orchestrator{position:relative;z-index:2;}

/* Trunk line from orchestrator down to branch bar */
.org-trunk{display:flex;justify-content:center;height:44px;width:100%;}
.trunk-line{width:3px;height:100%;background:linear-gradient(180deg,var(--gold),rgba(245,196,99,0.5));border-radius:2px;box-shadow:0 0 8px rgba(245,196,99,0.2);}

/* Horizontal branch bar connecting all chiefs */
.org-branches{display:flex;justify-content:center;width:100%;}
.branch-bar{width:92%;max-width:2000px;height:3px;background:linear-gradient(90deg,rgba(245,196,99,0.3),var(--gold) 10%,var(--gold) 90%,rgba(245,196,99,0.3));border-radius:2px;box-shadow:0 0 8px rgba(245,196,99,0.15);}

/* Chiefs row — auto-fit grid, all chiefs visible without scrolling */
.chiefs-row{display:grid !important;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;width:98%;max-width:2000px;margin-top:0;}

/* Individual chief column */
.chief-column{display:flex;flex-direction:column;align-items:center;min-width:0;}

/* Vertical connector from branch bar down to each chief card */
.chief-connector{display:flex;flex-direction:column;align-items:center;height:32px;}
.cc-dot{width:12px;height:12px;border-radius:50%;border:2.5px solid var(--bg);margin-top:-6px;z-index:1;box-shadow:0 0 6px rgba(0,0,0,0.3);}
.cc-line{width:3px;flex:1;border-radius:2px;box-shadow:0 0 6px rgba(0,0,0,0.15);}

/* Chief agent card */
.chief-card{width:calc(100% - 6px);border:1px solid;border-radius:12px;padding:12px;cursor:pointer;transition:var(--transition);position:relative;}
.chief-card:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(0,0,0,0.4);}
.chief-header{display:flex;align-items:center;gap:8px;}
.chief-emoji{font-size:1.4rem;flex-shrink:0;}
.chief-info{flex:1;min-width:0;}
.chief-name{font-size:0.88rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.chief-role{font-size:0.65rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.chief-badge{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.65rem;font-weight:700;flex-shrink:0;}
.chief-chevron{font-size:0.9rem;color:var(--muted2);flex-shrink:0;transition:var(--transition);line-height:1;}
.chief-desc{font-size:0.7rem;color:var(--muted);margin-top:8px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.chief-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;}
.board-chat-btn{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;font-size:.72rem;font-weight:700;color:var(--bg);background:var(--accent);border:none;border-radius:6px;cursor:pointer;transition:var(--transition);}
.board-chat-btn:hover{opacity:.88;transform:translateY(-1px);}
.chief-site-btn{display:inline-flex;align-items:center;justify-content:center;padding:5px 10px;font-size:.72rem;font-weight:600;border-radius:6px;text-decoration:none;transition:var(--transition);}
.chief-site-btn:hover{opacity:.9;transform:translateY(-1px);}
.chief-toggle{display:flex;align-items:center;gap:6px;margin-top:8px;cursor:pointer;padding:4px 0;flex-wrap:nowrap;}
.chief-toggle:hover .chief-chevron{color:var(--text);}
.chief-chat-btn{opacity:0.4;font-size:0.85rem;transition:var(--transition);flex-shrink:0;}
.chief-header:hover .chief-chat-btn{opacity:1;}
.chief-header{cursor:pointer;}

/* Sub-agents panel (expandable) */
.sub-agents-panel{flex-direction:column;gap:6px;margin-top:8px;padding:8px 6px 6px;position:relative;}
.subs-connector{position:absolute;left:50%;top:0;width:2px;height:8px;transform:translateX(-1px);}

.sub-agent-card{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--panel);border:1px solid var(--border);border-radius:10px;transition:var(--transition);cursor:default;}
.sub-agent-card:hover{border-color:var(--border2);background:var(--panel2);cursor:pointer;}
.sub-agent-card:hover .sa-chat-icon{opacity:1;}
.sa-emoji{font-size:1.1rem;flex-shrink:0;margin-top:1px;}
.sa-info{flex:1;min-width:0;}
.sa-name{font-size:0.78rem;font-weight:600;color:var(--text);}
.sa-desc{font-size:0.68rem;color:var(--muted);line-height:1.35;margin-top:2px;}
.sa-chat-icon{opacity:0;font-size:0.85rem;transition:var(--transition);flex-shrink:0;}

/* Tag styles */
.tag{display:inline-block;padding:2px 7px;border-radius:4px;font-size:.6rem;font-weight:600;}
.tag-green{background:var(--green-dim);color:var(--green);}
.tag-accent{background:var(--accent-dim);color:var(--accent);}

/* ═══ CHAT PAGE ═══ */
.chat-layout{display:flex;height:100%;overflow:hidden;}
.chat-sidebar{width:240px;background:var(--bg2);border-right:1px solid var(--border);overflow-y:auto;flex-shrink:0;}
.ch-section-label{padding:10px 14px 4px;font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600;}
.ch-item{display:flex;align-items:center;gap:8px;padding:7px 14px;cursor:pointer;font-size:.82rem;color:var(--muted2);border-radius:4px;margin:1px 6px;transition:var(--transition);}
.ch-item:hover{background:rgba(255,255,255,.03);color:var(--text);}
.ch-item.active{background:var(--accent-dim);color:var(--accent);}
.ch-item .ch-icon{font-size:.9rem;}
.dm-item{display:flex;align-items:center;gap:8px;padding:7px 14px;cursor:pointer;font-size:.82rem;color:var(--muted2);border-radius:4px;margin:1px 6px;transition:var(--transition);}
.dm-item:hover{background:rgba(255,255,255,.03);color:var(--text);}
.dm-item.active{background:var(--accent-dim);color:var(--accent);}
.dm-group-label{padding:10px 14px 2px;font-size:.6rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700;}
.dm-item.dm-chief{font-weight:600;}
.dm-item.dm-sub{padding-left:28px;font-size:.78rem;color:var(--muted);}

/* Chat main */
.chat-main{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative;background:var(--bg);}
.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--muted);text-align:center;}
.ce-icon{font-size:3.5rem;margin-bottom:12px;opacity:.3;}
.chat-empty h2{font-size:1rem;color:var(--text);font-weight:500;margin-bottom:4px;}
.chat-empty p{font-size:.82rem;}
.chat-header{display:flex;align-items:center;gap:10px;padding:8px 16px;height:50px;background:var(--panel);border-bottom:1px solid var(--border);flex-shrink:0;}
.new-session-btn{margin-left:auto;padding:4px 12px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--muted);font-size:12px;cursor:pointer;transition:all 0.2s;}
.new-session-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent);}
.ch-avatar{width:34px;height:34px;border-radius:50%;background:var(--panel2);display:flex;align-items:center;justify-content:center;font-size:1rem;}
.ch-info{flex:1;}
.ch-name{font-size:.88rem;font-weight:600;}
.ch-status{font-size:.7rem;color:var(--green);}
.chat-messages{flex:1;overflow-y:auto;padding:16px 48px;display:flex;flex-direction:column;gap:4px;}
.bubble{max-width:65%;padding:6px 10px 4px;border-radius:8px;font-size:.86rem;line-height:1.45;word-break:break-word;overflow-wrap:anywhere;white-space:pre-wrap;}
.bubble.out{background:var(--bubble-out);align-self:flex-end;border-top-right-radius:2px;}
.bubble.in{background:var(--bubble-in);align-self:flex-start;border-top-left-radius:2px;}
.bubble .b-name{font-size:.72rem;font-weight:600;margin-bottom:2px;display:block;}
.bubble .b-time{font-size:.6rem;color:var(--muted);float:right;margin-left:10px;margin-top:4px;}
.bubble.error{border-left:2px solid var(--red);}
.bubble .b-name.client{color:var(--accent);}
.bubble .b-name.agent-turbo{color:var(--gold);}
.bubble .b-name.agent-darwin{color:var(--blue);}
.bubble .b-name.agent-riley{color:var(--green);}
.bubble .b-name.agent-morgan{color:var(--gold);}
.bubble .b-name.agent-harper{color:var(--purple);}
.bubble .b-name.agent-casey{color:var(--orange);}
.bubble .b-name.agent-website{color:#00cec9;}
.bubble .b-name.agent-rat{color:#ef4444;}
.bubble .b-name.agent-bob{color:#84cc16;}
.bubble .b-name.agent-brianna{color:#d4a545;}
.system-msg{text-align:center;font-size:.72rem;color:var(--muted);padding:4px 12px;margin:8px auto;background:rgba(0,0,0,.25);border-radius:6px;max-width:80%;}
.typing-indicator{background:var(--bubble-in);padding:10px 16px;border-radius:8px;font-size:.78rem;color:var(--muted);font-style:italic;display:none;margin:4px 48px;align-self:flex-start;flex-shrink:0;border-left:3px solid var(--accent);}
.typing-indicator.show{display:flex;align-items:center;gap:10px;animation:none;}
.typing-indicator .typing-dots{display:flex;gap:4px;}
.typing-indicator .typing-dots span{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:typingBounce 1.2s infinite;}
.typing-indicator .typing-dots span:nth-child(2){animation-delay:0.2s;}
.typing-indicator .typing-dots span:nth-child(3){animation-delay:0.4s;}
@keyframes typingBounce{0%,60%,100%{transform:translateY(0);opacity:0.4;}30%{transform:translateY(-6px);opacity:1;}}

/* Pulsing border on chat area while agent is thinking */
.chat-main.thinking{box-shadow:inset 0 0 0 2px var(--accent);animation:thinkingPulse 2s ease-in-out infinite;}
@keyframes thinkingPulse{0%,100%{box-shadow:inset 0 0 0 2px rgba(99,245,198,0.15);}50%{box-shadow:inset 0 0 0 2px rgba(99,245,198,0.5),inset 0 0 20px rgba(99,245,198,0.05);}}
@keyframes typingPulse{0%,100%{opacity:1;}50%{opacity:.5;}}
.chat-hint{padding:2px 16px;font-size:0.68rem;color:var(--muted);flex-shrink:0;display:none;}
.chat-hint code{background:var(--panel2);padding:1px 5px;border-radius:3px;font-size:0.66rem;color:var(--accent);}
.chat-input-bar{display:flex;gap:8px;padding:10px 16px;background:var(--panel);flex-shrink:0;align-items:flex-end;}
.chat-input-bar textarea{flex:1;background:var(--bg2);border:1px solid var(--border2);color:var(--text);border-radius:20px;padding:9px 16px;font-size:.86rem;font-family:inherit;resize:none;outline:none;max-height:100px;}
.chat-input-bar textarea:focus{border-color:var(--accent);}
.chat-input-bar textarea::placeholder{color:var(--muted);}
.send-btn{width:38px;height:38px;background:var(--accent);color:var(--bg);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;}
.send-btn:hover{opacity:.85;}
.attach-btn{width:38px;height:38px;background:transparent;color:var(--muted);border:1px solid var(--border2);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;transition:all .2s;}
.attach-btn:hover{color:var(--accent);border-color:var(--accent);}
.attachment-preview{display:none;padding:6px 16px;gap:8px;flex-wrap:wrap;background:var(--panel);border-top:1px solid var(--border2);}
.attachment-preview.has-files{display:flex;}
.att-thumb{position:relative;width:80px;height:80px;border-radius:8px;overflow:hidden;border:1px solid var(--border2);background:var(--bg2);}
.att-thumb img,.att-thumb video{width:100%;height:100%;object-fit:cover;}
.att-thumb .att-file{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.65rem;color:var(--muted);text-align:center;padding:4px;}
.att-thumb .att-file .att-icon{font-size:1.5rem;margin-bottom:2px;}
.att-remove{position:absolute;top:2px;right:2px;width:20px;height:20px;background:rgba(0,0,0,.7);color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:.7rem;display:flex;align-items:center;justify-content:center;line-height:1;}
.att-remove:hover{background:var(--red);}
.chat-drop-overlay{display:none;position:absolute;inset:0;background:rgba(0,0,0,.6);z-index:100;align-items:center;justify-content:center;border-radius:12px;}
.chat-drop-overlay.active{display:flex;}
.chat-drop-overlay span{font-size:1.3rem;color:var(--accent);background:var(--panel);padding:16px 32px;border-radius:12px;border:2px dashed var(--accent);}
.msg-attachments{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px;}
.msg-att-img{max-width:280px;max-height:240px;border-radius:8px;cursor:pointer;object-fit:cover;border:1px solid var(--border2);}
.msg-att-img:hover{opacity:.9;}
.msg-att-video{max-width:320px;max-height:240px;border-radius:8px;border:1px solid var(--border2);}
.msg-att-file{display:inline-block;padding:6px 12px;background:var(--bg2);border:1px solid var(--border2);border-radius:8px;color:var(--accent);text-decoration:none;font-size:.8rem;}
.msg-att-file:hover{background:var(--border2);}

/* ═══ WORKBOOKS ═══ */
.workbooks-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px;}
.workbook-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:18px;box-shadow:0 8px 24px rgba(0,0,0,.18);}
.workbook-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px;}
.workbook-title{font-size:1rem;font-weight:700;color:var(--text);}
.workbook-meta{font-size:.78rem;color:var(--muted2);margin-top:4px;}
.workbook-status{font-size:.72rem;font-weight:700;padding:6px 10px;border-radius:999px;border:1px solid var(--border2);}
.workbook-status.ok{color:var(--green);background:var(--green-dim);}
.workbook-status.bad{color:var(--red);background:var(--red-dim);}
.workbook-desc{color:var(--muted2);font-size:.84rem;line-height:1.5;margin-bottom:14px;}
.workbook-facts{display:grid;gap:6px;font-size:.8rem;color:var(--muted2);margin-bottom:16px;}
.workbook-facts strong{color:var(--text);}
.workbook-actions{display:flex;flex-wrap:wrap;gap:10px;}
.workbook-btn{appearance:none;border:1px solid var(--border2);background:transparent;color:var(--text);padding:10px 14px;border-radius:10px;cursor:pointer;font-size:.82rem;font-weight:600;text-decoration:none;font-family:inherit;}
.workbook-btn.primary{background:var(--accent-dim);border-color:rgba(99,245,198,.25);color:var(--accent);}
.workbook-btn:hover{border-color:var(--accent);color:var(--accent);}

/* ═══ MARKDOWN RENDERING ═══ */
.b-text{word-break:break-word;}
.b-text .md-heading{display:block;margin:6px 0 2px;font-size:.92rem;color:var(--text);}
.b-text .md-code-block{background:var(--bg);border:1px solid var(--border2);border-radius:6px;padding:8px 12px;margin:6px 0;overflow-x:auto;font-family:'Fira Code',Consolas,'Courier New',monospace;font-size:.78rem;line-height:1.5;color:var(--muted2);white-space:pre-wrap;word-break:break-all;}
.b-text .md-inline-code{background:rgba(99,245,198,.12);border:1px solid rgba(99,245,198,.2);border-radius:4px;padding:1px 5px;font-family:'Fira Code',Consolas,'Courier New',monospace;font-size:.82em;color:var(--accent);}
.b-text .md-link{color:var(--accent);text-decoration:underline;text-decoration-color:rgba(99,245,198,.3);}
.b-text .md-link:hover{text-decoration-color:var(--accent);}
.b-text .md-list{margin:4px 0;padding-left:20px;}
.b-text .md-list li{margin:2px 0;line-height:1.5;}
.b-text .md-hr{border:none;border-top:1px solid var(--border2);margin:8px 0;}
.b-text .md-break{height:6px;}
.b-text strong{color:var(--text);font-weight:600;}
.b-text em{font-style:italic;color:var(--muted2);}
.b-text img.msg-att-img{display:block;margin:6px 0;}
.b-text video.msg-att-video{display:block;margin:6px 0;}

/* Members panel */
.chat-members{width:180px;background:var(--bg2);border-left:1px solid var(--border);overflow-y:auto;flex-shrink:0;padding:10px 0;}
.members-title{font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;padding:4px 14px 6px;font-weight:600;}
.member{display:flex;align-items:center;gap:6px;padding:3px 14px;font-size:.78rem;}
.member .m-dot{width:6px;height:6px;border-radius:50%;background:var(--green);margin-left:auto;}

/* ═══ ACTIVITY ═══ */
.activity-scroll{flex:1;overflow-y:auto;padding:24px 32px;}
.feed-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.feed-header{padding:12px 16px;border-bottom:1px solid var(--border);}
.feed-header h3{font-size:.85rem;font-weight:700;}
.feed-list{max-height:calc(100vh - 180px);overflow-y:auto;}
.feed-row{display:flex;align-items:flex-start;gap:10px;padding:8px 16px;border-bottom:1px solid var(--border);font-size:.8rem;}
.feed-row .f-time{font-size:.68rem;color:var(--muted);min-width:55px;white-space:nowrap;}
.feed-row .f-emoji{font-size:.9rem;}
.feed-row .f-text{color:var(--text);}

/* ═══ USER MENU ═══ */
.user-menu{position:relative;margin-left:10px;}
.user-menu-btn{background:var(--panel2);border:1px solid var(--border2);color:var(--text);width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center;}
.user-menu-btn:hover{border-color:var(--accent);}
.user-dropdown{display:none;position:absolute;top:40px;right:0;background:var(--panel);border:1px solid var(--border2);border-radius:var(--radius-sm);min-width:220px;box-shadow:0 8px 30px rgba(0,0,0,.5);z-index:100;overflow:hidden;}
.user-dropdown.show{display:block;}
.ud-name{padding:12px 14px 2px;font-size:.85rem;font-weight:600;}
.ud-email{padding:0 14px 10px;font-size:.7rem;color:var(--muted);}
.ud-divider{height:1px;background:var(--border);margin:0;}
.user-dropdown button{width:100%;text-align:left;background:none;border:none;color:var(--text);padding:10px 14px;font-size:.8rem;cursor:pointer;font-family:inherit;}
.user-dropdown button:hover{background:rgba(255,255,255,.04);}
.user-dropdown .ud-logout{color:var(--red);}
.user-dropdown .ud-logout:hover{background:var(--red-dim);}

/* ═══ MODAL ═══ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);display:flex;align-items:center;justify-content:center;z-index:200;}
.modal-box{background:var(--panel);border:1px solid var(--border2);border-radius:var(--radius);padding:24px;max-width:380px;width:90%;}
.modal-box h3{font-size:.95rem;margin-bottom:16px;}
.modal-box input{width:100%;padding:10px 14px;border:1px solid var(--border2);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);font-size:.85rem;outline:none;font-family:inherit;margin-bottom:10px;}
.modal-box input:focus{border-color:var(--accent);}
.modal-error{color:var(--red);font-size:.75rem;min-height:18px;margin-bottom:8px;}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;}
.modal-cancel{background:var(--panel2);border:1px solid var(--border2);color:var(--muted2);padding:8px 16px;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:.8rem;}
.modal-confirm{background:var(--accent);border:none;color:var(--bg);padding:8px 16px;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:.8rem;font-weight:600;}
.modal-confirm:hover{opacity:.85;}

/* ═══ MOBILE TOGGLE ELEMENTS ═══ */
.mobile-menu-btn{display:none;background:none;border:none;color:var(--text);font-size:1.3rem;cursor:pointer;padding:4px 8px;line-height:1;}
.mobile-sidebar-toggle{display:none;background:none;border:1px solid var(--border2);color:var(--muted2);font-size:0.75rem;padding:6px 10px;border-radius:var(--radius-sm);cursor:pointer;margin:6px;font-family:inherit;width:calc(100% - 12px);}
.mobile-sidebar-toggle:hover{color:var(--text);border-color:var(--accent);}
.mobile-back-btn{display:none;background:none;border:none;color:var(--accent);font-size:0.85rem;cursor:pointer;padding:8px;font-family:inherit;}

/* ═══ RESPONSIVE — LARGE TABLETS (≤1200px) ═══ */
@media(max-width:1200px){
  .chiefs-row{width:98% !important;gap:6px;}
  .branch-bar{width:98%;}
  .chat-members{width:140px;}
  .orch-card{min-width:400px;padding:20px 24px;}
}

/* ═══ RESPONSIVE — TABLETS (≤900px) ═══ */
@media(max-width:900px){
  /* Topbar: collapse nav text */
  .topbar{padding:0 10px;height:44px;}
  .topbar-logo{font-size:0.85rem;margin-right:12px;}
  .topbar-nav button{padding:0 8px;font-size:0.72rem;}
  .topbar-user{display:none;}
  .topbar-link{display:none;}

  /* Chat: hide members, shrink sidebar */
  .chat-members{display:none;}
  .chat-sidebar{width:200px;}

  /* Stats: 3-col */
  .stats-row{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:24px;}
  .stat .v{font-size:1.6rem;}

  /* Org chart: keep all chiefs visible, hide connectors on tablets */
  .chiefs-row{grid-template-columns:repeat(auto-fit,minmax(140px,1fr)) !important;width:98% !important;gap:6px;}
  .branch-bar{display:none;}
  .chief-connector{display:none;}
  .orch-card{min-width:auto;flex-wrap:wrap;padding:16px 20px;}
  .orch-avatar{font-size:2rem;}
  .orch-name{font-size:1.1rem;}
  .org-trunk{height:24px;}

  /* Chat messages */
  .chat-messages{padding:12px 16px;}
  .bubble{max-width:85%;}
}

/* ═══ RESPONSIVE — SMALL TABLETS / LARGE PHONES (≤768px) ═══ */
@media(max-width:768px){
  /* Show mobile menu button, hide nav buttons */
  .mobile-menu-btn{display:flex;}
  .topbar-nav{display:none;position:absolute;top:44px;left:0;right:0;background:var(--bg2);border-bottom:1px solid var(--border);flex-direction:column;z-index:100;padding:4px 0;}
  .topbar-nav.open{display:flex;}
  .topbar-nav button{height:auto;padding:10px 16px;text-align:left;border-bottom:none;}
  .topbar-nav button.active{border-bottom:none;background:var(--accent-dim);}
  .topbar-badge{font-size:0.6rem;padding:2px 7px;}

  /* Overview */
  .overview-scroll{padding:16px 12px 40px;}
  .dashboard-shortcuts{grid-template-columns:1fr;gap:12px;margin-bottom:16px;}
  .dashboard-live-sheet{margin-bottom:20px;}
  .live-sheet-header{flex-direction:column;}
  .live-sheet-header-actions{justify-content:flex-start;}
  .morgan-chat-header{flex-direction:column;}
  .morgan-chat-actions{justify-content:flex-start;}
  .live-sheet-content{min-height:560px;}
  .sheet-table-wrap{max-height:560px;}
  .stats-row{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:20px;}
  .stat{padding:14px 10px;}
  .stat .v{font-size:1.4rem;}
  .stat .l{font-size:0.65rem;}

  /* Org chart: 2-col chiefs */
  .chiefs-row{grid-template-columns:repeat(2,1fr) !important;gap:6px;}
  .orch-card{padding:14px 16px;gap:12px;}
  .orch-avatar{font-size:1.8rem;}
  .orch-name{font-size:1rem;}
  .orch-scope{font-size:0.7rem;}
  .orch-label{font-size:0.55rem;}
  .orch-tags{gap:4px;}
  .otag{font-size:0.55rem;padding:3px 7px;}
  .org-trunk{height:16px;}

  /* Chief cards */
  .chief-card{padding:10px;}
  .chief-emoji{font-size:1.3rem;}
  .chief-name{font-size:0.8rem;}
  .chief-role{font-size:0.6rem;}
  .chief-desc{font-size:0.65rem;-webkit-line-clamp:1;}
  .chief-actions{gap:6px;}
  .board-chat-btn,.chief-site-btn{font-size:.68rem;padding:5px 8px;}
  .chief-badge{width:20px;height:20px;font-size:0.6rem;}
  .sub-agent-card{padding:8px 10px;gap:8px;}
  .sa-emoji{font-size:0.95rem;}
  .sa-name{font-size:0.72rem;}
  .sa-desc{font-size:0.62rem;}

  /* Chat layout: overlay sidebar */
  .chat-layout{position:relative;}
  .chat-sidebar{position:absolute;left:0;top:0;bottom:0;width:min(82vw,280px);z-index:50;transform:translateX(-100%);transition:transform 0.2s ease;box-shadow:4px 0 20px rgba(0,0,0,0.5);}
  .chat-sidebar.open{transform:translateX(0);}
  .mobile-sidebar-toggle{display:block;}
  .chat-input-bar{padding:8px 10px;}
  .chat-input-bar textarea{font-size:0.82rem;padding:8px 12px;}
  .send-btn{width:34px;height:34px;font-size:0.9rem;}

  /* Activity */
  .activity-scroll{padding:16px 12px;}
  .feed-row{padding:6px 12px;font-size:0.75rem;}
}

/* ═══ RESPONSIVE — PHONES (≤480px) ═══ */
@media(max-width:480px){
  /* Topbar ultra-compact */
  .topbar{height:40px;padding:0 8px;}
  .topbar-logo{font-size:0.8rem;margin-right:8px;}
  .topbar-badge{display:none;}
  .topbar-dot{margin-left:4px;}
  .user-menu-btn{width:28px;height:28px;font-size:0.75rem;}

  /* Auth screen */
  .auth-box{padding:24px 20px;max-width:320px;}
  .auth-box h1{font-size:1.1rem;}
  .auth-box input{padding:9px 12px;font-size:0.82rem;}

  /* Stats: 2-col tight */
  .dashboard-shortcuts{grid-template-columns:1fr;}
  .shortcut-card{padding:14px;}
  .shortcut-title{font-size:.92rem;}
  .shortcut-actions{flex-direction:column;}
  .shortcut-btn{width:100%;text-align:center;}
  .live-sheet-card{padding:14px;}
  .morgan-chat-panel{padding:14px;}
  .live-sheet-header h3{font-size:1rem;}
  .morgan-chat-header h3{font-size:.96rem;}
  .live-sheet-content{min-height:420px;}
  .sheet-table-wrap{max-height:420px;}
  .sheet-tabs{padding:10px 10px 0;gap:6px;}
  .sheet-tab{width:100%;border-radius:10px;padding:8px 10px;text-align:left;}
  .sheet-table td,.sheet-table th{min-width:90px;padding:6px 8px;font-size:.74rem;}
  .sheet-table .row-index{min-width:42px;width:42px;}
  .stats-row{grid-template-columns:repeat(2,1fr);gap:6px;}
  .stat{padding:12px 8px;border-radius:8px;}
  .stat .v{font-size:1.2rem;}
  .stat .l{font-size:0.6rem;}
  .stat .stat-icon{font-size:0.75rem;}

  /* Org chart: single column */
  .chiefs-row{grid-template-columns:1fr !important;gap:8px;}
  .orch-card{flex-direction:column;text-align:center;gap:8px;padding:12px;}
  .orch-avatar{font-size:1.5rem;}
  .orch-name{font-size:0.95rem;}
  .orch-tags{justify-content:center;}

  /* Chief cards stacked */
  .chief-card{padding:12px;}
  .chief-header{gap:8px;}
  .chief-emoji{font-size:1.2rem;}
  .chief-desc{display:none;}

  /* Chat */
  .chat-header{padding:6px 10px;height:44px;}
  .ch-avatar{width:30px;height:30px;font-size:0.9rem;}
  .ch-name{font-size:0.82rem;}
  .ch-status{font-size:0.65rem;}
  .chat-messages{padding:8px 10px;gap:2px;}
  .bubble{max-width:90%;padding:5px 9px 3px;font-size:0.82rem;border-radius:6px;}
  .bubble .b-name{font-size:0.68rem;}
  .bubble .b-time{font-size:0.55rem;}
  .system-msg{font-size:0.65rem;padding:3px 8px;}
  .typing-indicator{font-size:0.72rem;margin:4px 10px;}
  .chat-input-bar{padding:6px 8px;gap:6px;}
  .chat-input-bar textarea{border-radius:16px;font-size:0.8rem;padding:7px 12px;}
  .send-btn{width:32px;height:32px;font-size:0.85rem;}
  .chat-hint{font-size:0.62rem;padding:2px 10px;}
  .chat-sidebar{width:min(86vw,240px);}

  /* Activity */
  .activity-scroll{padding:12px 8px;}
  .feed-header{padding:10px 12px;}
  .feed-header h3{font-size:0.8rem;}
  .feed-row{gap:6px;font-size:0.72rem;}
  .feed-row .f-time{font-size:0.62rem;min-width:45px;}

  /* Modals */
  .modal-box{padding:20px 16px;max-width:calc(100vw - 32px);}
  .modal-box h3{font-size:0.88rem;}
  .modal-box input{font-size:0.82rem;}

  /* User dropdown */
  .user-dropdown{min-width:180px;right:-8px;}
  .ud-name{font-size:0.8rem;}
  .ud-email{font-size:0.65rem;}
  .user-dropdown button{font-size:0.75rem;padding:8px 12px;}
}

/* ═══ RESPONSIVE — TINY PHONES (≤360px) ═══ */
@media(max-width:360px){
  .topbar-logo span{display:none;}
  .stats-row{grid-template-columns:1fr 1fr;gap:4px;}
  .stat .v{font-size:1rem;}
  .overview-scroll{padding:10px 8px 30px;}
  .orch-card{padding:10px;}
  .orch-name{font-size:0.85rem;}
}

/* ═══ MEMORY PAGE ═══ */
.memory-scroll{padding:24px 32px 40px;max-width:1400px;margin:0 auto;overflow-y:auto;height:100%;}
.memory-header{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;margin-bottom:16px;}
.memory-header h2{font-size:1.15rem;margin-bottom:4px;}
.memory-header p{font-size:0.82rem;color:var(--muted);max-width:780px;}
.memory-controls{display:flex;gap:10px;align-items:center;}
.memory-controls input{min-width:280px;padding:10px 12px;border:1px solid var(--border2);border-radius:8px;background:var(--panel2);color:var(--text);outline:none;font-family:inherit;font-size:.82rem;}
.memory-controls input:focus{border-color:var(--accent);}
.memory-refresh{background:var(--panel2);border:1px solid var(--border);color:var(--muted);padding:10px 14px;border-radius:8px;cursor:pointer;font-size:0.78rem;font-weight:600;}
.memory-refresh:hover{color:var(--text);border-color:var(--accent);}

/* Stats Bar */
.memory-stats-bar{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:16px;}
.memory-stat{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px 12px;text-align:center;transition:var(--transition);}
.memory-stat:hover{border-color:var(--border2);transform:translateY(-1px);}
.ms-value{font-size:1.6rem;font-weight:800;}
.ms-label{font-size:0.68rem;color:var(--muted);margin-top:2px;}

/* Overview Card */
.memory-overview-card{background:linear-gradient(135deg,rgba(99,245,198,0.04),rgba(245,196,99,0.04));border:1px solid rgba(99,245,198,0.15);border-radius:14px;padding:16px 20px;margin-bottom:16px;}
.mo-header{display:flex;align-items:center;gap:14px;margin-bottom:12px;}
.mo-icon{font-size:1.8rem;}
.mo-title{font-size:0.92rem;font-weight:700;color:var(--text);}
.mo-range{font-size:0.72rem;color:var(--muted);}
.mo-body{display:flex;flex-direction:column;gap:8px;}
.mo-section{display:flex;align-items:flex-start;gap:8px;flex-wrap:wrap;}
.mo-label{font-size:0.72rem;font-weight:700;color:var(--muted2);min-width:80px;flex-shrink:0;padding-top:4px;}

/* Filters */
.memory-filters{display:flex;gap:8px;margin-bottom:16px;align-items:center;flex-wrap:wrap;}
.memory-filter{background:var(--panel2);border:1px solid var(--border);color:var(--muted);padding:8px 14px;border-radius:8px;cursor:pointer;font-size:0.78rem;font-weight:600;transition:all .15s;font-family:inherit;}
.memory-filter:hover{color:var(--text);border-color:var(--border2);}
.memory-filter.active{background:rgba(99,245,198,0.10);color:var(--accent);border-color:rgba(99,245,198,0.3);}
#memory-project-filter{background:var(--panel2);border:1px solid var(--border);color:var(--muted);padding:8px 12px;border-radius:8px;font-size:0.78rem;font-family:inherit;cursor:pointer;min-width:180px;outline:none;}
#memory-project-filter:focus{border-color:var(--accent);}

/* Layout */
.memory-layout{display:grid;grid-template-columns:340px 1fr;gap:18px;align-items:start;}
.memory-sidebar-card,.memory-main-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;}
.memory-sidebar-head{padding:14px 16px;border-bottom:1px solid var(--border);font-size:0.78rem;font-weight:700;color:var(--muted2);text-transform:uppercase;letter-spacing:0.04em;}
.memory-day-list{padding:10px;display:flex;flex-direction:column;gap:8px;max-height:calc(100vh - 420px);overflow-y:auto;}
.memory-day-item{width:100%;text-align:left;background:var(--panel2);border:1px solid transparent;border-radius:12px;padding:12px;cursor:pointer;color:var(--text);transition:all .15s ease;font-family:inherit;}
.memory-day-item:hover{border-color:var(--border2);transform:translateY(-1px);}
.memory-day-item.active{border-color:rgba(99,245,198,0.35);background:rgba(99,245,198,0.08);}
.memory-day-top{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-bottom:6px;}
.memory-day-date{font-size:0.8rem;font-weight:700;}
.memory-day-count{font-size:0.68rem;color:var(--muted);}
.memory-day-preview{font-size:0.74rem;color:var(--muted2);line-height:1.4;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.memory-main-card{padding:20px;min-height:420px;}
.memory-empty,.memory-empty-large{color:var(--muted);text-align:center;padding:30px 16px;}
.memory-empty-large{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:360px;}
.memory-empty-icon{font-size:2.8rem;margin-bottom:12px;opacity:.5;}
.memory-day-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:18px;}
.memory-day-header h3{font-size:1.1rem;margin-bottom:4px;}
.memory-day-meta{font-size:0.75rem;color:var(--muted);}
.memory-section{margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--border);}
.memory-section:last-child{border-bottom:none;padding-bottom:0;}
.memory-section h4{font-size:0.78rem;color:var(--muted2);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:10px;}
.memory-summary-list{padding-left:18px;color:var(--text);display:flex;flex-direction:column;gap:6px;font-size:0.82rem;line-height:1.5;}
.memory-chip-row{display:flex;flex-wrap:wrap;gap:8px;}
.memory-chip{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;background:rgba(99,245,198,0.10);color:var(--accent);font-size:0.72rem;border:1px solid rgba(99,245,198,0.12);}
.memory-chip.small{padding:3px 8px;font-size:0.66rem;}
.memory-chip.muted{background:rgba(96,165,250,0.08);color:var(--blue);border-color:rgba(96,165,250,0.14);}
.memory-chip.neutral{background:rgba(245,196,99,0.08);color:var(--gold);border-color:rgba(245,196,99,0.14);}
.memory-muted{font-size:0.75rem;color:var(--muted);}
.memory-entry-list{display:flex;flex-direction:column;gap:12px;}
.memory-entry-card{background:var(--panel2);border:1px solid var(--border);border-radius:12px;padding:14px;transition:border-color .15s;}
.memory-entry-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px;}
.memory-entry-time{font-size:0.68rem;color:var(--muted);margin-bottom:2px;}
.memory-entry-title{font-size:0.82rem;font-weight:700;}
.memory-entry-channel{font-size:0.68rem;color:var(--accent);background:rgba(99,245,198,0.08);padding:4px 8px;border-radius:999px;white-space:nowrap;}
.memory-entry-summary{font-size:0.78rem;color:var(--text);margin-bottom:10px;line-height:1.45;}
.memory-entry-block{font-size:0.75rem;color:var(--muted2);margin-bottom:8px;line-height:1.45;white-space:pre-wrap;overflow-wrap:anywhere;}

/* ═══ USAGE PAGE ═══ */
.usage-scroll{padding:24px 32px 40px;max-width:1200px;margin:0 auto;overflow-y:auto;height:100%;}
.usage-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;}
.usage-header h2{margin:0;font-size:1.15rem;color:var(--text);}
.usage-refresh{background:var(--surface2);border:1px solid var(--border);color:var(--muted);padding:6px 14px;border-radius:6px;cursor:pointer;font-size:0.78rem;font-weight:600;transition:all .15s;}
.usage-refresh:hover{background:var(--surface3);color:var(--text);}

.usage-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:20px;}
.usage-stat{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;text-align:center;}
.usage-stat .us-value{font-size:1.3rem;font-weight:800;color:var(--accent);}
.usage-stat .us-label{font-size:0.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;margin-top:2px;}
.usage-stat.warn .us-value{color:var(--gold);}
.usage-stat.danger .us-value{color:var(--red);}

.usage-toggle{display:flex;gap:4px;margin-bottom:16px;background:var(--surface2);border-radius:8px;padding:3px;width:fit-content;}
.usage-toggle button{background:none;border:none;color:var(--muted);padding:6px 16px;border-radius:6px;cursor:pointer;font-size:0.78rem;font-weight:600;transition:all .15s;}
.usage-toggle button.active{background:var(--accent);color:#000;}
.usage-toggle button:hover:not(.active){color:var(--text);}

.usage-table-wrap{overflow-x:auto;margin-bottom:24px;}
.usage-table{width:100%;border-collapse:collapse;font-size:0.78rem;}
.usage-table th{background:var(--surface2);color:var(--muted);text-transform:uppercase;font-size:0.68rem;letter-spacing:0.5px;padding:8px 12px;text-align:left;border-bottom:1px solid var(--border);position:sticky;top:0;}
.usage-table th.num{text-align:right;}
.usage-table td{padding:8px 12px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;}
.usage-table td.num{text-align:right;font-variant-numeric:tabular-nums;font-family:'Inter',monospace;}
.usage-table tr:hover{background:rgba(99,245,198,0.04);}
.usage-table .user-name{font-weight:600;color:var(--accent);}
.usage-table .user-id{font-size:0.7rem;color:var(--muted);display:block;}
.usage-table .channel-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:0.68rem;font-weight:600;text-transform:uppercase;}
.channel-whatsapp{background:rgba(37,211,102,0.15);color:#25d366;}
.channel-webchat{background:rgba(99,245,198,0.15);color:var(--accent);}
.channel-internal{background:rgba(128,128,128,0.15);color:var(--muted);}
.channel-unknown{background:rgba(128,128,128,0.1);color:var(--muted2);}
.usage-table .cost-cell{font-weight:700;}
.cost-high{color:var(--red);}
.cost-mid{color:var(--gold);}
.cost-low{color:var(--green);}

.usage-chart-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:16px 20px;margin-bottom:20px;}
.usage-chart-card h3{margin:0 0 12px;font-size:0.85rem;color:var(--muted);}
.usage-bar-chart{display:flex;flex-direction:column;gap:6px;}
.usage-bar-row{display:flex;align-items:center;gap:10px;}
.usage-bar-label{width:120px;font-size:0.72rem;color:var(--muted2);text-align:right;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.usage-bar-track{flex:1;height:20px;background:var(--surface3);border-radius:4px;overflow:hidden;position:relative;}
.usage-bar-fill{height:100%;border-radius:4px;transition:width .3s;}
.usage-bar-pct{font-size:0.68rem;color:var(--muted);width:50px;text-align:right;flex-shrink:0;}

.usage-loading{text-align:center;padding:40px;color:var(--muted);font-size:0.85rem;}

@media(max-width:768px){
  .memory-scroll{padding:12px 10px 30px;}
  .memory-header{flex-direction:column;align-items:stretch;}
  .memory-controls{flex-direction:column;align-items:stretch;}
  .memory-controls input{min-width:0;width:100%;}
  .memory-stats-bar{grid-template-columns:repeat(2,1fr);gap:8px;}
  .memory-overview-card{padding:12px 14px;}
  .mo-header{gap:10px;}
  .mo-icon{font-size:1.4rem;}
  .memory-filters{gap:6px;}
  .memory-filter{padding:6px 10px;font-size:0.72rem;}
  #memory-project-filter{min-width:140px;font-size:0.72rem;}
  .memory-layout{grid-template-columns:1fr;}
  .memory-day-list{max-height:none;}
  .usage-scroll{padding:12px 10px 30px;}
  .usage-summary{grid-template-columns:1fr 1fr;}
  .usage-table{font-size:0.7rem;}
  .usage-table th,.usage-table td{padding:6px 8px;}
  .usage-bar-label{width:80px;font-size:0.65rem;}
}

/* ═══ VOICE BUTTONS ═══ */
.voice-btn, .voice-mode-btn {
  background: none;
  border: none;
  color: var(--muted);
  cursor: pointer;
  padding: 6px 8px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  flex-shrink: 0;
}
.voice-btn:hover, .voice-mode-btn:hover {
  color: var(--accent);
  background: rgba(99,245,198,0.08);
}
.voice-btn.recording {
  color: #ef4444;
  background: rgba(239,68,68,0.15);
  animation: voice-pulse 1.2s ease-in-out infinite;
}
@keyframes voice-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(239,68,68,0.4); }
  50% { box-shadow: 0 0 0 8px rgba(239,68,68,0); }
}
.voice-mode-btn.active {
  color: var(--green);
  background: rgba(52,211,153,0.15);
}
.voice-mode-btn.active svg {
  filter: drop-shadow(0 0 4px rgba(52,211,153,0.5));
}

/* ═══ READ ALOUD BUTTON ON BUBBLES ═══ */
.b-meta {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  float: right;
  margin-left: 8px;
  margin-top: 2px;
}
.read-aloud-btn {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 0.72rem;
  opacity: 0;
  transition: opacity 0.2s;
  padding: 2px 4px;
  border-radius: 4px;
  line-height: 1;
}
.bubble:hover .read-aloud-btn {
  opacity: 0.6;
}
.read-aloud-btn:hover {
  opacity: 1 !important;
  background: rgba(255,255,255,0.08);
}

/* ═══ SESSION HISTORY ═══ */
.history-btn {
  background: rgba(99,245,198,0.08);
  border: 1px solid rgba(99,245,198,0.2);
  color: var(--accent);
  font-size: 0.72rem;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.2s;
}
.history-btn:hover { background: rgba(99,245,198,0.15); }

.session-history-panel {
  display: none;
  position: absolute;
  top: 52px;
  right: 0;
  width: 320px;
  max-height: 70vh;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  z-index: 100;
  flex-direction: column;
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
  overflow: hidden;
}
.session-history-panel.open { display: flex; }
.sh-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 14px;
  font-weight: 600;
  font-size: 0.82rem;
  color: var(--text);
  border-bottom: 1px solid var(--border);
}
.sh-close {
  background: none;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 1rem;
  padding: 2px 6px;
  border-radius: 4px;
}
.sh-close:hover { background: rgba(255,255,255,0.08); color: var(--text); }
.sh-list {
  flex: 1;
  overflow-y: auto;
  padding: 8px;
}
.sh-item {
  padding: 10px 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.15s;
  margin-bottom: 4px;
}
.sh-item:hover { background: rgba(99,245,198,0.06); }
.sh-date { font-size: 0.68rem; color: var(--muted); margin-bottom: 2px; }
.sh-preview { font-size: 0.78rem; color: var(--muted2); line-height: 1.3; }
.sh-meta { font-size: 0.65rem; color: var(--muted); margin-top: 3px; }
.sh-empty, .sh-loading { text-align: center; padding: 24px 12px; color: var(--muted); font-size: 0.78rem; }
.sh-back {
  padding: 8px;
  border-top: 1px solid var(--border);
}
.sh-back button {
  background: none;
  border: 1px solid var(--border);
  color: var(--accent);
  padding: 6px 14px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 0.75rem;
  width: 100%;
}
.sh-back button:hover { background: rgba(99,245,198,0.08); }

.archived-banner {
  background: rgba(99,245,198,0.06) !important;
  border: 1px solid rgba(99,245,198,0.15);
  border-radius: 8px;
  padding: 8px 14px;
  font-size: 0.78rem;
  color: var(--accent);
  text-align: center;
  margin-bottom: 8px;
}

/* Make chat header position:relative for the dropdown */
.chat-header { position: relative; }

/* Pinned resources bar */
.pinned-resources-bar{display:none;padding:6px 16px;background:linear-gradient(135deg,#1a1a2e,#16213e);border-bottom:1px solid var(--border);flex-shrink:0;}
.pinned-resources-bar.visible{display:flex !important;align-items:center;gap:8px;flex-wrap:wrap;}
.pinned-item{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:6px;background:rgba(245,196,99,0.15);border:1px solid rgba(245,196,99,0.3);color:#f5c463;font-size:12px;cursor:pointer;transition:all 0.2s;text-decoration:none;}
.pinned-item:hover{background:rgba(245,196,99,0.25);border-color:#f5c463;transform:translateY(-1px);}
.pinned-item .pin-icon{font-size:14px;}
.pinned-item .pin-label{font-weight:500;}
.pinned-item .pin-status{font-size:10px;opacity:0.7;margin-left:4px;}
.pinned-upload-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;background:rgba(96,165,250,0.15);border:1px solid rgba(96,165,250,0.3);color:#60a5fa;font-size:11px;cursor:pointer;transition:all 0.2s;}
.pinned-upload-btn:hover{background:rgba(96,165,250,0.25);border-color:#60a5fa;}

/* R&D Workbook viewer */
.rd-workbook-view{padding:16px;max-width:100%;}
.rd-wb-header{margin-bottom:12px;}
.rd-wb-header h3{margin:0 0 4px;color:var(--text);font-size:16px;}
.rd-wb-meta{font-size:11px;color:var(--muted);}
.rd-sheet-tabs{display:flex;gap:4px;margin-bottom:8px;flex-wrap:wrap;border-bottom:1px solid var(--border);padding-bottom:6px;}
.rd-sheet-tab{padding:4px 12px;border:1px solid var(--border);border-radius:6px 6px 0 0;background:var(--bg);color:var(--muted);font-size:11px;cursor:pointer;transition:all 0.2s;border-bottom:none;}
.rd-sheet-tab.active{background:var(--panel);color:#f5c463;border-color:#f5c463;font-weight:600;}
.rd-sheet-tab:hover{background:var(--panel);}
.rd-table-wrap{overflow-x:auto;max-height:60vh;overflow-y:auto;border:1px solid var(--border);border-radius:6px;}
.rd-table{width:100%;border-collapse:collapse;font-size:12px;}
.rd-table th{position:sticky;top:0;background:#1a1a2e;color:#f5c463;padding:6px 10px;text-align:left;border-bottom:2px solid #f5c463;font-weight:600;white-space:nowrap;z-index:1;}
.rd-table td{padding:5px 10px;border-bottom:1px solid var(--border);color:var(--text);white-space:nowrap;max-width:250px;overflow:hidden;text-overflow:ellipsis;}
.rd-table tr:hover td{background:rgba(245,196,99,0.05);}
.rd-table tr:nth-child(even) td{background:rgba(255,255,255,0.02);}
.rd-empty-sheet{padding:30px;text-align:center;color:var(--muted);font-style:italic;}
.rd-wb-footer{margin-top:12px;padding:10px 14px;background:rgba(96,165,250,0.08);border:1px solid rgba(96,165,250,0.2);border-radius:8px;font-size:12px;color:var(--muted);}
.rd-wb-footer strong{color:var(--text);}

@media(max-width:768px) {
  .session-history-panel { width: 100%; right: 0; border-radius: 0 0 10px 10px; }
}

/* ═══ VOICE CONVERSATION OVERLAY ═══ */
#voice-overlay {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 9999;
  align-items: center;
  justify-content: center;
}
#voice-overlay.active { display: flex; }
.vo-backdrop {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(10, 12, 16, 0.92);
  backdrop-filter: blur(20px);
}
.vo-content {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  z-index: 1;
  padding: 40px;
  max-width: 400px;
  width: 90%;
}
.vo-agent-emoji {
  font-size: 4rem;
  line-height: 1;
  animation: vo-float 3s ease-in-out infinite;
}
@keyframes vo-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}
.vo-agent-name {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--text);
}
.vo-status {
  font-size: 0.9rem;
  color: var(--muted);
  transition: color 0.3s;
}
.vo-status.listening { color: #ef4444; }
.vo-status.thinking { color: var(--accent); }
.vo-status.speaking { color: var(--green); }

/* Visualizer bars */
.vo-visualizer {
  display: flex;
  gap: 4px;
  align-items: center;
  height: 50px;
  margin: 10px 0;
}
.vo-bar {
  width: 6px;
  height: 8px;
  background: var(--muted);
  border-radius: 3px;
  transition: background 0.3s;
}
.vo-visualizer.listening .vo-bar {
  background: #ef4444;
  animation: vo-bar-pulse 0.6s ease-in-out infinite alternate;
}
.vo-visualizer.listening .vo-bar:nth-child(1) { animation-delay: 0s; }
.vo-visualizer.listening .vo-bar:nth-child(2) { animation-delay: 0.08s; }
.vo-visualizer.listening .vo-bar:nth-child(3) { animation-delay: 0.16s; }
.vo-visualizer.listening .vo-bar:nth-child(4) { animation-delay: 0.24s; }
.vo-visualizer.listening .vo-bar:nth-child(5) { animation-delay: 0.32s; }
.vo-visualizer.listening .vo-bar:nth-child(6) { animation-delay: 0.40s; }
.vo-visualizer.listening .vo-bar:nth-child(7) { animation-delay: 0.48s; }
@keyframes vo-bar-pulse {
  0% { height: 8px; }
  100% { height: 40px; }
}
.vo-visualizer.thinking .vo-bar {
  background: var(--accent);
  animation: vo-bar-think 1.2s ease-in-out infinite;
}
.vo-visualizer.thinking .vo-bar:nth-child(1) { animation-delay: 0s; }
.vo-visualizer.thinking .vo-bar:nth-child(2) { animation-delay: 0.1s; }
.vo-visualizer.thinking .vo-bar:nth-child(3) { animation-delay: 0.2s; }
.vo-visualizer.thinking .vo-bar:nth-child(4) { animation-delay: 0.3s; }
.vo-visualizer.thinking .vo-bar:nth-child(5) { animation-delay: 0.4s; }
.vo-visualizer.thinking .vo-bar:nth-child(6) { animation-delay: 0.5s; }
.vo-visualizer.thinking .vo-bar:nth-child(7) { animation-delay: 0.6s; }
@keyframes vo-bar-think {
  0%, 100% { height: 8px; opacity: 0.4; }
  50% { height: 24px; opacity: 1; }
}
.vo-visualizer.speaking .vo-bar {
  background: var(--green);
  animation: vo-bar-speak 0.5s ease-in-out infinite alternate;
}
.vo-visualizer.speaking .vo-bar:nth-child(1) { animation-delay: 0s; }
.vo-visualizer.speaking .vo-bar:nth-child(2) { animation-delay: 0.07s; }
.vo-visualizer.speaking .vo-bar:nth-child(3) { animation-delay: 0.14s; }
.vo-visualizer.speaking .vo-bar:nth-child(4) { animation-delay: 0.21s; }
.vo-visualizer.speaking .vo-bar:nth-child(5) { animation-delay: 0.28s; }
.vo-visualizer.speaking .vo-bar:nth-child(6) { animation-delay: 0.35s; }
.vo-visualizer.speaking .vo-bar:nth-child(7) { animation-delay: 0.42s; }
@keyframes vo-bar-speak {
  0% { height: 10px; }
  100% { height: 36px; }
}

.vo-live-text {
  font-size: 1rem;
  color: var(--muted2);
  text-align: center;
  min-height: 1.4em;
  max-width: 340px;
  line-height: 1.4;
  font-style: italic;
}
.vo-stop-btn {
  margin-top: 20px;
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(239, 68, 68, 0.15);
  border: 1px solid rgba(239, 68, 68, 0.3);
  color: #ef4444;
  padding: 12px 28px;
  border-radius: 50px;
  cursor: pointer;
  font-size: 0.9rem;
  font-weight: 600;
  transition: all 0.2s;
}
.vo-stop-btn:hover {
  background: rgba(239, 68, 68, 0.25);
  transform: scale(1.05);
}

/* ═══ CONTACTS PAGE ═══ */
.contacts-scroll { flex: 1; overflow-y: auto; padding: 24px; }
.contacts-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 20px; }
.contacts-header h2 { color: var(--accent); margin-bottom: 6px; }
.contacts-header p { color: var(--muted2); font-size: 0.88rem; max-width: 720px; }
.contacts-header-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.contacts-refresh-btn, .contacts-new-btn, .contacts-save-btn, .contacts-clear-btn, .contacts-inline-btn {
  background: var(--panel2); border: 1px solid var(--border2); color: var(--text); padding: 10px 14px; border-radius: 10px; cursor: pointer; font-size: 0.82rem; font-family: inherit; transition: var(--transition);
}
.contacts-new-btn, .contacts-save-btn { background: var(--accent-dim); color: var(--accent); border-color: color-mix(in srgb, var(--accent) 35%, transparent); }
.contacts-refresh-btn:hover, .contacts-new-btn:hover, .contacts-save-btn:hover, .contacts-clear-btn:hover, .contacts-inline-btn:hover { border-color: var(--accent); color: var(--accent); }
.contacts-inline-btn.danger { color: var(--red); border-color: color-mix(in srgb, var(--red) 40%, transparent); }
.contacts-inline-btn.danger:hover { border-color: var(--red); background: rgba(248,113,113,0.08); }
.contacts-layout { display: grid; grid-template-columns: minmax(300px, 360px) minmax(0, 1fr); gap: 20px; align-items: start; }
.contacts-form-card, .contacts-table-card { background: var(--panel); border: 1px solid var(--border); border-radius: 16px; box-shadow: 0 10px 28px rgba(0,0,0,.18); }
.contacts-form-card { padding: 18px; position: sticky; top: 16px; }
.contacts-form-head, .contacts-table-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 16px; }
.contacts-kicker { font-size: 0.68rem; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin-bottom: 6px; }
.contacts-form-head h3, .contacts-table-head h3 { font-size: 1.02rem; color: var(--text); }
.contacts-summary { color: var(--muted); font-size: 0.78rem; }
.contacts-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.contacts-field, .contacts-checkbox-field { display: flex; flex-direction: column; gap: 6px; font-size: 0.78rem; color: var(--muted2); }
.contacts-field-wide { grid-column: 1 / -1; }
.contacts-field input, .contacts-field select { width: 100%; padding: 10px 12px; border-radius: 10px; border: 1px solid var(--border2); background: var(--bg2); color: var(--text); font: inherit; outline: none; }
.contacts-field input:focus, .contacts-field select:focus { border-color: var(--accent); }
.contacts-checkbox-field { flex-direction: row; align-items: center; padding-top: 4px; }
.contacts-checkbox-field input { width: 16px; height: 16px; accent-color: var(--accent); }
.contacts-form-actions { margin-top: 16px; display: flex; justify-content: flex-end; }
.contacts-access-denied { padding: 18px; border: 1px solid rgba(248,113,113,0.25); background: rgba(248,113,113,0.08); color: var(--red); border-radius: 14px; }
.contacts-table-wrap { overflow: auto; border-radius: 14px; border: 1px solid var(--border); }
.contacts-table { width: 100%; min-width: 1100px; border-collapse: collapse; font-size: 0.8rem; }
.contacts-table th, .contacts-table td { padding: 12px 14px; border-bottom: 1px solid var(--border); vertical-align: top; }
.contacts-table th { text-align: left; color: var(--muted2); font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.04em; background: rgba(255,255,255,0.03); position: sticky; top: 0; z-index: 1; }
.contacts-table tbody tr:nth-child(odd) td { background: rgba(255,255,255,0.012); }
.contacts-table tbody tr:hover td { background: rgba(99,245,198,0.035); }
.contacts-table input, .contacts-table select { width: 100%; padding: 8px 10px; border-radius: 8px; border: 1px solid var(--border2); background: var(--bg2); color: var(--text); font: inherit; }
.contacts-table input:focus, .contacts-table select:focus { outline: none; border-color: var(--accent); }
.contacts-cell-muted { color: var(--muted); font-size: 0.76rem; }
.contacts-meta { color: var(--muted2); font-size: 0.74rem; line-height: 1.45; }
.contacts-actions { display: flex; flex-direction: column; gap: 8px; min-width: 112px; }
.contacts-toggle { display: inline-flex; align-items: center; gap: 8px; color: var(--text); }
.contacts-toggle input { width: 16px; height: 16px; accent-color: var(--accent); }
.contacts-empty-cell { text-align: center; color: var(--muted); padding: 26px 16px; }

/* ═══ ADMIN PANEL ═══ */
.admin-panel { padding: 24px; max-width: 1200px; margin: 0 auto; }
.admin-panel h2 { color: var(--accent); margin-bottom: 16px; }
.admin-tabs { display: flex; gap: 4px; flex-wrap: wrap; margin-bottom: 16px; border-bottom: 1px solid var(--border); padding-bottom: 8px; }
.admin-tab { background: transparent; border: none; color: var(--muted); padding: 8px 14px; border-radius: 6px; cursor: pointer; font-size: 0.85rem; transition: all 0.2s; }
.admin-tab:hover { background: var(--hover); color: var(--text); }
.admin-tab.active { background: var(--accent-dim); color: var(--accent); font-weight: 600; }
.admin-content { min-height: 300px; }
.admin-loading { color: var(--muted); text-align: center; padding: 40px; }
.admin-error { color: var(--red); padding: 16px; background: rgba(239,68,68,0.08); border-radius: 8px; }
.admin-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 16px; }
.admin-card { background: var(--card); border: 1px solid var(--border); border-radius: 10px; padding: 16px; }
.admin-card-title { font-size: 0.8rem; color: var(--muted); margin-bottom: 4px; }
.admin-card-value { font-size: 1.3rem; font-weight: 700; color: var(--text); }
.admin-card-detail { font-size: 0.75rem; color: var(--muted2); margin-top: 4px; }
.admin-json { background: var(--card); border: 1px solid var(--border); border-radius: 8px; padding: 16px; color: var(--text); font-size: 0.8rem; overflow-x: auto; max-height: 500px; overflow-y: auto; white-space: pre-wrap; word-break: break-word; }
.admin-list { display: flex; flex-direction: column; gap: 8px; }
.admin-list-item { background: var(--card); border: 1px solid var(--border); border-radius: 8px; padding: 12px 16px; }
.admin-list-item strong { color: var(--text); }
.admin-tag { background: var(--accent-dim); color: var(--accent); padding: 2px 8px; border-radius: 4px; font-size: 0.75rem; margin-left: 8px; }
.admin-logs { background: var(--bg2, #111); border: 1px solid var(--border); border-radius: 8px; padding: 12px; max-height: 500px; overflow-y: auto; font-family: monospace; font-size: 0.78rem; }
.admin-log-line { padding: 2px 0; color: var(--muted2); border-bottom: 1px solid rgba(255,255,255,0.03); white-space: pre-wrap; word-break: break-all; }
.admin-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.admin-action-btn { background: var(--card); border: 1px solid var(--border); color: var(--text); padding: 8px 16px; border-radius: 8px; cursor: pointer; font-size: 0.85rem; transition: all 0.2s; }
.admin-action-btn:hover { background: var(--hover); border-color: var(--accent); }
.admin-action-btn.danger { border-color: var(--red); color: var(--red); }
.admin-action-btn.danger:hover { background: rgba(239,68,68,0.1); }

/* OpenClaw nav link button */
.topbar-link-btn {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--muted);
  padding: 6px 14px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 0.82rem;
  text-decoration: none;
  transition: all 0.2s;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.topbar-link-btn:hover {
  background: var(--hover);
  color: var(--accent);
  border-color: var(--accent);
}

/* ═══════════════════════════════════════════════════════════════════════
   MEDIA & FILES PANEL (Phase 3)
   ═══════════════════════════════════════════════════════════════════════ */
:root {
  --mf-accent: #00cec9;
  --mf-accent-dim: rgba(0,206,201,0.14);
  --mf-panel-w: 480px;
  --mf-collapsed-w: 48px;
}

/* Root host inside .chat-layout (right edge, pushes chat) */
#mf-root { display: flex; height: 100%; flex-shrink: 0; }

/* ── Collapsed icon rail ──────────────────────────────── */
.mf-collapsed-bar {
  width: var(--mf-collapsed-w);
  background: var(--bg2);
  border-left: 1px solid var(--border);
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 14px;
  transition: width .2s ease, opacity .2s ease;
}
.mf-collapsed-bar.hidden { display: none; }
.mf-collapsed-btn {
  all: unset;
  cursor: pointer;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 10px 4px; border-radius: 10px;
  width: calc(var(--mf-collapsed-w) - 10px);
  color: var(--muted2);
  transition: background .15s ease, color .15s ease, transform .15s ease;
}
.mf-collapsed-btn:hover { background: var(--mf-accent-dim); color: var(--mf-accent); transform: translateY(-1px); }
.mf-collapsed-icon { font-size: 1.25rem; line-height: 1; }
.mf-collapsed-count {
  font-size: 0.65rem; font-weight: 700; letter-spacing: .02em;
  background: var(--mf-accent); color: var(--bg);
  padding: 1px 6px; border-radius: 999px; min-width: 18px; text-align: center;
}
.mf-collapsed-label {
  font-size: 0.6rem; letter-spacing: .14em; font-weight: 700;
  writing-mode: vertical-rl; transform: rotate(180deg);
  margin-top: 2px; opacity: .7;
}

/* ── Panel (expanded) ─────────────────────────────────── */
.mf-panel {
  width: 0;
  max-width: var(--mf-panel-w);
  background: var(--bg2);
  border-left: 1px solid var(--border);
  display: flex; flex-direction: column;
  overflow: hidden;
  transition: width .2s ease;
  flex-shrink: 0;
}
.mf-panel.open { width: var(--mf-panel-w); }

.mf-header {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 14px; border-bottom: 1px solid var(--border);
  background: var(--panel);
  flex-shrink: 0;
}
.mf-title { flex: 1; font-size: 0.88rem; font-weight: 700; color: var(--text); letter-spacing: .01em; }
.mf-close, .mf-back {
  all: unset; cursor: pointer;
  width: 28px; height: 28px; border-radius: 7px;
  display: flex; align-items: center; justify-content: center;
  color: var(--muted2); font-size: 0.92rem;
  transition: background .15s ease, color .15s ease;
}
.mf-close:hover, .mf-back:hover { background: var(--border); color: var(--text); }
.mf-back { display: none; } /* shown only on mobile */

/* ── Search bar ───────────────────────────────────────── */
.mf-search {
  position: relative; padding: 10px 12px; border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.mf-search-icon {
  position: absolute; left: 22px; top: 50%; transform: translateY(-50%);
  font-size: 0.85rem; opacity: .6; pointer-events: none;
}
#mf-search-input {
  width: 100%; padding: 8px 32px 8px 32px;
  background: var(--bg); border: 1px solid var(--border2); color: var(--text);
  border-radius: 10px; font-size: 0.82rem; font-family: inherit; outline: none;
}
#mf-search-input:focus { border-color: var(--mf-accent); box-shadow: 0 0 0 3px var(--mf-accent-dim); }
#mf-search-input::placeholder { color: var(--muted); }
.mf-search-clear {
  all: unset; cursor: pointer;
  position: absolute; right: 18px; top: 50%; transform: translateY(-50%);
  width: 20px; height: 20px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--muted); font-size: 0.7rem; background: var(--panel);
}
.mf-search-clear:hover { color: var(--text); background: var(--border); }

/* ── Upload pill ──────────────────────────────────────── */
.mf-upload-pill {
  margin: 8px 12px; padding: 8px 12px;
  background: var(--panel); border: 1px solid var(--border2);
  border-radius: 999px; font-size: 0.78rem; color: var(--text);
  display: inline-flex; align-items: center; gap: 8px;
  cursor: pointer; align-self: flex-start;
}
.mf-upload-pill.success { border-color: color-mix(in srgb, var(--green) 40%, transparent); color: var(--green); background: var(--green-dim); }
.mf-dot-spin {
  width: 10px; height: 10px; border-radius: 50%;
  border: 2px solid var(--mf-accent); border-top-color: transparent;
  animation: mf-spin .8s linear infinite;
}
@keyframes mf-spin { to { transform: rotate(360deg); } }

/* ── Body layout ──────────────────────────────────────── */
.mf-body { flex: 1; display: flex; flex-direction: column; overflow: hidden; }

/* ── Folders section ──────────────────────────────────── */
.mf-folders { padding: 10px 10px 8px; border-bottom: 1px solid var(--border); flex-shrink: 0; max-height: 260px; display: flex; flex-direction: column; }
.mf-folders-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 2px 6px 8px; font-size: 0.62rem; font-weight: 800;
  letter-spacing: .14em; color: var(--muted); text-transform: uppercase;
}
.mf-folder-add {
  all: unset; cursor: pointer;
  width: 22px; height: 22px; border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  color: var(--mf-accent); font-size: 1rem; font-weight: 700;
  background: var(--mf-accent-dim);
}
.mf-folder-add:hover { background: var(--mf-accent); color: var(--bg); }
.mf-folder-tree { flex: 1; overflow-y: auto; margin: 0 -4px; padding: 0 4px; }
.mf-folder-tree.searching { opacity: .5; pointer-events: none; }
.mf-folder-loading { padding: 10px 8px; color: var(--muted); font-size: 0.78rem; }
.mf-folder-sub {
  font-size: 0.6rem; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--muted); padding: 10px 8px 4px;
}
.mf-folder-group { }
.mf-folder-row {
  all: unset; display: flex; align-items: center; gap: 6px;
  width: 100%; min-width: 0; box-sizing: border-box;
  padding: 7px 8px; border-radius: 7px;
  font-size: 0.82rem; color: var(--text); cursor: pointer;
  transition: background .12s ease, color .12s ease;
  position: relative;
}
.mf-folder-row:hover { background: var(--panel); }
.mf-folder-row.active { background: var(--mf-accent-dim); color: var(--mf-accent); }
.mf-folder-row.active .mf-folder-count { background: var(--mf-accent); color: var(--bg); }
.mf-folder-row.indent { padding-left: 22px; }
.mf-folder-parent { font-weight: 600; }
.mf-tree-arrow { width: 14px; text-align: center; color: var(--muted); font-size: 0.7rem; }
.mf-tree-arrow-spacer { width: 14px; flex: 0 0 14px; text-align: center; color: var(--muted); font-size: 0.7rem; }
.mf-folder-icon { font-size: 0.9rem; width: 18px; text-align: center; }
.mf-folder-name { flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mf-folder-meta { font-size: 0.66rem; color: var(--muted2); margin-right: 6px; text-transform: uppercase; }
.mf-folder-count {
  font-size: 0.66rem; font-weight: 700;
  background: var(--border); color: var(--muted2);
  padding: 1px 7px; border-radius: 999px; min-width: 20px; text-align: center; flex: 0 0 auto;
}
.mf-folder-delete {
  all: unset; cursor: pointer;
  width: 18px; height: 18px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--muted); font-size: 1rem; line-height: 1;
  opacity: 0; transition: opacity .12s ease, color .12s ease;
}
.mf-folder-row:hover .mf-folder-delete { opacity: 1; }
.mf-folder-delete:hover { color: var(--red); }

.mf-new-folder-form {
  display: flex; gap: 6px; padding: 6px 4px 10px;
  border-bottom: 1px dashed var(--border); margin-bottom: 6px;
}
.mf-new-folder-form input {
  flex: 1; background: var(--bg); border: 1px solid var(--border2); color: var(--text);
  border-radius: 7px; padding: 6px 10px; font-size: 0.8rem; font-family: inherit; outline: none;
}
.mf-new-folder-form input:focus { border-color: var(--mf-accent); }

/* ── Filter chips ─────────────────────────────────────── */
.mf-filters {
  display: flex; gap: 6px; overflow-x: auto;
  padding: 10px 12px; border-bottom: 1px solid var(--border);
  flex-shrink: 0; scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.mf-filters::-webkit-scrollbar { display: none; height: 0; }
.mf-chip {
  all: unset; cursor: pointer; flex-shrink: 0;
  padding: 5px 12px; border-radius: 999px;
  border: 1px solid var(--border2); color: var(--muted2);
  font-size: 0.72rem; font-weight: 600;
  transition: background .12s ease, color .12s ease, border-color .12s ease;
}
.mf-rnd-toggle { border-color: var(--mf-accent); opacity: 0.7; }
.mf-rnd-toggle.active { background: var(--mf-accent); color: #000; opacity: 1; }
.mf-chip:hover { color: var(--text); border-color: var(--border2); }
.mf-chip.active { background: var(--mf-accent); color: var(--bg); border-color: var(--mf-accent); }

/* ── Grid ─────────────────────────────────────────────── */
.mf-grid-wrap { flex: 1; display: flex; flex-direction: column; overflow: hidden; }
.mf-grid-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px 6px; flex-shrink: 0;
}
.mf-grid-title { font-size: 0.82rem; font-weight: 700; color: var(--text); }
.mf-grid-count { font-size: 0.7rem; color: var(--muted); }
.mf-grid {
  flex: 1; overflow-y: auto;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 14px; padding: 10px 14px 20px;
  align-content: start;
}
.mf-grid.mf-grid-visual {
  grid-template-columns: 1fr;
  gap: 10px;
}
.mf-grid.mf-grid-docs {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.mf-grid.mf-grid-list {
  grid-template-columns: 1fr;
  gap: 10px;
}
.mf-row {
  display: grid;
  grid-template-columns: 20px 72px 1fr auto;
  gap: 10px;
  align-items: center;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 8px 10px;
  cursor: pointer;
}
.mf-row:hover {
  border-color: var(--mf-accent);
  box-shadow: 0 4px 14px rgba(0,0,0,.18);
}
.mf-row-select {
  display: flex; align-items: center; justify-content: center;
}
.mf-row-thumb {
  width: 72px; height: 72px; border-radius: 10px; overflow: hidden;
  background: linear-gradient(135deg, rgba(255,255,255,0.03), rgba(0,0,0,0.15));
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--border);
}
.mf-row-thumb.receipt { background: #0f1218; }
.mf-row-thumb-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mf-row-thumb.receipt .mf-row-thumb-img { object-fit: contain; }
.mf-row-thumb-icon { font-size: 2rem; }
.mf-row-body { min-width: 0; overflow: hidden; }
.mf-row-name {
  font-size: 0.82rem; font-weight: 600; color: var(--text);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0;
}
.mf-row-meta {
  margin-top: 4px; font-size: 0.68rem; color: var(--muted);
  display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
}
.mf-row-actions {
  display: flex; gap: 6px; align-items: center; justify-content: flex-end;
}
.mf-row-actions .mf-card-act {
  background: rgba(255,255,255,.08); color: var(--text);
}
@media (max-width: 600px) {
  .mf-grid, .mf-grid.mf-grid-visual, .mf-grid.mf-grid-docs { gap: 10px; padding: 8px 10px 16px; }
  .mf-grid.mf-grid-docs { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .mf-grid.mf-grid-list { grid-template-columns: 1fr; }
}

.mf-empty {
  grid-column: 1 / -1;
  text-align: center; color: var(--muted2); font-size: 0.82rem;
  padding: 40px 14px; line-height: 1.5;
}
.mf-empty-sub { color: var(--muted); font-size: 0.75rem; }
.mf-loading { display: flex; flex-direction: column; align-items: center; gap: 10px; }
.mf-spinner {
  width: 20px; height: 20px; border-radius: 50%;
  border: 2px solid var(--border2); border-top-color: var(--mf-accent);
  animation: mf-spin .7s linear infinite;
}

.mf-card {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 10px; overflow: hidden; cursor: pointer;
  transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease;
  display: flex; flex-direction: column;
}
.mf-card:hover { transform: translateY(-2px); border-color: var(--mf-accent); box-shadow: 0 6px 18px rgba(0,0,0,.25); }
.mf-thumb {
  position: relative; aspect-ratio: 1/1;
  background: linear-gradient(135deg, rgba(255,255,255,0.03), rgba(0,0,0,0.15));
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; border-bottom: 1px solid var(--border);
  flex-direction: column; gap: 4px;
}
.mf-thumb-img {
  width: 100%; height: 100%; object-fit: cover;
  display: block;
}
.mf-card-receipt .mf-thumb-img {
  object-fit: contain;
  background: #0f1218;
}
.mf-thumb-icon { font-size: 3rem; opacity: .95; line-height: 1; filter: drop-shadow(0 2px 4px rgba(0,0,0,.3)); }
.mf-thumb-ext {
  position: absolute; bottom: 10px; right: 10px;
  font-size: 0.58rem; font-weight: 800; letter-spacing: .05em;
  background: rgba(0,0,0,.55); color: #fff;
  padding: 2px 6px; border-radius: 4px;
}
.mf-thumb-label {
  font-size: 0.72rem; font-weight: 700; color: var(--muted2);
  letter-spacing: .02em; text-transform: uppercase;
}
.mf-card-badges {
  position: absolute; top: 6px; left: 6px;
  display: flex; gap: 4px; font-size: 0.75rem;
}
.mf-badge-shared, .mf-badge-rnd {
  background: rgba(0,0,0,.5); color: #fff;
  padding: 2px 5px; border-radius: 4px;
}
.mf-card-actions {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,.6));
  display: flex; align-items: flex-end; justify-content: center;
  gap: 6px; padding: 8px;
  opacity: 0; transition: opacity .15s ease;
}
.mf-card:hover .mf-card-actions { opacity: 1; }
.mf-card-act {
  all: unset; cursor: pointer;
  width: 30px; height: 30px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.12); color: #fff; font-size: 0.85rem;
  backdrop-filter: blur(6px);
  transition: background .12s ease, transform .12s ease;
}
.mf-card-act:hover { background: var(--mf-accent); color: var(--bg); transform: scale(1.08); }
.mf-card-name {
  padding: 8px 10px 2px; font-size: 0.78rem; font-weight: 600; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mf-card-meta {
  padding: 0 10px 10px; font-size: 0.68rem; color: var(--muted);
  display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
}
.mf-card-kind {
  color: var(--mf-accent); font-weight: 700;
}
.mf-inline-badge {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 2px 7px; border-radius: 999px; font-size: 0.62rem; font-weight: 800;
  letter-spacing: 0.02em; text-transform: uppercase;
}
.mf-inline-badge.rnd {
  background: rgba(245, 196, 99, 0.14); color: var(--gold); border: 1px solid rgba(245, 196, 99, 0.24);
}
.mf-inline-badge.shared {
  background: rgba(99, 245, 198, 0.1); color: var(--accent); border: 1px solid rgba(99, 245, 198, 0.22);
}
.mf-card-file .mf-thumb {
  padding: 16px;
  background: linear-gradient(135deg, rgba(255,255,255,0.04), rgba(0,0,0,0.18));
}
.mf-card-file .mf-thumb-icon {
  font-size: 3.6rem;
}
.mf-card-file .mf-card-name {
  white-space: normal;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.4em;
}
.mf-card-photo .mf-thumb,
.mf-card-receipt .mf-thumb {
  aspect-ratio: 4 / 3;
}
.mf-card-photo .mf-card-name,
.mf-card-receipt .mf-card-name {
  white-space: normal;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.4em;
}
.mf-card-photo .mf-card-meta,
.mf-card-receipt .mf-card-meta {
  gap: 4px;
}
.mf-browser-grid.mf-browser-grid-visual {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.mf-browser-grid.mf-browser-grid-docs {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* ── Modal ────────────────────────────────────────────── */
.mf-modal-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(0,0,0,.65); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  animation: mf-fade-in .15s ease;
}
@keyframes mf-fade-in { from { opacity: 0; } to { opacity: 1; } }
.mf-modal {
  background: var(--panel); border: 1px solid var(--border2); border-radius: 14px;
  max-width: 900px; width: 100%; max-height: 92vh;
  display: flex; flex-direction: column;
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
  overflow: hidden;
}
.mf-modal-sm { max-width: 480px; }
.mf-modal-head {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px; border-bottom: 1px solid var(--border);
  background: var(--bg2);
}
.mf-modal-title {
  flex: 1; min-width: 0;
  display: flex; align-items: center; gap: 10px;
  font-size: 0.92rem; font-weight: 700; color: var(--text);
}
.mf-modal-icon { font-size: 1.2rem; }
.mf-modal-name { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mf-modal-meta {
  display: flex; gap: 10px; font-size: 0.72rem; color: var(--muted2);
  align-items: center;
}
.mf-modal-folder {
  background: var(--mf-accent-dim); color: var(--mf-accent);
  padding: 2px 8px; border-radius: 999px; font-weight: 700;
}
.mf-modal-close {
  all: unset; cursor: pointer;
  width: 30px; height: 30px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: var(--muted2);
}
.mf-modal-close:hover { background: var(--border); color: var(--text); }
.mf-modal-body {
  flex: 1; overflow: auto;
  background: var(--bg);
  min-height: 200px; display: flex; align-items: center; justify-content: center;
}
.mf-share-body { display: block; padding: 16px 18px; }
.mf-modal-sm .mf-modal-body { min-height: 0; padding: 16px 18px; display: block; }
.mf-preview-img { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; padding: 10px; }
.mf-preview-img img { max-width: 100%; max-height: 78vh; object-fit: contain; border-radius: 6px; box-shadow: 0 4px 20px rgba(0,0,0,.3); }
.mf-preview-pdf { width: 100%; height: 78vh; border: none; background: #fff; }
.mf-preview-generic { text-align: center; padding: 40px; }
.mf-preview-icon { font-size: 3rem; margin-bottom: 8px; }
.mf-preview-ext { font-size: 0.8rem; font-weight: 700; color: var(--muted2); letter-spacing: .1em; margin-bottom: 8px; }
.mf-preview-hint { font-size: 0.78rem; color: var(--muted); }

.mf-modal-extras {
  padding: 10px 18px; background: var(--bg2); border-top: 1px solid var(--border);
  display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
}
.mf-modal-receipt {
  font-size: 0.78rem; color: var(--gold); background: var(--gold-dim);
  padding: 4px 10px; border-radius: 7px; font-weight: 600;
}
.mf-modal-tags { display: flex; flex-wrap: wrap; gap: 5px; }
.mf-tag {
  font-size: 0.7rem; padding: 3px 9px; border-radius: 999px;
  background: var(--border); color: var(--muted2);
}

.mf-modal-foot {
  display: flex; gap: 8px; padding: 12px 18px;
  border-top: 1px solid var(--border); background: var(--bg2);
  flex-wrap: wrap;
}
.mf-foot-right { justify-content: flex-end; }

.mf-btn {
  all: unset; cursor: pointer;
  padding: 8px 14px; border-radius: 8px;
  background: var(--panel); border: 1px solid var(--border2);
  color: var(--text); font-size: 0.78rem; font-weight: 600;
  transition: background .12s ease, border-color .12s ease, color .12s ease;
}
.mf-btn:hover { border-color: var(--mf-accent); color: var(--mf-accent); }
.mf-btn.primary { background: var(--mf-accent); color: var(--bg); border-color: var(--mf-accent); }
.mf-btn.primary:hover { opacity: .9; }
.mf-btn.danger:hover { border-color: var(--red); color: var(--red); }
.mf-btn-sm { padding: 5px 9px; font-size: 0.72rem; }

.mf-field-label {
  display: block; font-size: 0.7rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; color: var(--muted);
  margin-bottom: 6px;
}
.mf-select, .mf-input {
  width: 100%; box-sizing: border-box;
  padding: 9px 12px; border-radius: 8px;
  background: var(--bg); border: 1px solid var(--border2); color: var(--text);
  font-size: 0.84rem; font-family: inherit; outline: none;
}
.mf-select:focus, .mf-input:focus { border-color: var(--mf-accent); box-shadow: 0 0 0 3px var(--mf-accent-dim); }

/* Share list */
.mf-share-hint { font-size: 0.78rem; color: var(--muted2); margin-bottom: 10px; }
.mf-share-list { display: flex; flex-direction: column; gap: 4px; max-height: 320px; overflow-y: auto; }
.mf-share-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; border-radius: 8px; cursor: pointer;
  font-size: 0.82rem; background: var(--bg); border: 1px solid transparent;
  transition: background .12s ease, border-color .12s ease;
}
.mf-share-row:hover { background: var(--panel); border-color: var(--border2); }
.mf-share-row input[type="checkbox"] { accent-color: var(--mf-accent); width: 16px; height: 16px; cursor: pointer; }
.mf-share-name { flex: 1; font-weight: 600; color: var(--text); }
.mf-share-email { font-size: 0.72rem; color: var(--muted); }
.mf-share-empty { padding: 20px 10px; text-align: center; color: var(--muted); font-size: 0.82rem; }

/* ── Toasts ───────────────────────────────────────────── */
#mf-toast-host {
  position: fixed; right: 20px; bottom: 24px; z-index: 1100;
  display: flex; flex-direction: column; gap: 8px;
  pointer-events: none;
  max-width: min(420px, calc(100vw - 24px));
}
.mf-toast {
  background: var(--panel); border: 1px solid var(--border2);
  color: var(--text); padding: 10px 16px;
  border-radius: 10px; font-size: 0.82rem;
  box-shadow: 0 8px 30px rgba(0,0,0,.35);
  opacity: 0; transform: translateY(8px);
  transition: opacity .2s ease, transform .2s ease;
  pointer-events: auto;
}
.mf-toast.show { opacity: 1; transform: translateY(0); }
.mf-toast.success { border-color: color-mix(in srgb, var(--green) 50%, transparent); color: var(--green); }
.mf-toast.error { border-color: color-mix(in srgb, var(--red) 50%, transparent); color: var(--red); }

/* ── Small-width adjustments ──────────────────────────── */
@media (max-width: 1100px) {
  .contacts-layout { grid-template-columns: 1fr; }
  .contacts-form-card { position: static; }
  /* If chat is cramped, hide the right chat-members when panel open */
  body.mf-panel-open .chat-members { display: none; }
}

/* ── Mobile (<768px): fullscreen takeover ─────────────── */
@media (max-width: 768px) {
  .mf-collapsed-bar {
    position: fixed; right: 10px; bottom: 70px;
    width: 44px; height: 44px; border-radius: 50%;
    border: 1px solid var(--border2); padding: 0;
    background: var(--panel); z-index: 40;
    box-shadow: 0 6px 16px rgba(0,0,0,.35);
    align-items: center;
  }
  .mf-collapsed-btn { flex-direction: row; width: auto; padding: 6px; }
  .mf-collapsed-label { display: none; }
  .mf-collapsed-icon { font-size: 1.1rem; }
  .mf-collapsed-count { font-size: 0.6rem; padding: 0 5px; }

  /* Mobile: mf-root takes NO layout space — panel floats above everything */
  #mf-root { width: 0; height: 0; overflow: visible; flex-shrink: 0; }
  .mf-collapsed-bar { position: fixed; } /* already fixed, keep it out of flow */

  /* Mobile panel: hidden off-screen by default, slides in when .open */
  .mf-panel {
    position: fixed; inset: 0; z-index: 60;
    width: 100%; max-width: 100%;
    border-left: none;
    overflow-x: hidden;
    /* Slide off-screen to the right when closed */
    transform: translateX(100%);
    transition: transform 0.22s ease;
    visibility: hidden;
    pointer-events: none;
  }
  .mf-panel.open {
    transform: translateX(0);
    visibility: visible;
    pointer-events: auto;
  }

  /* Backdrop behind panel — tap to close */
  .mf-panel-backdrop {
    display: none;
    position: fixed; inset: 0;
    background: rgba(0,0,0,.55);
    z-index: 59;
  }
  .mf-panel-backdrop.active { display: block; }

  /* When panel open: hide chat layout behind it */
  body.mf-panel-open .topbar,
  body.mf-panel-open .chat-layout { /* panel covers via fixed positioning */ }

  /* On mobile: show ✕ close, hide ← back (back is only for sub-navigation) */
  .mf-back { display: flex; }
  .mf-close { display: flex !important; min-width: 40px; min-height: 40px; font-size: 1.1rem; z-index: 61; position: relative; }
  .mf-header-link { display: none; } /* hide 'Open full browser' on mobile to give ✕ room */
  .mf-folders { max-height: 40%; }
  .mf-grid { grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); }
  .mf-btn { padding: 10px 14px; font-size: 0.82rem; }
  .mf-chip { padding: 8px 14px; font-size: 0.78rem; }
  .mf-card-actions { opacity: 1; } /* touch — always show */
  .mf-row-thumb { width: 56px; height: 56px; }
}

@media (max-width: 480px) {
  .mf-grid { grid-template-columns: repeat(2, 1fr); }
  .contacts-scroll { padding: 16px; }
  .contacts-form-grid { grid-template-columns: 1fr; }
}

.mf-header-link{all:unset;cursor:pointer;font-size:.75rem;color:var(--mf-accent);padding:6px 10px;border-radius:8px;background:var(--mf-accent-dim);font-weight:700;}
.mf-header-link:hover{opacity:.9;}
.mf-selection-bar,.mf-grid-footer{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:8px 14px;border-top:1px solid var(--border);background:var(--bg2);}
.mf-selection-bar{position:sticky;bottom:0;z-index:3;box-shadow:0 -8px 20px rgba(0,0,0,.22);}
.mf-selection-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;}
.mf-action-divider{display:inline-block;width:1px;height:22px;background:var(--border);opacity:.8;align-self:center;}
.mf-grid-footer{justify-content:center;}
.mf-folder-help{margin-top:8px;font-size:.74rem;line-height:1.45;color:var(--muted);}
.mf-select-toggle{position:absolute;top:8px;right:8px;z-index:2;display:flex;cursor:pointer;}
.mf-select-toggle input{position:absolute;opacity:0;pointer-events:none;}
.mf-select-toggle span{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.8);background:rgba(0,0,0,.35);display:block;}
.mf-select-toggle input:checked+span{background:var(--mf-accent);border-color:var(--mf-accent);box-shadow:inset 0 0 0 4px var(--bg);}
.mf-card.browser{min-height:220px;}

.mf-browser-overlay{position:fixed;inset:0;z-index:90;background:rgba(8,10,14,.94);backdrop-filter:blur(10px);padding:18px;overflow:auto;}
.mf-browser-page{min-height:100%;max-height:calc(100vh - 36px);background:var(--bg);border:1px solid var(--border);border-radius:18px;display:flex;flex-direction:column;overflow:hidden;}
.mf-browser-top,.mf-browser-toolbar,.mf-browser-header-row,.mf-browser-pagination{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.mf-browser-top{padding:18px 22px;border-bottom:1px solid var(--border);background:var(--panel);position:sticky;top:0;z-index:4;}
.mf-browser-title{font-size:1.1rem;font-weight:800;}
.mf-browser-subtitle{font-size:.8rem;color:var(--muted2);margin-top:2px;}
.mf-browser-toolbar{padding:14px 22px;border-bottom:1px solid var(--border);background:var(--bg2);display:grid;grid-template-columns:minmax(260px,1fr) auto;align-items:center;gap:12px;position:sticky;top:73px;z-index:4;}
.mf-browser-toolbar .mf-btn{white-space:nowrap;}
.mf-browser-toolbar-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end;min-width:0;}
.mf-browser-search{flex:1;min-width:0;width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--border2);background:var(--bg);color:var(--text);font:inherit;outline:none;}
.mf-browser-search:focus{border-color:var(--mf-accent);box-shadow:0 0 0 3px var(--mf-accent-dim);}
.mf-browser-content{display:grid;grid-template-columns:minmax(240px,300px) minmax(0,1fr);min-height:0;flex:1;overflow:hidden;}
.mf-browser-sidebar{border-right:1px solid var(--border);background:var(--bg2);padding:14px;overflow:auto;min-width:0;}
.mf-browser-main{display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden;}
.mf-browser-folder-list{display:flex;flex-direction:column;gap:2px;}
.mf-browser-filters{position:sticky;top:0;z-index:3;background:var(--bg);padding-top:10px;padding-bottom:10px;}
.mf-browser-header-row{padding:14px 20px 0;color:var(--muted2);font-size:.85rem;flex-wrap:wrap;position:sticky;top:60px;z-index:3;background:var(--bg);}
.mf-browser-grid{padding:20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;flex:1;align-content:start;overflow:auto;min-height:0;}
.mf-browser-grid.mf-browser-grid-list{grid-template-columns:1fr;gap:12px;align-content:start;}
.mf-browser-grid.mf-browser-grid-list .mf-row{grid-template-columns:24px 88px minmax(0,1fr) auto;padding:12px;}
.mf-browser-grid.mf-browser-grid-list .mf-row-thumb{width:88px;height:88px;}
.mf-browser-grid.mf-browser-grid-list .mf-row-name{font-size:.92rem;-webkit-line-clamp:2;}
.mf-browser-grid.mf-browser-grid-list .mf-row-meta{font-size:.74rem;}
.mf-browser-pagination{padding:14px 20px;border-top:1px solid var(--border);justify-content:center;color:var(--muted2);flex-wrap:wrap;position:sticky;bottom:0;background:var(--bg2);z-index:3;}
body.mf-browser-open{overflow:hidden;}

@media (max-width: 1100px){
  .mf-browser-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));}
}
@media (max-width: 980px){
  .mf-browser-page{max-height:100vh;}
  .mf-browser-toolbar{grid-template-columns:1fr;align-items:stretch;}
  .mf-browser-toolbar-actions{justify-content:flex-start;}
  .mf-browser-content{grid-template-columns:1fr;}
  .mf-browser-sidebar{border-right:none;border-bottom:1px solid var(--border);max-height:220px;}
  .mf-browser-filters{top:0;}
  .mf-browser-header-row{top:60px;}
}
@media (max-width: 640px){
  .mf-browser-overlay{padding:0;}
  .mf-browser-page{border-radius:0;border:none;max-height:100vh;}
  .mf-browser-top,.mf-browser-toolbar,.mf-browser-header-row,.mf-browser-pagination{padding-left:14px;padding-right:14px;}
  .mf-browser-top{align-items:stretch;flex-direction:column;top:0;}
  .mf-browser-toolbar{top:73px;grid-template-columns:1fr;align-items:stretch;}
  .mf-browser-toolbar-actions{justify-content:stretch;display:grid;grid-template-columns:1fr;}
  .mf-browser-toolbar .mf-btn,.mf-browser-top .mf-btn{width:100%;justify-content:center;box-sizing:border-box;}
  .mf-browser-search{min-width:0;width:100%;}
  .mf-browser-filters{top:0;padding-top:12px;}
  .mf-browser-header-row{top:64px;}
  .mf-browser-grid{padding:14px;grid-template-columns:1fr;}
  .mf-browser-grid.mf-browser-grid-list .mf-row{grid-template-columns:20px 56px minmax(0,1fr);}
  .mf-browser-grid.mf-browser-grid-list .mf-row-thumb{width:56px;height:56px;}
  .mf-header-link{display:none;}
  .mf-modal-overlay{padding:12px;}
  .mf-modal{max-height:96vh;}
  .mf-row{grid-template-columns:20px 56px 1fr;}
  .mf-row-actions{grid-column:2 / 4;justify-content:flex-start;flex-wrap:wrap;}
}
