:root{--bg:#0f1115;--panel:#181b22;--line:#2a2f3a;--ink:#e8eaed;
  --mut:#8b929f;--acc:#5b8cff;--ok:#3fb950;--warn:#d29922;--rev:#d2992200;}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);
  font:15px/1.4 -apple-system,Segoe UI,Roboto,Arial,sans-serif}
a{color:var(--acc);text-decoration:none}
.topbar{display:flex;justify-content:space-between;align-items:center;
  padding:10px 18px;background:var(--panel);border-bottom:1px solid var(--line)}
.brand{font-weight:700;font-size:17px;color:var(--ink)}
.who{color:var(--mut);font-size:13px}
.wrap{max-width:1200px;margin:0 auto;padding:22px 18px}
.row-between{display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:12px}
h1{font-size:22px;margin:.2em 0}
.muted{color:var(--mut)}
.newproj input{background:#0c0e12;border:1px solid var(--line);color:var(--ink);
  padding:9px 11px;border-radius:7px;width:240px}
button,.btn{cursor:pointer;border:1px solid var(--line);background:#222733;
  color:var(--ink);padding:9px 13px;border-radius:7px;font-size:14px}
button:hover,.btn:hover{border-color:var(--acc)}
.btn{display:inline-block}.btn.ghost{background:transparent}
.newproj button{background:var(--acc);border-color:var(--acc);margin-left:8px}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:14px;margin-top:18px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:10px;
  padding:14px;display:block}
.card:hover{border-color:var(--acc)}
.card-title{font-weight:600;margin-bottom:6px}
.card-meta{font-size:12px;color:var(--mut)}

/* editor */
.ed-bar{display:flex;justify-content:space-between;align-items:center;
  gap:14px;flex-wrap:wrap;margin-bottom:18px}
.title-input{background:transparent;border:none;color:var(--ink);
  font-size:21px;font-weight:700;padding:6px 4px;border-bottom:1px solid transparent}
.title-input:focus{outline:none;border-bottom:1px solid var(--acc)}
.ed-actions{display:flex;align-items:center;gap:10px}
.ed-actions select{background:#0c0e12;color:var(--ink);
  border:1px solid var(--line);padding:7px;border-radius:6px}
.save-state{font-size:12px;color:var(--mut);min-width:54px;text-align:right}
.save-state.saving{color:var(--warn)}.save-state.saved{color:var(--ok)}

.frames{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:22px;align-items:start;position:relative}
/* persistent "keep on page" annotation overlay — drawn by editor.js */
#persist-ann{position:absolute;left:0;top:0;pointer-events:none;z-index:200;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}
#persist-ann[hidden]{display:none}
/* in filter view, frames reflow — hide annotations so they don't point
   at the wrong shots (restored when the filter clears) */
.frames.ann-hidden #persist-ann,
.frames.ann-hidden .persist-text{display:none !important}
.frame{position:relative;background:var(--panel);border:1px solid var(--line);
  border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:9px}
.frame.dragging{opacity:.4}
.frame.dragover{border-color:var(--acc)}
/* Insert buttons straddle the frame edges and only show on hover —
   no always-visible clutter, and the grid flows multi-column cleanly. */
.ins-row,.ins-end{position:absolute;top:50%;transform:translateY(-50%);
  width:28px;height:28px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;background:#14161b;color:var(--ink);
  border:1px solid var(--line);
  font-size:17px;font-weight:700;line-height:1;cursor:pointer;padding:0;
  opacity:0;transition:opacity .12s;z-index:6;
  box-shadow:0 2px 6px rgba(0,0,0,.5)}
.ins-row:hover,.ins-end:hover{border-color:var(--ink)}
.ins-row{left:-25px}   /* centred in the gap between frames */
.ins-end{right:-14px}
.frame:hover .ins-row,.frame:hover .ins-end,
.ins-row:focus-visible,.ins-end:focus-visible{opacity:1}
.ins-row:hover,.ins-end:hover{filter:brightness(1.18)}
.frame-head{display:flex;align-items:center;gap:7px}
.fnum{font-weight:700;background:#0c0e12;border:1px solid var(--line);
  border-radius:6px;padding:2px 9px;font-size:13px}
