:root {
  --bg:#0d0d0f; --surface:#141416; --surface2:#1c1c1f;
  --border:#2a2a2e; --accent:#7c6af7; --accent2:#f76a8a;
  --text:#f0f0f2; --muted:#6b6b75;
  --yt:#FF0000; --steam-text:#7b8cde; --twitter:#1DA1F2; --gmail:#EA4335; --rss:#FF6600;
  --green:#4ade80; --yellow:#fbbf24; --red:#f87171;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{background:var(--bg);color:var(--text);font-family:'Syne',sans-serif;min-height:100vh;overflow-x:hidden;}
body::before{content:'';position:fixed;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:40px 40px;opacity:.2;pointer-events:none;z-index:0;}
.app{position:relative;z-index:1;display:flex;min-height:100vh;}

/* Sidebar */
.sidebar{width:224px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:28px 0;position:fixed;top:0;left:0;bottom:0;z-index:100;}
.logo{padding:0 24px 28px;border-bottom:1px solid var(--border);}
.logo-mark{font-size:11px;font-weight:700;letter-spacing:.2em;color:var(--muted);text-transform:uppercase;margin-bottom:4px;}
.logo-name{font-size:20px;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.nav{padding:20px 12px;flex:1;overflow-y:auto;}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .15s;margin-bottom:2px;position:relative;user-select:none;}
.nav-item:hover{background:var(--surface2);color:var(--text);}
.nav-item.active{background:var(--surface2);color:var(--text);}
.nav-item.active::before{content:'';position:absolute;left:0;width:3px;height:32px;background:var(--accent);border-radius:0 4px 4px 0;}
.server-stop{padding:10px 16px;border-top:1px solid var(--border);}
.btn-stop-server{width:100%;padding:8px 12px;border-radius:8px;font-size:12px;font-weight:700;font-family:'Syne',sans-serif;cursor:pointer;background:transparent;color:var(--muted);border:1px solid var(--border);transition:all .15s;text-align:left;}
.btn-stop-server:hover{color:var(--red);border-color:var(--red);background:rgba(248,113,113,.07);}
.bot-status{padding:12px 24px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px;}
.restart-badge{display:none;margin:0 12px 8px;padding:8px 12px;background:rgba(251,191,36,.08);border:1px solid var(--yellow);border-radius:8px;font-size:11px;font-weight:700;color:var(--yellow);align-items:center;justify-content:space-between;gap:8px;}
.restart-badge.visible{display:flex;}
.restart-badge-btn{background:var(--yellow);color:#000;border:none;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:700;cursor:pointer;font-family:'Syne',sans-serif;white-space:nowrap;}
.restart-badge-btn:hover{background:#f59e0b;}
.status-dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:pulse 2s infinite;}
.status-dot.offline{background:var(--red);box-shadow:0 0 8px var(--red);animation:none;}
.status-text{font-size:12px;font-weight:600;color:var(--muted);}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.4;}}

/* Main */
.main{margin-left:224px;flex:1;padding:36px 40px;}
.page{display:none;}
.page.active{display:block;animation:fadeIn .2s ease;}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:translateY(0);}}
.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:36px;}
.page-title{font-size:28px;font-weight:800;}
.page-sub{font-size:13px;color:var(--muted);margin-top:4px;font-family:'DM Mono',monospace;}

/* Buttons */
.btn{padding:10px 20px;border-radius:8px;font-size:13px;font-weight:700;font-family:'Syne',sans-serif;cursor:pointer;border:none;transition:all .15s;}
.btn-primary{background:var(--accent);color:white;}
.btn-primary:hover{background:#6a58e8;transform:translateY(-1px);}
.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border);}
.btn-ghost:hover{color:var(--text);border-color:var(--muted);}
.btn-danger{background:transparent;color:var(--red);border:1px solid var(--red);}
.btn-danger:hover{background:rgba(248,113,113,.1);}
.btn-sm{padding:6px 12px;font-size:11px;}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px;}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;transition:border-color .2s;}
.stat-card:hover{border-color:var(--accent);}
.stat-label{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;}
.stat-value{font-size:28px;font-weight:800;}
.stat-sub{font-size:12px;color:var(--muted);margin-top:4px;font-family:'DM Mono',monospace;}

