/* ── Anim Tool — customizable floating-panel workspace ──────────────── */
:root{
  /* Neutral-grey tool chrome (design §0): canvas is the only real colour, one red accent. */
  --ink:#202020; --paper:#d6d6d6; --panel:#e4e4e4; --red:#B23A2E;
  --red-deep:#8F2C22; --gold:#c2a35c; --moss:#7f8f6e; --line:#000;
  --stage:#2b2b2b; --bar:#1b1b1b; --bar2:#262626;
  --t-panel:#2e2e2e; --t-panel-2:#242424; --t-text-2:#8c8c8c; --t-micro:#777;
  --mk-accent:#B23A2E; --mk-dialogue:#3b6ea5; --mk-sound:#cf9a3a; --mk-note:#9a9a9a;
  --key:#c9bda0; --breakdown:#5f86b0;
  --col:30px; --gutter:172px;   /* timeline column width + sticky label gutter (frame-alignment backbone) */
  --sans:-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif; --serif:Georgia,serif;
}
*{box-sizing:border-box;}
html,body{margin:0;height:100%;overscroll-behavior:none;}
body{background:var(--ink);color:var(--paper);font-family:var(--sans);font-size:13px;height:100vh;overflow:hidden;
  -webkit-font-smoothing:antialiased;user-select:none;-webkit-user-select:none;}
input,textarea{user-select:text;-webkit-user-select:text;}
button{font-family:var(--sans);cursor:pointer;}
kbd{background:var(--panel);color:var(--ink);border-radius:4px;padding:0 5px;font-size:10px;border:1px solid var(--line);}
[hidden]{display:none !important;}

/* ── menu bar ──────────────────────────────────────────────────────── */
#menubar{position:fixed;left:0;right:0;top:0;height:34px;display:flex;align-items:center;gap:1px;
  background:var(--bar2);border-bottom:1px solid #000;padding:0 8px;z-index:100;}
