:root{
  --bg:#0e1118; --bg-2:#141925; --panel:#171d2b; --panel-2:#1d2435;
  --line:#27304a; --line-soft:#212940;
  --text:#e8ecf5; --muted:#8b95ad; --muted-2:#6b7488;
  --accent:#6d8bff; --accent-2:#8a6dff;
  --ok:#3ecf8e; --busy:#5b9dff; --warn:#f5b84f; --paid:#2ec5b6; --gray:#7c879f; --danger:#ff6b6b;
  --radius:14px; --radius-sm:10px; --shadow:0 10px 30px rgba(0,0,0,.35);
  --sb:248px;
}
:root[data-theme="light"]{
  --bg:#f4f6fb; --bg-2:#eef1f8; --panel:#ffffff; --panel-2:#f7f9fd;
  --line:#e2e7f1; --line-soft:#eceff6;
  --text:#1d2435; --muted:#6b748c; --muted-2:#9aa3b8;
  --accent:#3f63e0; --accent-2:#7a5bf0;
  --shadow:0 10px 28px rgba(40,60,120,.10);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,Arial,sans-serif;
  background:var(--bg); color:var(--text); font-size:14px; line-height:1.45;
  -webkit-font-smoothing:antialiased;
}
.bg-decor{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(900px 500px at 12% -10%, rgba(109,139,255,.16), transparent 60%),
             radial-gradient(800px 500px at 100% 0%, rgba(138,109,255,.12), transparent 55%);}
a{color:inherit}
h1,h2,h3{margin:0}

/* layout */
.shell{position:relative;z-index:1;display:flex;min-height:100vh}
.sidebar{width:var(--sb);flex:0 0 var(--sb);position:sticky;top:0;height:100vh;
  background:linear-gradient(180deg,var(--panel),var(--bg-2));border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:18px 14px;gap:8px}
.brand{display:flex;align-items:center;gap:11px;padding:6px 8px 14px}
.brand.center{justify-content:center;padding:0 0 8px}
.brand-mark{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;
  font-weight:800;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-2));
  box-shadow:0 6px 16px rgba(109,139,255,.4)}
.brand-mark.big{width:54px;height:54px;font-size:24px;border-radius:16px}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-text small{color:var(--muted);font-size:11px}
.nav{display:flex;flex-direction:column;gap:3px;margin-top:6px}
.nav-link{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--radius-sm);
  color:var(--muted);font-weight:600;text-decoration:none;transition:.15s}
.nav-link:hover{background:var(--panel-2);color:var(--text)}
.nav-link.active{background:linear-gradient(90deg,rgba(109,139,255,.18),rgba(138,109,255,.08));
  color:var(--text);box-shadow:inset 0 0 0 1px var(--line)}
.sidebar-foot{margin-top:auto;display:flex;flex-direction:column;gap:6px}
.sidebar-foot form{margin:0}
.sidebar-foot .btn{width:100%;justify-content:flex-start}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:12px;
  padding:14px 26px;background:color-mix(in srgb,var(--bg) 82%,transparent);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line-soft)}
.topbar-title{font-size:18px;font-weight:700}
.icon-btn{display:none;background:var(--panel);border:1px solid var(--line);color:var(--text);
  width:38px;height:38px;border-radius:10px;cursor:pointer}
.content{padding:24px 26px 60px;max-width:1280px;width:100%}

/* cards */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;margin-bottom:18px;box-shadow:var(--shadow)}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.card-head h2{font-size:15px;font-weight:700;letter-spacing:.2px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.grid-2 .card{margin-bottom:0}
.grid-2+.card{margin-top:18px}

/* stat cards */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow)}
.stat strong{font-size:30px;font-weight:800;letter-spacing:-.5px}
.stat .stat-label{display:flex;align-items:center;gap:7px;color:var(--muted);font-weight:600;font-size:13px}
.stat.accent{background:linear-gradient(135deg,rgba(109,139,255,.22),rgba(138,109,255,.10));
  border-color:transparent}
