:root{--paper:#f7f5ef;--paper-2:#f1eee5;--ink:#1f2024;--ink-2:#494a52;--ink-3:#8a8b94;--line:#d8d4c7;--line-2:#e6e2d6;--accent:#2f6df0;--accent-soft:rgba(47,109,240,.12);--grid:rgba(0,0,0,.045);--shadow:0 1px 0 rgba(255,255,255,.6) inset, 0 1px 2px rgba(20,20,30,.06), 0 8px 24px rgba(20,20,30,.06);--ui-font: "Inter", ui-sans-serif, system-ui, sans-serif;--mono-font: "JetBrains Mono", ui-monospace, monospace;--tl-thickness: 2px;--tl-style: solid;--canvas-h: 600px;--ruler-h: 56px;--minimap-h: 64px;--app-fill-pct: 100}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);font-family:var(--ui-font);-webkit-font-smoothing:antialiased}body{background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);background-size:28px 28px,28px 28px;min-height:100vh}.app{width:calc(var(--app-fill-pct) * 1%);max-width:100%;margin:0 auto;padding:18px 22px 64px}.topbar{display:flex;align-items:center;gap:14px;padding:10px 14px;margin-bottom:14px;background:#ffffffb3;backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);flex-wrap:wrap;justify-content:space-between}.brand{display:flex;align-items:center;gap:10px;font-weight:600;letter-spacing:-.01em}.brand .dot{width:10px;height:10px;border-radius:3px;background:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.brand small{display:block;font-weight:400;color:var(--ink-3);font-size:11px;margin-top:1px}.group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.group .sep{width:1px;height:22px;background:var(--line)}.lab{font-size:11px;color:var(--ink-2);letter-spacing:.02em;font-weight:500;text-transform:uppercase}.seg{display:inline-flex;background:var(--paper-2);border:1px solid var(--line);border-radius:9px;padding:2px;gap:1px}.seg button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:var(--ink-2);font:500 12px/1 var(--ui-font);padding:6px 9px;border-radius:7px;cursor:pointer;font-variant-numeric:tabular-nums}.seg button:hover{color:var(--ink)}.seg button.on{background:#fff;color:var(--ink);box-shadow:0 1px 2px #00000014,0 0 0 1px var(--line)}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--line);background:#fff;color:var(--ink);font:500 12px/1 var(--ui-font);padding:7px 11px;border-radius:9px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:transform .04s ease,box-shadow .12s ease,border-color .12s ease}.btn:hover{border-color:#bfbbac;box-shadow:0 1px 2px #0000000f}.btn:active{transform:translateY(1px)}.btn.primary{background:var(--accent);color:#fff;border-color:transparent}.btn.primary:hover{filter:brightness(1.05)}.btn.ghost{background:transparent}.btn.danger{color:#a32;border-color:#e9c4bc;background:#fff7f4}.btn svg{width:13px;height:13px;flex-shrink:0}.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:10px;color:var(--ink-2);font-size:12px;flex-wrap:wrap}.modes{display:inline-flex;gap:2px;background:var(--paper-2);border:1px solid var(--line);border-radius:9px;padding:2px}.modes button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:var(--ink-2);padding:6px 10px;border-radius:7px;font:500 12px/1 var(--ui-font);cursor:pointer;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.modes button.on{background:#fff;color:var(--ink);box-shadow:0 1px 2px #00000014}.zoom{display:inline-flex;align-items:center;gap:6px;background:var(--paper-2);border:1px solid var(--line);border-radius:9px;padding:2px 4px}.zoom button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:var(--ink-2);width:24px;height:24px;border-radius:6px;cursor:pointer;font:600 14px/1 var(--ui-font)}.zoom button:hover{background:#fff;color:var(--ink)}.zoom .zlabel{font:500 11.5px/1 var(--mono-font);min-width:54px;text-align:center;color:var(--ink-2)}.hint{margin-left:auto;color:var(--ink-3);font-size:11.5px;background:#fff9;border:1px dashed var(--line);padding:6px 10px;border-radius:8px}kbd{font:500 11px/1 var(--mono-font);background:#fff;border:1px solid var(--line);border-bottom-width:2px;padding:2px 5px;border-radius:4px;color:var(--ink-2)}.toolbar.collapsed{padding:4px 6px;background:#fff9;border:1px solid var(--line);border-radius:10px;width:fit-content;box-shadow:var(--shadow)}.tb-collapse{padding:6px 8px}.tb-gear{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--line);background:#fff;color:var(--ink-2);width:30px;height:30px;border-radius:9px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.tb-gear:hover{color:var(--ink);border-color:#bfbbac}.tb-settings{position:absolute;top:calc(100% + 8px);right:0;z-index:30;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 32px #00000024;padding:10px 12px 12px;width:260px}.tb-settings-title{font:600 11px/1 var(--ui-font);text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);margin-bottom:8px}.tb-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 0;font-size:12.5px;color:var(--ink)}.tb-row+.tb-row{border-top:1px solid var(--line-2)}.tb-num{font:500 11px/1 var(--mono-font);color:var(--ink-2);min-width:30px;text-align:right}.tb-hint{font:400 10.5px/1.4 var(--ui-font);color:var(--ink-3);margin-top:8px;padding-top:8px;border-top:1px dashed var(--line-2)}.tb-switch{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:var(--line);width:32px;height:18px;border-radius:99px;position:relative;cursor:pointer;transition:background .15s ease;padding:0}.tb-switch.on{background:var(--accent)}.tb-knob{position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;box-shadow:0 1px 2px #0003;transition:transform .15s ease}.tb-switch.on .tb-knob{transform:translate(14px)}.workspace{display:flex;gap:14px;align-items:stretch}.canvas-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px}.side-col{width:320px;flex-shrink:0}.canvas-card{position:relative;background:#fdfcf7;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);height:var(--canvas-h);min-height:420px;display:flex;flex-direction:column;overflow:hidden}.ruler-row{position:relative;height:var(--ruler-h);flex-shrink:0;border-bottom:1px solid var(--line-2);background:linear-gradient(#faf8f1,#fdfcf7);overflow:hidden}.ruler-svg{display:block;height:100%}.ruler-svg .hour-tick{stroke:var(--ink);stroke-width:1.25}.ruler-svg .min-tick{stroke:var(--ink-3);stroke-width:1}.ruler-svg .hour-label{font:600 11.5px/1 var(--mono-font);fill:var(--ink)}.ruler-svg .min-label{font:400 9.5px/1 var(--mono-font);fill:var(--ink-3)}.ruler-svg .now-line{stroke:var(--accent);stroke-width:1.5;stroke-dasharray:3 3}.ruler-svg .now-label{font:600 10px/1 var(--mono-font);fill:var(--accent)}.canvas-scroll{position:relative;flex:1;overflow:auto;min-height:0;cursor:var(--canvas-cursor, default);background-image:radial-gradient(rgba(0,0,0,.06) 1px,transparent 1px);background-size:18px 18px;background-position:9px 9px}.canvas-inner{position:relative;height:100%}.ruler-track{position:absolute;left:0;top:0;height:100%}.axis-band{position:absolute;left:0;right:0;pointer-events:none}.axis-svg{display:block;overflow:visible;pointer-events:none}.axis-svg .axis{stroke:var(--ink);stroke-width:var(--tl-thickness);fill:none}.axis-svg .axis.dashed{stroke-dasharray:6 4}.axis-svg .axis.dotted{stroke-dasharray:1 4;stroke-linecap:round}.axis-svg .tick-h{stroke:var(--ink);stroke-width:1.25}.axis-svg .tick-m{stroke:var(--ink-3);stroke-width:1}.axis-svg .now-line{stroke:var(--accent);stroke-width:1.5;stroke-dasharray:3 3}.axis-svg .hit{pointer-events:stroke;cursor:crosshair}.hover-pill{position:absolute;transform:translate(-50%,-100%);background:var(--ink);color:#fff;font:500 11px/1 var(--mono-font);padding:4px 6px;border-radius:5px;pointer-events:none;white-space:nowrap;opacity:0;transition:opacity .08s;z-index:5}.hover-pill:after{content:"";position:absolute;left:50%;top:100%;transform:translate(-50%);border:4px solid transparent;border-top-color:var(--ink)}.annot-svg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:visible}.annot-svg .arrow{stroke:var(--ink);stroke-width:1.4;fill:none}.annot-svg .arrow-head{fill:var(--ink)}.annot-svg.placing .preview{stroke:var(--accent);stroke-dasharray:4 3}.annot-svg.placing .preview-head{fill:var(--accent)}.note{position:absolute;background:#fff;border:1px solid var(--ink);box-shadow:2px 2px #0000000f;border-radius:2px;padding:7px 9px 8px;min-width:90px;max-width:240px;font:400 12.5px/1.35 var(--ui-font);color:var(--ink);cursor:grab;-webkit-user-select:none;user-select:none;pointer-events:auto;z-index:10}.note.dragging{cursor:grabbing;box-shadow:3px 3px #0000001a}.note .ed{outline:none;min-height:1.2em;white-space:pre-wrap;word-wrap:break-word;cursor:text}.note .ed:empty:before{content:attr(data-placeholder);color:var(--ink-3)}.note .meta{margin-top:4px;font:500 10px/1 var(--mono-font);color:var(--ink-3);display:flex;justify-content:space-between;align-items:center;gap:6px}.note .del{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:var(--ink-3);font:500 11px/1 var(--ui-font);padding:2px 4px;border-radius:3px;cursor:pointer;opacity:0;transition:opacity .12s}.note:hover .del{opacity:1}.note .del:hover{background:#f1ddd8;color:#a32}.block{position:absolute;border:1px solid var(--block-stroke, var(--ink));background:var(--block-fill, rgba(47,109,240,.14));border-radius:7px;min-height:56px;display:flex;flex-direction:column;justify-content:flex-start;padding:6px 9px 7px;gap:3px;font:500 12px/1.2 var(--ui-font);color:var(--ink);cursor:grab;box-shadow:0 1px #ffffffb3 inset,0 1px 2px #0000000f;z-index:6;transition:box-shadow .12s ease,transform .04s ease}.block:hover{box-shadow:0 1px #ffffffb3 inset,0 4px 10px #0000001a;z-index:7}.block.selected{box-shadow:0 0 0 2px var(--accent),0 4px 12px #0000001f;z-index:8}.block.dragging{cursor:grabbing;opacity:.9}.block .bn{font-weight:600;white-space:normal;word-wrap:break-word;overflow-wrap:anywhere}.block .bd{font:400 11px/1.3 var(--ui-font);color:var(--ink-2);white-space:normal;word-wrap:break-word;overflow-wrap:anywhere}.block .bt{font:500 10px/1.2 var(--mono-font);color:var(--ink-3);white-space:normal;word-wrap:break-word}.block .handle{position:absolute;top:0;bottom:0;width:7px;cursor:ew-resize}.block .handle.l{left:-2px}.block .handle.r{right:-2px}.creating .canvas-scroll{cursor:crosshair}.ghost-block{position:absolute;height:56px;border:1.5px dashed var(--accent);background:#2f6df01f;border-radius:7px;pointer-events:none;z-index:6}.ghost-block .gtime{position:absolute;left:50%;top:-20px;transform:translate(-50%);font:500 10.5px/1 var(--mono-font);color:var(--accent);white-space:nowrap;background:#fff;border:1px solid var(--accent);padding:2px 5px;border-radius:4px}.minimap{height:var(--minimap-h);position:relative;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);overflow:hidden}.minimap .mm-svg{display:block;width:100%;height:100%}.minimap .mm-axis,.minimap .mm-tick{stroke:var(--ink-3);stroke-width:1}.minimap .mm-label{font:500 9.5px/1 var(--mono-font);fill:var(--ink-3)}.minimap .mm-block{stroke:var(--block-stroke);fill:var(--block-fill);stroke-width:1}.minimap .mm-vp{position:absolute;top:6px;bottom:6px;border:1.5px solid var(--accent);background:#2f6df014;border-radius:4px;pointer-events:none}.minimap .mm-grab{position:absolute;top:0;right:0;bottom:0;left:0;cursor:grab}.minimap .mm-grab.dragging{cursor:grabbing}.side-panel{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:16px;height:var(--canvas-h);min-height:420px;display:flex;flex-direction:column;gap:12px;overflow:hidden}.sp-empty{color:var(--ink-3);font-size:12.5px;text-align:center;display:flex;align-items:center;justify-content:center;flex:1;flex-direction:column;gap:8px}.sp-empty svg{width:42px;height:42px;color:var(--line)}.sp-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.sp-head .sp-color{width:10px;height:10px;border-radius:3px;margin-top:6px;flex-shrink:0;background:var(--block-stroke, var(--ink))}.sp-title-wrap{flex:1;min-width:0}.sp-title{font:600 16px/1.3 var(--ui-font);color:var(--ink);border:0;border-bottom:1px solid transparent;outline:none;background:transparent;width:100%;padding:2px 0}.sp-title:hover,.sp-title:focus{border-bottom-color:var(--line)}.sp-time{font:500 12px/1 var(--mono-font);color:var(--ink-2);margin-top:6px}.sp-time .sep{margin:0 6px;color:var(--ink-3)}.sp-time .dur{color:var(--ink-3)}.sp-x{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:var(--ink-3);font:500 18px/1 var(--ui-font);cursor:pointer;width:24px;height:24px;border-radius:6px}.sp-x:hover{background:var(--paper-2);color:var(--ink)}.sp-section{font:500 10.5px/1 var(--ui-font);text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3)}.sp-desc{width:100%;min-height:120px;flex:1;border:1px solid var(--line);border-radius:8px;padding:10px 11px;font:400 13px/1.45 var(--ui-font);color:var(--ink);background:#fcfaf3;resize:none;outline:none}.sp-desc:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px var(--accent-soft)}.sp-desc::placeholder{color:var(--ink-3)}.sp-actions{display:flex;justify-content:space-between;align-items:center;gap:8px}.sp-meta{font:400 11px/1.3 var(--ui-font);color:var(--ink-3)}.sp-color-row{display:flex;gap:6px;flex-wrap:wrap}.sp-color-row .sw{width:22px;height:22px;border-radius:6px;border:1px solid var(--line);cursor:pointer;background:var(--sw)}.sp-color-row .sw.on{box-shadow:0 0 0 2px var(--accent)}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#14141e66;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 20px 60px #0003;padding:18px 18px 16px;width:min(440px,92vw)}.modal h3{margin:0 0 4px;font-size:15px;font-weight:600}.modal p{margin:0 0 12px;color:var(--ink-2);font-size:12.5px}.modal label{display:block;font-size:11px;color:var(--ink-2);margin:8px 0 4px;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.modal input,.modal textarea{width:100%;border:1px solid var(--line);border-radius:8px;padding:8px 10px;font:400 13px/1.4 var(--ui-font);color:var(--ink);background:#fff}.modal input:focus,.modal textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.modal textarea{min-height:64px;resize:vertical}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}.corner-tip{position:absolute;top:14px;left:14px;color:var(--ink-3);font:400 11.5px/1.4 var(--ui-font);background:#ffffffb3;border:1px dashed var(--line);padding:6px 9px;border-radius:8px;pointer-events:none}.selectable{-webkit-user-select:auto;user-select:auto}@media (max-width: 1100px){.workspace{flex-direction:column}.side-col{width:auto}.side-panel{height:auto;max-height:340px}}
