:root {
  --bg: #0d1117; --bg2: #161b22; --bg3: #1c2230; --bghov: #1e2736; --bgact: #0d2d1e;
  --border: #21293a; --border2: #2d3748;
  --acc: #25D366; --acc2: #128c7e; --acchov: #1fb855;
  --red: #ef4444; --yellow: #f59e0b; --blue: #3b82f6; --purple: #8b5cf6;
  --t1: #e2e8f0; --t2: #94a3b8; --t3: #64748b;
  --chat-bg: #0a0f16;
  --msg-in: #1c2230; --msg-out: #0d2d1e; --msg-note: #2a1f0a;
  --sw: 220px; --pw: 310px;
  --r: 10px; --rs: 6px;
  --shadow: 0 8px 32px rgba(0,0,0,.5);
  font-family:'Plus Jakarta Sans',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--t1);height:100vh;overflow:hidden;font-size:14px;line-height:1.5}
button{font-family:inherit}
a{color:inherit}

/* ── LOGIN ── */
.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% -10%,#0a2a18 0%,var(--bg) 55%)}
.login-box{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:40px;width:100%;max-width:380px;box-shadow:var(--shadow)}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:28px}
.logo-icon{width:44px;height:44px;background:#0a2218;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.logo-text{display:flex;flex-direction:column;line-height:1.1}
.logo-name{font-size:17px;font-weight:700;color:var(--acc)}
.logo-sub{font-size:10px;color:var(--t3);letter-spacing:.5px;text-transform:uppercase}
.login-box h2{font-size:21px;font-weight:700;margin-bottom:4px}
.login-subtitle{color:var(--t2);margin-bottom:22px;font-size:13px}
.error-msg{color:var(--red);font-size:13px;margin-bottom:12px;padding:8px 12px;background:rgba(239,68,68,.1);border-radius:var(--rs);border-left:3px solid var(--red)}

/* ── FORM ── */
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:11px;font-weight:600;color:var(--t3);margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px}
.form-group input,.form-group select,.form-group textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);padding:9px 11px;color:var(--t1);font-size:13px;font-family:inherit;outline:none;transition:border-color .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--acc)}
.form-group textarea{resize:vertical;min-height:80px}
.form-group select option{background:var(--bg3)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ── BUTTONS ── */
.btn-primary{background:var(--acc);color:#000;border:none;border-radius:var(--rs);padding:8px 14px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background .15s,transform .1s}
.btn-primary:hover{background:var(--acchov)}
.btn-primary:active{transform:scale(.97)}
.btn-primary.btn-block{width:100%;justify-content:center;padding:11px}
.btn-secondary{background:var(--bg3);color:var(--t1);border:1px solid var(--border);border-radius:var(--rs);padding:7px 13px;font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background .15s}
.btn-secondary:hover{background:var(--bghov)}
.btn-danger{background:rgba(239,68,68,.12);color:var(--red);border:1px solid rgba(239,68,68,.25);border-radius:var(--rs);padding:6px 11px;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s}
.btn-danger:hover{background:rgba(239,68,68,.22)}
.btn-icon{background:none;border:none;color:var(--t3);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;transition:color .15s,background .15s}
.btn-icon:hover{color:var(--t1);background:var(--bghov)}

/* ── APP LAYOUT ── */
.app{display:flex;height:100vh;overflow:hidden}

/* ── SIDEBAR ── */
.sidebar{width:var(--sw);background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}
.sidebar-header{padding:14px;border-bottom:1px solid var(--border)}
.brand{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px}
.brand-icon{width:30px;height:30px;background:#0a2218;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sidebar-nav{flex:1;padding:8px;display:flex;flex-direction:column;gap:1px;overflow-y:auto}
.nav-item{width:100%;background:none;border:none;color:var(--t2);padding:8px 10px;border-radius:var(--rs);cursor:pointer;display:flex;align-items:center;gap:9px;font-size:13px;font-weight:500;font-family:inherit;text-align:left;transition:all .15s;position:relative}
.nav-item:hover{color:var(--t1);background:var(--bghov)}
.nav-item.active{color:var(--acc);background:rgba(37,211,102,.1)}
.nav-badge{margin-left:auto;background:var(--red);color:white;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:700;min-width:18px;text-align:center}
.sidebar-footer{padding:10px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px}
.agent-info{display:flex;align-items:center;gap:8px;flex:1;min-width:0}
.agent-avatar{width:30px;height:30px;border-radius:50%;background:var(--acc2);color:white;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}
.agent-details{min-width:0}
.agent-name{display:block;font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.agent-role{display:block;font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.4px}
.btn-logout{background:none;border:none;color:var(--t3);cursor:pointer;padding:4px;border-radius:4px;display:flex;transition:color .15s}
.btn-logout:hover{color:var(--red)}

/* ── MAIN ── */
.main-content{flex:1;min-width:0;overflow:hidden;display:flex}
.page{display:none;flex:1;overflow:hidden;flex-direction:column}
.page.active{display:flex}
.page-header{padding:16px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg2);flex-shrink:0}
.page-header h2{font-size:15px;font-weight:700}

/* ── DASHBOARD ── */
.dashboard-body{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:18px}
.stats-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:16px;display:flex;flex-direction:column;gap:6px;transition:border-color .15s}
.stat-card:hover{border-color:var(--border2)}
.stat-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-bottom:4px}
.stat-value{font-size:26px;font-weight:700;line-height:1}
.stat-label{font-size:11px;color:var(--t3);font-weight:500;text-transform:uppercase;letter-spacing:.4px}
.stat-sub{font-size:11px;color:var(--t2)}
.dash-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.dash-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:16px}
.dash-card h3{font-size:12px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}
.dash-card.full{grid-column:1/-1}
.activity-item{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.activity-item:last-child{border:none}
.ai-avatar{width:30px;height:30px;border-radius:50%;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--t2);flex-shrink:0}
.ai-info{flex:1;min-width:0}
.ai-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ai-msg{font-size:11px;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ai-status{flex-shrink:0}
.agent-stat-row{display:flex;align-items:center;gap:10px;padding:6px 0}
.agent-bar{flex:1;height:5px;background:var(--border);border-radius:3px;overflow:hidden}
.agent-bar-fill{height:100%;background:var(--acc);border-radius:3px}
.hourly-chart{display:flex;align-items:flex-end;gap:4px;height:60px}
.hour-bar{flex:1;background:var(--acc);border-radius:2px 2px 0 0;min-height:2px;transition:height .3s;opacity:.7}
.hour-bar:hover{opacity:1}

/* ── CHAT LAYOUT ── */
.chat-layout{display:flex;flex:1;overflow:hidden}
.chat-list-panel{width:var(--pw);border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--bg2);flex-shrink:0}
.panel-header{padding:12px 12px 8px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.panel-header h2{font-size:14px;font-weight:700}
.select-sm{background:var(--bg3);border:1px solid var(--border);border-radius:5px;color:var(--t1);padding:4px 7px;font-size:11px;font-family:inherit;outline:none;cursor:pointer;max-width:120px}
.chat-tabs{display:flex;padding:5px 8px;gap:2px;border-bottom:1px solid var(--border)}
.tab-btn{background:none;border:none;color:var(--t3);font-size:11px;font-weight:600;font-family:inherit;padding:3px 7px;border-radius:4px;cursor:pointer;transition:all .15s}
.tab-btn:hover{color:var(--t1)}
.tab-btn.active{color:var(--acc);background:rgba(37,211,102,.1)}
.search-bar{display:flex;align-items:center;gap:7px;padding:7px 10px;border-bottom:1px solid var(--border);color:var(--t3)}
.search-bar input{flex:1;background:none;border:none;color:var(--t1);font-size:12px;font-family:inherit;outline:none}
.search-bar input::placeholder{color:var(--t3)}
.chat-list{flex:1;overflow-y:auto}
.chat-item{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.03);cursor:pointer;display:flex;align-items:flex-start;gap:9px;transition:background .12s}
.chat-item:hover{background:var(--bghov)}
.chat-item.active{background:var(--bgact)}
.chat-avatar{width:38px;height:38px;border-radius:50%;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:var(--t2);flex-shrink:0}
.chat-info{flex:1;min-width:0}
.chat-name-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}
.chat-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}
.chat-time{font-size:10px;color:var(--t3);flex-shrink:0;margin-left:6px}
.chat-preview{font-size:11px;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-meta{display:flex;align-items:center;gap:4px;margin-top:3px;flex-wrap:wrap}
.sdot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.sdot.waiting{background:var(--yellow)}
.sdot.attending{background:var(--acc)}
.sdot.resolved{background:var(--t3)}
.sdot.spam{background:var(--red)}
.sdot.connected{background:var(--acc)}
.sdot.disconnected{background:var(--red)}
.sdot.starting{background:var(--yellow)}
.unread-badge{background:var(--acc);color:#000;border-radius:10px;padding:1px 5px;font-size:10px;font-weight:700;margin-left:auto}
.label-tag{display:inline-flex;align-items:center;padding:1px 5px;border-radius:3px;font-size:10px;font-weight:600;color:white}

/* ── CHAT WINDOW ── */
.chat-window{flex:1;display:flex;flex-direction:column;background:var(--chat-bg);overflow:hidden}
.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--t3)}
.chat-empty p{font-size:13px}
.chat-header{padding:11px 14px;background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-shrink:0}
.ch-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:var(--t2);flex-shrink:0}
.ch-info{flex:1;min-width:0}
.ch-name{font-size:13px;font-weight:700}
.ch-sub{font-size:11px;color:var(--t3)}
.ch-actions{display:flex;align-items:center;gap:3px}
.chat-messages{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:3px;background-image:radial-gradient(rgba(255,255,255,.015) 1px,transparent 1px);background-size:22px 22px}
.msg-group{display:flex;flex-direction:column;max-width:65%}
.msg-group.out{align-self:flex-end;align-items:flex-end}
.msg-group.in{align-self:flex-start}
.msg-group.note{align-self:center;max-width:75%}
.message{padding:7px 11px;border-radius:9px;font-size:13px;line-height:1.45;word-wrap:break-word;margin-bottom:1px}
.message.in{background:var(--msg-in);border-bottom-left-radius:3px}
.message.out{background:var(--msg-out);border-bottom-right-radius:3px}
.message.note{background:var(--msg-note);border:1px solid rgba(245,158,11,.2);font-size:12px;font-style:italic;text-align:center}
.msg-time{font-size:10px;color:var(--t3);padding:0 3px}
.msg-sender{font-size:10px;font-weight:600;color:var(--acc);margin-bottom:2px}
.chat-input-area{background:var(--bg2);border-top:1px solid var(--border);padding:8px 12px;flex-shrink:0}
.chat-modes{display:flex;gap:3px;margin-bottom:7px}
.mode-btn{background:none;border:1px solid var(--border);color:var(--t3);font-size:11px;font-weight:600;font-family:inherit;padding:3px 9px;border-radius:4px;cursor:pointer;transition:all .15s}
.mode-btn.active{background:var(--bg3);color:var(--t1);border-color:var(--border2)}
.mode-btn.note.active{color:var(--yellow);border-color:var(--yellow);background:rgba(245,158,11,.1)}
.chat-input-row{display:flex;align-items:flex-end;gap:7px}
.chat-input{flex:1;background:var(--bg3);border:1px solid var(--border);border-radius:18px;padding:8px 13px;color:var(--t1);font-size:13px;font-family:inherit;resize:none;outline:none;max-height:110px;min-height:38px;line-height:1.4;transition:border-color .2s}
.chat-input:focus{border-color:var(--acc)}
.btn-send{width:36px;height:36px;border-radius:50%;background:var(--acc);border:none;color:#000;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,transform .1s}
.btn-send:hover{background:var(--acchov)}
.btn-send:active{transform:scale(.93)}
.chat-side{width:240px;border-left:1px solid var(--border);background:var(--bg2);overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:14px}
.side-section h4{font-size:11px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.assign-select,.status-select{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:5px;color:var(--t1);padding:5px 8px;font-size:12px;font-family:inherit;outline:none;cursor:pointer}
.quick-list{display:flex;flex-direction:column;gap:3px;max-height:160px;overflow-y:auto;margin-bottom:6px}
.quick-item{display:flex;align-items:center;gap:7px;padding:5px 8px;background:var(--bg3);border-radius:5px;cursor:pointer;transition:background .12s}
.quick-item:hover{background:var(--bghov)}
.qs{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--acc);background:rgba(37,211,102,.1);padding:1px 4px;border-radius:3px;flex-shrink:0}
.qt{font-size:11px;color:var(--t2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}

/* ── SESSIONS ── */
.sessions-grid{padding:18px;display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:14px;overflow-y:auto;align-content:start}
.session-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:15px;display:flex;flex-direction:column;gap:11px;transition:border-color .15s}
.session-card:hover{border-color:var(--border2)}
.sc-header{display:flex;align-items:center;gap:10px}
.sc-icon{width:38px;height:38px;border-radius:9px;background:#0a2218;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sc-info{flex:1;min-width:0}
.sc-name{font-size:13px;font-weight:700}
.sc-url{font-size:11px;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sess-status{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 8px;border-radius:4px}
.sess-status.connected{color:var(--acc);background:rgba(37,211,102,.1)}
.sess-status.disconnected{color:var(--red);background:rgba(239,68,68,.1)}
.sess-status.starting{color:var(--yellow);background:rgba(245,158,11,.1)}
.sc-actions{display:flex;gap:5px;flex-wrap:wrap}

/* ── RESPONDERS ── */
.responders-list{padding:18px;display:flex;flex-direction:column;gap:8px;overflow-y:auto}
.resp-item{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:13px 14px;display:flex;align-items:center;gap:12px;transition:border-color .15s}
.resp-item:hover{border-color:var(--border2)}
.toggle{width:34px;height:19px;background:var(--border);border-radius:10px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}
.toggle.on{background:var(--acc)}
.toggle::after{content:'';position:absolute;width:13px;height:13px;background:white;border-radius:50%;top:3px;left:3px;transition:transform .2s}
.toggle.on::after{transform:translateX(15px)}
.resp-info{flex:1;min-width:0}
.resp-name{font-size:13px;font-weight:600;margin-bottom:3px}
.resp-meta{font-size:11px;color:var(--t3);display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.resp-trigger{font-family:'JetBrains Mono',monospace;background:var(--bghov);padding:1px 5px;border-radius:3px;color:var(--acc)}
.resp-actions{display:flex;gap:3px;flex-shrink:0}

/* ── CAMPAIGNS ── */
.campaigns-list{padding:18px;display:flex;flex-direction:column;gap:10px;overflow-y:auto}
.camp-item{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:15px;display:flex;align-items:center;gap:14px;transition:border-color .15s}
.camp-item:hover{border-color:var(--border2)}
.camp-icon{width:40px;height:40px;border-radius:9px;background:rgba(59,130,246,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.camp-info{flex:1;min-width:0}
.camp-name{font-size:13px;font-weight:700;margin-bottom:3px}
.camp-meta{font-size:11px;color:var(--t3);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.camp-progress{width:100%;margin-top:6px}
.prog-bar{width:100%;height:4px;background:var(--border);border-radius:2px;overflow:hidden}
.prog-fill{height:100%;background:var(--acc);border-radius:2px;transition:width .4s}
.prog-text{font-size:10px;color:var(--t3);margin-top:3px}
.camp-status{font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px}
.camp-status.draft{color:var(--t2);background:var(--bg3)}
.camp-status.running{color:var(--blue);background:rgba(59,130,246,.1)}
.camp-status.finished{color:var(--acc);background:rgba(37,211,102,.1)}
.camp-status.paused{color:var(--yellow);background:rgba(245,158,11,.1)}
.camp-actions{display:flex;gap:4px;flex-shrink:0}
.contacts-textarea{font-family:'JetBrains Mono',monospace;font-size:12px;min-height:120px}

/* ── LABELS ── */
.labels-grid{padding:18px;display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px;overflow-y:auto;align-content:start}
.lbl-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:13px;display:flex;align-items:center;gap:10px}
.lbl-dot{width:18px;height:18px;border-radius:50%;flex-shrink:0}
.lbl-name{flex:1;font-weight:600;font-size:13px}
.lbl-actions{display:flex;gap:2px}
.color-row{display:flex;align-items:center;gap:8px}
.color-row input[type="color"]{width:34px;height:34px;border:1px solid var(--border);background:var(--bg3);border-radius:5px;padding:2px;cursor:pointer;outline:none}

/* ── AGENTS ── */
.agents-list{padding:18px;display:flex;flex-direction:column;gap:7px;overflow-y:auto}
.agent-row{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:13px 14px;display:flex;align-items:center;gap:12px}
.ar-avatar{width:38px;height:38px;border-radius:50%;background:var(--acc2);color:white;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;flex-shrink:0}
.ar-info{flex:1;min-width:0}
.ar-name{font-size:13px;font-weight:700}
.ar-email{font-size:11px;color:var(--t3)}
.role-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px;text-transform:uppercase;letter-spacing:.4px}
.role-badge.admin{background:rgba(59,130,246,.15);color:var(--blue)}
.role-badge.agent{background:rgba(37,211,102,.12);color:var(--acc)}
.online-dot{width:7px;height:7px;border-radius:50%;background:var(--t3)}
.online-dot.online{background:var(--acc)}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);display:flex;align-items:center;justify-content:center;z-index:1000;backdrop-filter:blur(4px)}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);width:100%;max-width:490px;max-height:88vh;display:flex;flex-direction:column;box-shadow:var(--shadow)}
.modal-sm{max-width:340px}
.modal-lg{max-width:600px}
.modal-header{padding:15px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.modal-header h3{font-size:14px;font-weight:700}
.modal-close{background:none;border:none;color:var(--t3);cursor:pointer;font-size:15px;padding:2px;transition:color .15s}
.modal-close:hover{color:var(--t1)}
.modal-body{padding:18px;overflow-y:auto}
.modal-footer{padding:12px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:7px;flex-shrink:0}

/* ── MISC ── */
.spinner{width:26px;height:26px;border:3px solid var(--border);border-top-color:var(--acc);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.empty-state{text-align:center;padding:44px 20px;color:var(--t3)}
.empty-state p{font-size:13px}
.divider{height:1px;background:var(--border);margin:8px 0}
.toast{position:fixed;bottom:22px;right:22px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:11px 14px;font-size:13px;color:var(--t1);box-shadow:var(--shadow);z-index:9999;animation:slideUp .25s ease;max-width:280px;border-left:3px solid var(--border2)}
.toast.success{border-left-color:var(--acc)}
.toast.error{border-left-color:var(--red)}
.toast.info{border-left-color:var(--blue)}
@keyframes slideUp{from{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}
#qr-container img{max-width:230px;border-radius:8px}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:var(--border2)}

/* ── MEDIA MESSAGES ── */
.msg-media { padding: 6px 8px !important; }
.media-placeholder {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  background: rgba(255,255,255,.06);
  border-radius: 6px;
  font-size: 13px;
  min-width: 140px;
}
.media-placeholder span { color: var(--t2); }
.media-caption {
  font-size: 11px;
  color: var(--t3);
  margin-top: 4px;
  font-style: italic;
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: 4px;
  width: 100%;
}
.img-placeholder { cursor: default; }