.section-title{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;display:flex;align-items:center;gap:10px;}
.section-title::after{content:'';flex:1;height:1px;background:var(--border);}

/* Tables */
.data-table{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:32px;}
.table-header{display:grid;padding:12px 20px;background:var(--surface2);border-bottom:1px solid var(--border);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);}
.table-row{display:grid;padding:14px 20px;border-bottom:1px solid var(--border);align-items:center;transition:background .1s;}
.table-row:last-child{border-bottom:none;}
.table-row:hover{background:var(--surface2);}
.cols-4{grid-template-columns:160px 1fr 80px 80px;}
.cols-5{grid-template-columns:180px 1fr 120px 80px 80px;}

/* Source tags */
.source-tag{display:inline-flex;align-items:center;gap:7px;padding:5px 10px;border-radius:6px;font-size:12px;font-weight:700;font-family:'DM Mono',monospace;}
.source-tag .dot{width:7px;height:7px;border-radius:50%;}
.source-yt   {background:rgba(255,0,0,.12);   color:var(--yt);}
.source-steam{background:rgba(123,140,222,.12); color:var(--steam-text);}
.source-tw   {background:rgba(29,161,242,.12); color:var(--twitter);}
.source-gmail{background:rgba(234,67,53,.12);  color:var(--gmail);}

/* Gmail gradient dot */
.dot-gmail{background:linear-gradient(135deg,#EA4335 0%,#FBBC05 33%,#34A853 66%,#4285F4 100%) !important;}

/* Channel pills */
.channel-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;font-size:12px;font-family:'DM Mono',monospace;color:var(--text);margin-right:4px;margin-bottom:4px;}
.channel-hash{color:var(--accent);font-weight:700;}
.channel-pill .remove-pill{color:var(--muted);cursor:pointer;font-size:10px;margin-left:2px;}
.channel-pill .remove-pill:hover{color:var(--red);}
.add-channel{display:inline-flex;align-items:center;padding:5px 8px;background:transparent;border:1px dashed var(--border);border-radius:6px;font-size:11px;color:var(--muted);cursor:pointer;font-family:'DM Mono',monospace;transition:all .15s;}
.add-channel:hover{border-color:var(--accent);color:var(--accent);}

/* Toggle */
.toggle{width:36px;height:20px;background:var(--green);border-radius:10px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;}
.toggle::after{content:'';position:absolute;width:14px;height:14px;background:white;border-radius:50%;top:3px;left:19px;transition:left .2s;}
.toggle.off{background:var(--border);}
.toggle.off::after{left:3px;}
.interval-badge{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);}

/* Tags */
.tag{font-size:9px;font-weight:800;letter-spacing:.1em;padding:2px 6px;border-radius:4px;text-transform:uppercase;}
.tag-ok {background:rgba(74,222,128,.15);color:var(--green);}
.tag-err{background:rgba(248,113,113,.15);color:var(--red);}

/* Panels */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:32px;}
.panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;}
.panel-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.panel-title{font-size:14px;font-weight:700;}
.panel-body{padding:16px 20px;}
.list-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);}
.list-row:last-child{border-bottom:none;}
.row-name{display:flex;align-items:center;gap:8px;font-size:13px;font-family:'DM Mono',monospace;}
.row-badges{display:flex;gap:4px;}
.badge{width:8px;height:8px;border-radius:50%;}
.tooltip-wrap{position:relative;}
.tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--surface2);border:1px solid var(--border);padding:6px 10px;border-radius:6px;font-size:11px;white-space:nowrap;color:var(--text);pointer-events:none;opacity:0;transition:opacity .15s;font-family:'DM Mono',monospace;z-index:10;}
.tooltip-wrap:hover .tooltip{opacity:1;}
.activity-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);}
.activity-item:last-child{border-bottom:none;}
.activity-left{display:flex;align-items:center;gap:10px;}
.activity-msg{font-size:12px;}
.activity-ch{color:var(--accent);font-family:'DM Mono',monospace;}
.activity-time{font-size:11px;color:var(--muted);font-family:'DM Mono',monospace;white-space:nowrap;}