.grip{cursor:grab;color:var(--mut);margin-left:auto;font-size:16px;user-select:none}
.status{background:#0c0e12;color:var(--ink);border:1px solid var(--line);
  border-radius:6px;padding:4px;font-size:12px}
.status.status-in_progress{border-color:var(--acc)}
.status.status-needs_review{border-color:var(--warn)}
.status.status-approved{border-color:var(--ok)}
.mini{padding:4px 8px;font-size:12px}
.mini.danger:hover{border-color:#e5534b;color:#e5534b}
.img-slot{position:relative;display:flex;align-items:center;justify-content:center;
  background:#0c0e12;border:1px dashed var(--line);border-radius:8px;
  overflow:hidden;cursor:pointer;width:100%}
.img-slot img{width:100%;height:100%;object-fit:cover;display:block;
  cursor:zoom-in}
.img-slot.drop-hot{border-style:solid;border-color:var(--acc);
  box-shadow:0 0 0 2px var(--acc) inset}
.img-empty{color:var(--mut);font-size:13px;text-align:center;
  display:flex;flex-direction:column;gap:3px}
.img-empty small{font-size:11px;opacity:.7}
/* WIP placeholder — looks like an uploaded image: flat grey, bold white WIP */
.img-wip{width:100%;height:100%;display:flex;align-items:center;
  justify-content:center;background:#73777e;color:#fff;
  font-size:32px;font-weight:800;letter-spacing:.09em}
/* hover (or always, on touch) actions on a filled image */
.img-acts{position:absolute;top:6px;right:6px;display:flex;gap:5px;
  opacity:0;transition:opacity .12s}
.img-slot:hover .img-acts{opacity:1}
@media (hover:none){.img-acts{opacity:1}}
.img-act{background:rgba(12,14,18,.92);color:#fff;border:1px solid var(--line);
  border-radius:6px;padding:4px 8px;font-size:11px;font-weight:600;
  cursor:pointer}
.img-act:hover{border-color:var(--acc)}
.img-acts{z-index:5}
/* red revision flag — image stays visible, red wash + an obvious Clear */
.revflag{position:absolute;inset:0;z-index:4;pointer-events:none;
  background:rgba(224,32,32,.33)}   /* see-through, but unmistakably red at a glance */
.revflag-tag{position:absolute;top:8px;left:10px;font-size:18px;
  font-weight:800;color:#fff;letter-spacing:.06em;
  text-shadow:0 1px 4px rgba(0,0,0,.8)}
/* understated — a red outline chip, not a black-and-white glob */
.revflag-clear{position:absolute;bottom:8px;right:8px;pointer-events:auto;
  background:rgba(12,14,18,.5);color:#ffd9d6;border:1px solid rgba(255,255,255,.45);
  border-radius:6px;padding:5px 10px;font-size:10.5px;font-weight:600;
  cursor:pointer;opacity:.7}
.revflag-clear:hover{opacity:1;background:#e5534b;color:#fff;
  border-color:#e5534b}

/* ── tags ──────────────────────────────────────────────────────── */
.ftags{display:flex;flex-wrap:wrap;gap:5px;align-items:center;
  border-top:1px solid var(--line);margin-top:2px;padding-top:8px}
.ftag{font-size:11px;font-weight:700;color:#fff;border-radius:5px;
  padding:2px 7px;line-height:1.5;max-width:130px;overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap;
  text-shadow:0 1px 2px rgba(0,0,0,.4)}
.ftag-btn{background:#0c0e12;border:1px solid var(--line);border-radius:5px;
  font-size:12px;line-height:1;padding:3px 6px;cursor:pointer}
.ftag-btn:hover{border-color:var(--acc)}
/* 3+ tags collapse to colour-only squares (hover shows the label) —
   the filter bar does the finding, the frame just needs a glance-key */
.ftags-mini .ftag{font-size:0;width:15px;height:15px;padding:0;
  border-radius:4px}
.tag-filter{display:flex;flex-wrap:wrap;align-items:center;gap:7px;
  padding:9px 4px 2px}
.tag-filter[hidden]{display:none}
.tf-label{font-size:12px;color:var(--mut);font-weight:600}
.tf-chip{font-size:12px;font-weight:600;color:var(--ink);cursor:pointer;
  background:#0c0e12;border:1px solid var(--line);border-radius:99px;
  padding:4px 11px;border-left:5px solid var(--tc,#888)}
.tf-chip:hover{border-color:var(--acc)}
.tf-chip.on{background:var(--tc,#888);color:#fff;border-color:var(--tc,#888)}
.tf-clear{font-size:12px;color:var(--warn);background:none;border:none;
  cursor:pointer}
#tag-pop{position:fixed;z-index:1500;width:248px;background:var(--panel);
  border:1px solid var(--acc);border-radius:12px;padding:12px;
  box-shadow:0 12px 36px rgba(0,0,0,.6)}
#tag-pop[hidden]{display:none}
#tag-pop-head{font-size:12px;font-weight:700;color:var(--mut);
  text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}
#tag-pop-list{max-height:240px;overflow-y:auto;margin-bottom:8px}
.tag-pop-cat{font-size:10px;font-weight:800;color:var(--mut);
  text-transform:uppercase;letter-spacing:.06em;margin:8px 0 3px}
.tag-pop-row{display:flex;align-items:center;gap:7px;padding:4px 0;
  font-size:13px;cursor:pointer}
.tag-pop-sw{width:13px;height:13px;border-radius:3px;flex:none}
.tag-pop-empty{font-size:12px;color:var(--mut);padding:4px 0}
.tag-pop-new{display:flex;gap:5px;margin-bottom:8px}
.tag-pop-new input{flex:1;min-width:0;background:#0c0e12;color:var(--ink);
  border:1px solid var(--line);border-radius:6px;padding:6px;
  font:12px/1.3 inherit}
#tag-pop-add{flex:none;background:var(--acc);color:#fff;border:none;
  border-radius:6px;padding:6px 9px;font-size:12px;font-weight:700;
  cursor:pointer}
#tag-pop-close{width:100%}

/* ── export dialog ── */
#export-dlg{position:fixed;inset:0;z-index:1600;background:rgba(0,0,0,.6);
  display:flex;align-items:center;justify-content:center}
#export-dlg[hidden]{display:none}
#export-box{background:var(--panel);border:1px solid var(--acc);
  border-radius:12px;padding:20px 22px;width:310px;
  box-shadow:0 16px 48px rgba(0,0,0,.7)}
.exp-head{font-size:15px;font-weight:700;margin-bottom:14px}
.exp-row{display:flex;justify-content:space-between;align-items:center;
  font-size:13px;color:var(--mut);margin-bottom:10px;gap:12px}
.exp-row select{flex:1;background:#0c0e12;color:var(--ink);
  border:1px solid var(--line);border-radius:6px;padding:6px 8px;
  font:13px/1.3 inherit}
.exp-note{font-size:12px;color:var(--acc);margin:6px 0 12px;min-height:1.1em}
.exp-actions{display:flex;justify-content:flex-end;gap:8px}

/* ── the egg ── */
#egg-btn{position:fixed;left:10px;top:9px;z-index:900;width:22px;
  height:22px;padding:0;font-size:13px;line-height:1;background:none;
  border:none;color:var(--line);cursor:pointer;opacity:.55}