.dot{width:9px;height:9px;border-radius:50%;display:inline-block}
.dot.ok{background:var(--ok)} .dot.busy{background:var(--busy)} .dot.paid{background:var(--paid)}
.mini-stats{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.mini-stats>div{display:flex;flex-direction:column;background:var(--panel-2);border-radius:var(--radius-sm);
  padding:12px 14px;border:1px solid var(--line-soft)}
.mini-stats strong{font-size:22px;font-weight:800}

/* bars */
.bars{display:flex;flex-direction:column;gap:12px}
.bar-row{display:grid;grid-template-columns:130px 1fr 44px;align-items:center;gap:12px}
.bar-track{height:9px;background:var(--panel-2);border-radius:999px;overflow:hidden}
.bar-fill{display:block;height:100%;border-radius:999px;background:var(--accent)}
.bar-val{text-align:right;font-weight:700}
.fill-available{background:var(--ok)} .fill-assigned{background:var(--busy)}
.fill-written{background:var(--warn)} .fill-paid{background:var(--paid)} .fill-archived{background:var(--gray)}

/* tables */
.table-wrap{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--line-soft)}
.data-table{width:100%;border-collapse:collapse;table-layout:fixed}
.data-table.tasks{min-width:1480px}
.data-table th,.data-table td{padding:11px 14px;text-align:left;vertical-align:middle;
  border-bottom:1px solid var(--line-soft);overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap;word-break:normal;overflow-wrap:normal}
.data-table thead th{position:sticky;top:0;background:var(--panel-2);color:var(--muted);
  font-size:12px;text-transform:uppercase;letter-spacing:.5px;font-weight:700;z-index:1}
.data-table tbody tr:hover{background:var(--panel-2)}
.data-table td.num,.data-table th.num{text-align:right;font-variant-numeric:tabular-nums}
.data-table .empty{text-align:center;color:var(--muted);padding:26px}
.cell-link{color:var(--accent);text-decoration:none;display:inline-block;max-width:100%;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:bottom}
.cell-link:hover{text-decoration:underline}
.cell-clamp{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.who{display:flex;flex-direction:column;line-height:1.25}
.who .muted{font-size:11px}
.small{font-size:12px}

/* badges */
.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;
  font-size:12px;font-weight:700;white-space:nowrap;border:1px solid transparent}
