/* ===== Rotary Project Planner ===== */
:root{
  --brand:#17458F;
  --brand-d:color-mix(in srgb, var(--brand) 68%, #000);
  --brand-t:color-mix(in srgb, var(--brand) 11%, transparent);
  --gold:#F7A81B;
  --bg:#eaedf2;
  --bg-2:#e2e7ef;
  --surface:#ffffff;
  --ink:#16243a;
  --muted:#5d6b80;
  --faint:#8a97a8;
  --line:#e3e8f0;
  --line-2:#d4dbe6;
  --shadow:0 1px 2px rgba(20,40,70,.06),0 1px 3px rgba(20,40,70,.05);
  --shadow-md:0 4px 14px rgba(20,40,70,.12),0 1px 3px rgba(20,40,70,.08);
  --shadow-lg:0 18px 50px rgba(15,30,60,.30),0 4px 12px rgba(15,30,60,.18);
  --radius:12px;
  --col-w:300px;
  --card-pad:12px;
  --card-gap:9px;
  --card-fs:13.5px;
  --card-title-fs:14px;
  font-synthesis:none;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Public Sans",system-ui,-apple-system,sans-serif;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow:hidden;
}
#root{height:100%}
button{font-family:inherit}
::selection{background:var(--brand-t)}

/* density */
[data-density="compact"]{ --card-pad:9px; --card-gap:6px; --card-fs:12.5px; --card-title-fs:13px; --col-w:272px; }

/* ===== App shell ===== */
.app{display:flex;flex-direction:column;height:100%;min-height:0}

/* Header */
.hdr{
  display:flex;align-items:center;gap:14px;
  padding:11px 18px;
  background:var(--brand);
  background:linear-gradient(180deg,var(--brand),var(--brand-d));
  color:#fff;flex:0 0 auto;
  box-shadow:0 1px 0 rgba(0,0,0,.12),0 2px 10px rgba(15,30,60,.18);
  position:relative;z-index:30;
}
.hdr-mark{display:flex;align-items:center;gap:11px;min-width:0}
.hdr-wheel{
  width:30px;height:30px;border-radius:50%;flex:0 0 auto;
  background:radial-gradient(circle at 50% 50%,var(--gold) 0 34%,transparent 35%),
             conic-gradient(from 0deg,var(--gold) 0 100%);
  -webkit-mask:radial-gradient(circle,#000 30%,transparent 31% 40%,#000 41%);
          mask:radial-gradient(circle,#000 30%,transparent 31% 40%,#000 41%);
  box-shadow:inset 0 0 0 2px rgba(0,0,0,.04);
  position:relative;
}
.hdr-wheel::after{
  content:"";position:absolute;inset:0;border-radius:50%;
  background:
    repeating-conic-gradient(from 0deg,transparent 0 12deg,rgba(15,47,102,.55) 12deg 15deg);
  -webkit-mask:radial-gradient(circle,transparent 0 30%,#000 31% 50%);
          mask:radial-gradient(circle,transparent 0 30%,#000 31% 50%);
}
.hdr-club{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.7);font-weight:600;line-height:1}
.hdr-sub{font-size:12.5px;color:rgba(255,255,255,.82);line-height:1.3;margin-top:3px;font-weight:500}

/* project switcher */
.proj-switch{position:relative}
.proj-btn{
  display:flex;align-items:center;gap:9px;
  background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.2);
  color:#fff;border-radius:10px;padding:7px 11px;cursor:pointer;
  font-size:16px;font-weight:700;letter-spacing:-.01em;max-width:46vw;
  transition:background .15s;
}
.proj-btn:hover{background:rgba(255,255,255,.2)}
.proj-btn .chev{opacity:.8;transition:transform .18s}
.proj-btn.open .chev{transform:rotate(180deg)}
.proj-btn .ttl{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.menu{
  position:absolute;top:calc(100% + 8px);left:0;min-width:280px;
  background:var(--surface);color:var(--ink);border-radius:14px;
  box-shadow:var(--shadow-lg);border:1px solid var(--line);
  padding:7px;z-index:60;animation:pop .14s ease;
}
.menu.right{left:auto;right:0}
@keyframes pop{from{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:none}}
.menu-lbl{font-size:10.5px;letter-spacing:.09em;text-transform:uppercase;color:var(--faint);font-weight:700;padding:7px 10px 5px}
.menu-item{
  display:flex;align-items:center;gap:10px;width:100%;text-align:left;
  background:none;border:0;border-radius:9px;padding:9px 10px;cursor:pointer;
  font-size:14px;color:var(--ink);font-weight:500;
}
.menu-item:hover{background:#f2f5fa}
.menu-item .ic{width:18px;display:flex;justify-content:center;color:var(--muted);flex:0 0 auto}
.menu-item.active{background:var(--brand-t)}
.menu-item.active .ic{color:var(--brand)}
.menu-item small{margin-left:auto;color:var(--faint);font-weight:600;font-size:12px}
.menu-item.danger{color:#c0392b}
.menu-item.danger .ic{color:#c0392b}
.menu-sep{height:1px;background:var(--line);margin:6px 8px}

/* header right cluster */
.hdr-right{margin-left:auto;display:flex;align-items:center;gap:9px}
.hbtn{
  display:flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.22);
  color:#fff;border-radius:9px;padding:8px 12px;cursor:pointer;font-size:13px;font-weight:600;
  transition:background .15s;white-space:nowrap;
}
.hbtn:hover{background:rgba(255,255,255,.24)}
.hbtn.gold{background:var(--gold);border-color:transparent;color:#3a2c05}
.hbtn.gold:hover{background:#ffb733}
.hbtn.icon{padding:8px}

/* toolbar */
.toolbar{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  padding:10px 18px;background:var(--bg-2);border-bottom:1px solid var(--line-2);
  flex:0 0 auto;position:relative;z-index:20;
}
.search{position:relative;display:flex;align-items:center}
.search svg{position:absolute;left:10px;color:var(--faint)}
.search input{
  border:1px solid var(--line-2);background:#fff;border-radius:9px;
  padding:8px 12px 8px 32px;font-size:13.5px;width:230px;max-width:48vw;color:var(--ink);
  outline:none;transition:border-color .15s,box-shadow .15s;
}
.search input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-t)}
.filt-grp{display:flex;align-items:center;gap:7px}
.filt-lbl{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--faint)}
.av-toggle{
  border:2px solid transparent;border-radius:50%;padding:0;background:none;cursor:pointer;
  opacity:.5;transition:opacity .15s,transform .12s,border-color .15s;
}
.av-toggle:hover{opacity:.85;transform:translateY(-1px)}
.av-toggle.on{opacity:1;border-color:var(--brand)}
.tb-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.progress-wrap{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--muted);font-weight:600}
.progress-bar{width:120px;height:7px;border-radius:99px;background:#cfd8e6;overflow:hidden}
.progress-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--brand),#2f6fc4);border-radius:99px;transition:width .4s cubic-bezier(.4,1,.4,1)}

/* ===== Board ===== */
.board-scroll{flex:1 1 auto;min-height:0;overflow-x:auto;overflow-y:hidden;padding:16px 18px 22px}
.board{display:flex;align-items:flex-start;gap:14px;height:100%;min-height:0}

.col{
  flex:0 0 var(--col-w);width:var(--col-w);max-height:100%;
  background:var(--bg-2);border:1px solid var(--line-2);border-radius:14px;
  display:flex;flex-direction:column;min-height:0;
  transition:background .15s,box-shadow .15s;
}
.col.drop-active{background:#dde6f4;box-shadow:0 0 0 2px var(--brand) inset}
.col-hd{display:flex;align-items:center;gap:8px;padding:11px 10px 9px 13px;flex:0 0 auto}
.col-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.col-name{font-size:13.5px;font-weight:700;letter-spacing:.01em;color:var(--ink);outline:none;border-radius:5px;padding:1px 3px;margin:-1px -3px}
.col-name[contenteditable="true"]{background:#fff;box-shadow:0 0 0 2px var(--brand-t)}
.col-count{font-size:12px;font-weight:700;color:var(--faint);background:#d7dfeb;border-radius:99px;padding:1px 8px;min-width:22px;text-align:center}
.col-hd .sp{flex:1}
.icon-btn{
  width:26px;height:26px;border-radius:7px;border:0;background:none;cursor:pointer;
  color:var(--muted);display:flex;align-items:center;justify-content:center;
  transition:background .15s,color .15s;flex:0 0 auto;
}
.icon-btn:hover{background:#d7dfeb;color:var(--ink)}

.col-list{
  flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;
  padding:3px 8px 8px;display:flex;flex-direction:column;gap:var(--card-gap);
  scrollbar-width:thin;scrollbar-color:#bcc7d8 transparent;
}
.col-list::-webkit-scrollbar{width:8px}
.col-list::-webkit-scrollbar-thumb{background:#bcc7d8;border-radius:99px;border:2px solid transparent;background-clip:content-box}
.col-empty{
  border:1.5px dashed var(--line-2);border-radius:10px;
  padding:16px 12px;text-align:center;color:var(--faint);font-size:12.5px;font-weight:500;
}

/* card */
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:11px;
  padding:var(--card-pad);box-shadow:var(--shadow);cursor:pointer;
  display:flex;flex-direction:column;gap:8px;
  transition:box-shadow .15s,transform .06s,border-color .15s;
  position:relative;touch-action:manipulation;user-select:none;
}
.card:hover{box-shadow:var(--shadow-md);border-color:var(--line-2)}
.card.lifting{opacity:.32}
.card.flag-high{border-left:4px solid #e2483a;padding-left:calc(var(--card-pad) - 3px)}
.card.flag-medium{border-left:4px solid var(--gold);padding-left:calc(var(--card-pad) - 3px)}
.card.flag-low{border-left:4px solid #4a90d9;padding-left:calc(var(--card-pad) - 3px)}

.card-labels{display:flex;flex-wrap:wrap;gap:5px}
.lbl{
  font-size:10.5px;font-weight:700;letter-spacing:.02em;
  padding:2px 8px;border-radius:6px;line-height:1.4;white-space:nowrap;
}
.card-title{font-size:var(--card-title-fs);font-weight:600;line-height:1.32;color:var(--ink);text-wrap:pretty;margin:0}

.card-meta{display:flex;align-items:center;flex-wrap:wrap;gap:6px 7px;font-size:12px;color:var(--muted);font-weight:600}
.chip{display:inline-flex;align-items:center;gap:4px;background:#f1f4f9;border-radius:6px;padding:2px 7px;white-space:nowrap}
.chip svg{flex:0 0 auto}
.chip.due-soon{background:#fdeede;color:#9a6a08}
.chip.due-over{background:#fbe5e2;color:#b3392c}
.chip.budget{background:#e8f3ec;color:#1f7a44}
.chip.vol{background:#eef0fb;color:#42459b}

.card-foot{display:flex;align-items:center;gap:8px;margin-top:1px}
.card-foot .sp{flex:1}
.checkbar{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:var(--muted)}
.checkbar.done{color:#1f7a44}
.mini-prog{width:42px;height:5px;border-radius:99px;background:#e1e7f0;overflow:hidden}
.mini-prog i{display:block;height:100%;background:#9aa6b8;border-radius:99px}
.checkbar.done .mini-prog i{background:#2faa63}

.avatar{
  width:26px;height:26px;border-radius:50%;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;
  font-size:10.5px;font-weight:800;color:#fff;letter-spacing:.02em;
  box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.55);
}
.avatar.sm{width:22px;height:22px;font-size:9.5px}
.avatar.lg{width:34px;height:34px;font-size:13px}
.avatar.empty{background:#dfe5ee!important;color:var(--faint);box-shadow:inset 0 0 0 1.5px #fff}

/* card placeholder during drag */
.card-ph{border:2px dashed var(--brand);border-radius:11px;background:var(--brand-t);min-height:46px;flex:0 0 auto}

/* add-card composer */
.add-card{
  display:flex;align-items:center;gap:8px;width:100%;border:0;background:none;cursor:pointer;
  padding:9px 10px;border-radius:9px;color:var(--muted);font-size:13px;font-weight:600;
  margin:2px 8px 9px;width:calc(100% - 16px);transition:background .15s,color .15s;
}
.add-card:hover{background:#d7dfeb;color:var(--ink)}
.composer{margin:2px 8px 9px;display:flex;flex-direction:column;gap:7px}
.composer textarea{
  border:1px solid var(--brand);border-radius:9px;padding:9px 10px;font:inherit;font-size:13.5px;
  resize:none;outline:none;box-shadow:0 0 0 3px var(--brand-t);color:var(--ink);min-height:54px;
}
.composer-row{display:flex;gap:8px;align-items:center}

/* add-stage */
.add-stage{
  flex:0 0 auto;width:220px;border:1.5px dashed var(--line-2);background:rgba(255,255,255,.4);
  border-radius:14px;color:var(--muted);font-weight:600;font-size:13.5px;cursor:pointer;
  padding:13px;display:flex;align-items:center;justify-content:center;gap:8px;
  transition:background .15s,border-color .15s,color .15s;
}
.add-stage:hover{background:#fff;border-color:var(--brand);color:var(--brand)}

/* ghost (dragged card) */
.drag-ghost{
  position:fixed;top:0;left:0;z-index:9999;pointer-events:none;
  box-shadow:var(--shadow-lg);transform:rotate(2.5deg) scale(1.02);
  transition:none;will-change:transform;
}
.drag-ghost .card{cursor:grabbing;box-shadow:none}

/* ===== Buttons (generic) ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid var(--line-2);
  background:#fff;color:var(--ink);border-radius:9px;padding:9px 14px;font-size:13.5px;font-weight:600;
  cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s}
.btn:hover{background:#f5f8fc;border-color:#c4cedd}
.btn.primary{background:var(--brand);border-color:transparent;color:#fff}
.btn.primary:hover{background:var(--brand-d)}
.btn.danger{color:#c0392b;border-color:#e8c4bf}
.btn.danger:hover{background:#fbeeec}
.btn.ghost{border-color:transparent;background:none}
.btn.ghost:hover{background:#eef2f8}

/* ===== Modal ===== */
.scrim{position:fixed;inset:0;background:rgba(16,28,48,.5);backdrop-filter:blur(3px);
  z-index:1000;display:flex;align-items:flex-start;justify-content:center;
  padding:40px 16px;overflow-y:auto;animation:fade .15s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{
  background:var(--surface);border-radius:16px;box-shadow:var(--shadow-lg);
  width:100%;max-width:620px;margin:auto 0;animation:rise .18s cubic-bezier(.3,.8,.4,1);overflow:hidden;
}
.modal.sm{max-width:440px}
@keyframes rise{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.modal-top{height:7px;background:var(--brand)}
.modal-hd{display:flex;align-items:flex-start;gap:12px;padding:18px 20px 6px}
.modal-hd .stage-pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;color:var(--muted);
  background:#eef2f8;border-radius:99px;padding:4px 11px;white-space:nowrap}
.modal-title{
  font-size:21px;font-weight:700;line-height:1.25;color:var(--ink);width:100%;border:0;outline:none;
  resize:none;font-family:inherit;background:none;padding:2px 0;margin:0;text-wrap:pretty;
}
.modal-title:focus{box-shadow:0 2px 0 var(--brand)}
.modal-x{margin-left:auto;flex:0 0 auto}
.modal-body{padding:6px 20px 8px;display:flex;flex-direction:column;gap:18px}
.modal-foot{display:flex;align-items:center;gap:10px;padding:15px 20px;border-top:1px solid var(--line);background:#fafbfd}
.modal-foot .sp{flex:1}

.fgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 18px}
.field{display:flex;flex-direction:column;gap:6px}
.field-lbl{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}
.inp,.sel,.ta{border:1px solid var(--line-2);border-radius:9px;padding:9px 11px;font:inherit;font-size:14px;
  color:var(--ink);background:#fff;outline:none;width:100%;transition:border-color .15s,box-shadow .15s}
.inp:focus,.sel:focus,.ta:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-t)}
.ta{resize:vertical;min-height:74px;line-height:1.5}

.owner-row{display:flex;gap:8px;flex-wrap:wrap}
.owner-opt{display:flex;align-items:center;gap:7px;border:1px solid var(--line-2);background:#fff;border-radius:99px;
  padding:4px 12px 4px 4px;cursor:pointer;font-size:13px;font-weight:600;color:var(--ink);transition:border-color .15s,background .15s}
.owner-opt:hover{background:#f5f8fc}
.owner-opt.sel{border-color:var(--brand);background:var(--brand-t);box-shadow:0 0 0 1px var(--brand)}

.lbl-row{display:flex;gap:7px;flex-wrap:wrap}
.lbl-opt{font-size:12px;font-weight:700;padding:5px 11px;border-radius:7px;cursor:pointer;border:1.5px solid transparent;opacity:.5;transition:opacity .15s,transform .1s}
.lbl-opt:hover{opacity:.85}
.lbl-opt.sel{opacity:1}

.prio-row{display:flex;gap:7px}
.prio-opt{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line-2);
  background:#fff;border-radius:9px;padding:8px;cursor:pointer;font-size:12.5px;font-weight:700;color:var(--muted);transition:.15s}
.prio-opt:hover{background:#f5f8fc}
.prio-opt.sel{color:#fff}
.prio-opt.sel[data-p="none"]{background:#8a97a8;border-color:transparent}
.prio-opt.sel[data-p="low"]{background:#4a90d9;border-color:transparent}
.prio-opt.sel[data-p="medium"]{background:var(--gold);border-color:transparent;color:#3a2c05}
.prio-opt.sel[data-p="high"]{background:#e2483a;border-color:transparent}

/* checklist */
.check-head{display:flex;align-items:center;gap:9px;margin-bottom:2px}
.check-head .field-lbl{margin:0}
.check-prog{font-size:12px;font-weight:700;color:var(--muted)}
.check-list{display:flex;flex-direction:column;gap:3px}
.check-item{display:flex;align-items:center;gap:9px;padding:5px 4px;border-radius:8px}
.check-item:hover{background:#f5f8fc}
.check-box{width:19px;height:19px;border-radius:6px;border:1.8px solid var(--line-2);background:#fff;cursor:pointer;
  flex:0 0 auto;display:flex;align-items:center;justify-content:center;color:#fff;transition:.12s}
.check-box.on{background:#2faa63;border-color:#2faa63}
.check-item input.ci{flex:1;border:0;background:none;font:inherit;font-size:13.5px;color:var(--ink);outline:none;padding:2px 0}
.check-item.checked input.ci{text-decoration:line-through;color:var(--faint)}
.check-del{opacity:0;transition:opacity .15s}
.check-item:hover .check-del{opacity:1}
.check-add{display:flex;align-items:center;gap:9px;padding:5px 4px}
.check-add input{flex:1;border:1px solid var(--line-2);border-radius:8px;padding:7px 10px;font:inherit;font-size:13.5px;outline:none}
.check-add input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-t)}

/* empty project */
.empty-board{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  height:100%;color:var(--muted);text-align:center;padding:40px}
.empty-board h3{margin:0;font-size:18px;color:var(--ink)}

/* toast */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:2000;
  background:var(--ink);color:#fff;border-radius:11px;padding:11px 18px;font-size:13.5px;font-weight:600;
  box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px;animation:rise .2s ease}
.toast .undo{color:var(--gold);font-weight:700;cursor:pointer;background:none;border:0;font-size:13.5px}

/* ===== Identity, roles, members (added) ===== */
.av-stack{display:flex;align-items:center}
.av-stack .avatar{margin-left:-7px;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.55),0 0 0 2px #fff}
.av-stack .avatar:first-child{margin-left:0}
.avatar.more{background:#c3cdda;color:#46566c}

/* identity chip */
.id-chip{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.2);
  color:#fff;border-radius:99px;padding:4px 9px 4px 4px;cursor:pointer;font-weight:600;font-size:13.5px;transition:background .15s}
.id-chip:hover{background:rgba(255,255,255,.22)}
.id-chip .chev{opacity:.8}
.id-name{white-space:nowrap;max-width:120px;overflow:hidden;text-overflow:ellipsis}
.id-head{display:flex;align-items:center;gap:11px;padding:10px 11px 6px}
.id-h-name{font-weight:700;font-size:14.5px;color:var(--ink)}
.id-h-mail{font-size:12px;color:var(--faint)}
.id-note{font-size:11.5px;color:var(--faint);line-height:1.45;padding:7px 11px 6px}

/* menu item name + admin badge */
.mi-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;gap:7px;min-width:0}
.mi-badge{font-size:9.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--brand);
  background:var(--brand-t);border-radius:5px;padding:1px 6px;flex:0 0 auto}

/* My-tasks toolbar toggle */
.chip-toggle{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line-2);background:#fff;color:var(--muted);
  border-radius:9px;padding:7px 11px;font-size:13px;font-weight:600;cursor:pointer;transition:.15s;white-space:nowrap}
.chip-toggle:hover{border-color:#c4cedd;color:var(--ink)}
.chip-toggle.on{background:var(--brand);border-color:transparent;color:#fff}
.ct-count{font-size:11.5px;font-weight:800;background:rgba(0,0,0,.10);border-radius:99px;padding:0 7px;min-width:18px;text-align:center}
.chip-toggle.on .ct-count{background:rgba(255,255,255,.25)}

/* read-only states */
.ro-pill{font-size:10.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);
  background:#eef2f8;border:1px solid var(--line);border-radius:99px;padding:3px 10px;margin-left:2px}
.ro-note{display:flex;align-items:center;gap:9px;background:#f4f7fb;border:1px solid var(--line);border-radius:10px;
  padding:10px 12px;font-size:13px;color:var(--muted);font-weight:500;line-height:1.4}
.ro-note svg{flex:0 0 auto;color:var(--faint)}
.ro-muted{font-size:13.5px;color:var(--faint);font-weight:500}
.card.locked{cursor:pointer}
.inp:disabled,.sel:disabled,.ta:read-only,.prio-opt:disabled,.lbl-opt:disabled,.check-box:disabled,.ci:read-only{
  opacity:.7;cursor:default}
.prio-opt:disabled,.lbl-opt:disabled{pointer-events:none}

/* dialog text */
.dlg-title{margin:0;font-size:18px;font-weight:700}
.dlg-hint{font-size:12.5px;color:var(--muted);line-height:1.45}
.dlg-body{margin:0;color:var(--muted);line-height:1.55;font-size:14.5px}

/* admins dialog */
.admin-list{display:flex;flex-direction:column;gap:7px;margin-top:6px}
.admin-row{display:flex;align-items:center;gap:11px;width:100%;text-align:left;border:1px solid var(--line-2);
  background:#fff;border-radius:11px;padding:10px 12px;cursor:pointer;transition:.15s}
.admin-row:hover{background:#f5f8fc}
.admin-row.on{border-color:var(--brand);background:var(--brand-t)}
.admin-row:disabled{opacity:.5;cursor:not-allowed}
.admin-meta{display:flex;flex-direction:column;gap:1px;min-width:0}
.admin-meta b{font-size:14px;font-weight:700;color:var(--ink)}
.admin-meta small{font-size:12px;color:var(--faint)}
.admin-tick{margin-left:auto;width:22px;height:22px;border-radius:50%;border:1.8px solid var(--line-2);
  display:flex;align-items:center;justify-content:center;color:#fff;flex:0 0 auto}
.admin-tick.on{background:var(--brand);border-color:var(--brand)}

.tweak-tip{font-size:11px;color:rgba(41,38,27,.55);line-height:1.45;padding-top:2px}

/* mobile */
@media (max-width:680px){
  :root{--col-w:84vw}
  .hdr{padding:10px 13px;gap:10px}
  .hdr-sub{display:none}
  .hbtn .lbl-txt{display:none}
  .hbtn{padding:8px}
  .id-name{display:none}
  .id-chip{padding:4px}
  .proj-btn{font-size:15px;max-width:52vw}
  .toolbar{padding:9px 13px;gap:9px}
  .search input{width:100%;max-width:none}
  .search{flex:1 1 100%}
  .tb-right{width:100%;justify-content:space-between}
  .board-scroll{padding:13px 13px 18px;scroll-snap-type:x proximity}
  .col{scroll-snap-align:start}
  .fgrid{grid-template-columns:1fr}
  .scrim{padding:14px 10px}
  .modal-body{gap:15px}
}