/* Sources */
.source-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.source-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;display:flex;align-items:stretch;}
.source-card-inner{flex:1;min-width:0;}
.source-card-header{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;}
.source-card-left{display:flex;align-items:center;gap:10px;}
.source-card-title{display:flex;align-items:center;gap:10px;}
.account-row{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.account-row:last-child{border-bottom:none;}
.account-name{font-size:13px;font-family:'DM Mono',monospace;}
.account-meta{font-size:11px;color:var(--muted);margin-top:3px;}
.account-actions{display:flex;align-items:center;gap:8px;}

/* Channels */
.channels-list{display:flex;flex-direction:column;gap:12px;}
.channel-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 20px;display:flex;align-items:center;gap:12px;}
.channel-card.locked{border-color:rgba(124,106,247,.3);background:rgba(124,106,247,.04);}
.lock-icon{font-size:11px;color:var(--accent);margin-left:6px;opacity:.7;}
.channel-card-left{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0;}
.channel-card-name{font-size:15px;font-weight:700;font-family:'DM Mono',monospace;}
.channel-card-name span{color:var(--accent);}
.channel-card-url{font-size:11px;color:var(--muted);font-family:'DM Mono',monospace;}
.channel-card-sources{display:flex;gap:6px;flex-wrap:wrap;}
.channel-card-right{display:flex;align-items:center;gap:10px;flex-shrink:0;}

/* Routing */
.routing-rule-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:14px;transition:opacity .2s;display:flex;align-items:flex-start;}
.routing-rule-card.disabled{opacity:.45;pointer-events:none;}
.routing-rule-card.disabled .toggle{pointer-events:all;}
.rule-header{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;border-bottom:1px solid var(--border);background:var(--surface2);}
.rule-header-left{display:flex;align-items:center;gap:12px;}
.rule-account{font-size:12px;font-family:'DM Mono',monospace;color:var(--muted);}
.rule-header-right{display:flex;align-items:center;gap:10px;}
.rule-body{padding:18px 20px;display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start;}
.rule-channels-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;}
.rule-channels-wrap{display:flex;flex-wrap:wrap;align-items:center;gap:6px;}
.rule-test-section{display:flex;flex-direction:column;gap:10px;}
.rule-test-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;}
.rule-test-row{display:flex;gap:8px;align-items:center;}
.rule-test-select{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:12px;color:var(--text);font-family:'DM Mono',monospace;outline:none;transition:border-color .15s;}
.rule-test-select:focus{border-color:var(--accent);}
.test-status{font-size:11px;font-family:'DM Mono',monospace;display:flex;align-items:center;gap:6px;}
.test-status.ok{color:var(--green);}
.test-status.fail{color:var(--red);}
.test-status.testing{color:var(--yellow);}

/* Settings */
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.settings-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;}
.settings-card-header{padding:16px 20px;border-bottom:1px solid var(--border);}
.settings-card-title{font-size:14px;font-weight:700;}
.settings-card-body{padding:20px;display:flex;flex-direction:column;gap:16px;}
.setting-row{display:flex;flex-direction:column;gap:6px;}
.setting-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;}
.setting-input{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 14px;font-size:13px;color:var(--text);font-family:'DM Mono',monospace;outline:none;width:100%;transition:border-color .15s;}
.setting-input:focus{border-color:var(--accent);}
.setting-input[readonly]{opacity:.5;cursor:not-allowed;}
.setting-hint{font-size:11px;color:var(--muted);font-family:'DM Mono',monospace;line-height:1.5;}
.twitter-validate-row{display:flex;gap:8px;align-items:center;margin-top:4px;}
.twitter-validate-status{font-size:11px;font-family:'DM Mono',monospace;}
.twitter-validate-status.ok{color:var(--green);}
.twitter-validate-status.fail{color:var(--red);}