#egg-btn:hover{opacity:.85}
#egg-player{position:fixed;right:20px;bottom:20px;z-index:1800;width:340px;
  background:var(--panel);border:1px solid var(--acc);border-radius:12px;
  overflow:hidden;box-shadow:0 14px 44px rgba(0,0,0,.7)}
#egg-player[hidden]{display:none}
#egg-bar{display:flex;align-items:center;gap:6px;padding:7px 9px;
  background:#0c0e12;cursor:move;user-select:none}
#egg-bar .egg-sp{flex:1}
#egg-bar button{background:none;border:1px solid var(--line);color:var(--ink);
  border-radius:6px;width:30px;height:26px;font-size:11px;cursor:pointer;
  padding:0;display:flex;align-items:center;justify-content:center;line-height:1}
#egg-bar button:hover{border-color:var(--acc)}
#egg-video{display:block;width:100%;background:#000;max-height:70vh}
.fields{display:flex;flex-direction:column;gap:7px}
.field{display:flex;flex-direction:column;gap:3px}
.flab{font-size:11px;color:var(--mut);text-transform:uppercase;letter-spacing:.04em}
.fval{background:#0c0e12;color:var(--ink);border:1px solid var(--line);
  border-radius:6px;padding:7px;font:14px/1.4 inherit;resize:vertical;width:100%}