.brandmini{display:flex;align-items:center;gap:7px;font-weight:700;margin-right:8px;}
.brandmini .seal{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;background:var(--red);border-radius:50%;font-family:var(--serif);font-size:14px;}
.menu-top{position:relative;}
.menu-top>button{background:none;border:none;color:var(--paper);padding:7px 11px;font-size:13px;border-radius:4px;}
.menu-top>button:hover,.menu-top.open>button{background:var(--ink);}
.menu-drop{position:absolute;left:0;top:31px;min-width:210px;background:var(--bar2);border:1px solid #000;border-radius:7px;padding:5px;display:none;flex-direction:column;gap:1px;z-index:110;box-shadow:0 16px 40px rgba(0,0,0,.6);}
.menu-top.open .menu-drop{display:flex;}
.menu-drop button,.menu-drop label{display:flex;justify-content:space-between;align-items:center;gap:18px;background:none;border:none;color:var(--paper);text-align:left;padding:7px 10px;border-radius:5px;font-size:12px;cursor:pointer;white-space:nowrap;}
.menu-drop button:hover,.menu-drop label:hover{background:var(--red);}
.menu-drop .sep{height:1px;background:#000;margin:4px 2px;}
.menu-drop .lbl{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);padding:6px 10px 2px;}
.menu-drop .chkitem input{margin-right:8px;accent-color:var(--moss);}
.mb-save{margin-left:auto;font-size:11px;opacity:.6;font-style:italic;font-family:var(--serif);}

/* ── docks ─────────────────────────────────────────────────────────── */
.dock{position:fixed;background:var(--bar);overflow:auto;z-index:20;border:0 solid #000;}
.dock.dock-v{top:34px;display:flex;flex-direction:column;}
#dock-left{left:0;border-right-width:1px;} #dock-right{right:0;border-left-width:1px;}
#dock-bottom{bottom:0;}
.dock.dock-h{display:flex;flex-direction:row;border-top-width:1px;}
.dock.empty{display:none;}
.dragger{position:fixed;z-index:21;background:#000;}
.dragger:hover{background:var(--red);}
.dragger.v{width:6px;top:34px;cursor:col-resize;}
.dragger.h{height:6px;left:0;right:0;cursor:row-resize;}
.dragger.hidden{display:none;}
#dropzone{position:fixed;z-index:95;background:rgba(178,58,46,.20);border:2px dashed var(--red);pointer-events:none;display:none;}
.panelw.docked{position:static!important;width:100%!important;border:none;border-bottom:1px solid #000;border-radius:0;box-shadow:none;resize:vertical;flex:0 0 auto;}
.dock-h .panelw.docked{width:auto!important;height:100%!important;flex:1 1 0;resize:horizontal;border-bottom:none;border-right:1px solid #000;min-width:240px;}

/* ── stage / canvas ────────────────────────────────────────────────── */
#stage{position:fixed;top:34px;left:0;right:0;bottom:0;overflow:hidden;background:var(--stage);
  background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:36px 36px;}
#frame{position:absolute;left:50%;top:50%;transform-origin:center center;line-height:0;box-shadow:0 0 0 1px #000,0 18px 60px rgba(0,0,0,.6);}
#frame canvas{display:block;}
/* Both canvases MUST occupy the exact same box, or the live preview and the
   committed result land in different places (stroke "jumps" on release). */
#composite{background:#fff;position:absolute;inset:0;width:100%;height:100%;}
#live{position:absolute;inset:0;width:100%;height:100%;touch-action:none;cursor:crosshair;}
.b-blend{font-size:11px;background:#2a2723;color:#d8cfc4;border:1px solid #443f39;border-radius:4px;padding:1px 2px;max-width:88px;}
#frame.pixelated canvas{image-rendering:pixelated;image-rendering:crisp-edges;}
.empty{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);text-align:center;color:#8a8077;max-width:560px;pointer-events:none;}
.empty .seal{display:inline-flex;width:92px;height:92px;align-items:center;justify-content:center;background:var(--red);border-radius:50%;font-family:var(--serif);font-size:50px;margin-bottom:16px;opacity:.6;}
.empty h2{color:var(--paper);margin:0 0 8px;} .empty p{font-family:var(--serif);margin:5px 0;} .empty .muted{font-size:11px;opacity:.6;margin-top:12px;}
.zoomhud{position:absolute;left:10px;bottom:10px;background:rgba(0,0,0,.5);padding:4px 9px;border-radius:5px;font-size:11px;font-weight:600;color:var(--paper);pointer-events:none;}

/* ── floating panels ───────────────────────────────────────────────── */
.panelw{position:fixed;background:var(--bar);border:1px solid #000;border-radius:8px;display:flex;flex-direction:column;
  z-index:30;box-shadow:0 12px 34px rgba(0,0,0,.5);min-width:150px;min-height:54px;overflow:hidden;resize:both;}
.panelw.closed{display:none;}
.panelw__bar{display:flex;align-items:center;gap:6px;background:var(--bar2);padding:5px 9px;cursor:move;
  font-size:10px;font-weight:700;letter-spacing:.07em;color:var(--t-micro);flex:0 0 auto;}
.panelw__bar .ttl{pointer-events:none;}
.panelw__bar .prev-fps{color:var(--paper);opacity:.6;font-weight:400;margin-left:6px;letter-spacing:0;}
.panelw__bar .x{margin-left:auto;background:none;border:none;color:var(--paper);opacity:.55;font-size:16px;line-height:1;}
.panelw__bar .x:hover{opacity:1;color:var(--red);}
.panelw__body{padding:9px 11px;overflow:auto;flex:1;min-height:0;}
.panelw__body.nopad{padding:0;overflow:hidden;}
.panelw__body.timeline-body{padding:0;display:flex;flex-direction:column;}

/* shared small controls */
.tb-btn{background:var(--ink);color:var(--paper);border:1px solid #000;padding:6px 11px;border-radius:5px;font-weight:600;font-size:12px;}
.tb-btn:hover{background:#332c25;} .tb-btn.ic{min-width:32px;font-size:15px;} .tb-btn.wide{width:100%;margin-top:6px;}
.row{display:flex;align-items:center;justify-content:space-between;gap:9px;margin:6px 0;font-size:12px;}
.row.chk{justify-content:flex-start;gap:7px;} .row.small{opacity:.7;font-size:11px;}
.row.name{font-family:var(--serif);font-style:italic;opacity:.7;display:block;word-break:break-all;font-size:11px;}
.row input[type=number]{width:62px;background:var(--ink);color:var(--paper);border:1px solid #000;border-radius:4px;padding:4px;}
.row input[type=range]{flex:1;accent-color:var(--red);}

/* tools panel */
.tools{display:flex;flex-wrap:wrap;gap:3px;background:var(--ink);border-radius:6px;padding:3px;}
.tool{background:transparent;color:var(--paper);border:none;padding:7px 10px;border-radius:4px;font-size:16px;opacity:.7;}
.tool:hover{opacity:1;background:rgba(255,255,255,.07);} .tool.active{opacity:1;background:var(--red);}
.swrow{display:flex;align-items:center;gap:6px;margin-top:8px;flex-wrap:wrap;}
.swatches{display:flex;gap:4px;}
.sw{width:20px;height:20px;border-radius:50%;border:2px solid rgba(255,255,255,.25);padding:0;}
.sw.active{border-color:#fff;box-shadow:0 0 0 2px rgba(255,255,255,.4);}
#picker{width:28px;height:28px;border:none;background:none;padding:0;border-radius:4px;}

/* brush panel */
.dyn label{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:11px;margin:7px 0;}
.dyn input[type=range]{flex:1;accent-color:var(--red);} .dyn .chk{justify-content:flex-start;gap:7px;}

/* layers panel */
.lay-list{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:5px;}
.lay-item{display:flex;align-items:center;gap:6px;background:var(--ink);border:1px solid #000;border-radius:6px;padding:6px 8px;}
.lay-item.active{outline:2px solid var(--red);outline-offset:-2px;}
.lay-item button{background:none;border:none;color:var(--paper);font-size:14px;opacity:.55;padding:0 1px;line-height:1;}
.lay-item button.on{opacity:1;} .lay-item .b-hold.on{color:var(--gold);font-weight:700;} .lay-item .b-lock.on{color:var(--red);} .lay-item .b-vis.on{color:var(--moss);}
.lay-item .lname{flex:1;font-size:12px;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.lay-item input[type=range]{width:54px;accent-color:var(--moss);}
.lay-hint{font-size:10px;opacity:.55;margin-top:8px;line-height:1.5;font-family:var(--serif);}

/* notes panel */
#note-text{width:100%;background:var(--ink);color:var(--paper);border:1px solid #000;border-radius:5px;padding:7px;font-family:var(--serif);resize:vertical;}
.sort{font-size:11px;opacity:.7;cursor:pointer;color:var(--paper);margin-left:auto;}
.chk{display:inline-flex;align-items:center;gap:6px;font-size:12px;opacity:.85;}
.notes{list-style:none;margin:9px 0 0;padding:0;display:flex;flex-direction:column;gap:6px;}
.note{background:var(--ink);border:1px solid #000;border-left:3px solid var(--red);border-radius:5px;padding:7px 9px;cursor:pointer;}
.note.general{border-left-color:var(--gold);} .note:hover{background:#211c17;}
.note__h{display:flex;justify-content:space-between;font-size:10px;opacity:.7;margin-bottom:2px;}
.note__f{color:var(--red);font-weight:700;} .note.general .note__f{color:var(--gold);}
.note__t{font-family:var(--serif);font-size:12px;line-height:1.35;} .note__x{color:#8a8077;}

/* preview panel */
#prev-canvas{display:block;width:100%;height:100%;background:#fff;object-fit:contain;}

/* timeline panel */
.transport{display:flex;align-items:center;gap:5px;padding:7px 10px;border-bottom:1px solid #000;flex-wrap:wrap;flex:0 0 auto;}
.t{background:var(--ink);color:var(--paper);border:1px solid #000;border-radius:5px;padding:6px 10px;font-size:12px;font-weight:600;min-width:34px;}
.t:hover{background:#332c25;} .t.play{background:var(--red);border-color:var(--red);min-width:42px;} .t.play.on{background:var(--red-deep);}
.t.small{padding:5px 9px;min-width:auto;font-size:11px;} .t.small.on{background:var(--moss);border-color:var(--moss);}
.counter{font-weight:700;font-size:15px;margin:0 8px;white-space:nowrap;} .counter small{opacity:.6;font-weight:400;font-size:12px;}
.spacer{flex:1;}
.grid-scroll{overflow:auto;flex:1;min-height:0;}
/* let panels finger-scroll on iPad while the page itself stays put */
.dock,.panelw__body,.grid-scroll{touch-action:pan-x pan-y;-webkit-overflow-scrolling:touch;}
.grid{display:inline-grid;font-size:11px;position:relative;}
.g-corner{position:sticky;left:0;top:0;z-index:6;background:var(--bar2);min-width:var(--gutter);border-right:2px solid #000;border-bottom:1px solid #000;display:flex;align-items:center;padding:0 8px;font-weight:600;color:var(--t-micro);height:26px;letter-spacing:.08em;}
.g-fnum{position:sticky;top:0;z-index:3;background:var(--bar2);min-width:var(--col);height:26px;display:flex;align-items:center;justify-content:center;border-right:1px solid #000;border-bottom:1px solid #000;color:#9a9a9a;cursor:ew-resize;font-size:10px;}
.g-fnum.cur{color:#fff;font-weight:700;}
.g-lhead{position:sticky;left:0;z-index:4;background:var(--bar2);min-width:var(--gutter);border-right:2px solid #000;border-bottom:1px solid #000;display:flex;align-items:center;gap:4px;padding:3px 6px;}
.g-lhead.active{outline:2px solid var(--red);outline-offset:-2px;}
.g-lhead .lname{flex:1;font-size:11px;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.g-lhead button{background:none;border:none;color:var(--paper);font-size:13px;opacity:.8;padding:0 1px;}
.g-lhead button.on{opacity:1;color:var(--moss);}
.g-lhead input[type=range]{width:42px;accent-color:var(--moss);}
.cell{min-width:var(--col);height:34px;border-right:1px solid #000;border-bottom:1px solid #000;background:var(--t-panel-2);position:relative;cursor:pointer;}
.cell:hover{background:#333;}
.cell .thumb{position:absolute;inset:3px 3px 6px 3px;background:#fff no-repeat center/contain;border-radius:1px;}
.cell.key::after{content:"";position:absolute;left:3px;right:3px;bottom:2px;height:3px;background:var(--key);border-radius:2px;}
.cell.breakdown::after{content:"";position:absolute;left:3px;right:3px;bottom:2px;height:3px;background:var(--breakdown);border-radius:2px;}
.cell.held::before{content:"";position:absolute;left:-1px;right:-1px;top:50%;height:2px;background:#4a4a4a;transform:translateY(-50%);}
/* one continuous red playhead spanning header + every row + dopesheet */
#playhead{position:absolute;top:0;bottom:0;width:var(--col);background:rgba(178,58,46,.13);border-left:2px solid var(--red);border-right:2px solid var(--red);pointer-events:none;z-index:5;}
/* ── dopesheet ── */
.dope-header{grid-column:1/-1;position:sticky;left:0;display:flex;align-items:center;gap:8px;height:24px;background:#1f1f1f;border-top:2px solid #000;border-bottom:1px solid #000;padding:0 8px;color:var(--t-micro);font-size:10px;letter-spacing:.08em;font-weight:700;z-index:5;}
.dope-toggle{background:none;border:none;color:var(--paper);font-size:12px;cursor:pointer;padding:0 2px;}
.dope-add{margin-left:auto;background:var(--t-panel-2);border:1px solid var(--t-edge,#111);color:var(--paper);border-radius:5px;width:22px;height:18px;cursor:pointer;font-size:13px;line-height:1;}
.dope-legend{color:var(--t-micro);font-weight:400;}
.lane__label{position:sticky;left:0;z-index:4;min-width:var(--gutter);height:20px;background:#202020;border-right:2px solid #000;border-bottom:1px solid #000;display:flex;align-items:center;gap:6px;padding:0 8px;color:var(--t-text-2);font-size:10px;}
.lane__label i{width:8px;height:8px;border-radius:2px;display:inline-block;}
.lane__track{position:relative;height:20px;background:#191919;border-bottom:1px solid #000;}
.grid.dope-expanded .lane__label,.grid.dope-expanded .lane__track{height:36px;}
.marker{position:absolute;top:50%;transform:translate(-50%,-50%);display:flex;align-items:center;gap:4px;cursor:pointer;white-space:nowrap;}
.marker--span{transform:none;top:4px;height:12px;border-radius:3px;opacity:.8;cursor:grab;display:flex;align-items:center;padding:0 4px;color:#fff;font-size:9px;}
.grid.dope-expanded .marker--span{height:26px;}
.mk-diamond{width:9px;height:9px;background:var(--lc);transform:rotate(45deg);}
.mk-dot{width:8px;height:8px;border-radius:50%;background:var(--lc);}
.mk-sq{width:8px;height:8px;border-radius:1px;background:var(--lc);}
.mk-chip{background:var(--mk-dialogue);color:#fff;border-radius:6px;padding:1px 5px;font-size:9px;font-weight:700;}
.mk-lab,.mk-note{color:var(--t-text);font-size:9px;}
.mk-note{max-width:120px;white-space:normal;line-height:1.1;}
/* marker editor popover */
.mk-pop{position:fixed;z-index:140;background:var(--t-panel);border:1px solid #000;border-radius:10px;padding:10px;width:230px;box-shadow:0 14px 40px rgba(0,0,0,.6);display:flex;flex-direction:column;gap:8px;}
.mk-pop__label{background:var(--t-panel-2);color:var(--paper);border:1px solid var(--t-edge,#111);border-radius:6px;padding:7px;font-size:13px;}
.mk-pop__types{display:flex;gap:4px;}
.mk-pop__types button{flex:1;background:var(--t-panel-2);color:var(--t-text-2);border:1px solid #111;border-radius:6px;padding:6px 2px;font-size:11px;cursor:pointer;}
.mk-pop__types button.on{background:var(--red);color:#fff;border-color:var(--red);}
.mk-pop__span{font-size:11px;color:var(--t-text-2);display:flex;align-items:center;gap:6px;}
.mk-pop__span input{background:var(--t-panel-2);color:var(--paper);border:1px solid #111;border-radius:5px;padding:5px;}
.mk-pop__row{display:flex;gap:6px;}
.mk-pop__row button{flex:1;border:none;border-radius:6px;padding:8px;cursor:pointer;font-weight:600;}
#mk-del{background:#3a2422;color:#e7a59c;} #mk-done{background:var(--red);color:#fff;}
/* ── guided tour ── */
.tour-hole{display:none;position:fixed;z-index:150;border-radius:10px;border:2px solid var(--red);box-shadow:0 0 0 9999px rgba(0,0,0,.62);pointer-events:none;transition:left .18s,top .18s,width .18s,height .18s;}
.tour-pop{display:none;position:fixed;z-index:151;width:300px;background:var(--t-panel);color:var(--t-text);border:1px solid #000;border-radius:12px;padding:14px 16px;box-shadow:0 16px 50px rgba(0,0,0,.6);}
.tour-pop__t{margin:0 0 6px;font-size:15px;color:#fff;}
.tour-pop__x{margin:0 0 12px;font-size:13px;line-height:1.5;color:var(--t-text);}
.tour-pop__bar{display:flex;align-items:center;justify-content:space-between;}
.tour-pop__n{font-size:11px;color:var(--t-micro);}
.tour-pop__btns{display:flex;gap:6px;}
.tour-pop__btns button{border:none;border-radius:7px;padding:7px 12px;font-size:12px;font-weight:600;cursor:pointer;}
.tour-skip{background:transparent;color:var(--t-micro);}
.tour-back{background:var(--t-panel-2);color:var(--t-text);}
.tour-next{background:var(--red);color:#fff;}
/* ── X-sheet panels band (on timeline) ── */
.g-panhead{position:sticky;left:0;z-index:4;min-width:var(--gutter);height:22px;background:#232323;border-right:2px solid #000;border-bottom:1px solid #000;display:flex;align-items:center;padding:0 8px;color:var(--t-micro);font-size:10px;font-weight:700;letter-spacing:.08em;}
.panel-track{position:relative;height:22px;background:#1d1d1d;border-bottom:1px solid #000;}
.panel-span{position:absolute;top:2px;bottom:2px;border-radius:4px;background:#34506b;border:1px solid #4a6e90;color:#dfeaf4;font-size:10px;display:flex;align-items:center;padding:0 6px;overflow:hidden;white-space:nowrap;cursor:pointer;}
.panel-span.cur{background:#3f6890;border-color:var(--red);}
/* ── X-sheet editor table ── */
#xsheet-body{overflow:auto;max-height:340px;margin-top:8px;}
table.xs{border-collapse:collapse;width:100%;font-size:11px;}
table.xs th{position:sticky;top:0;background:#202020;color:var(--t-micro);font-weight:700;text-align:left;padding:5px 6px;border-bottom:1px solid #000;font-size:9px;letter-spacing:.05em;text-transform:uppercase;}
table.xs td{padding:3px 5px;border-bottom:1px solid #2a2a2a;vertical-align:top;}
table.xs tr.cur{background:rgba(178,58,46,.12);}
table.xs .xs-n{color:var(--t-text-2);font-weight:700;cursor:pointer;width:18px;}
table.xs input{width:100%;background:var(--t-panel-2);color:var(--paper);border:1px solid #111;border-radius:5px;padding:5px;font-size:11px;}
table.xs .xs-fr{white-space:nowrap;} table.xs .xs-fr input{width:42px;display:inline-block;} table.xs .xs-fr span{color:var(--t-micro);padding:0 2px;}
table.xs .xs-sec{color:var(--t-text-2);white-space:nowrap;} table.xs .xs-sec small{opacity:.6;}
table.xs .xs-del{background:none;border:none;color:#8a6a66;cursor:pointer;font-size:13px;}
table.xs .xs-cat{width:14px;height:14px;border-radius:50%;border:1px solid rgba(255,255,255,.25);cursor:pointer;padding:0;}
table.xs .xs-frms{font-weight:700;color:var(--paper);}
.xs-act{min-width:240px;}
.xs-line{display:flex;align-items:center;gap:5px;margin-bottom:4px;}
.xs-line .xs-ltext{flex:1;background:var(--t-panel-2);color:var(--paper);border:1px solid #111;border-radius:5px;padding:5px;font-size:11px;}
.xs-line .xs-lf{width:42px;background:var(--t-panel-2);color:var(--paper);border:1px solid #111;border-radius:5px;padding:5px;font-size:11px;}
.xs-line span{color:var(--t-micro);font-size:10px;} .xs-line .xs-lx{background:none;border:none;color:#8a6a66;cursor:pointer;}
.xs-addline{background:none;border:1px dashed #444;color:var(--t-text-2);border-radius:5px;padding:4px 8px;font-size:10px;cursor:pointer;margin-top:2px;}
/* ribbon sub-action ticks */
.panel-span i{position:absolute;top:0;bottom:0;width:1px;background:rgba(0,0,0,.45);}
.panel-span{overflow:visible;}
/* Sheet full-screen overlay */
#sheet-ov{display:none;position:fixed;inset:50px 0 0 0;z-index:120;background:rgba(20,20,20,.97);backdrop-filter:blur(8px);flex-direction:column;}
.sheet-ov__bar{display:flex;align-items:center;gap:10px;padding:12px 18px;border-bottom:1px solid #000;background:#1b1b1b;}
.sheet-ov__ttl{font-size:11px;letter-spacing:.1em;font-weight:700;color:var(--t-micro);} .sheet-ov__ttl small{color:var(--t-text-2);font-weight:400;margin-left:8px;letter-spacing:0;}
.sheet-ov__btns{margin-left:auto;display:flex;gap:8px;}
#sheet-ov-body{overflow:auto;padding:14px 18px;flex:1;}
#sheet-ov-body table.xs{font-size:12px;} #sheet-ov-body table.xs input{font-size:12px;}

/* jump + help */
.jump{position:fixed;left:50%;top:80px;transform:translateX(-50%);background:var(--bar2);border:1px solid #000;border-radius:8px;padding:11px 15px;display:flex;align-items:center;gap:9px;z-index:120;box-shadow:0 12px 40px rgba(0,0,0,.5);}
.jump input{width:84px;background:var(--ink);color:var(--paper);border:1px solid #000;border-radius:5px;padding:6px;font-size:14px;}
.help{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:130;}
.help__card{position:relative;background:var(--paper);color:var(--ink);border-radius:12px;border-top:6px solid var(--red);max-width:600px;width:calc(100% - 40px);padding:26px 30px;}
.help__x{position:absolute;top:8px;right:14px;background:none;border:none;font-size:25px;color:var(--ink);}
.help__card h2{margin:0 0 14px;}
.help__cols{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.help__cols ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;font-size:13px;}
.help .muted{margin-top:16px;font-family:var(--serif);font-size:13px;color:#5a5249;line-height:1.5;}

/* ════════════════════════════════════════════════════════════════════
   iOS-STYLE POLISH + iPad TOUCH (Phase 4)
   ════════════════════════════════════════════════════════════════════ */
:root{ --sans:-apple-system,BlinkMacSystemFont,"SF Pro Text","Segoe UI",Roboto,Helvetica,Arial,sans-serif; }
#stage{touch-action:none;}                 /* canvas owns all gestures (pinch/pan handled in JS) */

/* frosted, rounded iOS surfaces */
#menubar{background:rgba(36,31,26,.80);backdrop-filter:saturate(160%) blur(16px);-webkit-backdrop-filter:saturate(160%) blur(16px);border-bottom:1px solid rgba(0,0,0,.45);}
.menu-top>button{border-radius:9px;}
.menu-drop{border-radius:13px;border:1px solid rgba(255,255,255,.06);}
.menu-drop button,.menu-drop label{border-radius:9px;}
.panelw{border-radius:15px;border:1px solid rgba(255,255,255,.07);box-shadow:0 18px 50px rgba(0,0,0,.55);}
.panelw__bar{border-top-left-radius:15px;border-top-right-radius:15px;}
.tb-btn{border-radius:10px;border:1px solid rgba(0,0,0,.45);}
.tools{background:rgba(0,0,0,.28);border-radius:12px;}
.tool{border-radius:11px;transition:background .12s,transform .06s;}
.tool:active{transform:scale(.92);}
.tool.active{box-shadow:0 3px 10px rgba(178,58,46,.5);}
.lay-item{border-radius:11px;}
.zoomhud{border-radius:8px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);}

/* iOS-style sliders (apply everywhere) */
input[type=range]{-webkit-appearance:none;appearance:none;height:6px;border-radius:999px;background:rgba(255,255,255,.18);outline:none;}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.5);cursor:pointer;}
input[type=range]::-moz-range-thumb{width:18px;height:18px;border:none;border-radius:50%;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.5);}

/* Touch devices (iPad / phone): larger, finger-friendly targets */
@media (pointer:coarse){
  body{font-size:15px;}
  #menubar{height:50px;}
  .menu-top>button{padding:13px 15px;font-size:16px;}
  .menu-drop{min-width:240px;}
  .menu-drop button,.menu-drop label{padding:13px 15px;font-size:15px;}
  .dock.dock-v{ }
  .tools{gap:7px;padding:7px;}
  .tool{padding:14px 16px;font-size:23px;min-width:50px;min-height:50px;}
  .swrow{gap:10px;margin-top:12px;}
  .sw{width:32px;height:32px;}
  #picker{width:40px;height:40px;}
  .tb-btn{padding:12px 17px;font-size:15px;min-height:46px;}
  .row{margin:11px 0;font-size:15px;}
  .dyn label,.chk{font-size:14px;}
  .panelw__bar{padding:13px 14px;font-size:12px;min-height:46px;}
  .panelw__bar .x{font-size:24px;}
  .lay-item{padding:12px;gap:12px;}
  .lay-item button{font-size:21px;padding:5px;}
  .lay-item input[type=range]{width:70px;}
  .b-blend{font-size:14px;padding:6px 6px;max-width:110px;}
  input[type=range]{height:12px;}
  input[type=range]::-webkit-slider-thumb{width:28px;height:28px;}
  input[type=range]::-moz-range-thumb{width:28px;height:28px;}
  .row input[type=number],.jump input{padding:9px;font-size:16px;}
  .transport{gap:7px;padding:9px 11px;}
  .t{padding:11px 14px;font-size:15px;min-width:46px;min-height:46px;}
  .t.small{padding:10px 12px;min-height:42px;}
  .cell{min-width:38px;height:38px;}
  .g-fnum{min-width:38px;height:32px;}
  .dragger.v{width:16px;} .dragger.h{height:16px;}
  .menu-drop kbd,.help kbd{display:none;}     /* shortcuts irrelevant on touch */
}

/* ════════════════════════════════════════════════════════════════════
   TABLET / PROCREATE LAYOUT  (fixed arrangement; desktop keeps the docks)
   ════════════════════════════════════════════════════════════════════ */
@media (pointer:coarse),(hover:none),(max-width:1200px){
  .dragger,#dropzone{display:none!important;}
  .dock{display:contents!important;}                 /* collapse dock boxes but keep panels rendered */
  /* hide secondary panels on tablet (open from Window menu when needed) */
  #pnl-onion,#pnl-bg,#pnl-audio,#pnl-project,#pnl-notes,#pnl-xsheet,#pnl-preview,#pnl-layers{display:none!important;}
  /* TOOLS → floating left strip */
  #pnl-tools{position:fixed!important;left:8px!important;top:58px!important;bottom:auto!important;width:72px!important;height:auto!important;min-height:0!important;
    display:flex!important;border-radius:20px!important;z-index:60!important;resize:none!important;overflow:visible!important;
    background:rgba(27,27,27,.95)!important;backdrop-filter:saturate(150%) blur(16px);-webkit-backdrop-filter:saturate(150%) blur(16px);box-shadow:0 16px 44px rgba(0,0,0,.5)!important;}
  #pnl-tools .panelw__bar{display:none!important;}
  #pnl-tools .panelw__body{padding:9px!important;overflow:visible!important;}
  #pnl-tools .tools{flex-direction:column!important;background:transparent!important;gap:7px!important;padding:0!important;}
  #pnl-tools .swrow{flex-direction:column!important;align-items:center!important;gap:8px!important;margin-top:10px!important;}
  #pnl-tools .swrow:nth-of-type(2){display:none!important;}
  #pnl-tools .swatches{display:flex!important;flex-wrap:wrap!important;justify-content:center!important;max-width:54px!important;gap:6px!important;}
  /* BRUSH → floating right card */
  #pnl-brush{position:fixed!important;right:8px!important;top:58px!important;left:auto!important;bottom:auto!important;width:228px!important;height:auto!important;
    display:flex!important;border-radius:20px!important;z-index:60!important;resize:none!important;
    background:rgba(27,27,27,.95)!important;backdrop-filter:saturate(150%) blur(16px);-webkit-backdrop-filter:saturate(150%) blur(16px);box-shadow:0 16px 44px rgba(0,0,0,.5)!important;}
  /* TIMELINE → fixed bottom dock, right of the tool strip */
  #pnl-timeline{position:fixed!important;left:92px!important;right:0!important;bottom:0!important;top:auto!important;width:auto!important;height:280px!important;border-radius:0!important;z-index:55!important;resize:none!important;}
  /* canvas takes the free middle */
  #stage{left:92px!important;right:248px!important;bottom:282px!important;top:52px!important;}
  .zoomhud{bottom:292px!important;left:100px!important;}
}