/* Logs */
.log-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:0;}
.log-tab{padding:8px 20px;border-radius:8px 8px 0 0;font-size:13px;font-weight:600;cursor:pointer;border:1px solid transparent;border-bottom:none;background:transparent;color:var(--muted);font-family:'Syne',sans-serif;transition:all .15s;margin-bottom:-1px;}
.log-tab:hover{color:var(--text);background:var(--surface2);}
.log-tab.active{color:var(--text);background:var(--surface);border-color:var(--border);border-bottom-color:var(--surface);}
.log-container{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;}
.log-toolbar{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.log-filters{display:flex;gap:8px;}
.log-filter{padding:6px 14px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--muted);font-family:'Syne',sans-serif;transition:all .15s;}
.log-filter:hover{background:var(--surface2);color:var(--text);}
.log-filter.active{color:var(--accent);border-color:var(--accent);}
.log-body{padding:16px 20px;max-height:500px;overflow-y:auto;font-family:'DM Mono',monospace;font-size:12px;line-height:1.8;}
.log-line{display:flex;gap:16px;padding:3px 0;border-radius:4px;}
.log-line:hover{background:var(--surface2);padding:3px 8px;margin:0 -8px;}
.log-time{color:var(--muted);flex-shrink:0;width:80px;}
.log-level{flex-shrink:0;width:50px;}
.log-level.info{color:var(--green);}
.log-level.warn{color:var(--yellow);}
.log-level.error{color:var(--red);}
.log-source{color:var(--accent);margin-right:6px;}

/* Modals */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;display:none;place-items:center;backdrop-filter:blur(4px);}
.modal-backdrop.open{display:grid;}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;width:480px;animation:modalIn .2s ease;display:flex;flex-direction:column;max-height:90vh;}
@keyframes modalIn{from{opacity:0;transform:scale(.95);}to{opacity:1;transform:scale(1);}}
.modal-title{font-size:20px;font-weight:800;margin-bottom:6px;flex-shrink:0;}
.modal-sub{font-size:13px;color:var(--muted);margin-bottom:24px;font-family:'DM Mono',monospace;flex-shrink:0;}
.modal-form{display:flex;flex-direction:column;gap:16px;overflow-y:auto;padding-right:4px;flex:1;}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px;flex-shrink:0;border-top:1px solid var(--border);padding-top:16px;}

/* Toast */
.toast-container{position:fixed;bottom:24px;right:24px;z-index:999;display:flex;flex-direction:column;gap:8px;}
.toast{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px 18px;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:space-between;gap:16px;animation:toastIn .3s ease;max-width:360px;}
.toast.success{border-color:var(--green);}
.toast.error{border-color:var(--red);}
.toast-undo{background:transparent;border:1px solid var(--accent);color:var(--accent);padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700;cursor:pointer;font-family:'Syne',sans-serif;flex-shrink:0;}
.toast-undo:hover{background:var(--accent);color:white;}
@keyframes toastIn{from{opacity:0;transform:translateX(20px);}to{opacity:1;transform:translateX(0);}}
@keyframes toastOut{from{opacity:1;}to{opacity:0;transform:translateX(20px);}}

::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px;}

/* ── Drag and drop ── */
.drag-handle{cursor:grab;color:var(--muted);font-size:16px;padding:0 8px;user-select:none;flex-shrink:0;transition:color .15s;align-self:center;}
.drag-handle:hover{color:var(--text);}
.dragging{opacity:0.4;border:1px dashed var(--accent) !important;}
.drag-over{border-color:var(--accent) !important;background:var(--surface2) !important;}
.routing-rule-card .drag-handle{align-self:flex-start;padding:14px 8px 0 0;}