.fval:focus{outline:none;border-color:var(--acc)}
.add-frame{display:flex;align-items:center;justify-content:center;
  min-height:140px;border:1px dashed var(--line);background:transparent;
  color:var(--mut);font-size:15px}
.add-frame:hover{border-color:var(--acc);color:var(--ink)}

/* touch devices have no hover — show the insert buttons by default */
@media (hover: none){
  .ins-row,.ins-end{opacity:.92}
}
/* per-frame select checkbox + selected state */
.fsel{width:16px;height:16px;flex:none;cursor:pointer;accent-color:var(--acc)}
.frame.selected{border-color:var(--acc);box-shadow:0 0 0 1px var(--acc)}
/* per-frame delete — small, always-visible, unmistakably a red trash can */
.fdel{background:none;border:1px solid transparent;cursor:pointer;
  padding:4px 6px;border-radius:6px;color:#e5534b;opacity:.9;
  display:inline-flex;align-items:center}
.fdel svg{display:block}
.fdel:hover{opacity:1;background:#3a1715;border-color:#e5534b}
/* multi-select action bar */
.sel-bar{display:flex;align-items:center;gap:10px;margin:0 0 14px;
  padding:10px 14px;background:var(--panel);
  border:1px solid var(--acc);border-radius:10px}
.sel-bar[hidden]{display:none}
#selcount{font-weight:700;font-size:14px}
.sel-spacer{flex:1}
.btn.danger{background:#e5534b;border-color:#e5534b;color:#fff}
.btn.danger:hover{filter:brightness(1.1)}

/* comments — a clear button on every frame, no hover, no hunting */
.fcomments{border-top:1px solid var(--line);margin-top:2px;padding-top:9px}
.cbtn{display:flex;align-items:center;justify-content:center;gap:7px;
  width:100%;background:#0c0e12;color:var(--ink);border:1px solid var(--line);
  border-radius:8px;padding:9px;font-size:13px;font-weight:700;cursor:pointer}
.cbtn:hover{border-color:var(--acc)}
.cbadge{background:var(--acc);color:#fff;border-radius:99px;min-width:18px;
  height:18px;padding:0 5px;font-size:11px;font-weight:700;
  display:inline-flex;align-items:center;justify-content:center}
.cpanel{margin-top:8px}
.cpanel[hidden]{display:none}
.clist{display:flex;flex-direction:column;gap:7px;margin-bottom:8px}
.citem{position:relative;background:#0c0e12;border:1px solid var(--line);
  border-radius:8px;padding:7px 9px}
.cdel{position:absolute;top:4px;right:5px;background:none;border:none;
  color:var(--mut);font-size:12px;line-height:1;cursor:pointer;
  padding:3px 5px;border-radius:5px;opacity:.5}
.cdel:hover{opacity:1;background:#3a1715;color:#e5534b}
.cmeta{font-size:11px;color:var(--mut);margin-bottom:2px;padding-right:22px}
.cmeta b{color:var(--ink)}
.cdate{margin-left:6px}
.cbody{font-size:13px;white-space:pre-wrap;word-break:break-word}
.cimg{display:block;width:100%;border:1px solid var(--line);
  border-radius:6px;margin:5px 0;cursor:zoom-in}
/* click an annotation screenshot → blows up in-page (not a new tab) */
.lightbox{position:fixed;inset:0;z-index:3000;background:rgba(0,0,0,.86);
  display:flex;align-items:center;justify-content:center;
  cursor:zoom-out;padding:30px}
.lightbox img{max-width:100%;max-height:100%;border-radius:8px;
  box-shadow:0 14px 50px rgba(0,0,0,.8)}
.lightbox-annotate{position:fixed;left:50%;bottom:30px;
  transform:translateX(-50%);background:rgba(18,20,25,.92);color:#fff;
  border:1px solid rgba(255,255,255,.5);
  border-radius:9px;padding:11px 20px;font-size:14px;font-weight:700;
  cursor:pointer;box-shadow:0 8px 24px rgba(0,0,0,.6)}
.lightbox-annotate:hover{border-color:#fff;background:rgba(30,33,40,.95)}
/* draw straight on the enlarged frame image */
.lightbox.annotating{cursor:default}
.lb-canvas{position:fixed;z-index:3001;cursor:crosshair;touch-action:none;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.45))}
.lb-tools{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);
  z-index:3002;display:flex;gap:9px;align-items:center;background:var(--panel);
  border:1px solid var(--line);border-radius:11px;padding:9px 13px;
  box-shadow:0 10px 30px rgba(0,0,0,.6)}
.lb-sw{width:22px;height:22px;border-radius:50%;cursor:pointer;
  border:2px solid transparent;flex:none}
.lb-sw.on{border-color:#fff}
.lb-t{font:800 21px/1 Georgia,"Times New Roman",serif;padding:0 7px;
  cursor:grab;user-select:none;flex:none}
.lb-t:active{cursor:grabbing}
.lb-text{position:fixed;z-index:3003;min-width:24px;min-height:1.3em;
  max-width:240px;font:700 17px/1.35 -apple-system,"Segoe UI",Roboto,sans-serif;
  white-space:pre-wrap;word-wrap:break-word;outline:none;cursor:text;
  text-shadow:0 1px 3px rgba(0,0,0,.8)}
.lb-text:empty:before{content:"type\2026";opacity:.5}

/* ── link access — the unlock modal ── */
.lock-modal{position:fixed;inset:0;z-index:2400;background:rgba(0,0,0,.66);
  display:flex;align-items:center;justify-content:center;padding:20px}
.lock-modal[hidden]{display:none}
.lock-box{background:var(--panel);border:1px solid var(--acc);
  border-radius:13px;padding:24px 26px;width:360px;
  box-shadow:0 18px 54px rgba(0,0,0,.7)}
.lock-h{font-size:17px;font-weight:700;margin-bottom:9px}
.lock-p{font-size:13px;color:var(--mut);line-height:1.5;margin-bottom:14px}
.lock-p b{color:var(--ink)}
.lock-box input{width:100%;background:#0c0e12;color:var(--ink);
  border:1px solid var(--line);border-radius:7px;padding:10px 11px;
  font:14px/1.3 inherit}
.lock-err{color:#e5746e;font-size:12px;margin-top:6px}
.lock-err[hidden]{display:none}
.lock-opt{font-size:12px;color:var(--mut);margin:15px 0 6px}
.lock-acts{display:flex;justify-content:flex-end;gap:9px;margin-top:16px}
.editor.locked .frame-head,
.editor.locked .ftags{opacity:.5}
.cempty{font-size:12px;color:var(--mut);padding:4px 2px}
.cform{display:flex;flex-direction:column;gap:6px}
.cauthor,.cinput{background:#0c0e12;color:var(--ink);border:1px solid var(--line);
  border-radius:6px;padding:7px;font:13px/1.4 inherit;width:100%}
.cinput{resize:vertical}
.cauthor:focus,.cinput:focus{outline:none;border-color:var(--acc)}
/* name is optional + de-emphasised; the comment box is the star */
.crow{display:flex;gap:6px;align-items:stretch}
.crow .cauthor{flex:1;width:auto;font-size:11px;padding:6px 8px;opacity:.6}
.crow .cauthor:focus{opacity:1}
.cpost{flex:0 0 auto;background:var(--acc);color:#fff;border:none;
  border-radius:6px;padding:8px 14px;font-size:13px;font-weight:700;
  cursor:pointer}
.cpost:disabled{opacity:.5;cursor:default}

/* fourth-wall annotation overlay — draw straight on top of the page */
#annotate-btn.on{background:var(--acc);color:#fff;border-color:var(--acc)}
#annotate-layer{position:fixed;inset:0;z-index:1000}
#annotate-layer[hidden]{display:none}
#annotate-canvas{position:absolute;inset:0;width:100%;height:100%;
  cursor:crosshair;touch-action:none;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.45))}
