:root{--accent: #3b6ff6;--accent-ink: #ffffff;--ink: #0e1116;--muted: #586172;--surface: #ffffff;--surface-2: #f1f3f6;--paper: #f6f7f9;--border: #e4e7ec;--grid: #d2d8e2;--good: #16a34a;--bad: #dc2626;--radius: 14px;--shadow: 0 6px 20px rgba(16, 17, 22, .1), 0 2px 6px rgba(16, 17, 22, .06);--dur: .2s;--ease: cubic-bezier(.2, .7, .2, 1);color-scheme:light;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}:root[data-theme=dark]{--accent: #5b8def;--accent-ink: #0b1020;--ink: #e6e9ef;--muted: #9aa4b2;--surface: #171a21;--surface-2: #1e222b;--paper: #0e1116;--border: #262b34;--grid: #2b333e;--good: #22c55e;--bad: #f87171;--shadow: 0 8px 24px rgba(0, 0, 0, .5), 0 2px 6px rgba(0, 0, 0, .4);color-scheme:dark}*{box-sizing:border-box}html,body{margin:0;height:100%}#app{position:relative;height:100vh;display:grid;grid-template-rows:calc(56px + env(safe-area-inset-top,0px)) 1fr;background:var(--paper);color:var(--ink);overflow:hidden;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.topbar{display:flex;align-items:center;gap:16px;padding:env(safe-area-inset-top,0px) 14px 0;background:var(--surface);border-bottom:1px solid var(--border);z-index:20}.brand{font-weight:800;letter-spacing:-.02em;display:flex;align-items:center;gap:8px}.logo{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:7px;background:var(--accent);color:var(--accent-ink);font-size:13px}.room{color:var(--muted);font-size:14px;display:flex;align-items:center;gap:8px}.room strong{color:var(--ink)}.spacer{flex:1}.tb-history{display:none;gap:6px}.dot{width:9px;height:9px;border-radius:50%;background:var(--muted);transition:background var(--dur) var(--ease)}.dot[data-state=connected]{background:var(--good);box-shadow:0 0 0 4px color-mix(in srgb,var(--good) 22%,transparent)}.dot[data-state=disconnected]{background:var(--bad)}.devstatus{color:var(--muted);font-size:13px;font-variant-numeric:tabular-nums}.devstatus b{color:var(--ink)}.btn-share{display:inline-grid;place-items:center;width:38px;height:38px;color:#fff;background:var(--accent);border:0;border-radius:10px;cursor:pointer;transition:background var(--dur) var(--ease)}.btn-share:hover{background:color-mix(in srgb,var(--accent) 88%,#000)}.btn-share .ico{width:17px;height:17px}.identity-nudge{position:fixed;top:64px;right:14px;z-index:40;width:290px;max-width:calc(100vw - 28px);padding:13px 14px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 28px -12px #00000059;opacity:0;transform:translateY(-8px);transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease)}.identity-nudge.in{opacity:1;transform:none}.identity-nudge.leaving{opacity:0;transform:translateY(-8px);pointer-events:none}.identity-nudge-row{display:flex;align-items:flex-start;gap:10px;padding-right:16px}.identity-nudge-dot{flex:none;width:12px;height:12px;margin-top:3px;border-radius:50%;box-shadow:0 0 0 3px color-mix(in srgb,var(--ink) 6%,transparent)}.identity-nudge-line{margin:0;font-size:13px;color:var(--ink)}.identity-nudge-hint{margin:3px 0 0;font-size:12px;line-height:1.35;color:var(--muted)}.identity-nudge-actions{display:flex;justify-content:flex-end;margin-top:11px}.identity-nudge-edit{height:30px;padding:0 13px;font:600 12px Inter,system-ui,sans-serif;color:#fff;background:var(--accent);border:0;border-radius:8px;cursor:pointer;transition:background var(--dur) var(--ease)}.identity-nudge-edit:hover{background:color-mix(in srgb,var(--accent) 88%,#000)}.identity-nudge-close{position:absolute;top:8px;right:8px;width:22px;height:22px;display:grid;place-items:center;font-size:17px;line-height:1;color:var(--muted);background:transparent;border:0;border-radius:6px;cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.identity-nudge-close:hover{background:var(--surface-2);color:var(--ink)}@media(prefers-reduced-motion:reduce){.identity-nudge{transition:none}}.conn-banner{position:fixed;top:64px;left:50%;z-index:45;display:flex;align-items:center;gap:8px;height:34px;padding:0 16px;font:600 13px Inter,system-ui,sans-serif;color:var(--ink);background:var(--surface);border:1px solid var(--border);border-radius:999px;box-shadow:0 10px 26px -12px #0006;opacity:0;visibility:hidden;pointer-events:none;transform:translate(-50%) translateY(-6px);transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease),visibility var(--dur)}.conn-banner.in{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.conn-banner[data-mode=online]{color:var(--good);border-color:color-mix(in srgb,var(--good) 40%,var(--border))}.conn-spinner{width:14px;height:14px;border-radius:50%;border:2px solid color-mix(in srgb,var(--accent) 28%,transparent);border-top-color:var(--accent);animation:conn-spin .7s linear infinite}@keyframes conn-spin{to{transform:rotate(360deg)}}.conn-check{color:var(--good);font-weight:800}@media(prefers-reduced-motion:reduce){.conn-banner{transform:translate(-50%);transition:opacity var(--dur) var(--ease),visibility var(--dur)}.conn-banner.in{transform:translate(-50%)}.conn-spinner{animation:none}}.join-toasts{position:fixed;left:50%;bottom:26px;z-index:44;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}.join-toast{display:flex;align-items:center;gap:8px;height:32px;padding:0 15px;font:500 13px Inter,system-ui,sans-serif;color:var(--ink);background:var(--surface);border:1px solid var(--border);border-radius:999px;box-shadow:0 8px 22px -10px #0006;opacity:0;transform:translateY(8px);transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease)}.join-toast.in{opacity:1;transform:none}.join-toast b{font-weight:700}.join-toast-dot{flex:none;width:10px;height:10px;border-radius:50%}@media(prefers-reduced-motion:reduce){.join-toast{transform:none;transition:opacity var(--dur) var(--ease)}}.selection-actions{display:none}@media(max-width:640px),(pointer:coarse){.selection-actions{display:flex;background:var(--surface);border:1px solid var(--border);border-bottom:0}.sa-row{display:flex;align-items:center;justify-content:center;gap:2px}.sa-btn{display:inline-grid;place-items:center;width:42px;height:44px;color:var(--ink);background:transparent;border:0;border-radius:10px;cursor:pointer}.sa-btn:active{background:var(--surface-2)}.sa-ico{width:20px;height:20px}.sa-danger{color:var(--bad)}.insert-sheet{display:flex;background:var(--surface);border:1px solid var(--border);border-bottom:0}.insert-row{display:flex;align-items:stretch;justify-content:space-between;gap:4px}.insert-btn{flex:1;display:grid;place-items:center;gap:5px;padding:9px 2px;color:var(--muted);background:transparent;border:0;border-radius:12px;cursor:pointer;font:500 11px Inter,system-ui,sans-serif}.insert-btn:active{background:var(--surface-2);color:var(--ink)}.insert-ico{width:24px;height:24px}.insert-label{line-height:1}#app:has(.selection-actions.mini-sheet:not(.hidden)) .dock{border-top-left-radius:0;border-top-right-radius:0;border-top-color:transparent;box-shadow:0 14px 20px -8px #10111638}#app:has(.selection-actions.mini-sheet.collapsed) .dock{border-top-color:var(--border)}}.refused-body{display:flex;flex-direction:column;gap:6px;padding:4px 0;text-align:center}.refused-title{margin:0;font-size:16px;font-weight:700;color:var(--ink)}.refused-sub{margin:0;max-width:22rem;font-size:13px;line-height:1.5;color:var(--muted)}.refused-footer{display:flex;justify-content:flex-end;gap:8px}.share-body{display:flex;flex-direction:column;align-items:center;gap:10px}.share-qr{width:172px;height:172px;padding:10px;background:#fff;border:1px solid var(--border);border-radius:12px}.share-qr svg{display:block;width:100%;height:100%}.share-cap{margin:0;font-size:12px;color:var(--muted)}.share-url-row{display:flex;width:100%;gap:8px}.share-url{flex:1;min-width:0;height:36px;padding:0 10px;font-size:13px;color:var(--ink);background:var(--surface-2);border:1px solid var(--border);border-radius:9px}.share-copy{flex:none;height:36px;padding:0 14px;font-weight:600;font-size:13px;color:#fff;background:var(--accent);border:0;border-radius:9px;cursor:pointer;transition:background var(--dur) var(--ease)}.share-copy.ok{background:#3db46b}.share-helper{margin:2px 0 0;font-size:12px;color:var(--muted);text-align:center}.share-footer{display:flex;gap:8px;justify-content:flex-end}.share-native,.share-done{height:34px;padding:0 14px;font-weight:600;font-size:13px;border-radius:9px;cursor:pointer}.share-native{color:var(--ink);background:var(--surface-2);border:1px solid var(--border)}.share-done{color:#fff;background:var(--accent);border:0}.iconbtn{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.iconbtn:hover{background:var(--surface-2);color:var(--ink)}.brand .logo,.brand-name{display:none}.app-menu{position:fixed;z-index:80;width:300px;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}.app-menu-head{display:flex;align-items:center;gap:8px;padding:13px 15px;font-weight:800;font-size:16px;letter-spacing:-.02em;border-bottom:1px solid var(--border)}.app-menu-body{display:flex;flex-direction:column;gap:14px;padding:14px 15px}.app-menu-item{display:flex;align-items:center;justify-content:space-between;width:auto;margin:0 -15px;padding:9px 15px;border:none;background:transparent;color:var(--ink);font:inherit;font-size:14px;font-weight:600;text-align:left;cursor:pointer}.app-menu-item:hover{background:var(--surface-2)}.app-menu-item-ic{display:inline-grid;place-items:center;color:var(--muted)}.menu-avatar{flex:none;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:10px;font-weight:700;color:#fff;background:var(--av, var(--accent));background-size:cover;background-position:center;overflow:hidden}.profile-id{display:inline-flex;align-items:center;gap:8px;min-width:0}.profile-name{max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted);font-size:13px;font-weight:600}.app-menu-sep{height:1px;margin:0 -15px;background:var(--border)}.help-btn{position:absolute;right:16px;bottom:16px;z-index:25;display:grid;place-items:center;width:38px;height:38px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;box-shadow:var(--shadow);transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.help-btn:hover{background:var(--surface-2);color:var(--ink)}#help-btn{position:absolute}.canvas{position:relative;overflow:hidden;touch-action:none;-webkit-touch-callout:none;user-select:none;-webkit-user-select:none;background-image:radial-gradient(var(--grid) var(--grid-dot, 1.6px),transparent var(--grid-dot, 1.6px));background-size:var(--grid-fine, 24px) var(--grid-fine, 24px);background-position:var(--gx-fine, 0px) var(--gy-fine, 0px);background-image:radial-gradient(rgb(from var(--grid) r g b / var(--grid-fade, 1)) var(--grid-dot, 1.6px),transparent var(--grid-dot, 1.6px)),radial-gradient(var(--grid) var(--grid-dot, 1.6px),transparent var(--grid-dot, 1.6px));background-size:var(--grid-fine, 24px) var(--grid-fine, 24px),var(--grid-coarse, 48px) var(--grid-coarse, 48px);background-position:var(--gx-fine, 0px) var(--gy-fine, 0px),var(--gx-coarse, 0px) var(--gy-coarse, 0px)}.canvas[data-grid=lines]{background-image:linear-gradient(to bottom,transparent calc(50% - var(--grid-line, .5px)),var(--grid) calc(50% - var(--grid-line, .5px)) calc(50% + var(--grid-line, .5px)),transparent calc(50% + var(--grid-line, .5px))),linear-gradient(to right,transparent calc(50% - var(--grid-line, .5px)),var(--grid) calc(50% - var(--grid-line, .5px)) calc(50% + var(--grid-line, .5px)),transparent calc(50% + var(--grid-line, .5px)));background-size:var(--grid-fine, 24px) var(--grid-fine, 24px),var(--grid-fine, 24px) var(--grid-fine, 24px);background-position:0px var(--gy-fine, 0px),var(--gx-fine, 0px) 0px;background-image:linear-gradient(to bottom,transparent calc(50% - var(--grid-line, .5px)),rgb(from var(--grid) r g b / var(--grid-fade, 1)) calc(50% - var(--grid-line, .5px)) calc(50% + var(--grid-line, .5px)),transparent calc(50% + var(--grid-line, .5px))),linear-gradient(to right,transparent calc(50% - var(--grid-line, .5px)),rgb(from var(--grid) r g b / var(--grid-fade, 1)) calc(50% - var(--grid-line, .5px)) calc(50% + var(--grid-line, .5px)),transparent calc(50% + var(--grid-line, .5px))),linear-gradient(to bottom,transparent calc(50% - var(--grid-line, .5px)),var(--grid) calc(50% - var(--grid-line, .5px)) calc(50% + var(--grid-line, .5px)),transparent calc(50% + var(--grid-line, .5px))),linear-gradient(to right,transparent calc(50% - var(--grid-line, .5px)),var(--grid) calc(50% - var(--grid-line, .5px)) calc(50% + var(--grid-line, .5px)),transparent calc(50% + var(--grid-line, .5px)));background-size:var(--grid-fine, 24px) var(--grid-fine, 24px),var(--grid-fine, 24px) var(--grid-fine, 24px),var(--grid-coarse, 48px) var(--grid-coarse, 48px),var(--grid-coarse, 48px) var(--grid-coarse, 48px);background-position:0px var(--gy-fine, 0px),var(--gx-fine, 0px) 0px,0px var(--gy-coarse, 0px),var(--gx-coarse, 0px) 0px}.set-row{display:grid;grid-template-columns:1fr 168px;align-items:center;gap:16px}.set-label{font-size:13px;font-weight:600;color:var(--ink)}.set-row .theme-switch{justify-self:center}.theme-switch{position:relative;flex:none;display:inline-flex;width:64px;height:32px;padding:0;border:1px solid var(--border);border-radius:999px;background:var(--surface-2);cursor:pointer}.theme-switch-ic{position:relative;z-index:1;display:inline-grid;place-items:center;width:32px;height:32px;color:var(--muted);transition:color var(--dur) var(--ease)}.theme-switch-ic .ico{width:15px;height:15px}.theme-switch-knob{position:absolute;z-index:0;top:3px;left:3px;width:26px;height:26px;border-radius:50%;background:var(--surface);box-shadow:var(--shadow);transition:transform var(--dur) var(--ease)}.theme-switch[data-theme=dark] .theme-switch-knob{transform:translate(32px)}.theme-switch[data-theme=light] .sun,.theme-switch[data-theme=dark] .moon{color:var(--ink)}.dock{position:absolute;left:16px;top:calc(56px + (100vh - 56px)/2);transform:translateY(-50%);z-index:30;display:flex;flex-direction:column;gap:4px;padding:7px;background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow)}.tool{display:grid;place-items:center;width:42px;height:42px;border-radius:11px;border:none;background:transparent;color:var(--muted);cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.tool:hover{background:var(--surface-2);color:var(--ink)}.tool.active{background:var(--accent);color:var(--accent-ink)}.tool.disabled{opacity:.4;cursor:default}.tool.disabled:hover{background:transparent;color:var(--muted)}.tool[data-tool=insert]{display:none}.tool[data-tool=insert].active{background:var(--surface-2);color:var(--ink)}.ico{width:21px;height:21px}.sheet-wrap{display:contents}.swatches{display:flex;gap:8px;flex-wrap:wrap}.sw{width:24px;height:24px;border-radius:7px;background:var(--sw);border:2px solid var(--surface);box-shadow:0 0 0 1px var(--border);cursor:pointer;padding:0}.sw.on{box-shadow:0 0 0 2px var(--accent)}.seg{display:flex;gap:3px;padding:3px;background:var(--surface-2);border-radius:9px}.seg-opt{flex:1;border:none;background:transparent;color:var(--muted);font:inherit;font-size:12px;font-weight:600;padding:6px 0;border-radius:7px;cursor:pointer}.seg-opt.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}input[type=range]{width:100%;accent-color:var(--accent);cursor:pointer}.hint-chip{position:absolute;left:50%;bottom:16px;transform:translate(-50%);z-index:25;pointer-events:none;max-width:calc(100% - 32px);background:var(--surface);border:1px solid var(--border);color:var(--muted);font-size:12.5px;padding:7px 13px;border-radius:999px;box-shadow:var(--shadow);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hint-chip b{color:var(--ink)}.avatar-presence-row{display:flex;align-items:center;padding-left:7px;position:relative}.avatar-presence-row .avatar{width:28px;height:28px;border-radius:50%;margin-left:-7px;display:grid;place-items:center;font-size:11px;font-weight:700;color:#fff;background:var(--av, var(--accent));border:2px solid var(--surface);cursor:default;position:relative;overflow:hidden}.avatar-presence-row .avatar:first-child{margin-left:0}.avatar-presence-row .avatar.self{cursor:pointer;overflow:visible;box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 65%,transparent)}.avatar-presence-row .avatar.more{background:var(--surface-2);color:var(--muted);cursor:pointer;z-index:4;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.avatar-presence-row .avatar.more:hover{background:var(--border);color:var(--ink)}.avatar-presence-row .avatar.more:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.presence-overflow{position:fixed;z-index:80;width:224px;max-height:min(60vh,340px);overflow-y:auto;padding:6px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow)}.po-item{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:8px}.po-item:hover{background:var(--surface-2)}.po-av{flex:none;width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:700;color:#fff;background:var(--av, var(--accent));background-size:cover;background-position:center;overflow:hidden}.po-name{min-width:0;font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.zoombar{position:absolute;left:16px;bottom:16px;z-index:25;display:flex;align-items:center;gap:2px;padding:5px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow)}.zb{min-width:30px;height:30px;padding:0 8px;border:none;background:transparent;color:var(--muted);font:inherit;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;display:inline-grid;place-items:center}.zb:hover{background:var(--surface-2);color:var(--ink)}.zb.pct{min-width:56px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;cursor:text;border-radius:8px;transition:background var(--dur) var(--ease),box-shadow var(--dur) var(--ease),color var(--dur) var(--ease)}.zb.pct:focus-within{background:var(--surface-2);box-shadow:inset 0 0 0 2px var(--accent);color:var(--accent)}.zb.pct input{width:34px;border:none;background:transparent;color:var(--ink);font:inherit;font-weight:600;text-align:center;padding:0;outline:none;caret-color:var(--accent)}.zb.pct input:focus{color:var(--accent)}.zb.pct input::selection{background:color-mix(in srgb,var(--accent) 30%,transparent);color:var(--ink)}.zb-sep{width:1px;height:18px;background:var(--border);margin:0 2px}.ico-sm{width:17px;height:17px}.room-pill{display:flex;align-items:center;gap:7px;height:32px;padding:0 12px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);color:var(--muted);font-size:13px;font-weight:500;white-space:nowrap}.room-pill strong{color:var(--ink);font-weight:700}.kbd{font:600 11px ui-monospace,SF Mono,Menlo,monospace;background:var(--surface-2);border:1px solid var(--border);border-bottom-width:2px;border-radius:6px;padding:1px 6px;color:var(--ink)}.hidden{display:none!important}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:60;display:grid;place-items:center;background:color-mix(in srgb,var(--ink) 28%,transparent);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{width:340px;max-width:calc(100% - 32px);background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;font-weight:700;border-bottom:1px solid var(--border)}.modal-x{border:none;background:transparent;color:var(--muted);font-size:15px;line-height:1;padding:3px 6px;border-radius:7px;cursor:pointer}.modal-x:hover{background:var(--surface-2);color:var(--ink)}.modal-x:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.modal-body{padding:6px 16px 14px}.kbd-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;font-size:13px;color:var(--ink);border-bottom:1px solid var(--surface-2)}.kbd-row:last-child{border-bottom:none}.dialog{border:none;padding:0;width:360px;max-width:calc(100% - 32px);max-height:min(82dvh,720px);border-radius:18px;background:var(--surface);color:var(--ink);box-shadow:var(--shadow);opacity:0;transform:translateY(10px) scale(.97);transition:opacity .18s var(--ease),transform .18s var(--ease),overlay .18s var(--ease) allow-discrete,display .18s var(--ease) allow-discrete}.dialog[open]{opacity:1;transform:none;display:flex;flex-direction:column}@starting-style{.dialog[open]{opacity:0;transform:translateY(10px) scale(.97)}}.dialog::backdrop{background:color-mix(in srgb,#0b0e13 45%,transparent);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);opacity:0;transition:opacity .18s var(--ease),overlay .18s var(--ease) allow-discrete,display .18s var(--ease) allow-discrete}.dialog[open]::backdrop{opacity:1}@starting-style{.dialog[open]::backdrop{opacity:0}}.dialog-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;font-weight:700;font-size:15px;border-bottom:1px solid var(--border);flex:0 0 auto}.dialog-body{padding:18px;display:flex;flex-direction:column;gap:16px;flex:1 1 auto;min-height:0;overflow-y:auto}.dialog-foot{display:flex;justify-content:flex-end;gap:8px;padding:14px 18px;border-top:1px solid var(--border);flex:0 0 auto}.avatar-edit{display:flex;align-items:center;gap:14px}.avatar-preview{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:20px;background:var(--av, var(--accent));background-size:cover;background-position:center;flex:none}.avatar-edit-actions{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.field{display:flex;flex-direction:column;gap:7px;font-size:12px;font-weight:600;color:var(--muted)}.field input[type=text]{height:38px;padding:0 12px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--ink);font:inherit;font-size:14px;font-weight:500;outline:none}.field input[type=text]:focus{border-color:var(--accent)}.btn-soft{height:30px;padding:0 12px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--ink);font:inherit;font-size:13px;font-weight:600;cursor:pointer}.btn-soft:hover{background:var(--surface-2)}.btn-link{border:none;background:none;color:var(--muted);font:inherit;font-size:12px;cursor:pointer;padding:0}.btn-link:hover{color:var(--bad)}.btn-ghost{height:36px;padding:0 14px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--ink);font:inherit;font-weight:600;cursor:pointer}.btn-ghost:hover{background:var(--surface-2)}.btn-primary{height:36px;padding:0 16px;border-radius:10px;border:none;background:var(--accent);color:var(--accent-ink);font:inherit;font-weight:700;cursor:pointer}.avatar.has-photo{background-size:cover;background-position:center;color:transparent}@media(prefers-reduced-motion:reduce){*{transition:none!important}}.sw-custom{background:conic-gradient(from 90deg,#ff5a5a,#ffb24d,#ffe24d,#6fe08a,#4dd2ff,#4d7bff,#b072ff,#ff5ec4,#ff5a5a)!important;border:2px solid var(--surface)!important}[data-tip]{position:relative}.komu-tip{position:fixed;z-index:2147483000;inset:auto;margin:0;border:0;overflow:visible;display:none;background:#1e1e1e;color:#fff;font-size:12px;font-weight:600;padding:5px 9px;border-radius:8px;white-space:nowrap;pointer-events:none}.komu-tip.show{display:block}.komu-tip:after{content:"";position:absolute;border:5px solid transparent}.komu-tip:not(.below):not(.side):after{top:100%;left:var(--tail-x, 50%);transform:translate(-50%);border-top-color:#1e1e1e}.komu-tip.below:after{bottom:100%;left:var(--tail-x, 50%);transform:translate(-50%);border-bottom-color:#1e1e1e}.komu-tip.side:after{top:var(--tail-y, 50%);transform:translateY(-50%)}.komu-tip.side:not(.side-left):after{right:100%;border-right-color:#1e1e1e}.komu-tip.side.side-left:after{left:100%;border-left-color:#1e1e1e}.color-picker{position:fixed;z-index:80;width:232px;padding:12px;display:flex;flex-direction:column;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);-webkit-user-select:none;user-select:none}.cp-top{display:flex;align-items:center;gap:8px}.cp-eyedropper{display:grid;place-items:center;flex:none;width:30px;height:30px;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);color:var(--ink);cursor:pointer}.cp-eyedropper:hover{background:var(--surface)}.cp-hex{flex:1;min-width:0;font:600 13px ui-monospace,SF Mono,Menlo,monospace;text-transform:uppercase;padding:7px 9px;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);color:var(--ink)}.cp-hex:focus{outline:2px solid var(--accent);outline-offset:-1px}.cp-hue{position:relative;height:14px;border-radius:999px;cursor:pointer;background:linear-gradient(to right,red,#ff0,#0f0,#0ff,#00f,#f0f,red)}.cp-sv{position:relative;height:150px;border-radius:10px;cursor:crosshair;background:linear-gradient(to top,#000,transparent),linear-gradient(to right,#fff,var(--cp-hue, #f00))}.cp-thumb{position:absolute;top:50%;width:14px;height:14px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px #00000059,0 1px 3px #0006;transform:translate(-50%,-50%);pointer-events:none}.komu-tip .kbd{background:#ffffff26;border-color:#ffffff47;color:#fff}#profile-color-field .swatches{gap:10px}#profile-color-field .sw{width:26px;height:26px;border-radius:50%}#profile-color-field .sw.on{box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--accent)}.nav-btn{display:inline-grid}.sheet-handle{display:none;position:relative;height:30px;cursor:pointer;outline:none;touch-action:none}.sheet-handle:before{content:"";position:absolute;top:13px;left:50%;transform:translate(-50%);width:40px;height:4px;border-radius:2px;background:var(--border)}.zoom-pill{position:absolute;top:calc(68px + env(safe-area-inset-top,0px));left:50%;transform:translate(-50%) translateY(-6px);z-index:28;display:none;padding:5px 13px;border-radius:999px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);color:var(--ink);font-size:13px;font-weight:700;font-variant-numeric:tabular-nums;pointer-events:none;opacity:0;transition:opacity .16s var(--ease),transform .16s var(--ease)}.zoom-pill.show{opacity:1;transform:translate(-50%) translateY(0)}.drawer-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#10111673;opacity:0;visibility:hidden;transition:opacity .22s var(--ease),visibility .22s var(--ease)}.drawer-scrim.open{opacity:1;visibility:visible}.drawer{position:fixed;top:0;left:0;bottom:0;z-index:61;width:270px;max-width:82vw;padding:calc(16px + env(safe-area-inset-top,0px)) 16px 16px;display:flex;flex-direction:column;gap:8px;background:var(--surface);border-right:1px solid var(--border);box-shadow:var(--shadow);transform:translate(-100%);transition:transform .24s var(--ease)}.drawer.open{transform:translate(0)}.drawer-head{display:flex;align-items:center;gap:8px;font-weight:800;font-size:16px;letter-spacing:-.02em;padding-bottom:10px;border-bottom:1px solid var(--border)}.drawer-room{font-size:13px;color:var(--muted);padding:2px 0 8px}.drawer-room strong{color:var(--ink)}.drawer-item{display:flex;align-items:center;justify-content:space-between;width:auto;margin:4px -16px 0;padding:12px 16px;border:none;border-radius:0;background:transparent;color:var(--ink);font:inherit;font-size:14px;font-weight:600;cursor:pointer}.drawer-item:hover{background:var(--surface-2)}.drawer-item-ic{display:inline-grid;place-items:center;color:var(--muted)}.drawer .set-row,.drawer .drawer-item{margin:0 -16px;padding:12px 16px;border-top:1px solid var(--border)}.draw-bar{position:absolute;left:84px;top:calc(56px + (100vh - 56px)/2);transform:translateY(-50%);z-index:30;display:flex;flex-direction:column;gap:4px;padding:7px;background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow)}.draw-bar.hidden{display:none}.sticky-bar{position:absolute;left:84px;top:calc(56px + (100vh - 56px)/2);transform:translateY(-50%);z-index:30;display:flex;flex-direction:column;align-items:center;padding:12px 9px;background:var(--surface, #ffffff);border:1px solid var(--border, #e4e7ec);border-radius:999px;box-shadow:var(--shadow)}.sticky-bar.hidden{display:none}.sticky-bar .swatches{display:flex;flex-direction:column;align-items:center;gap:13px}.sticky-bar .sw{width:28px;height:28px;border-radius:50%}.sticky-bar .sw.on{box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--accent)}.shape-menu{position:absolute;left:84px;top:calc(56px + (100vh - 56px)/2);transform:translateY(-50%);z-index:40;display:flex;flex-direction:column;min-width:224px;padding:6px;background:var(--surface, #ffffff);border:1px solid var(--border, #e4e7ec);border-radius:12px;box-shadow:var(--shadow);max-height:calc(100vh - 110px);overflow-y:auto}.shape-menu.hidden{display:none}.sm-item{display:flex;align-items:center;gap:12px;height:40px;padding:0 12px 0 10px;border:0;border-radius:8px;background:transparent;color:var(--ink, #0e1116);font:15px Inter,system-ui,sans-serif;text-align:left;cursor:pointer}.sm-item:hover{background:var(--surface-2, #f1f3f5)}.sm-item.on{background:color-mix(in srgb,var(--accent, #3b6ff6) 12%,transparent);color:var(--accent, #3b6ff6)}.sm-ico{width:22px;height:22px;flex:none}.sm-label{flex:1}.sm-item.sm-sep{margin-top:7px;position:relative}.sm-item.sm-sep:before{content:"";position:absolute;top:-4px;left:6px;right:6px;height:1px;background:var(--border, #e4e7ec)}.komu-stamp-wheel{position:absolute;left:84px;top:calc(56px + (100vh - 56px)/2);transform:translateY(-50%);z-index:40;width:280px;height:280px;contain:layout paint}.komu-stamp-wheel.hidden{display:none}.sw-disc{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:var(--surface);box-shadow:var(--shadow)}.sw-wedges{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.sw-wedge{fill:var(--surface-2);stroke:var(--surface);stroke-width:2;pointer-events:auto;cursor:pointer;transition:fill 60ms linear}.sw-wedge:hover{fill:color-mix(in srgb,var(--accent) 13%,var(--surface-2))}.sw-wedge.on{fill:color-mix(in srgb,var(--accent) 24%,var(--surface-2))}.sw-ico{position:absolute;width:50px;height:50px;margin:-25px 0 0 -25px;pointer-events:none;filter:drop-shadow(0 2px 2px rgba(16,17,22,.3))}.sw-avatar{position:absolute;width:46px;height:46px;margin:-23px 0 0 -23px;pointer-events:none;display:grid;place-items:center;border-radius:50%;background-color:var(--av, #8a90a2);background-size:cover;background-position:center;color:#fff;font:600 17px Inter,system-ui,sans-serif;border:2px solid var(--surface);box-shadow:0 2px 5px #1011164d}.sw-inner{position:absolute;left:50%;top:50%;width:132px;height:132px;margin:-66px 0 0 -66px;border-radius:50%;background:color-mix(in srgb,var(--accent) 12%,var(--surface))}.komu-stamp-wheel button{position:absolute;display:grid;place-items:center;padding:0;border:0;border-radius:50%;background:transparent;cursor:pointer}.sw-emoji{width:40px;height:40px;margin:-20px 0 0 -20px;transition:transform .13s var(--ease, ease-out);will-change:transform}.sw-emoji img{width:36px;height:36px;pointer-events:none;filter:drop-shadow(0 1px 1px rgba(16,17,22,.28))}.sw-emoji:hover{background:color-mix(in srgb,var(--accent) 16%,transparent);transform:scale(1.22)}.sw-emoji.on{background:color-mix(in srgb,var(--accent) 22%,transparent);box-shadow:0 0 0 2px var(--accent)}.sw-plus{left:50%;top:50%;width:36px;height:36px;margin:-18px 0 0 -18px;color:var(--accent);background:var(--surface)!important;box-shadow:0 1px 4px #10111633;transition:transform .13s var(--ease, ease-out);will-change:transform}.sw-plus svg{width:18px;height:18px}.sw-plus:hover{background:var(--surface-2)!important;transform:scale(1.13)}@keyframes sw-disc-in{0%{opacity:0;transform:scale(.72)}to{opacity:1;transform:scale(1)}}@keyframes sw-pop-in{0%{opacity:0;transform:scale(.3)}to{opacity:1;transform:scale(1)}}.komu-stamp-wheel.sw-intro .sw-disc,.komu-stamp-wheel.sw-intro .sw-wedges,.komu-stamp-wheel.sw-intro .sw-ico,.komu-stamp-wheel.sw-intro .sw-avatar,.komu-stamp-wheel.sw-intro .sw-inner,.komu-stamp-wheel.sw-intro .sw-emoji,.komu-stamp-wheel.sw-intro .sw-plus{will-change:transform,opacity}.komu-stamp-wheel.sw-intro .sw-disc,.komu-stamp-wheel.sw-intro .sw-wedges{animation:sw-disc-in .28s var(--ease, ease-out) both}.komu-stamp-wheel.sw-intro .sw-ico,.komu-stamp-wheel.sw-intro .sw-avatar{animation:sw-pop-in .32s var(--ease, ease-out) both}.komu-stamp-wheel.sw-intro .sw-inner{animation:sw-disc-in .3s var(--ease, ease-out) .16s both}.komu-stamp-wheel.sw-intro .sw-emoji,.komu-stamp-wheel.sw-intro .sw-plus{animation:sw-pop-in .28s var(--ease, ease-out) .2s both}@media(prefers-reduced-motion:reduce){.komu-stamp-wheel.sw-intro .sw-disc,.komu-stamp-wheel.sw-intro .sw-wedges,.komu-stamp-wheel.sw-intro .sw-ico,.komu-stamp-wheel.sw-intro .sw-avatar,.komu-stamp-wheel.sw-intro .sw-inner,.komu-stamp-wheel.sw-intro .sw-emoji,.komu-stamp-wheel.sw-intro .sw-plus{animation:none}}.komu-emoji-picker{position:absolute;left:340px;top:calc(56px + (100vh - 56px)/2);transform:translateY(-50%);z-index:60;display:flex;flex-direction:column;width:320px;height:384px;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}.komu-emoji-picker.hidden{display:none}.ep-tabs{display:flex;gap:2px;padding:6px;border-bottom:1px solid var(--surface-2);overflow-x:auto;scrollbar-width:none}.ep-tabs::-webkit-scrollbar{display:none}.ep-tab{flex:0 0 auto;width:30px;height:30px;display:grid;place-items:center;padding:0;border:0;border-radius:8px;background:transparent;cursor:pointer;opacity:.65}.ep-tab img{width:20px;height:20px}.ep-tab:hover{background:var(--surface-2);opacity:1}.ep-tab.on{background:color-mix(in srgb,var(--accent) 14%,transparent);opacity:1}.ep-search{padding:8px 8px 6px}.ep-search input{width:100%;box-sizing:border-box;height:34px;padding:0 12px;border:1px solid var(--border);border-radius:9px;background:var(--surface-2);color:var(--ink);font:inherit;font-size:14px;outline:none}.ep-search input:focus{border-color:var(--accent)}.ep-grid{flex:1;display:grid;grid-template-columns:repeat(7,1fr);gap:1px;padding:0 8px 8px;overflow-y:auto;align-content:start}.ep-emoji{width:100%;aspect-ratio:1;display:grid;place-items:center;padding:0;border:0;border-radius:8px;background:transparent;cursor:pointer}.ep-emoji img{width:26px;height:26px}.ep-emoji:hover{background:var(--surface-2)}.ep-empty{grid-column:1 / -1;text-align:center;color:var(--muted);padding:28px 0;font-size:13px}.db-row{display:flex;flex-direction:column;gap:4px}.db-btn{position:relative;display:grid;place-items:center;width:42px;height:42px;padding:0;border:none;border-radius:11px;background:transparent;color:var(--muted);cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.db-btn:hover{background:var(--surface-2);color:var(--ink)}.db-btn.active{background:var(--accent);color:var(--accent-ink)}.db-btn .ico{width:21px;height:21px}.db-dot{width:20px;height:20px;border-radius:50%;background:var(--ink);box-shadow:inset 0 0 0 1.5px var(--surface),0 0 0 1px var(--border)}.db-tip{position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%);background:#1e1e1e;color:#fff;font-size:12px;font-weight:600;padding:5px 9px;border-radius:8px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .11s var(--ease);z-index:70}.db-tip:before{content:"";position:absolute;right:100%;top:50%;transform:translateY(-50%);border:5px solid transparent;border-right-color:#1e1e1e}.db-btn:not(.active):hover .db-tip{opacity:1}.draw-bar.pop-open .db-tip{display:none}.db-popover{position:fixed;z-index:80;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);-webkit-user-select:none;user-select:none}.db-pop-label{font-size:11px;font-weight:600;color:var(--muted);margin-bottom:9px}.db-pop-label b{color:var(--ink)}.db-popover input[type=range]{display:block;width:184px}.db-popover .swatches{display:grid;grid-template-columns:repeat(5,26px);justify-content:center;column-gap:12px;row-gap:12px}.db-popover .sw{position:relative;width:26px;height:26px;border-radius:50%}.db-popover .sw.on{box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--accent)}.db-popover .seg-opt{display:grid;place-items:center;padding:8px 18px}.db-popover .seg-opt .ico{width:24px;height:24px}@media(max-width:640px),(pointer:coarse){.mini-sheet{position:absolute;left:0;right:0;top:auto;bottom:0;margin:0 auto;width:min(340px,calc(100vw - 20px));max-width:min(340px,calc(100vw - 20px));min-width:0;flex-direction:column;align-items:stretch;gap:4px;padding:0 8px 10px;border-radius:16px 16px 0 0;box-shadow:none;pointer-events:auto;transform:translateY(0);transition:transform .28s var(--ease);will-change:transform}.mini-sheet>.sheet-handle{flex:0 0 30px}.draw-bar .db-row{flex-direction:row;justify-content:center;gap:6px}.mini-sheet.collapsed{transform:translateY(calc(100% - 30px))}.mini-sheet.hidden{display:flex!important;transform:translateY(101%);pointer-events:none}.db-tip,.devstatus,.settings-btn,.zoombar,.room-pill,.help-btn,.brand-name,.brand .logo{display:none}.nav-btn{display:inline-grid}.tb-history{display:flex}.dock{left:0;right:0;top:auto;margin:0 auto;width:min(340px,calc(100vw - 20px));bottom:calc(12px + env(safe-area-inset-bottom,0px));transform:none;flex-direction:row;justify-content:center;z-index:45}#app.sheet-open .dock{border-top-left-radius:0;border-top-right-radius:0;border-top-color:transparent;box-shadow:0 14px 20px -8px #10111638}#app.sheet-open:has(.mini-sheet.collapsed) .dock{border-top-color:var(--border)}.sticky-bar .swatches{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:14px;padding:2px 4px 4px}.sticky-bar .sw{width:32px;height:32px}.shape-menu{display:grid;grid-template-columns:repeat(4,52px);justify-content:center;column-gap:6px;row-gap:6px;padding-bottom:12px}.shape-menu.hidden{display:grid!important}.shape-menu .sm-item{width:52px;height:52px;padding:0;justify-content:center}.shape-menu .sm-item .sm-label{display:none}.shape-menu .sm-ico{width:26px;height:26px}.shape-menu .sm-item.sm-sep{margin-top:0;position:relative}.shape-menu .sm-item.sm-sep:before{display:block;top:-3px;left:0;right:auto;width:calc(400% + 18px)}.shape-menu>.sheet-handle{grid-column:1 / -1}.komu-stamp-wheel{left:50%;top:auto;bottom:8px;transform:translate(-50%)}.komu-emoji-picker{left:50%;top:auto;bottom:8px;transform:translate(-50%);width:min(340px,calc(100vw - 20px));height:min(60vh,384px)}.komu-text-bar{max-width:calc(100vw - 12px);flex-wrap:wrap;justify-content:center;row-gap:4px}.komu-text-bar .ctb-btn,.komu-text-bar .ctb-text{flex:0 0 auto}.komu-text-bar .ctb-sep{display:none}.komu-text-bar .ctb-marks{position:relative}.komu-text-bar .ctb-marks .ctb-marks-toggle{display:inline-flex}.komu-text-bar .ctb-marks .ctb-marks-menu{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) scaleY(0);transform-origin:bottom center;flex-direction:row;gap:2px;padding:4px;background:var(--surface, #ffffff);border:1px solid var(--border, #e3e6ea);border-radius:10px;box-shadow:0 8px 28px #0000002e;opacity:0;pointer-events:none;transition:transform .15s var(--ease, ease),opacity .15s var(--ease, ease);z-index:2}.komu-text-bar .ctb-marks.open .ctb-marks-menu{transform:translate(-50%) scaleY(1);opacity:1;pointer-events:auto}.sheet-wrap{display:block;position:absolute;left:0;right:0;top:0;bottom:calc(70px + env(safe-area-inset-bottom,0px));overflow:hidden;pointer-events:none;z-index:38}.sheet-handle,.zoom-pill{display:block}}.text-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;overflow:hidden;pointer-events:none}.cursor-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;overflow:hidden;pointer-events:none}.cursor-layer *{pointer-events:none}.komu-text{position:absolute;top:0;left:0;margin:0;padding:0;box-sizing:border-box;transform-origin:0 0;line-height:1.3;font-weight:400;white-space:pre;word-break:break-word;overflow-wrap:break-word;pointer-events:none;user-select:none;-webkit-user-select:none}.komu-text-editor{pointer-events:auto;cursor:text;outline:none;min-width:1ch;user-select:text;-webkit-user-select:text;border-radius:2px;box-shadow:0 0 0 1.5px #4a9eff}.komu-text a,.komu-text-editor a{color:#2563eb;text-decoration:none}.komu-text-remote{box-shadow:0 0 0 1.5px var(--remote, #4a9eff);border-radius:2px}.komu-text.selected{box-shadow:0 0 0 1.5px #4a9eff;border-radius:2px}.komu-stamp{position:absolute;top:0;left:0;box-sizing:border-box;aspect-ratio:1 / 1;pointer-events:none;user-select:none;-webkit-user-select:none}.komu-stamp img{display:block;width:100%;height:100%;object-fit:contain;pointer-events:none;-webkit-user-drag:none;-webkit-user-select:none;user-select:none;filter:drop-shadow(0 2px 3px rgba(16,17,22,.22))}.komu-stamp.selected{box-shadow:0 0 0 1.5px #4a9eff;border-radius:2px}.komu-image{position:absolute;top:0;left:0;box-sizing:border-box;overflow:hidden;border-radius:6px;pointer-events:none;user-select:none;-webkit-user-select:none}.komu-image img{display:block;width:100%;height:100%;object-fit:cover;pointer-events:none;-webkit-user-drag:none;-webkit-user-select:none;user-select:none}.komu-image.loading{background:var(--surface-2)}.komu-image.broken{background:var(--surface-2) center / 30px no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%239aa3ad' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m3 3 18 18'/%3E%3Cpath d='M21 15V5a2 2 0 0 0-2-2H9'/%3E%3Cpath d='M3 7v12a2 2 0 0 0 2 2h12'/%3E%3Ccircle cx='9' cy='9' r='2'/%3E%3C/svg%3E")}.komu-image.broken img{display:none}.komu-image.selected{box-shadow:0 0 0 1.5px #4a9eff}.komu-text[data-locked]:after,.komu-stamp[data-locked]:after,.komu-image[data-locked]:after{content:"🔒";position:absolute;top:1px;right:2px;font-size:11px;line-height:1;opacity:.75;pointer-events:none;filter:drop-shadow(0 1px 1px rgba(16,17,22,.35))}#app.drag-target #board{box-shadow:inset 0 0 0 2.5px #4a9eff}.export-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;background:var(--surface);color:var(--muted);font:600 14px Inter,system-ui,sans-serif}.export-row{display:flex;align-items:flex-start;gap:20px;padding:14px 0}.export-label{flex:0 0 132px;padding-top:3px;font:500 15px Inter,system-ui,sans-serif;color:var(--ink)}.export-radios{display:flex;flex-direction:column;gap:14px}.export-radio{display:inline-flex;align-items:center;gap:10px;cursor:pointer;color:var(--ink);font:15px Inter,system-ui,sans-serif}.export-radio input{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}.export-bg{position:relative}.export-bg-btn{display:inline-flex;align-items:center;gap:10px;min-width:132px;padding:8px 12px;border:1px solid var(--border);border-radius:9px;background:var(--surface);color:var(--ink);cursor:pointer;font:15px Inter,system-ui,sans-serif}.export-bg-caret{margin-left:auto;color:var(--muted)}.export-dialog .dialog{overflow:visible}.export-dialog .dialog-body{overflow:visible;position:relative;z-index:1}.export-bg-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:190px;padding:6px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);z-index:5}.export-bg-opt{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:0;border-radius:8px;background:transparent;color:var(--ink);cursor:pointer;text-align:left;font:15px Inter,system-ui,sans-serif}.export-bg-opt:hover{background:var(--surface-2)}.bg-check{width:14px;flex:none;color:var(--ink);opacity:0}.export-bg-opt.selected .bg-check{opacity:1}.bg-swatch{width:22px;height:22px;flex:none;border-radius:50%;border:1px solid var(--border)}.bg-grid{background-color:var(--surface);background-image:radial-gradient(var(--muted) 1.3px,transparent 1.3px);background-size:6px 6px}.bg-transparent{background-color:#fff;background-image:linear-gradient(45deg,#bbb 25%,transparent 25%),linear-gradient(-45deg,#bbb 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#bbb 75%),linear-gradient(-45deg,transparent 75%,#bbb 75%);background-size:8px 8px;background-position:0 0,0 4px,4px -4px,-4px 0}.bg-solid{background:var(--surface)}.komu-toasts{position:fixed;left:50%;bottom:26px;z-index:60;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}.komu-toast{max-width:min(92vw,420px);padding:9px 15px;font:500 13px Inter,system-ui,sans-serif;color:#fff;background:#2a2d36;border-radius:10px;box-shadow:0 10px 28px -12px #0000008c;opacity:0;transform:translateY(8px);transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease)}.komu-toast.show{opacity:1;transform:none}@media(prefers-reduced-motion:reduce){.komu-toast{transform:none;transition:opacity var(--dur) var(--ease)}}.komu-ink{position:absolute;top:0;left:0;overflow:visible;transform-origin:0 0;pointer-events:none}.komu-ink *{pointer-events:none}.komu-text.sticky{padding:1.2em;border-radius:0;box-shadow:0 3px 10px #10111629}.komu-text.sticky.selected{box-shadow:0 3px 10px #10111629,0 0 0 1.5px #4a9eff}.komu-text-ghost{opacity:.5;pointer-events:none}.komu-text.shape{padding:.7em;box-sizing:border-box;border:1.5px solid #1f2933;border-radius:4px;display:flex;flex-direction:column;justify-content:center;word-break:break-word}.komu-text-body{width:100%;outline:none}.komu-text.shape-ellipse{border-radius:50%}.komu-text.shape-triangle,.komu-text.shape-rhombus{border:none;border-radius:0;background-repeat:no-repeat;background-position:center;background-size:100% 100%}.komu-text.shape-triangle{justify-content:flex-end;padding-bottom:.9em}.komu-text.shape.selected:has(>.komu-text-body:empty):before,.komu-text.komu-text-editor.shape:has(>.komu-text-body:empty):before{content:"Add text";position:absolute;top:0;right:0;bottom:0;left:0;padding:inherit;box-sizing:border-box;display:flex;flex-direction:column;justify-content:center;text-align:inherit;color:#98a2b3;pointer-events:none}.komu-text.shape-triangle.selected:has(>.komu-text-body:empty):before,.komu-text.komu-text-editor.shape-triangle:has(>.komu-text-body:empty):before{justify-content:flex-end}.komu-text.shape.selected{box-shadow:0 0 0 1.5px #4a9eff}.komu-text-resize{position:absolute;z-index:2;pointer-events:none}.komu-group-box{position:absolute;z-index:2;pointer-events:none;box-shadow:0 0 0 1px #4a9eff}.komu-group-box.is-group{box-shadow:0 0 0 1.5px #4a9eff;border-radius:3px}.komu-group-ungroup{position:absolute;bottom:100%;left:-1px;margin-bottom:5px;display:inline-flex;align-items:center;gap:4px;height:22px;padding:0 8px;font:600 11px Inter,system-ui,sans-serif;color:#fff;background:#4a9eff;border:0;border-radius:999px;box-shadow:0 1px 3px #10111647;cursor:pointer;pointer-events:auto;white-space:nowrap}.komu-group-ungroup:hover{background:#3b8eef}.komu-group-ungroup svg{opacity:.95}.komu-group-handle{position:absolute;width:9px;height:9px;background:#fff;border:1.5px solid #4a9eff;border-radius:2px;pointer-events:auto;transform:translate(-50%,-50%)}.komu-group-handle.g-nw{left:0;top:0;cursor:nwse-resize}.komu-group-handle.g-ne{left:100%;top:0;cursor:nesw-resize}.komu-group-handle.g-sw{left:0;top:100%;cursor:nesw-resize}.komu-group-handle.g-se{left:100%;top:100%;cursor:nwse-resize}.komu-group-handle.g-w{left:0;top:50%;cursor:ew-resize}.komu-group-handle.g-e{left:100%;top:50%;cursor:ew-resize}.komu-group-handle.g-n{left:50%;top:0;cursor:ns-resize}.komu-group-handle.g-s{left:50%;top:100%;cursor:ns-resize}.komu-connector-dots{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none}.komu-connector-dot{position:absolute;width:12px;height:12px;border-radius:50%;background:#7ab8ff;border:1.5px solid #fff;box-shadow:0 0 0 1px #4a9eff80;transform:translate(-50%,-50%)}.komu-connector-dot.is-snapped{width:16px;height:16px;background:#3b6ff6;box-shadow:0 0 0 3px #3b6ff64d}.komu-connector-handles{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;pointer-events:none}.komu-connector-handle{position:absolute;width:15px;height:15px;border-radius:50%;background:#fff;border:2.5px solid #4a9eff;transform:translate(-50%,-50%);cursor:grab;pointer-events:auto;touch-action:none}.komu-connector-handle:active{cursor:grabbing}.komu-connector-bar{position:fixed;z-index:50;display:inline-flex;align-items:center;gap:2px;padding:5px;background:var(--surface, #ffffff);border:1px solid var(--border, #e3e6ea);border-radius:12px;box-shadow:0 8px 28px #0000002e;color:var(--ink, #0e1116);-webkit-user-select:none;user-select:none}.komu-connector-bar .cb-btn{display:inline-flex;align-items:center;gap:2px;height:34px;padding:0 7px;border:0;border-radius:8px;background:transparent;color:inherit;cursor:pointer}.komu-connector-bar .cb-btn:hover{background:var(--surface-2, #f1f3f5)}.komu-connector-bar .cb-ico{width:22px;height:22px;display:block}.komu-connector-bar .cb-weight .cb-ico{width:18px;height:18px}.komu-connector-bar .cb-caret{font-size:9px;opacity:.55}.komu-connector-bar .cb-color-dot{width:18px;height:18px;border-radius:50%;background:#1f2933;border:1.5px solid rgba(0,0,0,.18)}.komu-connector-bar .cb-sep{width:1px;height:22px;margin:0 3px;background:var(--border, #e3e6ea)}.cb-pop{position:fixed;z-index:51;display:flex;flex-wrap:wrap;gap:3px;padding:6px;background:var(--surface, #ffffff);border:1px solid var(--border, #e3e6ea);border-radius:10px;box-shadow:0 8px 28px #0000002e}.cb-pop .cb-opt,.cb-pop .cb-weight-opt{display:inline-flex;align-items:center;justify-content:center;width:40px;height:34px;border:0;border-radius:8px;background:transparent;color:var(--ink, #0e1116);cursor:pointer}.cb-pop .cb-opt:hover,.cb-pop .cb-weight-opt:hover{background:var(--surface-2, #f1f3f5)}.cb-pop .cb-opt.on,.cb-pop .cb-weight-opt.on{background:color-mix(in srgb,var(--accent, #3b6ff6) 16%,transparent);color:var(--accent, #3b6ff6)}.cb-pop .cb-opt .cb-ico{width:24px;height:24px}.cb-pop-list{flex-direction:column;flex-wrap:nowrap;min-width:150px}.cb-pop-list .cb-weight-opt{width:100%;height:34px;justify-content:space-between;gap:14px;padding:0 10px;font:14px Inter,system-ui,sans-serif}.cb-pop-list .cb-weight-line{flex:0 0 56px;border-radius:3px;background:currentColor}.cb-swatches{display:grid;grid-template-columns:repeat(5,24px);gap:8px;padding:2px}.cb-sw{width:24px;height:24px;border-radius:50%;background:var(--sw);border:2px solid var(--surface, #ffffff);box-shadow:0 0 0 1px var(--border, #e3e6ea);cursor:pointer;padding:0}.cb-sw.on{box-shadow:0 0 0 2px var(--surface, #ffffff),0 0 0 4px var(--accent, #3b6ff6)}.komu-text-handle{position:absolute;width:9px;height:9px;background:#fff;border:1.5px solid #4a9eff;border-radius:2px;pointer-events:auto;transform:translate(-50%,-50%)}.komu-text-handle.h-nw{left:0;top:0;cursor:nwse-resize}.komu-text-handle.h-ne{left:100%;top:0;cursor:nesw-resize}.komu-text-handle.h-sw{left:0;top:100%;cursor:nesw-resize}.komu-text-handle.h-se{left:100%;top:100%;cursor:nwse-resize}.komu-text-handle.h-w{left:0;top:50%;cursor:ew-resize}.komu-text-handle.h-e{left:100%;top:50%;cursor:ew-resize}.komu-text-handle.h-n,.komu-text-handle.h-s{display:none;left:50%;cursor:ns-resize}.komu-text-handle.h-n{top:0}.komu-text-handle.h-s{top:100%}.komu-text-resize-shape .komu-text-handle.h-n,.komu-text-resize-shape .komu-text-handle.h-s{display:block}.komu-text-resize-stamp .komu-text-handle.h-w,.komu-text-resize-stamp .komu-text-handle.h-e,.komu-text-resize-image .komu-text-handle.h-w,.komu-text-resize-image .komu-text-handle.h-e,.komu-text-resize-stroke .komu-text-handle,.komu-text-resize-stroke .komu-text-rotate{display:none}.komu-text-rotate{position:absolute;width:20px;height:20px;pointer-events:auto}.komu-text-rotate.r-nw{left:0;top:0;transform:translate(-100%,-100%)}.komu-text-rotate.r-ne{left:100%;top:0;transform:translateY(-100%)}.komu-text-rotate.r-sw{left:0;top:100%;transform:translate(-100%)}.komu-text-rotate.r-se{left:100%;top:100%;transform:translate(0)}.komu-text-bar{position:fixed;z-index:50;display:flex;align-items:center;gap:2px;padding:5px;background:var(--surface, #ffffff);border:1px solid var(--border, #e3e6ea);border-radius:12px;box-shadow:0 8px 28px #0000002e;font:14px/1 Inter,system-ui,sans-serif;color:var(--ink, #0e1116);-webkit-user-select:none;user-select:none}.komu-text-bar .ctb-sep{width:1px;align-self:stretch;margin:3px;background:var(--border, #e3e6ea)}.komu-text-bar .ctb-btn,.komu-text-bar .ctb-text{display:inline-flex;align-items:center;justify-content:center;height:34px;min-width:34px;padding:0 9px;border:0;border-radius:8px;background:transparent;color:inherit;font:inherit;cursor:pointer}.komu-text-bar .ctb-btn:hover,.komu-text-bar .ctb-text:hover{background:var(--surface-2, #f1f3f5)}.komu-text-bar .ctb-marks{display:inline-flex;align-items:center;gap:2px}.komu-text-bar .ctb-marks-toggle{display:none}.komu-text-bar .ctb-marks-menu{display:inline-flex;align-items:center;gap:2px}.komu-text-bar.shape-mode .ctb-marks{position:relative}.komu-text-bar.shape-mode .ctb-marks-toggle{display:inline-flex}.komu-text-bar.shape-mode .ctb-marks-menu{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) scaleY(0);transform-origin:bottom center;flex-direction:row;gap:2px;padding:4px;background:var(--surface, #ffffff);border:1px solid var(--border, #e3e6ea);border-radius:10px;box-shadow:0 8px 28px #0000002e;opacity:0;pointer-events:none;transition:transform .15s var(--ease, ease),opacity .15s var(--ease, ease);z-index:2}.komu-text-bar.shape-mode .ctb-marks.open .ctb-marks-menu{transform:translate(-50%) scaleY(1);opacity:1;pointer-events:auto}.komu-text-bar .ctb-btn.on{background:color-mix(in srgb,var(--accent, #3b6ff6) 16%,transparent);color:var(--accent, #3b6ff6)}.komu-text-bar .ctb-btn svg{width:20px;height:20px}.komu-text-bar .ctb-text{gap:4px;padding:0 8px;white-space:nowrap}.komu-text-bar .ctb-caret{font-size:9px;opacity:.55}.komu-text-bar .ctb-b{font-weight:700}.komu-text-bar .ctb-i{font-style:italic;font-family:Georgia,serif}.komu-text-bar .ctb-u{text-decoration:underline}.komu-text-bar .ctb-strike{text-decoration:line-through}.komu-text-bar .ctb-color{flex-direction:column;gap:1px}.komu-text-bar .ctb-color .ctb-a{font-weight:600;line-height:1}.komu-text-bar .ctb-underbar{width:18px;height:3px;border-radius:2px;background:#0e1116}.komu-text-bar .ctb-hl-box{width:18px;height:15px;border-radius:3px;background:#ffec99;border:1px solid rgba(0,0,0,.12)}.komu-text-bar .ctb-shape-only{display:none}.komu-text-bar.shape-mode .ctb-shape-only{display:inline-flex}.komu-text-bar .ctb-shape-kind,.komu-text-bar .ctb-fill,.komu-text-bar .ctb-border,.komu-text-bar .ctb-align{gap:3px}.komu-text-bar .ctb-shape-ico,.komu-text-bar .ctb-border-ico,.komu-text-bar .ctb-align-ico{display:inline-flex}.komu-text-bar .ctb-shape-ico svg,.komu-text-bar .ctb-align-ico svg{width:20px;height:20px}.komu-text-bar .ctb-border-ico svg{width:17px;height:17px}.komu-text-bar .ctb-border-ico.is-none{opacity:.4}.komu-text-bar .ctb-fill-dot{width:18px;height:18px;border-radius:50%;background:#fff;border:1.5px solid rgba(0,0,0,.22)}.komu-text-bar .ctb-fill-dot.is-none{background:linear-gradient(135deg,transparent 43%,#e03131 43%,#e03131 57%,transparent 57%),#fff}.ctb-shape-pop,.ctb-align-pop{flex-direction:row;gap:2px;padding:5px}.ctb-shape-opt,.ctb-align-opt{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:0;border-radius:8px;background:transparent;color:var(--ink, #0e1116);cursor:pointer}.ctb-shape-opt svg,.ctb-align-opt svg{width:22px;height:22px}.ctb-shape-opt:hover,.ctb-align-opt:hover{background:var(--surface-2, #f1f3f5)}.ctb-shape-opt.on,.ctb-align-opt.on{background:color-mix(in srgb,var(--accent, #3b6ff6) 16%,transparent);color:var(--accent, #3b6ff6)}.ctb-pop.ctb-border-pop{flex-direction:column;gap:10px;padding:12px}.ctb-border-styles{display:flex;gap:6px}.ctb-border-style{display:inline-flex;align-items:center;justify-content:center;flex:1;min-width:40px;height:30px;border:0;border-radius:7px;background:transparent;color:var(--ink, #0e1116);cursor:pointer}.ctb-border-style svg{width:22px;height:22px}.ctb-border-style:hover{background:var(--surface-2, #f1f3f5)}.ctb-border-style.on{background:color-mix(in srgb,var(--accent, #3b6ff6) 16%,transparent);color:var(--accent, #3b6ff6)}.ctb-border-pop .swatches{display:grid;grid-template-columns:repeat(4,26px);justify-content:center;column-gap:14px;row-gap:12px}.ctb-border-pop .sw{width:26px;height:26px;border-radius:50%}.ctb-border-pop .sw.on{box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--accent)}.ctb-pop{position:fixed;z-index:51;display:flex;flex-direction:column;padding:4px;background:var(--surface, #ffffff);border:1px solid var(--border, #e3e6ea);border-radius:8px;box-shadow:0 8px 28px #0000002e;max-height:280px;overflow:auto}.ctb-pop.ctb-pop-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}.ctb-pop-item{display:flex;align-items:center;justify-content:flex-start;gap:4px;min-width:150px;height:32px;padding:0 10px;border:0;border-radius:6px;background:transparent;color:var(--ink, #0e1116);font:14px Inter,system-ui,sans-serif;cursor:pointer}.ctb-pop.ctb-pop-grid .ctb-pop-item{min-width:0;width:32px;padding:0;justify-content:center}.ctb-pop-item:hover{background:var(--surface-2, #f1f3f5)}.ctb-check{flex:none;width:16px;text-align:center;color:var(--accent, #3b6ff6)}.ctb-pop-size{min-width:168px}.ctb-size-input{margin-top:4px;width:100%;height:32px;padding:0 10px;border:1.5px solid var(--accent, #3b6ff6);border-radius:6px;background:var(--surface, #ffffff);color:var(--ink, #0e1116);font:14px Inter,system-ui,sans-serif}.ctb-link-pop{flex-direction:row;align-items:center;gap:6px;padding:6px;overflow:visible}::highlight(komu-link-target){background:color-mix(in srgb,var(--accent, #3b6ff6) 30%,transparent)}.ctb-link-pop:after{content:"";position:absolute;left:50%;bottom:-7px;margin-left:-7px;border:7px solid transparent;border-top-color:var(--surface, #ffffff);filter:drop-shadow(0 1px 0 var(--border, #e3e6ea))}.ctb-link-input{width:300px;height:34px;padding:0 12px;border:1.5px solid var(--accent, #3b6ff6);border-radius:8px;background:var(--surface, #ffffff);color:var(--ink, #0e1116);font:14px Inter,system-ui,sans-serif;outline:none}.ctb-link-sep{flex:none;width:1px;align-self:stretch;margin:2px 0;background:var(--border, #e3e6ea)}.ctb-link-unlink{flex:none;display:grid;place-items:center;width:34px;height:34px;border:none;border-radius:8px;background:transparent;color:var(--muted, #586172);cursor:pointer}.ctb-link-unlink:hover{background:var(--surface-2, #f1f3f5);color:var(--ink, #0e1116)}.ctb-link-unlink svg{width:18px;height:18px}.ctb-link-card{position:fixed;z-index:52;display:flex;align-items:center;gap:8px;padding:6px 8px;max-width:360px;background:var(--surface, #ffffff);border:1px solid var(--border, #e3e6ea);border-radius:8px;box-shadow:0 8px 28px #0000002e}.ctb-link-card-url{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted, #6b7280);font:13px Inter,system-ui,sans-serif}.ctb-link-card-sep{width:1px;align-self:stretch;background:var(--border, #e3e6ea)}.ctb-link-card-btn{height:26px;padding:0 9px;display:inline-flex;align-items:center;border:none;border-radius:6px;background:transparent;color:var(--accent, #2563eb);font:13px Inter,system-ui,sans-serif;text-decoration:none;cursor:pointer}.ctb-link-card-btn:hover{background:var(--surface-2, #f1f3f5)}.ctb-color-pop{padding:10px}.ctb-color-pop .swatches{display:grid;grid-template-columns:repeat(5,26px);justify-content:center;column-gap:12px;row-gap:12px}.ctb-color-pop .sw{width:26px;height:26px;border-radius:50%}.ctb-color-pop .sw.on{box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--accent)}.sw-none{background:linear-gradient(135deg,transparent 44%,#e03131 44%,#e03131 56%,transparent 56%),var(--surface, #ffffff)}@media(max-width:640px){.dock{justify-content:space-evenly;gap:0}.tool{width:50px;height:50px;border-radius:13px}.tool .ico{width:24px;height:24px}.tool[data-group=insert],.tool[data-tool=hand]{display:none}.tool[data-tool=insert]{display:grid}}