/* ── Server Selector ── */
.server-selector{padding:10px 16px 4px;position:relative;}
.server-selector-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;}
.server-selector-current{display:flex;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 10px;cursor:pointer;font-size:13px;font-weight:600;transition:border-color .15s;}
.server-selector-current:hover{border-color:var(--accent);}
.server-selector-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.server-selector-arrow{color:var(--muted);font-size:11px;flex-shrink:0;}
.server-selector-dropdown{position:absolute;left:16px;right:16px;top:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;z-index:100;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.4);margin-top:4px;}
.server-selector-dropdown.hidden{display:none;}
.server-option{display:flex;align-items:center;padding:10px 12px;font-size:13px;font-weight:500;cursor:pointer;transition:background .12s;}
.server-option:hover{background:var(--surface3,#2a2a3a);}
.server-option.active{color:var(--accent);font-weight:700;}

/* ── Login Overlay ── */
.login-overlay{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:9999;}
.login-overlay.hidden{display:none;}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px;text-align:center;width:320px;display:flex;flex-direction:column;align-items:center;gap:12px;}
.login-logo{font-size:48px;color:var(--accent);}
.login-title{font-size:28px;font-weight:800;font-family:'Syne',sans-serif;color:var(--text);}
.login-sub{font-size:13px;color:var(--muted);margin-bottom:8px;}
.login-btn{display:flex;align-items:center;justify-content:center;width:100%;padding:12px;font-size:14px;font-weight:700;border-radius:10px;text-decoration:none;}
.login-hint{font-size:11px;color:var(--muted);margin-top:4px;}

/* ── Sidebar User ── */
.sidebar-user{display:flex;align-items:center;gap:8px;padding:10px 16px;border-top:1px solid var(--border);margin-top:auto;}
.sidebar-user.hidden{display:none;}
.sidebar-user-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0;}
.sidebar-user-name{font-size:12px;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sidebar-user-logout{color:var(--muted);font-size:14px;text-decoration:none;flex-shrink:0;transition:color .15s;}
.sidebar-user-logout:hover{color:var(--red);}

/* ── Server invite badge ── */
.server-option-invite{display:flex;align-items:center;padding:10px 12px;font-size:13px;font-weight:500;cursor:pointer;transition:background .12s;text-decoration:none;color:var(--text);}
.server-option-invite:hover{background:var(--surface3,#2a2a3a);}
.server-invite-badge{background:var(--accent);color:white;font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;flex-shrink:0;}

/* ── Channel Tabs ── */
.channel-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:0;}
.channel-tab{background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted);font-family:'Syne',sans-serif;font-weight:700;font-size:13px;padding:8px 16px;cursor:pointer;transition:color .15s,border-color .15s;margin-bottom:-1px;}
.channel-tab:hover{color:var(--text);}
.channel-tab.active{color:var(--accent);border-bottom-color:var(--accent);}

/* ── System Channels ── */
.system-channels-header{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:4px;}
.system-channels-desc{font-size:13px;color:var(--muted);line-height:1.6;}

/* ── Form Builder ── */
.form-field-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:10px;display:flex;align-items:flex-start;gap:12px;transition:border-color .15s;}
.form-field-card:hover{border-color:var(--accent);}

/* ── Log notify level ── */
.log-level.notify{color:#7c6af7;background:rgba(124,106,247,.12);border-radius:4px;padding:1px 6px;}

/* ── Gmail Options Panel ── */
.gmail-options-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:8px 0 6px;border-top:1px solid var(--border);margin-top:4px;}
.gmail-option-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;gap:12px;}
.gmail-option-label{display:flex;flex-direction:column;gap:2px;flex:1;}
.gmail-option-label span{font-size:13px;color:var(--text);}
.gmail-option-label small{font-size:11px;color:var(--muted);}