.badge-available{background:rgba(62,207,142,.16);color:#5fe0a6;border-color:rgba(62,207,142,.3)}
.badge-assigned{background:rgba(91,157,255,.16);color:#8fbaff;border-color:rgba(91,157,255,.3)}
.badge-written{background:rgba(245,184,79,.16);color:#f6c876;border-color:rgba(245,184,79,.3)}
.badge-paid{background:rgba(46,197,182,.16);color:#5fd6c9;border-color:rgba(46,197,182,.3)}
.badge-archived{background:rgba(124,135,159,.16);color:#aab3c6;border-color:rgba(124,135,159,.3)}

/* row actions */
.row-actions{display:flex;flex-wrap:wrap;gap:5px}
.row-actions form{margin:0}
.chip-btn{cursor:pointer;border:1px solid var(--line);background:var(--panel-2);color:var(--text);
  padding:5px 9px;border-radius:8px;font-size:11px;font-weight:700;transition:.12s}
.chip-btn:hover{transform:translateY(-1px);border-color:var(--accent)}
.chip-available:hover{border-color:var(--ok);color:var(--ok)}
.chip-assigned:hover{border-color:var(--busy);color:var(--busy)}
.chip-written:hover{border-color:var(--warn);color:var(--warn)}
.chip-paid:hover{border-color:var(--paid);color:var(--paid)}
.chip-btn.danger{color:var(--danger)}
.chip-btn.danger:hover{background:rgba(255,107,107,.12);border-color:var(--danger)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 15px;border-radius:10px;
  border:1px solid var(--line);background:var(--panel-2);color:var(--text);font-weight:700;
  cursor:pointer;text-decoration:none;font-size:13px;transition:.15s}
.btn:hover{transform:translateY(-1px)}
.btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:transparent;color:#fff;
  box-shadow:0 8px 18px rgba(109,139,255,.35)}
.btn.ghost{background:transparent}
.btn.ghost:hover{background:var(--panel-2)}
.btn.tiny{padding:5px 10px;font-size:11px}

/* filters */
.filters{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap}
.filter-field{display:flex;flex-direction:column}
.filter-field.grow{flex:1;min-width:220px}
label>span{display:block;color:var(--muted);font-size:12px;font-weight:600;margin-bottom:5px}
input[type=text],input[type=password],select,textarea{
  width:100%;background:var(--bg-2);border:1px solid var(--line);color:var(--text);
  padding:10px 12px;border-radius:10px;font-size:14px;font-family:inherit}
input[type=number]{
  width:100%;background:var(--bg-2);border:1px solid var(--line);color:var(--text);
  padding:10px 12px;border-radius:10px;font-size:14px;font-family:inherit}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(109,139,255,.18)}
textarea{resize:vertical}
.stack{display:flex;flex-direction:column;gap:13px}
.checkbox{display:flex;align-items:center;gap:9px}
.checkbox input{width:auto}
.checkbox span{margin:0}
.form-foot{margin-top:16px;display:flex;justify-content:flex-end}

/* settings */
.tabs{display:flex;gap:6px;margin-bottom:16px}
.tab{padding:9px 16px;border-radius:10px;border:1px solid var(--line);background:var(--panel);
  color:var(--muted);font-weight:700;cursor:pointer}
.tab.active{color:var(--text);background:var(--panel-2);border-color:var(--accent)}
.tab-pane{display:none}
.tab-pane.active{display:block}
.kv-list{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.kv{display:flex;flex-direction:column}
.kv-key{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;color:var(--accent);
  margin-bottom:5px;word-break:break-all}
.msg-list{display:flex;flex-direction:column;gap:14px}
.msg{display:flex;flex-direction:column}

/* broadcast page */
.broadcast-run-card .card-head{align-items:flex-start;gap:16px}
.broadcast-run-card .card-head p{margin:5px 0 0}
.broadcast-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.broadcast-summary>div{display:flex;flex-direction:column;gap:3px;background:var(--panel-2);
  border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:12px 14px}
.broadcast-summary strong{font-size:15px}
.broadcast-last{margin-top:12px;color:var(--muted);font-size:13px}
.broadcast-number-grid{grid-template-columns:repeat(4,1fr)}
.input-with-suffix{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px}
.input-with-suffix span{color:var(--muted);font-size:12px;font-weight:700;white-space:nowrap}
.broadcast-exclusions{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px}
.sticky-save{position:sticky;bottom:12px;z-index:3;background:color-mix(in srgb,var(--bg) 76%,transparent);
  border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:10px;backdrop-filter:blur(8px)}
.btn[disabled]{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}

/* timeline */
.timeline{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.timeline li{display:flex;align-items:center;gap:10px;padding:10px 2px;border-bottom:1px solid var(--line-soft)}
.timeline li:last-child{border-bottom:0}
.timeline .t-type{font-weight:700}
.timeline time{margin-left:auto;color:var(--muted);font-size:12px;white-space:nowrap}
.timeline .empty{color:var(--muted);justify-content:center}

/* pager */
.pager{display:flex;gap:6px;flex-wrap:wrap;margin-top:14px}
.pager-link{padding:7px 12px;border-radius:9px;border:1px solid var(--line);text-decoration:none;
  color:var(--muted);font-weight:700}
.pager-link.active{background:var(--accent);color:#fff;border-color:transparent}

/* auth */
.auth-wrap{min-height:100vh;display:grid;place-items:center;position:relative;z-index:1;padding:20px}
.auth-card{width:100%;max-width:380px;background:var(--panel);border:1px solid var(--line);
  border-radius:18px;padding:32px;box-shadow:var(--shadow);text-align:center}
.auth-card h1{font-size:22px;margin-bottom:6px}
.auth-card form{margin-top:18px;text-align:left}
.auth-card .btn{width:100%;justify-content:center;margin-top:4px}
.muted{color:var(--muted)}

/* toasts */
.toasts{position:fixed;right:20px;bottom:20px;z-index:50;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 16px;border-radius:11px;background:var(--panel);border:1px solid var(--line);
  box-shadow:var(--shadow);font-weight:600;animation:slideIn .25s ease;max-width:340px}
.toast.success{border-left:4px solid var(--ok)}
.toast.error{border-left:4px solid var(--danger)}
@keyframes slideIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* icons (CSS masks, no external assets) */
.ic{width:18px;height:18px;display:inline-block;background:currentColor;flex:0 0 auto;
  -webkit-mask-position:center;mask-position:center;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
  -webkit-mask-size:contain;mask-size:contain}
.ic-grid{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2"><rect x="3" y="3" width="7" height="7"/><rect x="14" y="3" width="7" height="7"/><rect x="3" y="14" width="7" height="7"/><rect x="14" y="14" width="7" height="7"/></svg>')}
.ic-list{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2"><line x1="8" y1="6" x2="21" y2="6"/><line x1="8" y1="12" x2="21" y2="12"/><line x1="8" y1="18" x2="21" y2="18"/><line x1="3" y1="6" x2="3.01" y2="6"/><line x1="3" y1="12" x2="3.01" y2="12"/><line x1="3" y1="18" x2="3.01" y2="18"/></svg>')}
.ic-users{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2"><path d="M17 21v-2a4 4 0 0 0-4-4H5a4 4 0 0 0-4 4v2"/><circle cx="9" cy="7" r="4"/><path d="M23 21v-2a4 4 0 0 0-3-3.87"/><path d="M16 3.13a4 4 0 0 1 0 7.75"/></svg>')}
.ic-layers{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2"><polygon points="12 2 2 7 12 12 22 7 12 2"/><polyline points="2 17 12 22 22 17"/><polyline points="2 12 12 17 22 12"/></svg>')}
.ic-activity{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2"><polyline points="22 12 18 12 15 21 9 3 6 12 2 12"/></svg>')}
.ic-sliders{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2"><line x1="4" y1="21" x2="4" y2="14"/><line x1="4" y1="10" x2="4" y2="3"/><line x1="12" y1="21" x2="12" y2="12"/><line x1="12" y1="8" x2="12" y2="3"/><line x1="20" y1="21" x2="20" y2="16"/><line x1="20" y1="12" x2="20" y2="3"/><line x1="1" y1="14" x2="7" y2="14"/><line x1="9" y1="8" x2="15" y2="8"/><line x1="17" y1="16" x2="23" y2="16"/></svg>')}
.ic-moon{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2"><path d="M21 12.79A9 9 0 1 1 11.21 3 7 7 0 0 0 21 12.79z"/></svg>')}
.ic-logout{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2"><path d="M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4"/><polyline points="16 17 21 12 16 7"/><line x1="21" y1="12" x2="9" y2="12"/></svg>')}
.ic-menu{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2"><line x1="3" y1="12" x2="21" y2="12"/><line x1="3" y1="6" x2="21" y2="6"/><line x1="3" y1="18" x2="21" y2="18"/></svg>')}
.ic[class*="ic-"]{mask-image:var(--m)}

/* responsive */
@media (max-width:980px){
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .grid-2{grid-template-columns:1fr}
  .kv-list{grid-template-columns:1fr}
  .broadcast-summary,.broadcast-number-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .sidebar{position:fixed;left:0;top:0;transform:translateX(-100%);transition:.2s;z-index:40}
  .sidebar.open{transform:none}
  .icon-btn{display:grid;place-items:center}
  .content{padding:18px 14px 50px}
  .broadcast-run-card .card-head{flex-direction:column}
  .broadcast-run-card .card-head form,.broadcast-run-card .card-head .btn{width:100%;justify-content:center}
  .broadcast-summary,.broadcast-number-grid{grid-template-columns:1fr}
}

/* ===== availability pill (topbar) ===== */
.topbar{display:flex;align-items:center;gap:14px}
.avail-pill{margin-left:auto;display:inline-flex;align-items:center;gap:9px;text-decoration:none;
  padding:8px 14px;border-radius:999px;border:1px solid var(--line);background:var(--panel);
  color:var(--text);font-weight:700;box-shadow:var(--shadow);transition:.15s}
.avail-pill:hover{transform:translateY(-1px);border-color:var(--accent)}
.avail-dot{width:9px;height:9px;border-radius:50%;background:var(--ok);
  box-shadow:0 0 0 4px rgba(46,197,182,.18);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.avail-label{color:var(--muted);font-size:13px;font-weight:600}
.avail-count{min-width:26px;text-align:center;padding:2px 9px;border-radius:8px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:14px}
@media (max-width:620px){.avail-label{display:none}}

/* ===== add task panel ===== */
.add-task{padding:0;overflow:hidden}
.add-task-summary{display:flex;align-items:center;gap:10px;cursor:pointer;padding:16px 18px;
  font-size:14px;list-style:none;user-select:none}
.add-task-summary::-webkit-details-marker{display:none}
.add-task-summary:hover{background:var(--panel-2)}
.add-task[open] .add-task-summary{border-bottom:1px solid var(--line)}
.add-task-form{padding:18px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:13px}

/* ===== settings ===== */
.tabs{flex-wrap:wrap}
.pane-head{margin-bottom:16px}
.pane-head h2{font-size:17px;margin-bottom:4px}
.pane-head .muted{font-size:13px}
.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.setting{display:flex;flex-direction:column;gap:5px;padding:14px;border:1px solid var(--line-soft);
  border-radius:12px;background:var(--panel-2)}
.setting.is-wide{grid-column:1 / -1}
.setting-label{font-weight:700;font-size:13px}
.setting-help{color:var(--muted);font-size:12px;line-height:1.45}
.setting-key{align-self:flex-start;margin-top:4px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:10px;color:var(--muted);opacity:.6;word-break:break-all}
.setting input[type=text],.setting input[type=number],.setting textarea{margin-top:3px}
/* toggle switch */
.setting.is-bool{justify-content:center}
.switch-row{display:flex;align-items:flex-start;gap:12px;cursor:pointer}
.switch{position:relative;flex:0 0 auto;width:44px;height:25px;margin-top:1px}
.switch input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer}
.switch .slider{position:absolute;inset:0;border-radius:999px;background:var(--line);transition:.18s}
.switch .slider::before{content:"";position:absolute;left:3px;top:3px;width:19px;height:19px;border-radius:50%;
  background:#fff;transition:.18s;box-shadow:0 1px 3px rgba(0,0,0,.3)}
.switch input:checked + .slider{background:linear-gradient(135deg,var(--accent),var(--accent-2))}
.switch input:checked + .slider::before{transform:translateX(19px)}
.switch-row .setting-text{display:flex;flex-direction:column;gap:3px}
.form-foot{position:sticky;bottom:0}

/* ===== message editor + preview ===== */
.msg-field{display:flex;flex-direction:column;gap:7px;padding:14px;border:1px solid var(--line-soft);
  border-radius:12px;background:var(--panel-2)}
.msg-field-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.msg-preview{border:1px dashed var(--line);border-radius:10px;padding:10px 12px;background:var(--bg-2);
  font-size:14px;line-height:1.5;min-height:20px;white-space:pre-wrap;word-break:break-word}
.msg-preview:empty::before{content:"предпросмотр";color:var(--muted);opacity:.5}
.msg-preview .pe{font-size:1.15em}
.emoji-open{white-space:nowrap}

/* ===== emoji picker modal ===== */
.emoji-modal{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:20px}
.emoji-modal[hidden]{display:none}
.emoji-backdrop{position:absolute;inset:0;background:rgba(8,10,18,.6);backdrop-filter:blur(2px)}
.emoji-dialog{position:relative;width:min(560px,100%);max-height:78vh;display:flex;flex-direction:column;
  background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}
.emoji-dialog-head{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--line)}
.emoji-dialog-head strong{font-size:14px;white-space:nowrap}
.emoji-search{flex:1}
.emoji-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:8px;padding:16px;overflow:auto}
.emoji-cell{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;cursor:pointer;
  border:1px solid var(--line-soft);border-radius:10px;background:var(--panel-2);color:var(--text);transition:.12s}
.emoji-cell:hover{transform:translateY(-1px);border-color:var(--accent);background:var(--bg-2)}
.emoji-glyph{font-size:24px;line-height:1}
.emoji-name{font-size:10px;color:var(--muted);text-align:center;word-break:break-word}
@media (max-width:980px){.settings-grid{grid-template-columns:1fr}.grid-2{grid-template-columns:1fr}}

.data-table.tasks{min-width:860px;font-size:12.5px}
.data-table.tasks th,.data-table.tasks td{padding:7px 9px}
.data-table.tasks .row-actions{gap:4px}
.data-table.tasks .chip-btn{padding:3px 7px;font-size:11px}
.chip-btn.chip-available{color:var(--accent);border-color:var(--accent)}
.img-modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px}
.img-modal[hidden]{display:none}
.img-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(2px);cursor:zoom-out}
.img-dialog{position:relative;z-index:1;max-width:min(92vw,900px);max-height:90vh;display:flex;flex-direction:column;gap:10px;align-items:center}
.img-view{max-width:100%;max-height:80vh;border-radius:var(--radius-sm);box-shadow:0 16px 48px rgba(0,0,0,.5);background:var(--panel-2)}
.img-close{position:absolute;top:-14px;right:-14px;width:34px;height:34px;border-radius:50%;border:1px solid var(--line);background:var(--panel-2);color:var(--text);cursor:pointer;font-size:15px;line-height:1}
.img-close:hover{border-color:var(--accent)}
body.modal-open{overflow:hidden}