#annotate-erase.on{background:var(--acc);color:#fff;border-color:var(--acc)}
/* floating Annotate — appears once scrolled down a long board */
#annotate-float{position:fixed;right:18px;bottom:18px;z-index:850;
  background:#14161b;color:var(--ink);border:1px solid var(--line);
  border-radius:9px;padding:11px 17px;font-size:14px;font-weight:700;
  cursor:pointer;box-shadow:0 6px 20px rgba(0,0,0,.55)}
#annotate-float:hover{border-color:var(--ink)}
#annotate-float[hidden]{display:none}
/* text tool — a draggable icon that shows the colour it will write */
#annotate-text{font:800 21px/1 Georgia,"Times New Roman",serif;
  padding:2px 9px;cursor:grab;user-select:none;border-radius:7px;
  border:1px dashed transparent}
#annotate-text:hover{border-color:var(--line)}
#annotate-text.on{border-color:currentColor;border-style:solid;
  background:rgba(255,255,255,.06)}
#annotate-text:active{cursor:grabbing}
.ann-text-ghost{position:fixed;z-index:2000;transform:translate(-50%,-50%);
  font:800 24px/1 Georgia,serif;pointer-events:none;
  text-shadow:0 1px 4px rgba(0,0,0,.6)}
/* annotate toolbar: tools | finish — divider + red Clear / green Done */
.atool-sep{display:inline-block;width:1px;height:20px;
  background:var(--line);margin:0 5px;vertical-align:middle}