/* ── Gmail Image Picker Grid ── */
.gmail-image-grid{display:flex;flex-wrap:wrap;gap:8px;width:100%;margin-top:2px;}
.gmail-img-thumb{position:relative;width:72px;height:72px;border-radius:8px;overflow:hidden;border:2px solid var(--border);cursor:pointer;transition:border-color .15s,transform .1s;flex-shrink:0;}
.gmail-img-thumb:hover{border-color:var(--accent);transform:scale(1.04);}
.gmail-img-thumb.selected{border-color:var(--accent);}
.gmail-img-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.gmail-img-index{position:absolute;bottom:3px;right:5px;font-size:10px;font-weight:700;color:#fff;background:rgba(0,0,0,.55);border-radius:3px;padding:1px 4px;pointer-events:none;}
.gmail-img-thumb.selected::after{content:'✓';position:absolute;top:4px;left:4px;font-size:12px;font-weight:700;color:#fff;background:var(--accent);border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;pointer-events:none;}

/* ── RSS source tag ── */
.source-rss{background:rgba(255,102,0,.12);color:var(--rss);}

/* ── Per-source / per-channel interval badges ── */
.interval-custom{font-size:9px;font-weight:700;letter-spacing:.06em;padding:2px 5px;border-radius:4px;background:rgba(124,106,247,.15);color:var(--accent);text-transform:uppercase;vertical-align:middle;}
.interval-default{font-size:9px;font-weight:600;letter-spacing:.06em;padding:2px 5px;border-radius:4px;background:rgba(107,107,117,.12);color:var(--muted);text-transform:uppercase;vertical-align:middle;}

/* ── Gmail Email Preview (body + links) ── */
.gmail-preview-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;}
.gmail-preview-box{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:12px;max-height:160px;overflow-y:auto;width:100%;}
.gmail-preview-box pre{font-family:'DM Mono',monospace;font-size:11px;color:var(--text);white-space:pre-wrap;word-break:break-word;line-height:1.6;margin:0;}
.gmail-links-box{display:flex;flex-direction:column;gap:4px;}
.gmail-link-item{font-family:'DM Mono',monospace;font-size:11px;}
.gmail-link-item a{color:var(--accent);text-decoration:none;word-break:break-all;}
.gmail-link-item a:hover{text-decoration:underline;}

/* ── Gmail Paragraph Checklist ── */
.gmail-para-list{display:flex;flex-direction:column;gap:6px;width:100%;max-height:200px;overflow-y:auto;padding-right:4px;}
.gmail-para-item{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:var(--bg);cursor:pointer;transition:opacity .15s,border-color .15s;}
.gmail-para-item:hover{border-color:var(--accent);}
.gmail-para-item.unchecked{opacity:.4;}
.gmail-para-item input[type="checkbox"]{flex-shrink:0;margin-top:2px;accent-color:var(--accent);width:14px;height:14px;cursor:pointer;}
.gmail-para-num{flex-shrink:0;font-size:10px;font-weight:700;color:var(--accent);font-family:'DM Mono',monospace;background:rgba(124,106,247,.12);border-radius:4px;padding:1px 6px;margin-top:1px;}
.gmail-para-text{font-family:'DM Mono',monospace;font-size:11px;color:var(--text);line-height:1.5;white-space:pre-wrap;word-break:break-word;}

/* ── Gmail Links Checklist ── */
.gmail-links-checklist{display:flex;flex-direction:column;gap:4px;width:100%;max-height:150px;overflow-y:auto;padding-right:4px;}
.gmail-link-check{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;border:1px solid var(--border);background:var(--bg);cursor:pointer;transition:border-color .15s;}
.gmail-link-check:hover{border-color:var(--accent);}
.gmail-link-check.checked{border-color:var(--accent);background:rgba(124,106,247,.06);}
.gmail-link-check input[type="checkbox"]{flex-shrink:0;accent-color:var(--accent);width:14px;height:14px;cursor:pointer;}
.gmail-link-check a{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted);text-decoration:none;word-break:break-all;flex:1;}
.gmail-link-check.checked a{color:var(--accent);}
.gmail-link-check a:hover{text-decoration:underline;}

