@import url(https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap);:root{--font-sans:'Montserrat',system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;--font-mono:var(--font-sans);--ui-font:var(--font-sans);--fz-hero:12px;--fz-display:12px;--fz-h1:12px;--fz-h2:12px;--fz-h3:12px;--fz-xl:12px;--fz-lg:12px;--fz-md:12px;--fz-sm:12px;--fz-xs:12px;--fz-tag:12px;--fz-micro:12px;--fw-medium:500;--fw-semibold:600;--fw-bold:700;--fw-heavy:800;--fw-black:900;--fw-ultra:950;--ls-display:-0.04em;--ls-tight:-0.02em;--ls-eyebrow:0.12em;--ls-uppercase:0.06em;--lh-tight:1.1;--lh-body:1.6;--gray-0:#f8f8f8;--gray-1:#f3f4f6;--gray-2:#e5e7eb;--gray-3:#d1d5db;--gray-4:#9ca3af;--gray-5:#6b7280;--gray-6:#4b5563;--gray-7:#374151;--gray-8:#1f2937;--gray-9:#34322d;--brand-0:#f2f2f1;--brand-1:#e5e5e3;--brand-2:#d8d8d5;--brand-8:#34322d;--brand-9:#2a2824;--blue-0:#e7f5ff;--blue-5:#339af0;--blue-9:#1864ab;--green-5:#51cf66;--green-7:#2f9e44;--orange-5:#ff922b;--red-0:#fff5f5;--red-1:#ffe3e3;--red-6:#fa5252;--red-7:#e03131;--red-8:#c92a2a;--fg-primary:var(--gray-9);--fg-secondary:var(--gray-7);--fg-tertiary:var(--gray-5);--fg-muted:var(--gray-4);--fg-on-dark:#ffffff;--bg-app:#ffffff;--bg-soft:var(--gray-0);--bg-subtle:var(--gray-1);--bg-inverse:var(--gray-9);--border-default:var(--gray-2);--border-subtle:var(--gray-1);--border-strong:var(--gray-3);--radius-xs:8px;--radius-sm:8px;--radius-md:8px;--radius-lg:8px;--radius-xl:8px;--radius-pill:9999px;--shadow-xs:0 1px 2px rgba(0, 0, 0, 0.05);--shadow-sm:0 1px 3px rgba(0, 0, 0, 0.08),0 1px 2px rgba(0, 0, 0, 0.05);--shadow-md:0 4px 6px -1px rgba(0, 0, 0, 0.08),0 2px 4px -1px rgba(0, 0, 0, 0.05);--shadow-bento-hover:0 20px 40px rgba(0, 0, 0, 0.05);--shadow-cta:0 20px 40px rgba(0, 0, 0, 0.1);--sp-xs:8px;--sp-sm:12px;--sp-md:16px;--sp-lg:24px;--sp-xl:32px;--sp-2xl:48px;--sp-3xl:60px;--ease-out:cubic-bezier(0.165, 0.84, 0.44, 1);--ease-default:ease;--dur-fast:0.15s;--dur-base:0.3s;--color-primary:var(--gray-9);--color-primary-darker:var(--brand-9);--color-primary-darkest:var(--brand-9);--color-primary-light:var(--gray-9);--color-primary-light-darker:var(--brand-9);--color-primary-hover:var(--gray-9);--color-brand-active:var(--fg-on-dark);--color-gray-10:var(--gray-0);--color-gray-20:var(--gray-1);--color-gray-30:var(--gray-2);--color-gray-40:var(--gray-3);--color-gray-50:var(--gray-4);--color-gray-60:var(--gray-5);--color-gray-70:var(--gray-6);--color-gray-80:var(--gray-7);--color-gray-85:var(--gray-8);--color-gray-90:var(--gray-9);--color-gray-100:var(--gray-9);--default-bg-color:var(--bg-app);--island-bg-color:var(--bg-app);--color-on-surface:var(--fg-primary);--text-primary-color:var(--fg-primary);--color-surface-high:var(--gray-1);--color-surface-mid:var(--gray-0);--color-surface-low:var(--gray-1);--color-surface-lowest:var(--bg-app);--default-border-color:var(--border-default);--focus-highlight-color:var(--gray-9);--button-hover-bg:var(--gray-1);--default-button-size:2rem;--default-icon-size:1.125rem;--lg-button-size:2.25rem;--lg-icon-size:1.25rem;--border-radius-md:8px;--border-radius-lg:8px;--bg:var(--bg-app);--panel:var(--bg-app);--text:var(--fg-primary);--muted:var(--fg-tertiary);--border:var(--border-default);--shadow:var(--shadow-xs);--radius:8px;--radius-sm:8px;--radius-xs:8px;--pad:12px;--gap:8px;--brand:var(--gray-9);--accent:var(--gray-9)}*{box-sizing:border-box}body,html{height:100%;margin:0;padding:0}body{background:var(--bg-app);color:var(--fg-primary);font-family:var(--font-sans);font-size:var(--fz-sm);font-weight:var(--fw-medium);line-height:var(--lh-body);overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:not(.ti):not([class*=ti-]):not([class*=icon-font]){font-family:var(--font-sans)}button,code,input,kbd,pre,samp,select,textarea,tt{font-family:var(--font-sans)}:not(.ti):not([class*=ti-]):not([class*=icon-font]){font-size:12px}button,code,h1,h2,h3,h4,h5,h6,input,kbd,label,pre,samp,select,small,strong,textarea,tt{font-size:12px}a{color:var(--fg-primary);font-weight:var(--fw-bold);text-decoration:none;transition:color var(--dur-fast) var(--ease-default)}a:hover{color:var(--brand-9);text-decoration:underline}a:visited{color:var(--fg-primary)}a:focus-visible{outline:2px solid var(--gray-9);outline-offset:2px;border-radius:2px}::selection{background:var(--gray-9);color:var(--fg-on-dark)}::-moz-selection{background:var(--gray-9);color:var(--fg-on-dark)}*{scrollbar-width:thin;scrollbar-color:var(--gray-3) transparent}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-3);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--gray-4)}button{font-family:inherit;font-weight:var(--fw-bold);color:inherit;border:0;background:0 0;cursor:pointer}button:focus{outline:2px solid var(--gray-9);outline-offset:2px}.btn .ti{font-size:var(--default-icon-size);line-height:1;margin:0 4px;vertical-align:-2px}.btn.icon>.ti{font-size:var(--default-icon-size)}.menu-button .ti{font-size:var(--lg-icon-size)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hide{display:none!important}.app{position:relative;min-height:100dvh}main{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden;background:var(--bg-app)}canvas{cursor:crosshair}.brand-island{position:fixed;left:14px;top:14px;z-index:30;display:inline-flex;align-items:stretch;height:36px;background:var(--bg-app);border:1px solid var(--border-default);border-radius:8px;box-shadow:var(--shadow-xs)}.brand-island>.menu-button{border-top-left-radius:7px;border-bottom-left-radius:7px}.brand-island>:last-child{border-top-right-radius:7px;border-bottom-right-radius:7px}.menu-button{position:static;width:36px;height:100%;border-radius:0;background:var(--bg-app);color:var(--fg-primary);border:0;display:inline-flex;align-items:center;justify-content:center;box-shadow:none;flex-shrink:0;transition:background-color var(--dur-fast) var(--ease-default),color var(--dur-fast) var(--ease-default),transform var(--dur-fast) var(--ease-default)}.menu-button:hover{background:var(--gray-9);color:var(--fg-on-dark);border-color:transparent;box-shadow:none}.menu-button[aria-expanded=true]{background:var(--gray-9);color:var(--fg-on-dark);border-color:transparent;box-shadow:none}.menu-button:active{transform:scale(.94)}.menu-button>.ti{margin:0;font-size:var(--lg-icon-size);line-height:1;vertical-align:0;display:inline-block}.toolbar{position:fixed;top:14px;left:50%;transform:translateX(-50%);display:flex;gap:2px;align-items:center;padding:6px;background:var(--bg-app);border:1px solid var(--border-default);border-radius:8px;box-shadow:var(--shadow-xs);z-index:20;max-width:90vw;overflow-x:auto;scrollbar-width:none}.toolbar::-webkit-scrollbar{display:none}.toolbar .btn{width:var(--default-button-size);height:var(--default-button-size);border-radius:8px;padding:0;color:var(--fg-secondary);background:0 0;font-weight:var(--fw-bold);position:relative;display:flex;align-items:center;justify-content:center;transition:background-color var(--dur-fast) var(--ease-default),color var(--dur-fast) var(--ease-default),transform var(--dur-fast) var(--ease-default)}.toolbar .btn .ti{font-size:var(--default-icon-size);line-height:1}.toolbar .btn:hover{background:var(--gray-1);color:var(--fg-primary)}.toolbar .btn:active{transform:scale(.98)}.toolbar .btn.active,.toolbar .btn.selected,.toolbar .btn[aria-pressed=true]{background:var(--gray-9);color:var(--fg-on-dark);box-shadow:none}.toolbar-sep{width:1px;height:20px;background:var(--border-default);margin:0 4px;flex-shrink:0}.file-name-container{display:none}.project-meta{display:flex;flex-direction:column;justify-content:center;gap:1px;padding:0 18px 0 14px;border-left:1px solid var(--border-subtle);text-align:left;cursor:pointer;max-width:280px;height:100%;min-width:0}.project-meta-eyebrow{font-size:9px!important;font-weight:var(--fw-heavy);text-transform:uppercase;letter-spacing:var(--ls-eyebrow);color:var(--fg-muted);line-height:1}.project-meta-name{font-size:13px;font-weight:var(--fw-bold);color:var(--fg-primary);letter-spacing:0;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;transition:color var(--dur-fast) var(--ease-default)}.project-meta:has(form) .project-meta-eyebrow{display:none}.project-meta:hover .project-meta-name{color:var(--brand-9)}.project-meta:empty,.project-meta:has(.project-meta-name:empty){display:none}.project-meta form{margin:0;padding:0;display:flex;align-items:center;width:100%;height:100%}.project-meta form input:not([type]),.project-meta form input[type=text]{width:170px!important;height:24px!important;margin:0!important;padding:0 6px!important;font-family:var(--font-sans);font-size:13px;font-weight:var(--fw-bold);letter-spacing:0;color:var(--fg-primary);text-align:left!important;background:var(--bg-app);border:1px solid var(--gray-9)!important;border-radius:4px!important;outline:0!important;box-shadow:none!important}.project-meta form button{display:none!important}.actions{position:fixed;top:14px;right:14px;display:flex;align-items:center;gap:8px;z-index:20}.actions>#div-user-header:not(:has(>:not(.hide):not(#div-user-information))){display:none}.actions-island{display:flex;align-items:stretch;gap:0;background:var(--bg-app);border:1px solid var(--border-default);border-radius:8px;height:36px;box-shadow:var(--shadow-xs);overflow:hidden}.actions-island>.btn.ghost{box-shadow:none;border:0;border-radius:0;padding:0 14px;height:100%;font-size:var(--fz-sm);font-weight:var(--fw-bold);color:var(--fg-primary);display:inline-flex;align-items:center;gap:8px}.actions-island>.btn.ghost:hover{box-shadow:none;background:var(--gray-1)}.actions-island>.btn.ghost .ti{margin:0;font-size:16px}.btn.primary{background:var(--gray-9);color:var(--fg-on-dark);border-radius:8px;padding:0 16px;height:36px;display:inline-flex;align-items:center;gap:8px;font-weight:var(--fw-bold);font-size:var(--fz-sm);box-shadow:var(--shadow-xs);transition:background-color var(--dur-fast) var(--ease-default),transform var(--dur-fast) var(--ease-default)}.btn.primary .ti{margin:0;font-size:16px}.btn.primary:hover{background:var(--brand-9)}.btn.primary:active{transform:scale(.98)}.btn.ghost{border:1px solid var(--border-default);background:var(--bg-app);color:var(--fg-secondary);border-radius:8px;height:36px;padding:0 16px;display:inline-flex;align-items:center;gap:8px;font-weight:var(--fw-bold);font-size:var(--fz-sm);box-shadow:var(--shadow-xs);transition:background-color var(--dur-fast) var(--ease-default),color var(--dur-fast) var(--ease-default),transform var(--dur-fast) var(--ease-default)}.btn.ghost .ti{margin:0;font-size:16px}.btn.ghost:hover{background:var(--gray-1);color:var(--fg-primary)}.btn.ghost:active{transform:scale(.98)}.btn.link{color:var(--fg-secondary);font-weight:var(--fw-bold)}.btn.link:hover{color:var(--fg-primary)}.bottom-controls{position:fixed;left:14px;bottom:14px;display:flex;align-items:center;gap:8px;z-index:20}.control-group{display:flex;align-items:center;background:var(--bg-app);border:1px solid var(--border-default);border-radius:8px;box-shadow:var(--shadow-xs);padding:2px}.ctrl-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:0 0;border-radius:6px;cursor:pointer;color:var(--fg-secondary);font-weight:var(--fw-bold);transition:background-color var(--dur-fast) var(--ease-default),color var(--dur-fast) var(--ease-default),transform var(--dur-fast) var(--ease-default)}.ctrl-btn:hover{background:var(--gray-1);color:var(--fg-primary)}.ctrl-btn:active{background:var(--gray-2);transform:scale(.98)}.ctrl-btn .ti{font-size:15px}.ctrl-btn:disabled{opacity:.4;cursor:not-allowed}.ctrl-btn:disabled:hover{background:0 0;color:var(--fg-secondary)}.zoom-controls .zoom-value{min-width:42px;text-align:center;font-family:var(--font-mono);font-size:11px;font-weight:var(--fw-bold);color:var(--fg-primary);padding:0 4px;letter-spacing:0}.history-controls{gap:0}.history-controls .ctrl-btn{color:var(--fg-secondary)}.history-controls .ctrl-btn:not(:disabled):hover{color:var(--fg-primary)}.history-controls .ctrl-btn:first-child{border-radius:6px 2px 2px 6px}.history-controls .ctrl-btn:last-child{border-radius:2px 6px 6px 2px}.history-controls .ctrl-btn:disabled{opacity:.3}.helpers{position:fixed;right:14px;bottom:14px;display:flex;align-items:center;gap:8px;color:var(--fg-tertiary);z-index:20}.helpers .help-card{display:grid;gap:6px;justify-items:center}.helpers .help-card .btn.icon{width:32px;height:32px;border-radius:8px;background:var(--bg-app);border:1px solid var(--border-default);color:var(--fg-secondary);box-shadow:var(--shadow-xs);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color var(--dur-fast) var(--ease-default),border-color var(--dur-fast) var(--ease-default),color var(--dur-fast) var(--ease-default),transform var(--dur-fast) var(--ease-default),box-shadow var(--dur-fast) var(--ease-default)}.helpers .help-card .btn.icon .ti{font-size:15px;margin:0;line-height:1}.helpers .help-card .btn.icon:hover{background:var(--gray-9);color:var(--fg-on-dark);border-color:var(--gray-9);box-shadow:var(--shadow-cta)}.helpers .help-card .btn.icon:active{transform:scale(.96)}.helpers .caption{font-size:var(--fz-xs);font-weight:var(--fw-medium);color:var(--fg-tertiary)}.helpers .sep{opacity:.4}html[data-panning],html[data-panning] *{cursor:grab!important}html[data-panning-active],html[data-panning-active] *{cursor:grabbing!important}.toolbar-hint{position:fixed;left:50%;transform:translateX(-50%);top:42px;color:var(--fg-tertiary);font-size:var(--fz-xs);font-weight:var(--fw-medium);z-index:18}.menu{position:fixed;left:14px;top:62px;z-index:40;width:300px;max-height:calc(100dvh - 90px);background:var(--bg-app);border:1px solid var(--border-default);border-radius:8px;box-shadow:var(--shadow-md);opacity:0;transform:translateY(-4px) scale(.99);transform-origin:top left;transition:opacity var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out)}.menu.open{opacity:1;transform:none}.menu[hidden]{display:none}.menu-scroll{overflow:auto;max-height:inherit;padding:8px;display:grid;gap:4px}.menu-group{display:grid;gap:2px;padding:6px 0}.menu-group+.menu-group{border-top:1px solid var(--border-subtle);margin-top:2px;padding-top:12px}.menu-group-label{font-size:var(--fz-micro);font-weight:var(--fw-heavy);text-transform:uppercase;letter-spacing:var(--ls-eyebrow);color:var(--fg-muted);padding:4px 10px 6px}.menu-list{list-style:none;margin:0;padding:0;display:grid;gap:1px}.menu-list+hr{margin:6px 10px;border:none;border-top:1px solid var(--border-subtle)}.menu-item{width:100%;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 10px;border-radius:6px;background:0 0;font-size:var(--fz-sm);font-weight:var(--fw-medium);color:var(--fg-secondary);text-align:left;cursor:pointer;transition:background-color var(--dur-fast) var(--ease-default),color var(--dur-fast) var(--ease-default)}.menu-item>span:first-child{display:inline-flex;align-items:center;gap:12px;min-width:0}.menu-item>span:first-child>i.ti{font-size:18px;line-height:1;width:18px;text-align:center;color:var(--fg-muted);flex-shrink:0;margin:0;transition:color var(--dur-fast) var(--ease-default)}.menu-item-label{font-size:var(--fz-sm);font-weight:var(--fw-medium);color:var(--fg-primary);letter-spacing:0}.menu-item:hover{background:var(--gray-1)}.menu-item:hover>span:first-child>i.ti{color:var(--fg-primary)}.menu-item:focus-visible{background:var(--gray-1);outline:2px solid var(--gray-9);outline-offset:-2px}.menu-item:active{background:var(--gray-2)}.menu-item kbd{font-family:var(--font-sans);font-size:var(--fz-micro);font-weight:var(--fw-bold);color:var(--fg-tertiary);letter-spacing:0;background:0 0;padding:0;border:0;flex-shrink:0}.menu-item:hover kbd{color:var(--fg-secondary)}.menu-item.emph .menu-item-label{font-weight:var(--fw-black)}.menu-section{padding:10px 12px 14px}.menu-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 0}.menu-label{font-size:var(--fz-xs);font-weight:var(--fw-heavy);text-transform:uppercase;letter-spacing:var(--ls-eyebrow);color:var(--fg-muted)}.theme-pills{display:flex;gap:8px}.pill{width:36px;height:28px;border-radius:8px;border:1px solid var(--border-default);background:var(--bg-app);cursor:pointer;transition:border-color var(--dur-fast) var(--ease-default)}.pill:hover{border-color:var(--gray-9)}.select{border:1px solid var(--border-default);border-radius:8px;padding:8px 10px;background:var(--bg-app);font-family:var(--font-sans);font-size:var(--fz-sm);font-weight:var(--fw-medium);color:var(--fg-primary);min-width:150px}.swatches{display:grid;grid-template-columns:repeat(8,1fr);gap:8px}.swatch{width:28px;height:28px;border-radius:8px;border:1px solid var(--border-default);background:var(--sw);cursor:pointer;transition:transform var(--dur-fast) var(--ease-default)}.swatch:hover{transform:scale(1.08)}.icon.square{border-radius:8px}.linklike{background:0 0;border:none;color:var(--fg-primary);font-weight:var(--fw-bold)}.linklike:hover{color:var(--brand-9)}.caption{font-size:var(--fz-xs);font-weight:var(--fw-medium);color:var(--fg-tertiary)}.eyebrow{font-size:var(--fz-tag);font-weight:var(--fw-heavy);text-transform:uppercase;letter-spacing:var(--ls-eyebrow);color:var(--fg-muted)}#mouse-cursor{position:absolute;top:-100px;left:-100px;width:20px;height:20px;z-index:15;pointer-events:none}div.mouse-information{position:absolute;font-family:var(--font-mono);font-size:var(--fz-xs);font-weight:var(--fw-medium);top:-100px;left:-100px;z-index:15;background:var(--bg-app);border:1px solid var(--border-default);border-radius:8px;padding:8px 12px;box-shadow:var(--shadow-xs);color:var(--fg-primary);pointer-events:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}div.mouse-information ul{list-style:none;margin:0;padding:0}div.mouse-information ul li{float:none;height:auto;overflow:hidden;line-height:1.6}div.mouse-information ul li label{display:inline-block;color:var(--fg-muted);font-weight:var(--fw-heavy);text-transform:uppercase;letter-spacing:var(--ls-eyebrow);font-size:var(--fz-micro);font-family:var(--font-sans);margin-right:6px}div.mouse-information ul li .normal{font-weight:var(--fw-bold);color:var(--fg-primary)}div.mouse-information ul li .atention{color:var(--red-7);font-weight:var(--fw-bold)}#axis{position:fixed;bottom:20px;left:20px;z-index:15;width:48px;height:48px;background:url(../icon/axis.svg) center/contain no-repeat;pointer-events:none}.bottom-controls{left:auto!important;right:58px!important}#menu-tool-option{position:absolute;z-index:35;top:-2000px;left:-2000px;background:var(--bg-app);backdrop-filter:none;-webkit-backdrop-filter:none;border:1px solid var(--border-default);border-radius:8px;box-shadow:var(--shadow-md);padding:4px;list-style:none;margin:0;min-width:220px;opacity:0;transform:scale(.98) translateY(-4px);transform-origin:top left;animation:ctx-menu-appear var(--dur-fast) var(--ease-out) forwards}@keyframes ctx-menu-appear{to{opacity:1;transform:scale(1) translateY(0)}}#menu-tool-option .ctx-menu-label{font-size:var(--fz-tag);font-weight:var(--fw-heavy);text-transform:uppercase;letter-spacing:var(--ls-eyebrow);color:var(--fg-muted);padding:10px 12px 6px;pointer-events:none}#menu-tool-option .ctx-menu-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 12px;border-radius:8px;cursor:pointer;font-family:var(--font-sans);font-size:var(--fz-sm);font-weight:var(--fw-bold);color:var(--fg-primary);transition:background-color var(--dur-fast) var(--ease-default),color var(--dur-fast) var(--ease-default),transform var(--dur-fast) var(--ease-default)}#menu-tool-option .ctx-menu-item:hover{background:var(--gray-1);color:var(--fg-primary)}#menu-tool-option .ctx-menu-item:active{background:var(--gray-2);transform:scale(.98)}#menu-tool-option .ctx-menu-content{display:flex;align-items:center;gap:10px;white-space:nowrap}#menu-tool-option .ctx-menu-item i{font-size:18px;width:22px;text-align:center;color:var(--fg-tertiary);transition:color var(--dur-fast) var(--ease-default)}#menu-tool-option .ctx-menu-item:hover i{color:var(--fg-primary)}#menu-tool-option .ctx-menu-item kbd{font-family:var(--font-mono);font-size:var(--fz-micro);font-weight:var(--fw-medium);color:var(--fg-tertiary);background:var(--gray-1);padding:3px 7px;border-radius:6px;border:1px solid var(--border-subtle)}#menu-tool-option .ctx-menu-separator{height:1px;background:var(--border-subtle);margin:4px 8px;pointer-events:none}#menu-tool-option .ctx-menu-primary{color:var(--fg-primary);font-weight:var(--fw-black)}#menu-tool-option .ctx-menu-primary i{color:var(--fg-primary)}#menu-tool-option .ctx-menu-primary:hover{background:var(--gray-9);color:var(--fg-on-dark)}#menu-tool-option .ctx-menu-primary:hover i{color:var(--fg-on-dark)}#menu-tool-option .ctx-menu-primary:hover kbd{color:var(--fg-on-dark);background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.15)}#menu-tool-option .ctx-menu-danger{color:var(--red-8)}#menu-tool-option .ctx-menu-danger i{color:var(--red-6)}#menu-tool-option .ctx-menu-danger:hover{background:var(--red-0);color:var(--red-8)}#menu-tool-option .ctx-menu-danger:hover i{color:var(--red-7)}#menu-tool-option .ctx-menu-danger kbd{color:var(--red-7);background:var(--red-0);border-color:var(--red-1)}dialog{border:1px solid var(--border-default);border-radius:8px;box-shadow:var(--shadow-cta);padding:0;max-width:90vw;max-height:90vh;overflow:hidden;color:var(--fg-primary);font-family:var(--font-sans)}dialog::backdrop{background:rgba(52,50,45,.6);backdrop-filter:blur(2px)}dialog .header{display:flex;align-items:center;gap:10px;padding:16px 20px;background:var(--bg-app);border-bottom:1px solid var(--border-default)}dialog .header strong{flex:1;font-size:var(--fz-md);font-weight:var(--fw-black);letter-spacing:var(--ls-tight);color:var(--fg-primary)}dialog .body{padding:20px;overflow-y:auto;max-height:60vh;font-size:var(--fz-sm);font-weight:var(--fw-medium);color:var(--fg-secondary)}dialog .footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px;background:var(--bg-soft);border-top:1px solid var(--border-default)}dialog input[type=text],dialog textarea{width:100%;padding:10px 12px;border:1px solid var(--border-default);border-radius:8px;font-family:var(--font-sans);font-size:var(--fz-sm);font-weight:var(--fw-medium);color:var(--fg-primary);background:var(--bg-app);margin-bottom:12px;transition:border-color var(--dur-fast) var(--ease-default)}dialog input[type=text]:focus,dialog textarea:focus{outline:0;border-color:var(--gray-9)}.button{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:8px;border:1px solid var(--border-default);background:var(--bg-app);color:var(--fg-primary);font-family:var(--font-sans);font-weight:var(--fw-bold);font-size:var(--fz-sm);line-height:1;cursor:pointer;transition:background-color var(--dur-fast) var(--ease-default),border-color var(--dur-fast) var(--ease-default),color var(--dur-fast) var(--ease-default),transform var(--dur-fast) var(--ease-default)}.button:hover{background:var(--gray-1)}.button:active{transform:scale(.98)}.button.success{background:var(--gray-9);border-color:var(--gray-9);color:var(--fg-on-dark)}.button.success:hover{background:var(--brand-9);border-color:var(--brand-9)}.button.info{background:var(--bg-soft);border-color:var(--border-default);color:var(--fg-primary)}.button.info:hover{background:var(--gray-1)}#list-history{list-style:none;margin:0;padding:0;max-height:300px;overflow-y:auto}#list-history li{display:flex;align-items:center;gap:10px;padding:12px;border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background-color var(--dur-fast) var(--ease-default)}#list-history li:hover{background:var(--gray-1)}#list-history li:last-child{border-bottom:none}#list-history li i{font-size:16px;color:var(--fg-tertiary)}#list-history li span{flex:1;font-size:var(--fz-sm);font-weight:var(--fw-medium);color:var(--fg-primary)}#input-revision-notes{min-height:80px;padding:12px;border:1px solid var(--border-default);border-radius:8px;font-family:var(--font-sans);font-size:var(--fz-sm);font-weight:var(--fw-medium);margin-bottom:16px}#input-revision-notes:focus{outline:0;border-color:var(--gray-9)}.div-revision-todo{max-height:200px;overflow-y:auto;border:1px solid var(--border-default);border-radius:8px;margin-top:8px}#list-revision-todo{list-style:none;margin:0;padding:0}#list-revision-todo li{display:flex;align-items:center;gap:10px;padding:12px;border-bottom:1px solid var(--border-subtle)}#list-revision-todo li:last-child{border-bottom:none}#list-revision-todo li input[type=checkbox]{width:16px;height:16px;margin:0;accent-color:var(--gray-9)}#list-revision-todo li span{flex:1;font-size:var(--fz-sm);font-weight:var(--fw-medium);color:var(--fg-primary)}#list-revision-todo li small{color:var(--fg-tertiary);font-size:var(--fz-xs);font-weight:var(--fw-medium)}#list-revision-todo li .icon-remove{cursor:pointer;opacity:.5;color:var(--fg-tertiary);transition:opacity var(--dur-fast) var(--ease-default),color var(--dur-fast) var(--ease-default)}#list-revision-todo li .icon-remove:hover{opacity:1;color:var(--red-6)}#dialog-start .body{padding:0}.start-list{display:flex;margin:0;padding:0;list-style:none}.start-list li{flex:1;padding:24px;border-right:1px solid var(--border-default);transition:background-color var(--dur-fast) var(--ease-default)}.start-list li:hover{background:var(--bg-soft)}.start-list li:last-child{border-right:none}.start-list h3{margin:0 0 12px 0;font-size:var(--fz-md);font-weight:var(--fw-black);letter-spacing:var(--ls-tight);color:var(--fg-primary)}.start-list p{margin:0;font-size:var(--fz-sm);font-weight:var(--fw-medium);color:var(--fg-secondary);line-height:var(--lh-body)}.start-list .start-image{width:100%;height:140px;background-size:contain;background-repeat:no-repeat;background-position:center;filter:grayscale(1)}#div-user-information{position:absolute;right:14px;top:50px;width:280px;background:var(--bg-app);border:1px solid var(--border-default);border-radius:8px;box-shadow:var(--shadow-md);z-index:50;padding:8px}#div-user-information table{width:100%;padding:12px}#div-user-information table td{vertical-align:middle;text-align:center;padding:4px;font-size:var(--fz-sm);font-weight:var(--fw-medium);color:var(--fg-primary)}#div-user-information img{border-radius:8px}#div-user-information .footer-user{background:var(--bg-soft);border-top:1px solid var(--border-subtle);padding:10px 16px;border-radius:0 0 8px 8px}#div-user-information a{color:var(--fg-primary);font-weight:var(--fw-bold);text-decoration:none}#div-user-information a:hover{text-decoration:underline}#input-file-manager{display:none}.text-center{text-align:center}.text-justify{text-align:justify}.right{float:right}.left{float:left}@media (max-width:1200px){.toolbar{padding:4px;gap:1px;max-width:85vw}.toolbar .btn{width:28px;height:28px}.toolbar .btn .ti{font-size:14px}}@media (max-width:768px){.toolbar{padding:4px;gap:1px;max-width:80vw;flex-wrap:wrap;justify-content:center}.toolbar .btn{width:24px;height:24px}.toolbar .btn .ti{font-size:12px}.toolbar-sep{width:1px;height:16px;margin:0 2px}.actions{right:8px;gap:6px}.menu{width:92vw}.start-list{flex-direction:column}.start-list li{border-right:none;border-bottom:1px solid var(--border-default)}.start-list li:last-child{border-bottom:none}}button.button{font-family:var(--font-sans);font-weight:var(--fw-bold);font-size:var(--fz-sm);display:inline-block;padding:8px 14px;margin:0 3px;color:var(--fg-primary);text-align:left;background:var(--bg-app);background-image:none;border:1px solid var(--border-default);border-radius:8px;outline:0;cursor:pointer!important;transition:background-color var(--dur-fast) var(--ease-default),border-color var(--dur-fast) var(--ease-default),color var(--dur-fast) var(--ease-default),transform var(--dur-fast) var(--ease-default)}button.button *{cursor:pointer!important}button.button>i{margin:0}button.button:hover{background-image:none;background-color:var(--gray-1);border-color:var(--border-strong);color:var(--fg-primary)}button.button:active{background-image:none;background-color:var(--gray-2);transform:scale(.98)}button.button.disabled{opacity:.4!important;color:var(--fg-tertiary)!important;background-image:none!important;background-color:var(--bg-app);border-color:var(--border-default)!important;cursor:default!important}button.button.selected{color:var(--fg-on-dark);background-image:none;background-color:var(--gray-9);border-color:var(--gray-9);cursor:default!important;opacity:1!important}button.button.success{color:var(--fg-on-dark);background-color:var(--gray-9);background-image:none;border-color:var(--gray-9)}button.button.success:active,button.button.success:hover{background-color:var(--brand-9);background-image:none;border-color:var(--brand-9)}button.button.info{color:var(--fg-primary);background-color:var(--bg-soft);background-image:none;border-color:var(--border-default)}button.button.info:active,button.button.info:hover{background-color:var(--gray-1);background-image:none;border-color:var(--border-strong)}button.button.danger{color:var(--fg-on-dark);background-color:var(--red-6);background-image:none;border-color:var(--red-6)}button.button.danger:active,button.button.danger:hover{background-color:var(--red-7);background-image:none;border-color:var(--red-7)}dialog.dialog{border-radius:8px;border:1px solid var(--border-default);padding:0}dialog.dialog>.header{background-color:var(--bg-app);background-image:none;border-bottom:1px solid var(--border-default);padding:14px 16px;font-weight:var(--fw-black);letter-spacing:var(--ls-tight)}dialog.dialog>.header>i{cursor:inherit;margin-left:0;margin-right:0;opacity:1;color:var(--fg-primary)}dialog.dialog .body{height:auto;overflow:hidden;padding:16px;cursor:default;font-size:var(--fz-sm);font-weight:var(--fw-medium);color:var(--fg-secondary)}dialog.dialog>.footer{background-color:var(--bg-soft);border-top:1px solid var(--border-default);height:auto;overflow:hidden;padding:12px 16px;cursor:default}dialog.help-dialog{width:640px;max-width:92vw;max-height:88vh;overflow:hidden}dialog.help-dialog[open]{display:flex;flex-direction:column}dialog.help-dialog .header{position:relative;padding:20px 20px 16px;border-bottom:1px solid var(--border-default);display:flex;align-items:center;gap:12px}dialog.help-dialog .header>i.ti{width:32px;height:32px;background:var(--gray-9);color:var(--fg-on-dark);border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;margin:0}dialog.help-dialog .header strong{font-size:var(--fz-h3);font-weight:var(--fw-black);letter-spacing:var(--ls-tight);color:var(--fg-primary);line-height:1.1}dialog.help-dialog .dialog-close{position:absolute;right:12px;top:12px;width:32px;height:32px;border-radius:8px;border:0;background:0 0;color:var(--fg-tertiary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color var(--dur-fast) var(--ease-default),color var(--dur-fast) var(--ease-default)}dialog.help-dialog .dialog-close .ti{font-size:18px;margin:0}dialog.help-dialog .dialog-close:hover{background:var(--gray-1);color:var(--fg-primary)}dialog.help-dialog .header{flex:0 0 auto}dialog.help-dialog .body{padding:24px;background:var(--bg-app);display:grid;gap:28px;flex:1 1 auto;min-height:0;max-height:none;overflow-y:auto;overscroll-behavior:contain}dialog.help-dialog .footer{background:var(--bg-soft);flex:0 0 auto;border-top:1px solid var(--border-default)}dialog.help-dialog .body{scrollbar-gutter:stable}dialog.help-dialog .body::-webkit-scrollbar{width:10px}dialog.help-dialog .body::-webkit-scrollbar-track{background:var(--bg-soft);border-radius:8px;margin:8px 0}dialog.help-dialog .body::-webkit-scrollbar-thumb{background:var(--gray-3);border-radius:8px;border:2px solid var(--bg-soft)}dialog.help-dialog .body::-webkit-scrollbar-thumb:hover{background:var(--gray-4)}.help-section{display:grid;gap:12px}.help-eyebrow{font-size:var(--fz-tag);font-weight:var(--fw-heavy);text-transform:uppercase;letter-spacing:var(--ls-eyebrow);color:var(--fg-muted)}.help-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:4px 24px}.help-list li{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 10px;border-radius:8px;transition:background-color var(--dur-fast) var(--ease-default)}.help-list li:hover{background:var(--gray-1)}.help-list li>span{display:inline-flex;align-items:center;gap:10px;font-size:var(--fz-sm);font-weight:var(--fw-medium);color:var(--fg-secondary);min-width:0}.help-list li>span>i.ti{font-size:16px;color:var(--fg-muted);width:18px;text-align:center;flex-shrink:0;margin:0}.help-list li:hover>span{color:var(--fg-primary)}.help-list li:hover>span>i.ti{color:var(--fg-secondary)}.help-list li kbd{font-family:var(--font-sans);font-size:var(--fz-micro);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:var(--ls-uppercase);color:var(--fg-secondary);background:var(--bg-app);border:1px solid var(--border-default);border-bottom-width:2px;border-radius:6px;padding:4px 8px;line-height:1;min-width:24px;text-align:center;flex-shrink:0}.help-list li kbd.kbd-combo{text-transform:none;letter-spacing:0;font-weight:var(--fw-semibold);font-size:var(--fz-xs);padding:4px 10px}.help-tips-list{list-style:none;margin:0;padding:0;display:grid;gap:10px}.help-tips-list li{position:relative;padding:12px 14px 12px 38px;background:var(--bg-soft);border:1px solid var(--border-subtle);border-radius:8px;font-size:var(--fz-sm);font-weight:var(--fw-medium);line-height:var(--lh-body);color:var(--fg-secondary)}.help-tips-list li::before{content:'';position:absolute;left:16px;top:18px;width:6px;height:6px;border-radius:50%;background:var(--gray-9)}.help-tips-list li strong{color:var(--fg-primary);font-weight:var(--fw-bold)}.help-tips-list li kbd{display:inline-flex;align-items:center;font-family:var(--font-sans);font-size:var(--fz-micro);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:var(--ls-uppercase);color:var(--fg-secondary);background:var(--bg-app);border:1px solid var(--border-default);border-bottom-width:2px;border-radius:6px;padding:2px 6px;line-height:1;margin:0 2px}@media (max-width:720px){.help-list{grid-template-columns:1fr}dialog.help-dialog .body{padding:18px;gap:22px}}input[type=email],input[type=password],input[type=text],textarea{padding:8px 12px;border:1px solid var(--border-default);border-radius:8px;font-family:var(--font-sans);font-size:var(--fz-sm);font-weight:var(--fw-medium);color:var(--fg-primary);background:var(--bg-app);outline:0;transition:border-color var(--dur-fast) var(--ease-default)}input[type=email]:focus,input[type=text]:focus,textarea:focus{border-color:var(--gray-9);box-shadow:none}p[contenteditable]{padding:10px 12px;border:1px solid var(--border-default);border-radius:8px;min-height:60px;outline:0;font-family:var(--font-sans);font-size:var(--fz-sm);font-weight:var(--fw-medium);color:var(--fg-primary);background:var(--bg-app);transition:border-color var(--dur-fast) var(--ease-default)}p[contenteditable]:focus{border-color:var(--gray-9);box-shadow:none}