#annotate-clear{color:#e5534b;border-color:rgba(229,83,75,.55)}
#annotate-clear:hover{background:rgba(229,83,75,.16);border-color:#e5534b}
#annotate-keep{color:#48c774;border-color:rgba(72,199,116,.55)}
#annotate-keep:hover{background:rgba(72,199,116,.16);border-color:#48c774}
/* text annotations — typed straight on the page */
#ann-text-layer{position:absolute;left:0;top:0;width:100%;height:100%;
  pointer-events:none;will-change:transform}
.ann-text-wrap{position:absolute;pointer-events:auto}
.ann-text{min-width:26px;min-height:1.3em;max-width:240px;
  font:700 17px/1.35 -apple-system,"Segoe UI",Roboto,sans-serif;
  white-space:pre-wrap;word-wrap:break-word;outline:none;cursor:text;
  text-shadow:0 1px 3px rgba(0,0,0,.75),0 0 2px rgba(0,0,0,.6)}
.ann-text:empty:before{content:"type\2026";opacity:.45}
.ann-text-del{position:absolute;top:-10px;right:-10px;width:18px;height:18px;
  border:none;border-radius:50%;background:#222;color:#fff;font-size:10px;
  line-height:1;cursor:pointer;padding:0;opacity:.9}
.persist-text{position:absolute;max-width:240px;z-index:200;
  font:700 17px/1.35 -apple-system,"Segoe UI",Roboto,sans-serif;
  white-space:pre-wrap;word-wrap:break-word;pointer-events:none;
  text-shadow:0 1px 3px rgba(0,0,0,.75),0 0 2px rgba(0,0,0,.6)}
#annotate-tools{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);
  display:flex;gap:9px;align-items:center;background:var(--panel);
  border:1px solid var(--acc);border-radius:14px;padding:11px 15px;
  box-shadow:0 10px 30px rgba(0,0,0,.65);z-index:1001}
#annotate-tools .atag{font-size:12px;color:var(--mut);font-weight:600;
  margin-right:3px}
.aswatch{width:26px;height:26px;border-radius:50%;cursor:pointer;
  border:2px solid #0c0e12;box-shadow:0 0 0 1px var(--line);
  transition:transform .1s}
.aswatch:hover{transform:scale(1.12)}
.aswatch.on{border-color:#fff;box-shadow:0 0 0 2px var(--acc)}
/* frame-size zoom slider */
.zoomctl{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--mut)}
.zoomctl input[type=range]{width:88px;cursor:pointer;accent-color:var(--acc)}
/* the screenshot flying into its comment */
.ann-fly{position:fixed;z-index:2000;border-radius:8px;object-fit:cover;
  box-shadow:0 12px 40px rgba(0,0,0,.75);pointer-events:none;
  transition:left .82s cubic-bezier(.5,0,.25,1),
    top .82s cubic-bezier(.5,0,.25,1),
    width .82s cubic-bezier(.5,0,.25,1),
    height .82s cubic-bezier(.5,0,.25,1),opacity .82s ease}