/* ── Logo status dot ── */
.logo-status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 6px var(--red);margin-left:4px;vertical-align:middle;transition:background .3s,box-shadow .3s;}
.logo-status-dot.online{background:var(--green);box-shadow:0 0 8px var(--green);animation:pulse 2s infinite;}

/* ── Dashboard user info ── */
.dash-user{display:flex;align-items:center;gap:8px;}
.dash-user.hidden{display:none;}

/* ── Bot controls dropdown ── */
.bot-controls-wrap{position:relative;}
.bot-controls-btn{min-width:110px;}
.bot-controls-dropdown{position:absolute;right:0;top:calc(100% + 6px);background:var(--surface2);border:1px solid var(--border);border-radius:10px;min-width:160px;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:50;}
.bot-controls-dropdown.hidden{display:none;}
.bot-ctrl-item{padding:10px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:background .12s;font-family:'Syne',sans-serif;}
.bot-ctrl-item:hover{background:var(--surface3,#2a2a3a);}
.bot-ctrl-danger{color:var(--red);}
.bot-ctrl-danger:hover{background:rgba(248,113,113,.1);}

/* ── Sidebar nav group label ── */
.nav-group-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;padding:16px 16px 4px;opacity:.7;}
.nav-sub{padding-left:24px !important;}

/* ── Commands page table ── */
.cols-3-cmd{grid-template-columns:140px 1fr 160px;}

/* ── Commands status message ── */
.commands-status{padding:10px 16px;border-radius:8px;font-size:13px;font-family:'DM Mono',monospace;}
.commands-status.ok{background:rgba(74,222,128,.1);border:1px solid var(--green);color:var(--green);}
.commands-status.fail{background:rgba(248,113,113,.1);border:1px solid var(--red);color:var(--red);}

/* ── Moderation page tabs ── */
.mod-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--border);padding-bottom:0;}
.mod-tab{background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted);font-family:'Syne',sans-serif;font-weight:700;font-size:13px;padding:8px 16px;cursor:pointer;transition:color .15s,border-color .15s;margin-bottom:-1px;}
.mod-tab:hover{color:var(--text);}
.mod-tab.active{color:var(--accent);border-bottom-color:var(--accent);}
.mod-panel-desc{font-size:13px;color:var(--muted);font-family:'DM Mono',monospace;margin-bottom:16px;line-height:1.6;}

/* ── Server dropdown groups ── */
.server-group-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;padding:6px 12px 2px;}
.server-option-installed{position:relative;}
.server-uninstall-btn{opacity:0;font-size:12px;color:var(--muted);padding:2px 6px;border-radius:4px;transition:opacity .15s,color .15s,background .15s;flex-shrink:0;}
.server-option-installed:hover .server-uninstall-btn{opacity:1;}
.server-uninstall-btn:hover{color:var(--red);background:rgba(255,68,68,.12);}

/* ── Roles page ── */
.role-gate-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  flex: 1;
}
.role-gate-role-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--bg);
  cursor: pointer;
  font-size: 13px;
  font-family: 'DM Mono', monospace;
  transition: border-color .15s, background .15s;
  user-select: none;
}
.role-gate-role-item:hover { border-color: var(--accent); }
.role-gate-role-item.checked {
  border-color: var(--accent);
  background: rgba(124,106,247,.08);
}
.role-color-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
  border: 1px solid rgba(255,255,255,.15);
}
.role-gate-check {
  color: var(--accent);
  font-weight: 700;
  font-size: 11px;
  min-width: 12px;
}

/* ── Role tabs (reuse mod-tabs style) ── */
.role-tabs { display: flex; gap: 4px; margin-bottom: 20px; border-bottom: 1px solid var(--border); }

/* ── Owner Settings card highlight ── */
.owner-only { transition: opacity .2s; }

/* ── Logo avatar ── */
#logoAvatar { border: 1px solid var(--border); }

/* ── Rules editor ── */
#rulesSectionsList .form-field-card textarea {
  resize: vertical;
  min-height: 80px;
}
