@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400..800&family=Hanken+Grotesk:wght@400;500;600;700;800&display=swap";:root{--ink: oklch(.23 .014 28);--ink-soft: oklch(.4 .012 28);--muted: oklch(.56 .01 30);--faint: oklch(.7 .008 40);--line: oklch(.92 .005 40);--line-soft: oklch(.95 .004 45);--wash: oklch(.975 .006 55);--paper: oklch(.992 .004 70);--surface: #ffffff;--brand: oklch(.655 .195 12);--brand-strong: oklch(.585 .205 14);--brand-press: oklch(.52 .2 15);--brand-tint: oklch(.955 .035 14);--brand-tint-2: oklch(.92 .06 14);--brand-ink: oklch(.42 .16 16);--violet: oklch(.6 .17 295);--amber: oklch(.8 .135 72);--teal: oklch(.72 .1 195);--grass: oklch(.74 .13 145);--display: "Bricolage Grotesque", system-ui, sans-serif;--ui: "Hanken Grotesk", system-ui, -apple-system, sans-serif;--r-xs: 7px;--r-sm: 10px;--r-md: 14px;--r-lg: 20px;--r-xl: 28px;--r-pill: 999px;--sh-sm: 0 1px 2px rgba(40, 20, 18, .06), 0 1px 1px rgba(40, 20, 18, .04);--sh-md: 0 6px 16px -6px rgba(40, 20, 18, .14), 0 2px 5px -2px rgba(40, 20, 18, .08);--sh-lg: 0 18px 40px -14px rgba(40, 20, 18, .22), 0 4px 12px -6px rgba(40, 20, 18, .1);--sh-pop: 0 2px 6px rgba(40, 20, 18, .07), 0 14px 34px -10px rgba(40, 20, 18, .2);--ring: 0 0 0 4px var(--brand-tint-2);--canvas-bg: oklch(.948 .006 55);--canvas-dot: oklch(.88 .006 50);--ruler-bg: var(--surface);--ruler-tick: oklch(.82 .006 50);--ruler-text: var(--muted);--bg: var(--wash);--panel: var(--surface);--panel-border: var(--line);--accent: var(--brand);--accent-soft: var(--brand-tint);font-family:var(--ui);color-scheme:light}:root[data-theme=dark]{--ink: oklch(.96 .008 70);--ink-soft: oklch(.82 .01 60);--muted: oklch(.66 .012 55);--faint: oklch(.52 .012 50);--line: oklch(.33 .01 45);--line-soft: oklch(.28 .008 45);--wash: oklch(.205 .01 45);--paper: oklch(.175 .01 45);--surface: oklch(.245 .012 47);--brand: oklch(.685 .195 14);--brand-strong: oklch(.735 .18 16);--brand-press: oklch(.78 .16 18);--brand-tint: oklch(.32 .075 16);--brand-tint-2: oklch(.4 .1 16);--brand-ink: oklch(.82 .12 18);--violet: oklch(.7 .15 295);--amber: oklch(.82 .135 72);--teal: oklch(.76 .1 195);--grass: oklch(.78 .13 145);--sh-sm: 0 1px 2px rgba(0, 0, 0, .45), 0 1px 1px rgba(0, 0, 0, .3);--sh-md: 0 6px 16px -6px rgba(0, 0, 0, .55), 0 2px 5px -2px rgba(0, 0, 0, .4);--sh-lg: 0 18px 40px -14px rgba(0, 0, 0, .65), 0 4px 12px -6px rgba(0, 0, 0, .45);--sh-pop: 0 2px 6px rgba(0, 0, 0, .4), 0 14px 34px -10px rgba(0, 0, 0, .62);--canvas-bg: oklch(.155 .01 45);--canvas-dot: oklch(.27 .01 45);--ruler-tick: oklch(.45 .01 45);color-scheme:dark}.theme-toggle .sun{display:none}.theme-toggle .moon{display:block}:root[data-theme=dark] .theme-toggle .sun{display:block}:root[data-theme=dark] .theme-toggle .moon{display:none}.appbar,.rail,.context,.panel-col,.page-tabs,.palette,.canvas-view,.brand-home,.doc-name,.ab-btn,.tool,.ctx-btn{transition:background-color .25s ease,color .2s ease,box-shadow .25s ease,border-color .25s ease}*{box-sizing:border-box}html,body,#app{margin:0;height:100%}body{background:var(--bg);color:var(--ink);user-select:none;-webkit-user-select:none}input,textarea,select,[contenteditable]:not([contenteditable=false]){user-select:text;-webkit-user-select:text}.shell{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;grid-template-columns:auto auto 1fr var(--panel-w, 300px);grid-template-rows:54px auto 1fr auto auto;grid-template-areas:"appbar  appbar  appbar  appbar" "rail    gfx     context context" "rail    gfx     canvas  panel" "rail    gfx     pages   pages" "palette palette palette palette";background:var(--surface)}.page-tabs{grid-area:pages;display:flex;align-items:center;gap:10px;padding:6px 12px;border-top:1px solid var(--line);background:var(--surface);overflow:hidden;transition:padding .18s ease}.page-tabs-toggle{flex:none;display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;border-radius:6px;background:transparent;color:var(--ink-soft);cursor:pointer;transition:background .12s,color .12s,transform .18s ease}.page-tabs-toggle:hover{background:var(--wash);color:var(--ink)}.page-tabs-toggle:after{content:"";display:block;width:6px;height:6px;border-right:2px solid currentColor;border-top:2px solid currentColor;transform:rotate(-45deg) translate(-1px,1px);transition:transform .18s ease}.page-tabs:not(.collapsed) .page-tabs-toggle:after{transform:rotate(135deg) translate(-1px,1px)}.page-tabs.collapsed{padding:0 8px;gap:0;height:32px}.page-tabs.collapsed .page-tabs-list{gap:0}.page-tabs.collapsed .page-tab{flex-direction:row;max-width:none;width:auto;height:32px;padding:0 14px;gap:0;border:none;border-top:2px solid transparent;border-radius:0;background:transparent;color:var(--ink-soft);font-size:12px;font-weight:500;box-shadow:none}.page-tabs.collapsed .page-tab:hover{background:var(--wash);border-color:transparent}.page-tabs.collapsed .page-tab.active{background:var(--brand-tint);border-top-color:var(--brand);color:var(--brand-ink);font-weight:600;box-shadow:none}.page-tabs.collapsed .page-thumb,.page-tabs.collapsed .page-tab-close,.page-tabs.collapsed .page-act--expand-only{display:none}.page-tabs.collapsed .page-tabs-actions{gap:2px}.page-tabs.collapsed .page-act{width:24px;height:24px;border-radius:6px;border:none;background:transparent}.page-tabs-list{display:flex;align-items:center;gap:6px;overflow-x:auto;flex:1;min-width:0}.page-tab{position:relative;display:flex;flex-direction:column;align-items:center;gap:5px;flex:none;max-width:132px;padding:6px;border:1px solid var(--line);border-radius:10px;background:var(--surface);color:var(--ink-soft);font-size:11.5px;font-weight:600;cursor:pointer;transition:border-color .12s,background .12s}.page-tab:hover{border-color:var(--brand)}.page-tab.active{background:var(--brand-tint);border-color:var(--brand);color:var(--brand-ink);box-shadow:var(--sh-sm)}.page-thumb{display:block;border-radius:5px;background:#fff;box-shadow:inset 0 0 0 1px var(--line);object-fit:cover}.page-tab-label{max-width:116px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.page-tab-close{position:absolute;top:3px;right:3px;width:16px;height:16px;display:none;place-items:center;border:none;border-radius:4px;background:#ffffffeb;color:var(--ink-soft);font-size:10px;cursor:pointer;box-shadow:var(--sh-sm)}.page-tab:hover .page-tab-close{display:grid}.page-tab-close:hover{background:#fff;color:#dc2626}.page-tabs-actions{display:flex;gap:4px;flex:none}.page-act{width:30px;height:30px;display:grid;place-items:center;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--ink-soft);cursor:pointer}.page-act:hover{border-color:var(--brand);color:var(--brand)}.page-act svg{width:16px;height:16px}.xy-row{display:flex;gap:8px}.xy-field{display:flex;align-items:center;gap:6px;flex:1;min-width:0;padding:0 8px;background:var(--wash);border-radius:9px}.xy-tag{font-size:11px;font-weight:700;color:var(--faint)}.xy-field .number{flex:1;min-width:0;height:32px;border:none;background:transparent;padding:0}.bg-preview{display:block;width:100%;max-height:120px;object-fit:contain;border-radius:8px;background:var(--wash);box-shadow:inset 0 0 0 1px var(--line)}.panel-btn{display:block;width:fit-content;height:28px;padding:0 12px;margin:8px 0 12px auto;border:1px solid var(--line);border-radius:8px;background:var(--wash);color:var(--ink);font:inherit;font-size:12px;font-weight:600;cursor:pointer}.panel-btn:hover{border-color:var(--brand);color:var(--brand)}.hint-sub{margin:4px 0 0;font-size:12px}.toast-host{position:fixed;z-index:200;top:16px;right:16px;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{pointer-events:auto;min-width:200px;max-width:360px;padding:11px 14px;border-radius:10px;background:var(--ink);color:#fff;font-size:13px;font-weight:600;box-shadow:var(--sh-pop);cursor:pointer;opacity:0;transform:translateY(-8px);transition:opacity .18s,transform .18s}.toast.show{opacity:1;transform:none}.toast-success{background:var(--grass)}.toast-error{background:#dc2626}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:210;display:grid;place-items:center;padding:16px;background:#140c0a57;opacity:0;transition:opacity .16s}.dialog-overlay.show{opacity:1}.dialog{width:min(420px,100%);padding:20px;border-radius:16px;background:var(--surface);box-shadow:var(--sh-lg);transform:translateY(6px) scale(.98);transition:transform .16s}.dialog-overlay.show .dialog{transform:none}.sc-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:220;display:grid;place-items:center;padding:16px;background:#140c0a5c;opacity:0;transition:opacity .18s}.sc-overlay.show{opacity:1}.sc-dialog{width:min(680px,100%);max-height:min(88vh,780px);overflow-y:auto;background:var(--surface);border-radius:16px;box-shadow:var(--sh-lg);padding:20px 24px 24px;transform:translateY(8px) scale(.98);transition:transform .18s}.sc-overlay.show .sc-dialog{transform:none}.sc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.sc-heading{font-size:15px;font-weight:700;margin:0;color:var(--ink)}.sc-close{width:28px;height:28px;border:none;border-radius:6px;background:transparent;font-size:20px;line-height:1;cursor:pointer;color:var(--ink-soft);display:grid;place-items:center}.sc-close:hover{background:var(--hover);color:var(--ink)}.sc-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px 28px}@media(max-width:520px){.sc-grid{grid-template-columns:1fr}}.sc-group-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);margin-bottom:8px}.sc-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:3px 0}.sc-keys{display:flex;align-items:center;gap:3px;flex-shrink:0}kbd{display:inline-block;padding:2px 6px;font-family:inherit;font-size:11.5px;font-weight:600;line-height:1.5;color:var(--ink);background:var(--bg);border:1px solid var(--line);border-radius:5px;box-shadow:0 1px 0 var(--line);white-space:nowrap}.sc-plus{font-size:11px;color:var(--ink-soft);padding:0 1px}.sc-label{font-size:13px;color:var(--ink);text-align:right}.icon-dialog{width:min(680px,100%);display:flex;flex-direction:column;max-height:min(80vh,720px)}.icon-sources{display:flex;gap:6px;margin:14px 0 10px}.icon-dialog .icon-cat{margin:10px 0 0}.cat-ico{display:grid;place-items:center;width:100%;height:100%;color:var(--ink)}.cat-ico svg{width:20px;height:20px}.icon-search{height:40px;margin:10px 0 8px;padding:0 14px;border:1px solid var(--panel-border)}.icon-count{margin:0 0 10px}.icon-grid{flex:1 1 auto;min-height:160px;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:6px;padding:4px;border:1px solid var(--panel-border);border-radius:10px}.icon-tile{aspect-ratio:1;display:grid;place-items:center;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--ink);cursor:pointer;transition:background .1s,border-color .1s}.icon-tile:hover{background:var(--accent-soft);border-color:var(--accent)}.icon-tile svg{width:48px;height:48px}.icon-cats{display:flex;flex-wrap:wrap;gap:5px;margin:10px 0 4px;max-height:128px;overflow-y:auto;padding:2px}.icon-cat-btn{display:inline-flex;align-items:center;gap:6px;padding:4px 9px 4px 6px;border:1px solid var(--panel-border);border-radius:999px;background:var(--surface);color:var(--ink-soft);font:inherit;font-size:12px;cursor:pointer;transition:background .1s,border-color .1s,color .1s}.icon-cat-btn:hover{color:var(--ink);border-color:var(--accent)}.icon-cat-btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--ink)}.icon-cat-ico{display:grid;place-items:center;width:18px;height:18px;color:var(--ink);flex:none}.icon-cat-ico svg{width:16px;height:16px}.icon-cat-n{font-size:10.5px;color:var(--faint);font-variant-numeric:tabular-nums}.icon-cat-btn.active .icon-cat-n{color:var(--ink-soft)}.icon-credit{position:relative;display:inline-flex}.icon-credit-btn{display:inline-flex;align-items:center;gap:5px;padding:3px 9px 3px 7px;border:1px solid var(--panel-border);border-radius:999px;background:transparent;color:var(--faint);font:inherit;font-size:11.5px;cursor:help;transition:color .1s,border-color .1s}.icon-credit-btn:hover{color:var(--ink-soft);border-color:var(--accent)}.icon-credit-ico{display:grid;place-items:center}.icon-credit-ico svg{width:14px;height:14px}.icon-credit-pop{position:absolute;bottom:calc(100% + 6px);left:0;z-index:10;display:none;flex-direction:column;gap:6px;min-width:210px;padding:10px 12px;border:1px solid var(--panel-border);border-radius:10px;background:var(--surface);box-shadow:var(--sh-pop);font-size:11.5px;color:var(--ink-soft)}.icon-credit:hover .icon-credit-pop,.icon-credit:focus-within .icon-credit-pop{display:flex}.icon-credit-row{white-space:nowrap}.icon-credit-row a{color:var(--accent)}.dialog-title{font-size:15px;font-weight:700;margin:0 0 14px;color:var(--ink)}.dialog-label:first-child{margin-top:0}.dialog-label{border-bottom:1px solid var(--line);display:block;font-size:12px;font-weight:600;color:var(--ink-soft);margin-bottom:6px;margin-top:12px;padding-bottom:6px}.dialog-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.btn-primary{padding:7px 18px;border-radius:8px;border:none;background:var(--accent);color:#fff;font-size:13px;font-weight:600;cursor:pointer}.btn-primary:hover{filter:brightness(1.1)}.btn-secondary{padding:7px 14px;border-radius:8px;border:1px solid var(--line);background:transparent;color:var(--ink);font-size:13px;font-weight:500;cursor:pointer}.btn-secondary:hover{background:var(--hover)}.contrast-field{align-items:center}.contrast-result{display:flex;align-items:center;gap:6px}.contrast-ratio{font-size:12px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}.contrast-badge{font-size:10.5px;font-weight:700;padding:2px 7px;border-radius:4px;line-height:1.5}.cc-aaa{background:#d1fae5;color:#065f46}.cc-pass{background:#dcfce7;color:#166534}.cc-large{background:#fef9c3;color:#854d0e}.cc-fail{background:#fee2e2;color:#991b1b}[data-theme=dark] .cc-aaa{background:#064e3b;color:#6ee7b7}[data-theme=dark] .cc-pass{background:#14532d;color:#86efac}[data-theme=dark] .cc-large{background:#713f12;color:#fde68a}[data-theme=dark] .cc-fail{background:#7f1d1d;color:#fca5a5}.uploads-topbar{margin-bottom:10px}.uploads-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:8px;max-height:420px;overflow-y:auto;padding:2px}.upload-tile{position:relative;aspect-ratio:1;border-radius:7px;overflow:hidden;cursor:pointer;background:var(--surface-2, #f3f4f6);border:1.5px solid var(--border, #e5e7eb);transition:border-color .12s}.upload-tile:hover{border-color:var(--accent, #6366f1)}.upload-tile img{width:100%;height:100%;object-fit:cover;display:block}.upload-tile:hover img{opacity:.82}.upload-del{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:#0000008c;color:#fff;border:none;font-size:15px;line-height:22px;cursor:pointer;display:none;align-items:center;justify-content:center;padding:0}.upload-tile:hover .upload-del{display:flex}.upload-del:hover{background:#dc2626d9}.upload-tile.deleting{opacity:.45;pointer-events:none}.dialog-footer{margin-top:10px;font-size:11.5px;color:var(--faint)}.dialog-footer a{color:var(--accent)}.px-dialog{width:min(700px,100%);display:flex;flex-direction:column;max-height:min(82vh,760px)}.px-body{display:flex;flex-direction:column;min-height:0;flex:1 1 auto}.icon-dialog .icon-search,.px-dialog .px-search,.px-dialog .px-key{height:40px;padding:8px 14px;border:1px solid var(--panel-border)}.px-search{margin:14px 0 8px}.px-status{margin:0 0 10px}.px-key-row{display:flex;gap:8px;margin-top:12px}.px-key-row .px-key{flex:1 1 auto}.px-grid{flex:1 1 auto;min-height:200px;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;padding:4px}.px-thumb{position:relative;aspect-ratio:1;padding:0;border:1px solid var(--panel-border);border-radius:8px;background:var(--wash);overflow:hidden;cursor:pointer;transition:border-color .1s,box-shadow .1s}.px-thumb:hover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.px-thumb-img{width:100%;height:100%;object-fit:cover;display:block}.px-thumb.loading{opacity:.5;pointer-events:none}.bg-dialog{width:min(720px,100%);display:flex;flex-direction:column;max-height:min(82vh,760px)}.bg-controls{display:flex;align-items:flex-end;gap:12px;margin:14px 0 4px;flex-wrap:wrap}.bg-field{display:flex;flex-direction:column;gap:5px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--faint)}.bg-field .select,.bg-field .preview-select{min-width:200px}.preview-select{display:flex;align-items:center;gap:9px;width:100%;height:42px;padding:0 10px;border:1px solid var(--line);border-radius:10px;background:var(--surface);color:var(--ink);font:inherit;font-size:13.5px;cursor:pointer;transition:border-color .12s,box-shadow .12s}.preview-select:hover{border-color:var(--accent)}.preview-select:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.preview-select:disabled{opacity:.5;cursor:default}.preview-thumb{flex:0 0 auto;width:40px;height:26px;border-radius:5px;overflow:hidden;box-shadow:inset 0 0 0 1px #00000014;display:block}.preview-img,.preview-grad{display:block;width:100%;height:100%;object-fit:cover}.preview-swatches{display:flex;width:100%;height:100%}.preview-sw{flex:1 1 0}.preview-label{flex:1 1 auto;min-width:0;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.preview-caret{flex:0 0 auto;display:grid;place-items:center;color:var(--faint)}.preview-caret svg{width:16px;height:16px}.preview-pop{position:fixed;z-index:230;max-height:340px;overflow-y:auto;padding:5px;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--sh-lg)}.preview-opt{display:flex;align-items:center;gap:9px;width:100%;padding:6px 8px;border:0;border-radius:8px;background:transparent;color:var(--ink);font:inherit;font-size:13.5px;cursor:pointer}.preview-opt:hover{background:var(--accent-soft)}.preview-opt.active{background:var(--accent-soft);color:var(--accent)}.px-shuffle{margin-left:auto;display:inline-flex;align-items:center;gap:8px}.px-shuffle svg{width:15px;height:15px}.bg-grid{flex:1 1 auto;min-height:200px;margin-top:12px;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-auto-rows:max-content;gap:10px;padding:4px}.bg-tile{padding:0;border:1px solid var(--panel-border);border-radius:8px;overflow:hidden;cursor:pointer;transition:border-color .1s,box-shadow .1s}.bg-tile:hover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.bg-tile-img{display:block;width:100%;height:auto}.bg-tile.loading{opacity:.5;pointer-events:none}.tmpl-dialog{width:min(880px,100%)}.tmpl-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-auto-rows:max-content}.tmpl-tile{background:var(--surface, #fff)}.tmpl-tile-svg{display:block;width:100%}.tmpl-tile-svg svg{display:block;width:100%;height:auto}.tmpl-prev{display:block;width:100%;height:100%;overflow:hidden;border-radius:3px}.tmpl-prev svg{display:block;width:100%;height:100%}.tmpl-modes{margin:4px 0 10px}.deck-grid{grid-template-columns:repeat(auto-fill,minmax(380px,1fr))}.curated-grid{display:block}.curated-section+.curated-section{margin-top:22px}.curated-head{display:flex;align-items:baseline;gap:8px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft, #475569);padding:6px 2px 9px;position:sticky;top:-4px;background:var(--surface, #fff);z-index:2}.curated-count{font-weight:600;color:var(--faint);opacity:.75}.curated-section-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-auto-rows:max-content;gap:10px}.deck-tile{display:flex;flex-direction:column;gap:9px;padding:10px;text-align:left;background:var(--surface, #fff);border:1px solid var(--panel-border);border-radius:10px;cursor:pointer;transition:border-color .1s,box-shadow .1s}.deck-tile:hover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.deck-strip{display:flex;gap:4px;width:100%}.deck-frame{flex:1 1 0;min-width:0;border:1px solid var(--panel-border);border-radius:4px;overflow:hidden}.deck-frame svg{display:block;width:100%;height:100%}.deck-meta{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.deck-meta b{color:var(--ink);font-size:13px}.deck-count{color:var(--muted, #64748b);font-size:11px;font-weight:600;white-space:nowrap}.tmpl-font-prev{display:flex;align-items:baseline;justify-content:center;gap:8px;width:100%;height:100%;color:var(--ink)}.tmpl-font-h{font-size:22px;font-weight:700;line-height:1}.tmpl-font-b{font-size:16px;color:var(--muted, #64748b);line-height:1}.ill-dialog{width:min(720px,100%);display:flex;flex-direction:column;max-height:min(82vh,760px)}.ill-controls{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:14px 0 8px;flex-wrap:wrap}.ill-accent{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--faint)}input.ill-search{height:38px;padding:8px 14px;border:1px solid var(--panel-border);margin-bottom:10px}.ill-grid{flex:1 1 auto;min-height:220px;overflow-y:auto;display:block;gap:10px;padding:4px}.ill-tile{aspect-ratio:4 / 3;padding:8px;border:1px solid var(--panel-border);border-radius:10px;background:var(--surface);cursor:pointer;transition:border-color .1s,box-shadow .1s}.ill-tile:hover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.ill-tile-img{width:100%;height:100%;object-fit:contain;display:block}.ai-photos-grid .ill-tile{aspect-ratio:16 / 9;padding:0;overflow:hidden}.ai-photo-thumb{object-fit:cover!important}.ai-photos-tags{display:flex;flex-wrap:wrap;gap:6px;padding:8px 2px 2px}.ai-tag-chip{font-size:12px;padding:3px 10px;border-radius:999px;border:1px solid var(--line);background:var(--surface);color:var(--faint);cursor:pointer;transition:background .12s,color .12s,border-color .12s}.ai-tag-chip:hover{color:var(--ink);border-color:var(--accent)}.ai-tag-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}.ai-photos-pager{display:flex;align-items:center;justify-content:space-between;padding:8px 4px 0;gap:8px}.ai-pager-btn{min-width:72px}.ai-pager-info{font-size:12px;color:var(--faint);font-variant-numeric:tabular-nums}.dialog-title{font-family:var(--display);font-size:16px;font-weight:700;color:var(--ink)}.dialog-msg{margin:8px 0 0;font-size:13.5px;line-height:1.5;color:var(--ink-soft)}.dialog-input{width:100%;height:38px;margin-top:14px;padding:0 11px;border:1px solid var(--line);border-radius:9px;background:var(--wash);font:inherit;font-size:14px;color:var(--ink)}.dialog-input:focus{outline:none;background:var(--surface);box-shadow:var(--ring)}.dialog-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}.dialog-btn{height:38px;padding:0 16px;border:1px solid transparent;border-radius:10px;font:inherit;font-size:14px;font-weight:600;cursor:pointer}.dialog-btn.ghost{background:var(--wash);color:var(--ink);border-color:var(--line)}.dialog-btn.ghost:hover{background:var(--line-soft)}.dialog-btn.primary{background:var(--brand);color:#fff}.dialog-btn.primary:hover{background:var(--brand-strong)}.dialog-btn.danger{background:#dc2626;color:#fff}.dialog-btn.danger:hover{background:#b91c1c}.export-formats{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:16px}.export-formats .dialog-btn{padding:0 8px}.export-opts{display:flex;flex-direction:column;gap:10px;margin-top:14px;min-height:8px}.export-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.export-label{font-size:13.5px;font-weight:600;color:var(--ink-soft)}.export-row .select{height:30px}.export-row .range{flex:1;max-width:160px}.export-section-label{margin:16px 0 6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft)}.export-dest-seg{grid-template-columns:repeat(3,1fr);margin-top:0}.export-dest{display:flex;flex-direction:column;gap:10px;margin-top:12px}.export-dest:empty{margin-top:0}.export-note{margin:0;font-size:12.5px;color:var(--ink-soft);line-height:1.4}.export-connect{align-self:flex-start}.export-dest .input,.export-dest .select{height:32px}.toggle{position:relative;width:40px;height:22px;flex:none;border:none;border-radius:999px;background:var(--line);cursor:pointer;transition:background .14s}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:var(--sh-sm);transition:transform .14s}.toggle.on{background:var(--brand)}.toggle.on:after{transform:translate(18px)}.shell.panel-collapsed{grid-template-columns:auto auto 1fr 0}.shell.panel-collapsed .panel-col{display:none}.spacer{flex:1 1 auto}.appbar{grid-area:appbar;display:flex;align-items:center;gap:6px;padding:0 14px;background:var(--surface);border-bottom:1px solid var(--line);position:relative}.brand{display:flex;align-items:center;gap:6px;padding-right:2px}.brand-glyph{width:30px;height:30px;flex:none;display:block;filter:drop-shadow(0 1px 1.5px rgba(40,20,18,.22))}.brand-glyph svg{width:100%;height:100%;display:block}.brand-home{display:inline-flex;align-items:center;gap:9px;padding:5px 8px 5px 6px;border-radius:10px;text-decoration:none;color:var(--ink);transition:background .12s}.brand-home:hover{background:var(--wash)}.brand-name{font-family:var(--display);font-size:16px;font-weight:700;letter-spacing:-.02em;color:var(--ink)}.doc-name{width:200px;max-width:30vw;height:32px;padding:0 10px;border:1px solid transparent;border-radius:8px;background:transparent;font-family:var(--ui);font-size:14px;font-weight:600;color:var(--ink);text-overflow:ellipsis;transition:background .12s,border-color .12s,box-shadow .12s}.doc-name::placeholder{color:var(--faint);font-weight:500}.doc-name:hover{background:var(--wash)}.doc-name:focus{outline:none;background:var(--surface);border-color:var(--brand);box-shadow:var(--ring);text-overflow:clip}.vsep{width:1px;height:26px;background:var(--line);margin:0 6px;flex:none}.appbar-group{display:flex;align-items:center;gap:2px}.ab-btn{height:38px;min-width:38px;padding:0 11px;border:none;border-radius:8px;background:transparent;display:inline-flex;align-items:center;justify-content:center;gap:8px;font:inherit;font-weight:600;font-size:14px;color:var(--ink-soft);cursor:pointer}.ab-btn:hover{background:var(--wash);color:var(--ink)}.ab-btn svg{width:19px;height:19px}.shell.anim-mode .rail,.shell.anim-mode .context,.shell.anim-mode .palette-bar{display:none}.shell.anim-mode .panel.properties,.shell.anim-mode .panel.layers{display:none!important}.shell.anim-mode .ab-btn--edit{display:none}.shell.anim-mode{--panel-w: 280px}.ab-mode-toggle{position:absolute;left:50%;transform:translate(-50%);display:flex;align-items:center;background:var(--surface-raised, var(--surface));border:1px solid var(--line);border-radius:8px;padding:3px;pointer-events:auto}.ab-mode-btn{padding:4px 16px;border-radius:5px;border:none;background:transparent;font-size:13px;font-weight:600;cursor:pointer;color:var(--ink-soft);transition:color .12s,background .12s;line-height:1.4}.ab-mode-btn.active{background:var(--bg);color:var(--ink);box-shadow:0 1px 3px #0000001f}.ab-share{height:38px;padding:0 16px;border:none;border-radius:10px;background:var(--brand);color:#fff;display:inline-flex;align-items:center;gap:8px;font:inherit;font-weight:600;font-size:14px;cursor:pointer;box-shadow:var(--sh-sm)}.ab-share svg{width:18px;height:18px}.ab-share:hover{background:var(--brand-strong);box-shadow:var(--sh-md)}.ab-present{height:38px;padding:0 14px;margin-right:6px;border:1px solid var(--line);border-radius:10px;background:var(--surface);color:var(--ink);display:inline-flex;align-items:center;gap:7px;font:inherit;font-weight:600;font-size:14px;cursor:pointer}.ab-present svg{width:15px;height:15px}.ab-present:hover{background:var(--wash)}.pp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0b0b0d}.pp-stage{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;cursor:pointer}.pp-slide{max-width:100%;max-height:100%;object-fit:contain;box-shadow:0 12px 60px #0000008c}.pp-bar{position:absolute;bottom:22px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:4px;padding:6px 8px;border-radius:999px;background:#16161bd1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;box-shadow:0 10px 34px #00000073;transition:opacity .25s}.pp-btn{width:38px;height:38px;border:none;background:transparent;color:#fff;border-radius:999px;cursor:pointer;display:grid;place-items:center}.pp-btn:hover{background:#ffffff24}.pp-btn svg{width:20px;height:20px}.pp-counter{min-width:66px;text-align:center;font-size:13px;font-weight:600;font-variant-numeric:tabular-nums;opacity:.92}.pp-gap{width:1px;height:22px;background:#ffffff2e;margin:0 5px}.pp-overlay.pp-idle{cursor:none}.pp-overlay.pp-idle .pp-bar{opacity:0;pointer-events:none}.pp-stage{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;overflow:hidden;cursor:pointer}.pp-scene{grid-area:1 / 1;position:relative;width:min(100vw,calc(100vh * 16 / 9));height:min(100vh,56.25vw);max-width:100%;max-height:calc(100vh - 80px);box-shadow:0 12px 60px #0000008c;z-index:1;overflow:hidden}.pp-scene.pp-active{z-index:2}.pp-bg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:fill;display:block}.pp-anim-layer{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.pp-anim-obj{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0}[data-tx=fade] .pp-scene-out{animation:pp-tx-fade-out var(--pp-tx-dur, .5s) ease forwards}[data-tx=fade] .pp-scene-in{animation:pp-tx-fade-in var(--pp-tx-dur, .5s) ease forwards}[data-tx=slide-left] .pp-scene-out{animation:pp-tx-slide-out-left var(--pp-tx-dur, .5s) ease forwards}[data-tx=slide-left] .pp-scene-in{animation:pp-tx-slide-in-right var(--pp-tx-dur, .5s) ease forwards}[data-tx=slide-right] .pp-scene-out{animation:pp-tx-slide-out-right var(--pp-tx-dur, .5s) ease forwards}[data-tx=slide-right] .pp-scene-in{animation:pp-tx-slide-in-left var(--pp-tx-dur, .5s) ease forwards}[data-tx=slide-up] .pp-scene-out{animation:pp-tx-slide-out-up var(--pp-tx-dur, .5s) ease forwards}[data-tx=slide-up] .pp-scene-in{animation:pp-tx-slide-in-down var(--pp-tx-dur, .5s) ease forwards}[data-tx=slide-down] .pp-scene-out{animation:pp-tx-slide-out-down var(--pp-tx-dur, .5s) ease forwards}[data-tx=slide-down] .pp-scene-in{animation:pp-tx-slide-in-up var(--pp-tx-dur, .5s) ease forwards}[data-tx=zoom] .pp-scene-out{animation:pp-tx-zoom-out-fade var(--pp-tx-dur, .5s) ease forwards}[data-tx=zoom] .pp-scene-in{animation:pp-tx-zoom-in var(--pp-tx-dur, .5s) ease forwards}[data-tx=zoom-out] .pp-scene-out{animation:pp-tx-zoom-out-big var(--pp-tx-dur, .5s) ease forwards}[data-tx=zoom-out] .pp-scene-in{animation:pp-tx-fade-in var(--pp-tx-dur, .5s) ease forwards}@keyframes pp-tx-fade-out{to{opacity:0}}@keyframes pp-tx-fade-in{0%{opacity:0}to{opacity:1}}@keyframes pp-tx-slide-out-left{to{transform:translate(-105%)}}@keyframes pp-tx-slide-in-right{0%{transform:translate(105%)}to{transform:translate(0)}}@keyframes pp-tx-slide-out-right{to{transform:translate(105%)}}@keyframes pp-tx-slide-in-left{0%{transform:translate(-105%)}to{transform:translate(0)}}@keyframes pp-tx-slide-out-up{to{transform:translateY(-105%)}}@keyframes pp-tx-slide-in-down{0%{transform:translateY(105%)}to{transform:translateY(0)}}@keyframes pp-tx-slide-out-down{to{transform:translateY(105%)}}@keyframes pp-tx-slide-in-up{0%{transform:translateY(-105%)}to{transform:translateY(0)}}@keyframes pp-tx-zoom-out-fade{to{transform:scale(1.08);opacity:0}}@keyframes pp-tx-zoom-in{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}@keyframes pp-tx-zoom-out-big{to{transform:scale(.85);opacity:0}}.pp-anim-appear{opacity:1}.pp-anim-fade{animation:pp-kf-fade var(--pp-anim-dur, .5s) ease forwards}.pp-anim-fly-left{animation:pp-kf-fly-left var(--pp-anim-dur, .5s) cubic-bezier(.22,.68,0,1.2) forwards}.pp-anim-fly-right{animation:pp-kf-fly-right var(--pp-anim-dur, .5s) cubic-bezier(.22,.68,0,1.2) forwards}.pp-anim-fly-top{animation:pp-kf-fly-top var(--pp-anim-dur, .5s) cubic-bezier(.22,.68,0,1.2) forwards}.pp-anim-fly-bottom{animation:pp-kf-fly-bottom var(--pp-anim-dur, .5s) cubic-bezier(.22,.68,0,1.2) forwards}.pp-anim-zoom{animation:pp-kf-zoom var(--pp-anim-dur, .5s) cubic-bezier(.34,1.56,.64,1) forwards}.pp-anim-zoom-out{animation:pp-kf-zoom-out var(--pp-anim-dur, .5s) ease forwards}.pp-anim-bounce{animation:pp-kf-bounce var(--pp-anim-dur, .7s) cubic-bezier(.36,.07,.19,.97) forwards}.pp-anim-spin{animation:pp-kf-spin var(--pp-anim-dur, .6s) ease forwards}.pp-anim-float{animation:pp-kf-float var(--pp-anim-dur, .6s) ease forwards}@keyframes pp-kf-fade{0%{opacity:0}to{opacity:1}}@keyframes pp-kf-fly-left{0%{opacity:0;transform:translate(-60%)}to{opacity:1;transform:translate(0)}}@keyframes pp-kf-fly-right{0%{opacity:0;transform:translate(60%)}to{opacity:1;transform:translate(0)}}@keyframes pp-kf-fly-top{0%{opacity:0;transform:translateY(-60%)}to{opacity:1;transform:translateY(0)}}@keyframes pp-kf-fly-bottom{0%{opacity:0;transform:translateY(60%)}to{opacity:1;transform:translateY(0)}}@keyframes pp-kf-zoom{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@keyframes pp-kf-zoom-out{0%{opacity:0;transform:scale(1.4)}to{opacity:1;transform:scale(1)}}@keyframes pp-kf-bounce{0%{opacity:0;transform:scale(.3)}60%{opacity:1;transform:scale(1.1)}80%{transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pp-kf-spin{0%{opacity:0;transform:rotate(-180deg) scale(.5)}to{opacity:1;transform:rotate(0) scale(1)}}@keyframes pp-kf-float{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.ap-panel.panel-hidden{display:none}.ap-panel{display:flex;flex-direction:column;gap:0;padding:0 0 12px;overflow-y:auto;height:100%}.ap-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 6px;border-bottom:1px solid var(--line-soft)}.ap-header-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--faint)}.ap-section{padding:10px 12px 6px;border-bottom:1px solid var(--line-soft)}.ap-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);margin-bottom:8px}.ap-tx-grid{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}.ap-tx-btn{padding:4px 8px;border-radius:5px;border:1px solid var(--line-soft);background:var(--bg);color:var(--text);font-size:11px;cursor:pointer;transition:background .1s,border-color .1s}.ap-tx-btn:hover{background:var(--surface)}.ap-tx-btn.active{background:var(--accent, #6366f1);color:#fff;border-color:var(--accent, #6366f1)}.ap-label{font-size:11px;color:var(--faint);margin-right:6px}.ap-duration-row{display:flex;align-items:center;gap:6px;padding:2px 0 6px}.ap-slider{flex:1;accent-color:var(--accent, #6366f1)}.ap-readout{font-size:11px;font-variant-numeric:tabular-nums;color:var(--faint);min-width:38px;text-align:right}.ap-anim-list{display:flex;flex-direction:column;gap:3px;padding:2px 12px 6px}.ap-anim-row{display:flex;align-items:center;gap:5px;padding:5px 6px;border-radius:6px;cursor:pointer;font-size:12px;transition:background .1s}.ap-anim-row:hover{background:var(--surface)}.ap-anim-row.active{background:color-mix(in srgb,var(--accent, #6366f1) 12%,transparent)}.ap-order{display:grid;place-items:center;width:18px;height:18px;border-radius:50%;background:var(--accent, #6366f1);color:#fff;font-size:10px;font-weight:700;flex-shrink:0}.ap-anim-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ap-anim-tag{font-size:10px;padding:2px 5px;border-radius:4px;background:var(--surface);color:var(--faint);white-space:nowrap}.ap-anim-trigger{color:var(--accent, #6366f1)}.ap-icon-btn{width:22px;height:22px;border:none;background:transparent;color:var(--faint);border-radius:4px;cursor:pointer;display:grid;place-items:center;flex-shrink:0;opacity:0;transition:opacity .1s,color .1s}.ap-icon-btn svg{width:13px;height:13px}.ap-anim-row:hover .ap-icon-btn{opacity:1}.ap-icon-btn--danger:hover{color:#ef4444}.ap-empty{font-size:12px;color:var(--faint);text-align:center;padding:12px 0 4px;margin:0}.ap-add-section{padding:4px 12px 8px}.ap-add-btn{width:100%;padding:6px;border:1.5px dashed var(--line-soft);border-radius:6px;background:transparent;color:var(--accent, #6366f1);font-size:12px;font-weight:600;cursor:pointer;transition:background .1s}.ap-add-btn:hover{background:color-mix(in srgb,var(--accent, #6366f1) 8%,transparent)}.ap-picker{padding:10px 12px 8px;border-bottom:1px solid var(--line-soft);display:flex;flex-direction:column;gap:7px}.ap-picker-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);margin-top:2px}.ap-picker-back{align-self:flex-start;font-size:12px;color:var(--accent, #6366f1);background:transparent;border:none;cursor:pointer;padding:2px 0;font-weight:600}.ap-effect-grid{display:flex;flex-wrap:wrap;gap:4px}.ap-effect-btn{padding:4px 7px;border-radius:5px;border:1px solid var(--line-soft);background:var(--bg);color:var(--text);font-size:11px;cursor:pointer;transition:background .1s}.ap-effect-btn:hover{background:var(--surface)}.ap-effect-btn.active{background:var(--accent, #6366f1);color:#fff;border-color:var(--accent, #6366f1)}.ap-trigger-row{display:flex;gap:4px}.ap-trigger-btn{flex:1;padding:4px;border-radius:5px;border:1px solid var(--line-soft);background:var(--bg);color:var(--text);font-size:10px;cursor:pointer;transition:background .1s;white-space:nowrap}.ap-trigger-btn:hover{background:var(--surface)}.ap-trigger-btn.active{background:var(--accent, #6366f1);color:#fff;border-color:var(--accent, #6366f1)}.ap-slider-row{display:flex;align-items:center;gap:6px}.ap-picker-apply{padding:6px 14px;border-radius:6px;border:none;background:var(--accent, #6366f1);color:#fff;font-size:12px;font-weight:600;cursor:pointer;align-self:flex-end;transition:opacity .1s}.ap-picker-apply:hover{opacity:.88}.rail{grid-area:rail;z-index:30;background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;align-items:center;padding:10px 8px;gap:4px;overflow-y:auto;scrollbar-width:thin}.tool{width:42px;height:42px;border:none;border-radius:12px;background:transparent;display:grid;place-items:center;font-size:19px;color:var(--ink-soft);cursor:pointer;transition:background .12s,color .12s}.tool:hover{background:var(--wash);color:var(--ink)}.tool.is-active{background:var(--brand);color:#fff;box-shadow:0 4px 11px -3px var(--brand)}.rail .tool svg{width:22px;height:22px}.rail-sep{width:30px;height:1px;background:var(--line);margin:5px 0;flex:none}.context{grid-area:context;z-index:30;background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:3px;height:52px;padding:7px 12px;overflow-x:auto;overflow-y:hidden;scrollbar-width:thin}.ctx-lab{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);padding:0 8px 0 3px;white-space:nowrap}.ctx-sep{width:1px;height:24px;background:var(--line);margin:0 7px;flex:none}.ctx-btn{width:38px;height:38px;flex:none;border:none;border-radius:9px;background:transparent;display:grid;place-items:center;color:var(--ink-soft);cursor:pointer;transition:background .12s,color .12s}.ctx-btn svg{width:20px;height:20px}.ctx-btn:hover{background:var(--wash);color:var(--ink)}.ctx-btn.on{background:var(--brand-tint);color:var(--brand-ink)}.ctx-dropdown{width:auto;padding:0 6px;display:inline-flex;align-items:center;gap:2px}.ctx-caret{font-size:15px;color:var(--ink-soft);line-height:1}.dropdown-menu{position:fixed;z-index:60;min-width:216px;padding:6px;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--sh-pop)}.dropdown-item{width:100%;display:flex;align-items:center;gap:11px;padding:8px 10px;border:none;border-radius:8px;background:transparent;font:inherit;font-size:13.5px;font-weight:600;color:var(--ink);text-align:left;cursor:pointer}.dropdown-item:hover{background:var(--wash)}.dropdown-item.disabled{color:var(--faint);cursor:default}.dropdown-ico{width:20px;height:20px;flex:none;display:grid;place-items:center;color:var(--ink-soft)}.dropdown-item.disabled .dropdown-ico{color:var(--faint)}.dropdown-ico svg{width:20px;height:20px}.dropdown-sep{height:1px;margin:5px 8px;background:var(--line)}.obj-menu{position:fixed;z-index:70;min-width:248px;padding:6px;background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--sh-pop)}.obj-menu-item{width:100%;display:flex;align-items:center;gap:12px;padding:9px 10px;border:none;border-radius:9px;background:transparent;font:inherit;font-size:14px;font-weight:600;color:var(--ink);text-align:left;cursor:pointer}.obj-menu-item:hover{background:var(--wash)}.obj-menu-item.disabled{color:var(--faint);cursor:default}.obj-menu-item.disabled:hover{background:transparent}.obj-menu-item.danger:hover{background:#dc26261a;color:#dc2626}.obj-menu-ico{width:22px;height:22px;flex:none;display:grid;place-items:center;color:var(--ink-soft)}.obj-menu-ico svg{width:21px;height:21px}.obj-menu-item.disabled .obj-menu-ico,.obj-menu-item.danger .obj-menu-ico{color:inherit}.obj-menu-label{flex:1 1 auto;white-space:nowrap}.obj-menu-label-col{flex:1 1 auto;display:flex;flex-direction:column;gap:1px;min-width:0}.obj-menu-label-col .obj-menu-label{flex:none}.obj-menu-sublabel{font-size:10px;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.obj-menu-accel{flex:none;font-size:11px;font-weight:600;color:var(--muted);background:var(--wash);border-radius:6px;padding:3px 7px}.obj-menu-item:hover .obj-menu-accel{background:var(--surface)}.obj-menu-arrow{flex:none;display:grid;place-items:center;color:var(--muted)}.obj-menu-arrow svg{width:16px;height:16px}.obj-menu-sep{height:1px;margin:5px 8px;background:var(--line)}.ctx-btn:disabled{opacity:.32;cursor:default}.ctx-btn:disabled:hover{background:transparent;color:var(--ink-soft)}.canvas-view{grid-area:canvas;position:relative;overflow:visible;min-width:0;min-height:0;background-color:var(--canvas-bg);background-image:radial-gradient(var(--canvas-dot) 1.4px,transparent 1.4px);background-size:26px 26px;background-position:13px 13px}.panel-col{grid-area:panel;position:relative;border-left:1px solid var(--line);background:var(--surface);display:flex;flex-direction:column;min-height:0}.panel-resize{position:absolute;left:-3px;top:0;bottom:0;width:7px;z-index:6;cursor:ew-resize}.panel-resize:after{content:"";position:absolute;left:2px;top:0;bottom:0;width:2px;background:transparent;transition:background .12s}.panel-resize:hover:after{background:var(--brand)}.zoom-pill{position:absolute;z-index:20;bottom:18px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:2px;height:44px;padding:6px;background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--sh-pop)}.zb{height:32px;min-width:32px;padding:0 8px;border:none;border-radius:8px;background:transparent;display:inline-flex;align-items:center;justify-content:center;gap:6px;font:inherit;font-weight:600;font-size:13px;color:var(--ink-soft);cursor:pointer;transition:background .12s,color .12s}.zb:hover{background:var(--wash);color:var(--ink)}.zb svg{width:17px;height:17px}.zval{min-width:46px;font-variant-numeric:tabular-nums}button svg{display:block}.icon-toggle svg{width:15px;height:15px}.btn{min-width:34px;height:34px;padding:0 8px;font-size:15px;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--ink);cursor:pointer;transition:background .12s,border-color .12s}.btn:hover{background:var(--accent-soft);border-color:var(--panel-border)}.btn:disabled{opacity:.35;cursor:default;background:transparent}.btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.select{height:34px;border:none;border-radius:9px;padding:0 10px;background:var(--wash);color:var(--ink);font:inherit;font-size:13px;font-weight:600;cursor:pointer}.font-picker{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;height:34px;padding:0 10px;border:none;border-radius:9px;background:var(--wash);color:var(--ink);font:inherit;font-size:13px;cursor:pointer}.font-picker-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:15px;line-height:1.7}.font-picker-caret{flex:none;color:var(--ink-soft);font-size:11px}.font-panel{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;flex-direction:column;padding:12px;background:var(--surface)}.font-panel--float{position:fixed;inset:auto;width:260px;max-height:60vh;z-index:1000;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 32px #0000002e}.font-panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.font-panel-title{font-size:14px;font-weight:700;color:var(--ink)}.font-panel-close{width:28px;height:28px;display:grid;place-items:center;border:none;border-radius:8px;background:var(--wash);color:var(--ink-soft);font-size:13px;cursor:pointer}.font-panel-close:hover{background:var(--line);color:var(--ink)}.font-search{width:100%;height:32px;margin-bottom:6px;padding:0 10px;border:1px solid var(--line);border-radius:8px;background:var(--wash);color:var(--ink);font:inherit;font-size:13px}.font-search:focus{outline:none;box-shadow:var(--ring)}.font-list{flex:1;min-height:0;overflow-y:auto}.font-group{position:sticky;top:0;z-index:1;margin-top:10px;padding:10px 10px 5px;border-top:1px solid var(--line);background:var(--surface);color:var(--ink-soft);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.font-group-sep{height:1px;background:var(--line);margin:4px 10px 0}.font-list>.font-group:first-child{margin-top:0;padding-top:4px;border-top:none}.font-option{width:100%;padding:4px 10px;border:none;border-radius:8px;background:transparent;color:var(--ink);font-size:17px;line-height:1.9;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}.font-option:hover{background:var(--wash)}.font-option.active{background:var(--brand-tint);color:var(--brand-ink)}.hidden-input{display:none}.panel{background:var(--surface);display:flex;flex-direction:column;min-height:0}.panel.properties{flex:1 1 auto;min-height:0}.panel.layers{flex:0 0 auto;max-height:44%;border-top:1px solid var(--line)}.panel.layers.panel-hidden{display:none}.panel-body,.layer-list{flex:1 1 auto;min-height:0}.panel-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);padding:12px 16px 8px}.panel-title.has-action{display:flex;align-items:center;justify-content:space-between}.panel-close{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;margin:-4px -6px -4px 0;border:none;border-radius:6px;background:transparent;color:var(--faint);cursor:pointer}.panel-close:hover{background:var(--hover, rgba(0, 0, 0, .06));color:var(--ink, inherit)}.panel-close svg{width:15px;height:15px}.panel-body,.layer-list{padding:4px 12px 16px;overflow-y:auto}.hint{font-size:12px;color:var(--ink-soft);line-height:1.5;padding:4px}.shape-styles-sublabel{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);margin:0 0 5px}.shape-styles-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:10px}.shape-style-cell{aspect-ratio:1;border-radius:4px;cursor:pointer;padding:0;transition:transform .1s,box-shadow .1s}.shape-style-cell:hover{transform:scale(1.15);box-shadow:0 0 0 2px var(--accent, #6366f1);z-index:1;position:relative}.shape-styles-more{display:flex;align-items:center;justify-content:space-between;width:100%;margin:4px 0 0;padding:4px 2px;font-size:11px;font-weight:600;color:var(--accent, #6366f1);background:transparent;border:none;cursor:pointer;border-radius:4px;gap:4px}.shape-styles-more:hover{color:var(--accent-hi, #818cf8)}.shape-styles-more svg{width:14px;height:14px;flex-shrink:0}.shape-styles-dropdown{position:fixed;z-index:9999;background:var(--surface, #fff);border:1px solid var(--line);border-radius:10px;box-shadow:0 8px 32px #0000002e,0 2px 8px #0000001a;padding:10px 12px 12px;width:220px;max-height:70vh;overflow-y:auto}.layer-row{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:8px;cursor:pointer}.layer-row:hover{background:var(--bg)}.layer-row.selected{background:var(--accent-soft);outline:1px solid var(--accent)}.layer-name{flex:1 1 auto;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.icon-toggle{border:none;background:transparent;cursor:pointer;font-size:13px;padding:2px 4px;border-radius:6px}.icon-toggle:hover{background:var(--panel-border)}.field-group{margin-bottom:2px;border-bottom:1px solid var(--line-soft)}.field-group:last-child{border-bottom:none;margin-bottom:0}.field-group-title{display:flex;align-items:center;font-size:12px;font-weight:700;color:var(--ink);padding:8px 0;cursor:pointer;-webkit-user-select:none;user-select:none;list-style:none}.field-group-title::-webkit-details-marker{display:none}.field-group-title:after{content:"";display:block;width:5px;height:5px;border-right:1.5px solid var(--ink-soft);border-bottom:1.5px solid var(--ink-soft);transform:rotate(-45deg);transition:transform .15s ease;flex-shrink:0;margin-left:auto}details[open]>.field-group-title:after{transform:rotate(45deg)}.field-group-body{padding-bottom:10px}.field-subgroup{padding:10px 10px 0;margin-bottom:12px;border:1px solid var(--line-soft);border-radius:8px;background:var(--wash)}.wordart-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;margin-bottom:12px}.wordart-tile{aspect-ratio:1;padding:2px;background:var(--wash);border:1.5px solid transparent;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .1s,background .1s}.wordart-tile:hover{border-color:var(--accent);background:var(--hover)}.wordart-tile svg{width:100%;height:100%;display:block;overflow:visible}.field-subgroup-title{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--faint);margin:0 0 10px}.field-subgroup>:last-child{margin-bottom:10px}.field{display:grid;grid-template-columns:90px 1fr;align-items:center;gap:8px;margin-bottom:12px}.field-label{font-size:11px;font-weight:700;color:var(--faint)}.preset-trigger{width:100%;display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--panel);border:1px solid var(--panel-border);border-radius:8px;cursor:pointer;text-align:left;font:inherit;transition:border-color .12s,box-shadow .12s}.preset-trigger:hover{border-color:var(--accent)}.preset-trigger:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.preset-trigger-text{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;line-height:1.25}.preset-trigger-title{font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.preset-trigger-sub{font-size:11px;color:var(--ink-soft)}.preset-trigger-caret{flex:0 0 auto;color:var(--ink-soft);font-size:11px}.preset-popover{position:fixed;z-index:50;width:360px;max-height:min(70vh,520px);display:flex;flex-direction:column;padding:12px;background:var(--panel);border:1px solid var(--panel-border);border-radius:12px;box-shadow:0 12px 32px #11182738}.preset-pop-head{flex:0 0 auto;margin-bottom:10px}.preset-search{width:100%;border:1px solid var(--panel-border);border-radius:8px;padding:8px 10px;font:inherit;font-size:13px}.preset-search:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.preset-groups{flex:1 1 auto;overflow-y:auto;padding-right:2px}.preset-group-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);margin:10px 2px 8px}.preset-group-label:first-child{margin-top:0}.preset-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.preset-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 6px;background:var(--panel);border:1px solid var(--panel-border);border-radius:10px;cursor:pointer;font:inherit;transition:border-color .12s,box-shadow .12s,transform .06s}.preset-card:hover{border-color:var(--accent);transform:translateY(-1px)}.preset-card.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.preset-thumb{width:100%;height:46px;display:grid;place-items:center}.preset-thumb-shape{display:block;overflow:hidden;background:var(--surface);border:1px solid var(--line);border-radius:2px;--wire-block: var(--brand-tint);--wire-bar: var(--brand-tint-2);--wire-soft: var(--brand-tint-2);--wire-glyph: var(--brand)}.preset-thumb-shape svg{display:block;width:100%;height:100%}.preset-card-name{font-size:11px;font-weight:600;color:var(--ink);text-align:center;line-height:1.2}.preset-card-dims{font-size:10px;color:var(--ink-soft)}.preset-empty{font-size:12px;color:var(--ink-soft);text-align:center;padding:16px 8px}.context-menu{position:fixed;z-index:60;display:inline-flex;align-items:center;gap:2px;padding:4px;background:var(--panel);border:1px solid var(--panel-border);border-radius:10px;box-shadow:0 12px 32px #11182738}.context-item{width:32px;height:32px;display:grid;place-items:center;border:none;border-radius:6px;background:transparent;cursor:pointer;font:inherit;font-size:15px;color:var(--ink);transition:background .1s,color .1s}.context-item:hover{background:var(--accent-soft)}.context-item.active{color:var(--accent);background:var(--accent-soft)}.context-item.danger{color:#dc2626}.context-item.danger:hover{background:#dc26261a}.context-icon{line-height:1}.context-icon svg{display:block;width:20px;height:20px}.context-sep{width:1px;height:22px;margin:0 3px;background:var(--panel-border)}.context-select{height:30px;max-width:130px;padding:0 6px;border:1px solid var(--panel-border);border-radius:6px;background:var(--panel);font:inherit;font-size:13px;color:var(--ink);cursor:pointer}.context-color{width:30px;height:30px;padding:0;border:1px solid var(--panel-border);border-radius:7px;background:none;cursor:pointer}.context-color::-webkit-color-swatch-wrapper{padding:3px}.context-color::-webkit-color-swatch{border:none;border-radius:5px}.context-select:focus{outline:none;border-color:var(--accent)}.context-size-wrap{display:flex;align-items:center;height:30px;border:1px solid var(--panel-border);border-radius:6px;overflow:hidden}.context-size{width:38px;height:100%;border:none;padding:0 4px;font:inherit;font-size:13px;text-align:center;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.context-size:focus{outline:none}.context-size::-webkit-outer-spin-button,.context-size::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.context-steps{display:flex;flex-direction:column;border-left:1px solid var(--panel-border)}.context-step{width:16px;height:15px;display:grid;place-items:center;border:none;background:var(--panel);color:var(--ink-soft);font-size:6px;line-height:1;cursor:pointer}.context-step:first-child{border-bottom:1px solid var(--panel-border)}.context-step:hover{background:var(--accent-soft);color:var(--accent)}.color-swatch{width:28px;height:28px;padding:0;justify-self:end;border:1px solid var(--panel-border);border-radius:50%;cursor:pointer;font-size:0;text-indent:-9999px;overflow:hidden;display:inline-flex;flex:0 0 auto;box-shadow:inset 0 0 0 1px #ffffff40;transition:box-shadow .12s,transform .06s}.color-swatch:hover{box-shadow:inset 0 0 0 1px #fff6,0 0 0 3px var(--accent-soft)}.color-swatch:active{transform:scale(.99)}.color-swatch.is-none{color:var(--ink);background:var(--panel);background-image:linear-gradient(to top left,transparent calc(50% - 1px),#ef4444 calc(50% - 1px),#ef4444 calc(50% + 1px),transparent calc(50% + 1px)),conic-gradient(#e5e7eb 0,#e5e7eb 25%,#fff 0,#fff 50%,#e5e7eb 0,#e5e7eb 75%,#fff 0);background-size:100% 100%,10px 10px}.color-popover{position:fixed;z-index:10001;width:308px;padding:14px;background:var(--panel);border:1px solid var(--panel-border);border-radius:12px;box-shadow:0 12px 32px #11182738}.pop-head{display:flex;gap:8px;margin-bottom:10px}.hex-input{flex:1 1 auto;min-width:0;border:1px solid var(--panel-border);border-radius:8px;padding:7px 10px;font:inherit;font-size:13px;text-transform:uppercase}.hex-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.native-btn{position:relative;flex:0 0 auto;width:34px;display:grid;place-items:center;border:1px solid var(--panel-border);border-radius:8px;cursor:pointer;overflow:hidden;background:conic-gradient(from 0deg,#f43f5e,#eab308,#22c55e,#06b6d4,#6366f1,#d946ef,#f43f5e)}.native-plus{position:relative;z-index:1;width:22px;height:22px;border-radius:50%;background:var(--panel);display:grid;place-items:center;font-size:16px;line-height:1;color:var(--ink)}.native-color{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;border:none;cursor:pointer}.none-btn{flex:0 0 auto;width:34px;border:1px solid var(--panel-border);border-radius:8px;cursor:pointer;padding:0;background-image:linear-gradient(to top left,transparent calc(50% - 1.5px),#ef4444 calc(50% - 1.5px),#ef4444 calc(50% + 1.5px),transparent calc(50% + 1.5px)),conic-gradient(#e5e7eb 0,#e5e7eb 25%,#fff 0,#fff 50%,#e5e7eb 0,#e5e7eb 75%,#fff 0);background-size:100% 100%,8px 8px}.none-btn:hover{border-color:var(--accent)}.none-btn.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.pop-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);margin:12px 0 6px}.swatch-row,.swatch-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:5px}.mini-swatch{width:22px;height:22px;justify-self:center;border:1px solid rgba(17,24,39,.12);border-radius:6px;cursor:pointer;padding:0;box-shadow:inset 0 0 0 1px #fff3;transition:transform .08s,box-shadow .08s}.mini-swatch:hover{transform:scale(1.12);box-shadow:0 2px 6px #11182740}.mini-swatch.selected{box-shadow:0 0 0 2px var(--panel),0 0 0 4px var(--accent)}.number,.textarea{width:100%;border:none;border-radius:9px;padding:7px 9px;background:var(--wash);font:inherit;font-size:13px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums;transition:box-shadow .12s,background .12s}.input{width:100%;min-width:0;height:32px;border:none;border-radius:9px;padding:0 9px;background:var(--wash);font:inherit;font-size:13px;font-weight:600;color:var(--ink);transition:box-shadow .12s,background .12s}.link-field{display:flex;align-items:center;gap:6px}.link-field .seg-btn{flex:0 0 32px;height:32px}.number:focus,.textarea:focus,.input:focus,.select:focus{outline:none;background:var(--surface);box-shadow:inset 0 0 0 1.5px var(--brand)}.slider-field{display:grid;grid-template-columns:1fr 54px;align-items:center;gap:10px}.slider-field.has-stepper{grid-template-columns:1fr 44px auto;gap:6px}.stepper{display:flex;flex-direction:column;gap:2px}.step-btn{width:20px;height:14px;display:grid;place-items:center;padding:0;border:1px solid var(--panel-border);border-radius:4px;background:var(--panel);color:var(--ink-soft);font-size:7px;line-height:1;cursor:pointer;transition:border-color .12s,color .12s}.step-btn:hover{border-color:var(--accent);color:var(--ink)}.step-btn:active{background:var(--accent-soft)}.btn-group{display:flex;gap:4px}.seg-btn{flex:1 1 0;min-width:0;height:30px;display:grid;place-items:center;padding:0;border:1px solid var(--panel-border);border-radius:6px;background:var(--panel);color:var(--ink);font:inherit;font-size:14px;line-height:1;cursor:pointer;transition:border-color .12s,background .12s,color .12s}.seg-btn:hover{border-color:var(--accent)}.seg-btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.seg-icon svg{width:20px;height:20px}.seg-btn.has-icon{display:flex;align-items:center;justify-content:center;gap:7px;white-space:nowrap;flex:0 0 auto;padding:0 12px}.seg-btn.has-icon .seg-ico{display:inline-grid;place-items:center}.seg-btn.has-icon .seg-ico svg{width:16px;height:16px}.switch{position:relative;flex:0 0 auto;justify-self:end;width:42px;height:24px;padding:0;border:none;border-radius:999px;background:var(--line);cursor:pointer;transition:background .18s ease}.switch.on{background:var(--accent)}.switch:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-soft)}.switch-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #11182759;transition:transform .18s ease}.switch.on .switch-thumb{transform:translate(18px)}.gradient-preview{width:100%;height:28px;margin-bottom:12px;border-radius:6px;border:1px solid var(--panel-border)}.gradient-stop-controls{display:flex;align-items:center;gap:6px;min-width:0}.gradient-stop-controls .range{flex:1 1 auto;min-width:0}.gradient-stop-remove{flex:0 0 auto;width:30px}.seg-bold{font-weight:700}.seg-italic{font-style:italic;font-family:Georgia,Times New Roman,serif}.seg-underline{text-decoration:underline}.seg-strike{text-decoration:line-through}.ratio-controls{display:flex;justify-self:end;gap:6px}.ratio-controls .btn{border-color:var(--panel-border)}.ratio-controls .btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.range{--fill: 0%;-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;min-width:0;height:20px;margin:0;background:transparent;cursor:pointer}.range:focus{outline:none}.range::-webkit-slider-runnable-track{height:6px;border-radius:999px;background:linear-gradient(to right,var(--accent) 0 var(--fill),var(--panel-border) var(--fill) 100%)}.range::-moz-range-track{height:6px;border-radius:999px;background:var(--panel-border)}.range::-moz-range-progress{height:6px;border-radius:999px;background:var(--accent)}.range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;margin-top:-6px;border-radius:50%;background:#fff;border:2px solid var(--accent);box-shadow:0 1px 3px #11182740;transition:transform .1s,box-shadow .1s}.range::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid var(--accent);box-shadow:0 1px 3px #11182740;transition:transform .1s,box-shadow .1s}.range:hover::-webkit-slider-thumb{transform:scale(1.12)}.range:hover::-moz-range-thumb{transform:scale(1.12)}.range:active::-webkit-slider-thumb,.range:focus-visible::-webkit-slider-thumb{box-shadow:0 0 0 6px var(--accent-soft)}.range:active::-moz-range-thumb,.range:focus-visible::-moz-range-thumb{box-shadow:0 0 0 6px var(--accent-soft)}.slider-field .number{padding:6px 4px;text-align:center;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.slider-field .number::-webkit-outer-spin-button,.slider-field .number::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.textarea{resize:vertical}.palette-bar{grid-area:palette;display:flex;align-items:center;gap:12px;padding:7px 14px;background:var(--surface);border-top:1px solid var(--line)}.palette-nav{flex:1 1 auto;min-width:0;display:flex;align-items:center;gap:4px}.palette-arrow{flex:0 0 auto;width:24px;height:24px;border:none;border-radius:6px;background:transparent;display:grid;place-items:center;color:var(--ink-soft);cursor:pointer}.palette-arrow:hover{background:var(--wash);color:var(--ink)}.palette-arrow svg{width:16px;height:16px}.palette-swatches{flex:1 1 auto;min-width:0;display:flex;gap:4px;overflow-x:auto;scrollbar-width:none;padding:3px 4px}.palette-swatches::-webkit-scrollbar{height:0;width:0;display:none}.palette-swatch{flex:0 0 auto;width:20px;height:20px;padding:0;border:1px solid rgba(17,24,39,.12);border-radius:4px;cursor:pointer;box-shadow:inset 0 0 0 1px #fff3;transition:transform .08s,box-shadow .08s}.palette-swatch:hover{transform:scale(1.18);box-shadow:0 2px 6px #1118274d}.palette-swatch.is-none{background-image:linear-gradient(to top left,transparent calc(50% - 1px),#ef4444 calc(50% - 1px),#ef4444 calc(50% + 1px),transparent calc(50% + 1px)),conic-gradient(#e5e7eb 0,#e5e7eb 25%,#fff 0,#fff 50%,#e5e7eb 0,#e5e7eb 75%,#fff 0);background-size:100% 100%,8px 8px}.canvas-view{position:relative;overflow:hidden;min-width:0;min-height:0}.canvas-scroll{position:absolute;top:0;right:0;bottom:0;left:0;overflow:auto;display:flex;align-items:safe center;justify-content:safe center;background:transparent}.stage{padding:0}.stage-surface{line-height:0}.ruler{position:absolute;z-index:20;display:block}.ruler-top{top:0;left:0;width:100%;height:18px;border-bottom:1px solid var(--panel-border);cursor:ns-resize}.ruler-left{top:0;left:0;width:18px;height:100%;border-right:1px solid var(--panel-border);cursor:ew-resize}.ruler-corner{position:absolute;z-index:21;top:0;left:0;width:18px;height:18px;background:var(--panel);border-right:1px solid var(--panel-border);border-bottom:1px solid var(--panel-border)}.guide-preview{position:absolute;z-index:19;background:#11b3c6;pointer-events:none}.guide-preview.v{top:0;bottom:0;width:1px}.guide-preview.h{left:0;right:0;height:1px}.zoom-bar{position:absolute;bottom:16px;right:16px;display:flex;align-items:center;gap:4px;padding:4px;background:var(--panel);border:1px solid var(--panel-border);border-radius:10px;box-shadow:0 4px 12px #1118271f}.zoom-label{min-width:48px;text-align:center;font-size:13px;color:var(--ink-soft)}.drawing-popup{position:fixed;z-index:220;background:var(--surface);border-radius:14px;box-shadow:0 8px 32px #1118272e;padding:8px;display:flex;flex-direction:column;gap:2px;min-width:56px}.popup-sec{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-muted, var(--ink-soft));padding:6px 10px 2px}.drawing-popup .tool svg{width:22px;height:22px}.graphics-panel,.text-panel{grid-area:gfx;width:0;overflow:hidden;background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;transition:width .2s ease}.graphics-panel.open,.text-panel.open{width:280px}.txt-scroll{flex:1;overflow-y:auto;min-height:0;display:flex;flex-direction:column}.txt-section-sep{height:1px;background:var(--line);margin:4px 0;flex-shrink:0}.txt-section-label{font-size:11px;font-weight:600;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;padding:10px 12px 6px}.txt-panel-body{display:flex;flex-direction:column;gap:10px;padding:12px 12px 10px;flex-shrink:0}.txt-panel-input{width:100%;box-sizing:border-box;resize:vertical;min-height:80px;padding:9px 11px;border:1px solid var(--line);border-radius:8px;background:var(--input-bg, var(--surface));color:var(--ink);font-size:13px;font-family:inherit;line-height:1.5;outline:none;transition:border-color .12s}.txt-panel-input:focus{border-color:var(--accent)}.txt-panel-add{width:100%;padding:8px 0;border:none;border-radius:8px;background:var(--accent);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .12s}.txt-panel-add:hover{opacity:.88}.txt-quick-section{display:flex;flex-direction:column;flex-shrink:0}.txt-quick-row{display:flex;align-items:stretch}.txt-quick-row:hover{background:var(--wash)}.txt-quick-btn{display:flex;align-items:center;gap:12px;padding:8px 8px 8px 12px;border:none;background:transparent;cursor:pointer;text-align:left;flex:1;min-width:0;transition:background .1s}.txt-quick-edit{display:flex;align-items:center;justify-content:center;width:36px;flex-shrink:0;border:none;background:transparent;cursor:pointer;color:var(--ink-soft);opacity:0;transition:opacity .12s,color .12s}.txt-quick-edit svg{width:14px;height:14px}.txt-quick-row:hover .txt-quick-edit{opacity:1}.txt-quick-edit:hover{color:var(--accent)}.txt-quick-a{width:44px;text-align:center;line-height:1;flex-shrink:0;font-family:inherit}.txt-quick-info{display:flex;flex-direction:column;gap:1px}.txt-quick-name{font-size:13px;font-weight:500;color:var(--ink)}.txt-quick-size{font-size:11px;color:var(--ink-soft)}.txt-add-style-btn{display:flex;align-items:center;gap:6px;width:100%;padding:8px 12px;border:none;background:transparent;color:var(--accent);font-size:12px;font-weight:500;cursor:pointer;text-align:left;transition:background .1s}.txt-add-style-btn:hover{background:var(--wash)}.txt-add-style-icon{display:flex;align-items:center}.txt-add-style-icon svg{width:14px;height:14px}.txt-combos-section{display:flex;flex-direction:column;flex-shrink:0;padding-bottom:12px}.txt-combo-card{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:12px 12px 10px;border:none;background:transparent;cursor:pointer;text-align:left;width:100%;transition:background .1s}.txt-combo-card:hover{background:var(--wash)}.txt-combo-card+.txt-combo-card{border-top:1px solid var(--line)}.txt-combo-preview{display:flex;flex-direction:column;gap:3px;width:100%}.txt-combo-h{font-size:19px;font-weight:700;color:var(--ink);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.txt-combo-b{font-size:11px;color:var(--ink-soft);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.txt-combo-name{font-size:10px;font-weight:600;color:var(--faint);text-transform:uppercase;letter-spacing:.07em;margin-top:2px}.txt-home,.txt-style-editor{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.txt-home[hidden],.txt-style-editor[hidden]{display:none}.txt-style-editor{display:flex;flex-direction:column;position:relative}.txt-editor-scroll{flex:1;overflow-y:auto;min-height:0;padding:8px 12px 16px;display:flex;flex-direction:column;gap:14px}.txt-ed-field{display:flex;flex-direction:column;gap:5px}.txt-ed-label{font-size:11px;font-weight:600;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.05em}.txt-ed-controls{display:flex;align-items:center;gap:8px}.txt-ed-name{flex:1;height:32px;padding:0 10px;border:1px solid var(--line);border-radius:7px;background:var(--surface);color:var(--ink);font-size:13px;font-weight:500;font-family:inherit;outline:none;min-width:0}.txt-ed-name:focus{border-color:var(--accent)}.txt-ed-controls .font-picker{flex:1;min-width:0}.txt-ed-controls .font-picker-caret{font-size:16px}.txt-ed-range{flex:1;min-width:0;accent-color:var(--accent)}.txt-ed-num{width:56px;flex-shrink:0;height:30px;padding:0 6px;border:1px solid var(--line);border-radius:7px;background:var(--surface);color:var(--ink);font-size:12px;text-align:center;outline:none}.txt-ed-num:focus{border-color:var(--accent)}.txt-ed-row{display:flex;gap:4px}.txt-ed-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:30px;border:1px solid var(--line);border-radius:7px;background:var(--surface);color:var(--ink);font-size:13px;cursor:pointer;transition:background .1s,border-color .1s,color .1s}.txt-ed-toggle svg{width:14px;height:14px}.txt-ed-toggle:hover{border-color:var(--accent)}.txt-ed-toggle.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.txt-ed-align{flex:1}.txt-ed-align .txt-ed-toggle{flex:1;width:auto}.txt-ed-controls .color-swatch{flex-shrink:0}.txt-ed-hint{font-size:11px;color:var(--faint);line-height:1.5;margin:0;padding:8px 0 0;border-top:1px solid var(--line)}.gfx-header{display:flex;align-items:center;gap:6px;padding:10px 12px;border-bottom:1px solid var(--line);flex:none}.gfx-title{font-size:14px;font-weight:600;color:var(--ink);flex:1}.gfx-close,.gfx-back{width:28px;height:28px;border:none;border-radius:8px;background:transparent;display:grid;place-items:center;color:var(--ink-soft);cursor:pointer;transition:background .12s,color .12s}.gfx-close:hover,.gfx-back:hover{background:var(--wash);color:var(--ink)}.gfx-close svg,.gfx-back svg{width:16px;height:16px}.gfx-home{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:10px;overflow-y:auto;align-content:start}.gfx-home[hidden]{display:none}.gfx-cat{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border:none;border-radius:10px;background:transparent;cursor:pointer;color:var(--ink-soft);font-size:12px;transition:background .12s,color .12s;line-height:1.3;text-align:center}.gfx-cat:hover{background:var(--wash);color:var(--ink)}.gfx-cat-icon svg{width:28px;height:28px;display:block}.gfx-detail{display:flex;flex-direction:column;flex:1;overflow:hidden;min-height:0}.gfx-detail[hidden]{display:none}.gfx-detail-header{display:flex;align-items:center;gap:8px;padding:8px 10px;border-bottom:1px solid var(--line);flex:none}.gfx-detail-title{font-size:13px;font-weight:600;color:var(--ink)}.gfx-content{flex:1;overflow-y:auto;display:flex;flex-direction:column;min-height:0}.bg-picker-content,.ill-picker-content,.icon-picker-content,.ai-picker-content,.uploads-picker-content{display:flex;flex-direction:column;flex:1;min-height:0}.gfx-content .bg-picker-content,.gfx-content .ill-picker-content,.gfx-content .icon-picker-content,.gfx-content .ai-picker-content,.gfx-content .uploads-picker-content{padding:10px 12px;box-sizing:border-box}.gfx-content .bg-controls,.gfx-content .ill-controls{flex-direction:column;align-items:stretch;gap:8px}.gfx-content .icon-sources{flex-wrap:wrap;gap:4px;margin:0 0 8px}.gfx-content .icon-search,.gfx-content .ill-search,.gfx-content .px-search,.gfx-content .px-key{width:100%;box-sizing:border-box}.gfx-content .uploads-grid{max-height:none}.gfx-content .ill-grid{min-height:0}.gfx-content .bg-grid{flex:1;overflow-y:auto;min-height:0}.gfx-content .ai-picker-content{overflow-x:hidden;padding:8px 10px}.gfx-content .ai-picker-content .icon-sources{flex-wrap:wrap;gap:4px;margin:0 0 6px}.gfx-content .ai-picker-content .seg-btn{flex:0 0 auto;height:auto;padding:4px 10px;font-size:11px;border-radius:999px}.gfx-content .ai-photos-tags{flex-wrap:wrap;gap:4px;padding:0 0 4px}.gfx-content .ai-tag-chip{font-size:11px;padding:3px 8px}.ai-photo-placeholder{aspect-ratio:16 / 9;background:var(--wash);border-radius:6px}.ai-scroll-sentinel{grid-column:1 / -1;height:1px}.gfx-content .ai-photos-grid{grid-template-columns:1fr 1fr;flex:1;min-height:0;overflow-y:auto;align-content:start}.gfx-content .icon-grid{flex:1;overflow-y:auto;min-height:0}.qr-picker-content{display:flex;flex-direction:column;gap:10px;padding:16px}.qr-picker-actions{display:flex;justify-content:flex-end}.eq-picker-content{display:flex;flex-direction:column;gap:12px;padding:14px}.eq-picker-actions{display:flex;justify-content:flex-end}.eq-dialog{width:min(460px,100%)}.eq-form{display:flex;flex-direction:column;gap:8px}.eq-preview{display:grid;place-items:center;min-height:72px;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--wash);color:var(--ink);overflow:auto}.eq-preview svg{max-width:100%;height:auto;color:var(--ink)}.eq-preview.is-error{color:var(--danger, #dc2626);font-size:12px;text-align:center}.eq-preview-empty{color:var(--ink-soft);font-size:12px}.eq-input{width:100%;resize:vertical;font-family:ui-monospace,SF Mono,Cascadia Code,Consolas,monospace;font-size:13px;line-height:1.5}.eq-symbols{display:flex;flex-direction:column;gap:4px}.eq-symbol-row{display:flex;flex-wrap:wrap;gap:4px}.eq-symbol{min-width:30px;height:30px;padding:0 7px;border:1px solid var(--line);border-radius:7px;background:var(--surface);color:var(--ink);font-size:14px;cursor:pointer;transition:background .12s,border-color .12s}.eq-symbol:hover{background:var(--wash);border-color:var(--accent)}.ws-panel{display:flex;flex-direction:column;gap:14px;padding:14px}.ws-hint{margin:0;font-size:11.5px;color:var(--ink-soft)}.ws-section{display:flex;flex-direction:column;gap:8px}.ws-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft)}.ws-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.ws-block{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--panel-border);border-radius:9px;background:var(--surface);color:var(--ink-soft);font:inherit;font-size:12px;font-weight:600;text-align:left;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.ws-block:hover{color:var(--ink);border-color:var(--accent);background:var(--accent-soft)}.ws-block-ico{display:grid;place-items:center;flex:none;color:var(--ink)}.ws-block-ico svg{width:20px;height:20px;display:block}.ws-block-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chart-picker-content{display:flex;flex-direction:column;gap:12px;padding:14px}.chart-picker-actions{display:flex;justify-content:flex-end}.chart-dialog{width:min(440px,100%)}.chart-form{display:flex;flex-direction:column;gap:12px}.chart-field{display:flex;flex-direction:column}.chart-types{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;padding:2px}.chart-type-btn{display:flex;align-items:center;gap:7px;padding:7px 8px;border:1px solid transparent;border-radius:8px;background:var(--wash);color:var(--ink-soft);font:inherit;font-size:11px;font-weight:600;text-align:left;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.chart-type-btn:hover{color:var(--ink)}.chart-type-ico{display:grid;place-items:center;flex:none}.chart-type-ico svg{width:18px;height:18px;display:block}.chart-type-lab{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chart-type-btn.is-active{background:var(--surface);color:var(--ink);border-color:var(--accent)}.chart-rows{display:flex;flex-direction:column;gap:6px}.chart-row{display:flex;gap:6px;align-items:center}.chart-row-head{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft);padding:0 2px 2px}.chart-row-head .chart-row-label,.chart-row-head .chart-row-value{padding:0 2px}.chart-row-label{flex:1;min-width:0}.chart-row-value{width:64px;flex:none}.chart-row-del-spacer{width:30px;flex:none}.chart-row-del{flex:none;display:grid;place-items:center;width:30px;height:30px;border:none;border-radius:8px;background:transparent;color:var(--ink-soft);cursor:pointer;transition:background .12s,color .12s}.chart-row-del:hover{background:var(--hover);color:var(--danger, #e23b3b)}.chart-row-del svg{width:16px;height:16px}.chart-add-row{display:inline-flex;align-items:center;gap:5px;margin-top:8px;padding:5px 10px;border:1px dashed var(--line);border-radius:8px;background:transparent;color:var(--ink-soft);font:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:background .12s,color .12s}.chart-add-row:hover{background:var(--wash);color:var(--ink)}.chart-add-row svg{width:14px;height:14px}.chart-palettes{display:flex;flex-wrap:wrap;gap:6px}.chart-palette{display:flex;padding:3px;border:2px solid transparent;border-radius:8px;background:var(--wash);cursor:pointer;overflow:hidden;transition:border-color .12s}.chart-palette.is-active{border-color:var(--accent)}.chart-swatch{width:14px;height:16px;display:block}.chart-swatch:first-child{border-radius:3px 0 0 3px}.chart-swatch:last-child{border-radius:0 3px 3px 0}.chart-legend-row{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer}.chart-legend-row input{cursor:pointer}.c3d-launch{display:flex;flex-direction:column;gap:12px;padding:14px}.c3d-launch-hint{margin:0;font-size:12px;color:var(--ink-soft);line-height:1.4}.c3d-launch-tiles{display:flex;flex-direction:column;gap:6px}.c3d-launch-tile{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:9px;background:var(--wash);color:var(--ink);font:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:background .12s,border-color .12s}.c3d-launch-tile:hover{background:var(--hover);border-color:var(--accent)}.c3d-launch-ico{display:grid;place-items:center;flex:none}.c3d-launch-ico svg{width:22px;height:22px}.c3d-overlay{z-index:300}.c3d-modal{display:flex;flex-direction:column;width:min(960px,96vw);height:min(660px,92vh);background:var(--surface);border-radius:16px;box-shadow:var(--sh-lg);overflow:hidden;transform:translateY(6px) scale(.98);transition:transform .16s}.c3d-overlay.show .c3d-modal{transform:none}.c3d-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line);flex:none}.c3d-head .dialog-title{margin:0}.c3d-body{flex:1;display:grid;grid-template-columns:286px 1fr;min-height:0}.c3d-side{display:flex;flex-direction:column;gap:8px;padding:14px;overflow-y:auto;border-right:1px solid var(--line)}.c3d-stage{position:relative;min-width:0;min-height:0;background:radial-gradient(120% 120% at 50% 0%,color-mix(in srgb,var(--accent) 8%,var(--wash)) 0%,var(--wash) 70%)}.c3d-stage canvas{display:block}.c3d-foot{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:12px 16px;border-top:1px solid var(--line);flex:none}.c3d-foot-hint{margin-right:auto;font-size:12px;color:var(--ink-soft)}.c3d-types{display:flex;gap:4px}.c3d-types .chart-type-btn{flex:1;flex-direction:column;text-align:center}.c3d-data{display:flex;flex-direction:column;gap:8px}.c3d-steppers{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.c3d-stepper{display:flex;align-items:center;gap:7px}.c3d-stepper-label{font-size:12px;font-weight:600;color:var(--ink-soft);min-width:36px}.c3d-step{display:inline-flex;align-items:stretch;height:26px;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--surface)}.c3d-step-btn{width:26px;display:grid;place-items:center;border:none;background:transparent;color:var(--ink);font-size:16px;line-height:1;cursor:pointer;transition:background .12s}.c3d-step-btn:hover{background:var(--hover)}.c3d-step-val{min-width:32px;display:grid;place-items:center;padding:0 4px;font-size:12px;font-weight:700;color:var(--ink);border-left:1px solid var(--line);border-right:1px solid var(--line)}.c3d-clear{margin-left:auto;padding:5px 11px;border:1px solid var(--line);border-radius:8px;background:transparent;color:var(--ink-soft);font:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:background .12s,color .12s}.c3d-clear:hover{background:var(--hover);color:var(--ink)}.c3d-actions{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:8px}.c3d-actions .chart-add-row{margin-top:0}.c3d-actions .c3d-clear{margin-left:0}.c3d-grid-scroll{overflow-x:auto;padding-bottom:4px}.c3d-table{display:grid;gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}.c3d-grid{margin-top:8px;width:max-content}.c3d-scatter-table{width:100%;grid-template-columns:1fr 1fr 1fr 34px}.c3d-cell,.c3d-hcell,.c3d-delcell{height:30px;margin:0;border:none;border-right:1px solid var(--line);border-bottom:1px solid var(--line);box-sizing:border-box}.c3d-cell{width:100%;min-width:0;padding:0 4px;border-radius:0;background:var(--surface);font:inherit;font-size:12px;font-weight:600;color:var(--ink);text-align:center;outline:none;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.c3d-cell::-webkit-outer-spin-button,.c3d-cell::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.c3d-cell:focus{background:color-mix(in srgb,var(--accent) 12%,var(--surface));box-shadow:inset 0 0 0 1px var(--accent)}.c3d-hcell{display:grid;place-items:center;background:var(--wash);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft)}.c3d-delcell{display:grid;place-items:center;background:var(--surface);color:var(--ink-soft);cursor:pointer}.c3d-delcell:hover{background:var(--hover);color:var(--danger, #e23b3b)}.c3d-delcell svg{width:15px;height:15px}.c3d-labels{display:flex;flex-direction:column;gap:6px}.c3d-axis-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}.c3d-axis-row .input{font-size:12px}.c3d-display{display:flex;flex-direction:column;gap:10px}.c3d-range-row{display:flex;align-items:center;gap:8px}.c3d-range-label{font-size:12px;font-weight:600;color:var(--ink)}.c3d-range{flex:1;min-width:0;accent-color:var(--accent);cursor:pointer}.c3d-range-val{width:36px;text-align:right;font-size:12px;font-weight:600;color:var(--ink-soft)}.c3d-toggles{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px}.c3d-toggles .chart-legend-row{font-size:12px}.c3d-settings{position:absolute;top:10px;right:10px;z-index:5;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.c3d-settings-btn{width:34px;height:34px;display:grid;place-items:center;border:1px solid var(--line);border-radius:9px;background:color-mix(in srgb,var(--surface) 86%,transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:var(--ink);cursor:pointer;box-shadow:var(--sh-sm, 0 1px 3px rgba(0, 0, 0, .14));transition:background .12s}.c3d-settings-btn:hover{background:var(--surface)}.c3d-settings-btn svg{width:18px;height:18px}.c3d-settings-panel{width:232px;padding:12px;display:flex;flex-direction:column;gap:10px;border:1px solid var(--line);border-radius:12px;background:var(--surface);box-shadow:var(--sh-lg)}.c3d-settings-panel[hidden]{display:none}.c3d-settings-title{font-size:12px;font-weight:700;color:var(--ink)}.tmpl-fs-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:210;display:grid;place-items:center;padding:16px;background:#140c0a66;opacity:0;transition:opacity .16s}.tmpl-fs-overlay.show{opacity:1}.tmpl-fs{width:min(1480px,98vw);height:min(1040px,96vh);display:flex;flex-direction:column;background:var(--surface);border-radius:18px;box-shadow:var(--sh-lg);overflow:hidden;transform:translateY(8px) scale(.99);transition:transform .16s}.tmpl-fs-overlay.show .tmpl-fs{transform:none}.tmpl-fs-head{display:flex;align-items:center;gap:16px;padding:14px 20px;border-bottom:1px solid var(--line)}.tmpl-fs-title{font-family:var(--display);font-size:20px;font-weight:700;color:var(--ink)}.tmpl-fs-tabs{display:flex;gap:6px;margin:0 auto;flex-wrap:wrap;justify-content:center}.tmpl-fs-close{width:36px;height:36px;display:grid;place-items:center;border:1px solid var(--line);border-radius:10px;background:var(--surface);color:var(--muted);cursor:pointer;transition:.12s}.tmpl-fs-close:hover{color:var(--ink);border-color:var(--faint)}.tmpl-fs-close svg{width:18px;height:18px}.tmpl-fs-bar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:11px 20px;min-height:38px;border-bottom:1px solid var(--line-soft)}.tmpl-bar-hint{font-size:13px;color:var(--muted);align-self:center}.tmpl-crumb{font-family:var(--display);font-size:16px;font-weight:700;color:var(--ink);align-self:center}.tmpl-bar-controls{display:flex;align-items:flex-end;gap:12px;margin-left:auto}.tmpl-back{display:inline-flex;align-items:center;gap:5px;padding:6px 13px 6px 9px;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--surface);color:var(--ink-soft);font:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:.12s}.tmpl-back:hover{border-color:var(--faint);color:var(--ink)}.tmpl-back svg{width:16px;height:16px}.tmpl-fs-body{flex:1 1 auto;overflow-y:auto;padding:18px 20px 26px}.tmpl-fs-body .curated-section+.curated-section{margin-top:22px}.tmpl-fs-body .curated-head{top:-18px}.size-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:12px}.size-tile{display:flex;flex-direction:column;align-items:center;gap:7px;padding:14px 10px 12px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);cursor:pointer;transition:.12s}.size-tile:hover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.size-frame{height:98px;display:flex;align-items:center;justify-content:center}.size-shape{display:block;overflow:hidden;background:var(--surface);border:1px solid var(--line);border-radius:3px;box-shadow:var(--sh-sm);--wire-block: var(--brand-tint);--wire-bar: var(--brand-tint-2);--wire-soft: var(--brand-tint-2);--wire-glyph: var(--brand)}.size-shape svg{display:block;width:100%;height:100%}.size-name{font-size:12.5px;font-weight:600;color:var(--ink);text-align:center;line-height:1.2}.size-dim{font-size:11px;color:var(--faint)}.user-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.user-card{display:flex;flex-direction:column;gap:8px;padding:12px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);text-align:left;cursor:pointer;transition:.12s}.user-card:hover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.user-card-prev{display:block;width:100%;aspect-ratio:4 / 3;overflow:hidden;border-radius:8px;background:var(--wash);box-shadow:inset 0 0 0 1px #0000000f}.user-card-prev svg{display:block;width:100%;height:100%}.user-card-name{font-family:var(--display);font-size:15px;font-weight:700;color:var(--ink)}.user-card-blurb{font-size:12.5px;color:var(--muted);line-height:1.3}.user-card-count{font-size:11px;font-weight:600;color:var(--faint);text-transform:uppercase;letter-spacing:.04em}.tmpl-layout-tile{display:flex;flex-direction:column;padding-bottom:2px}.tmpl-tile-name{display:block;padding:7px 6px 4px;font-size:12px;font-weight:600;color:var(--ink-soft);text-align:center;line-height:1.2}.deck-grid-flow{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));grid-auto-rows:max-content;gap:14px}.tmpl-fs-head .tmpl-fs-close{margin-left:auto}.tmpl-fs-main{display:flex;flex:1 1 auto;min-height:0}.tmpl-fs-nav{flex:0 0 234px;width:234px;overflow-y:auto;padding:12px 10px;border-right:1px solid var(--line);background:var(--wash)}.tmpl-fs-col{flex:1 1 auto;min-width:0;display:flex;flex-direction:column}.tmpl-nav-group+.tmpl-nav-group{margin-top:3px}.tmpl-nav-head{display:flex;align-items:center;gap:9px;width:100%;padding:9px 10px;border:none;background:none;border-radius:9px;font:inherit;font-size:14px;font-weight:700;color:var(--ink);text-align:left;cursor:pointer;transition:background .1s,color .1s}.tmpl-nav-head:hover{background:var(--line-soft)}.tmpl-nav-head.active{color:var(--brand)}.tmpl-nav-ico{display:inline-flex;width:18px;height:18px;color:var(--muted)}.tmpl-nav-head.active .tmpl-nav-ico{color:var(--brand)}.tmpl-nav-ico svg{width:18px;height:18px}.tmpl-nav-chev{flex:0 0 auto;margin-left:auto;display:inline-flex;color:var(--faint);transition:transform .16s,color .1s}.tmpl-nav-chev svg{width:15px;height:15px}.tmpl-nav-head:hover .tmpl-nav-chev{color:var(--muted)}.tmpl-nav-head.expanded .tmpl-nav-chev{transform:rotate(90deg);color:var(--brand)}.tmpl-nav-sub{display:flex;flex-direction:column;gap:1px;margin:2px 0 7px 17px;padding-left:9px;border-left:1px solid var(--line)}.tmpl-nav-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;border:none;background:none;border-radius:8px;font:inherit;font-size:13px;color:var(--ink-soft);text-align:left;cursor:pointer;transition:background .1s,color .1s}.tmpl-nav-item:hover{background:var(--line-soft);color:var(--ink)}.tmpl-nav-item.active{background:var(--brand-tint);color:var(--brand-ink);font-weight:600}.tmpl-nav-subico{flex:0 0 auto;display:inline-flex;width:16px;height:16px;color:var(--muted)}.tmpl-nav-subico svg{width:16px;height:16px}.tmpl-nav-item.active .tmpl-nav-subico{color:var(--brand)}.tmpl-nav-label{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tmpl-nav-count{flex:0 0 auto;font-size:11px;font-weight:600;color:var(--faint)}.tmpl-nav-item.active .tmpl-nav-count{color:var(--brand)}.persona-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.persona-card{display:flex;align-items:center;gap:14px;padding:14px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);text-align:left;cursor:pointer;transition:.12s}.persona-card:hover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.persona-ico{flex:0 0 auto;width:58px;height:58px;display:grid;place-items:center;border-radius:15px;background:var(--brand-tint);color:var(--brand)}.persona-ico svg{width:30px;height:30px}.persona-text{display:flex;flex-direction:column;gap:2px;min-width:0}.persona-name{font-family:var(--display);font-size:15px;font-weight:700;color:var(--ink)}.persona-blurb{font-size:12px;color:var(--muted);line-height:1.3}.persona-count{font-size:11px;font-weight:600;color:var(--faint);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}.page-tab{position:relative}.page-tab[draggable=true]{cursor:grab}.page-tab.dragging{opacity:.45}.page-tab.drop-before:before,.page-tab.drop-after:after{content:"";position:absolute;top:6px;bottom:6px;width:3px;border-radius:2px;background:var(--brand);pointer-events:none}.page-tab.drop-before:before{left:-4px}.page-tab.drop-after:after{right:-4px}.table-panel .txt-scroll{padding:4px 14px 16px;gap:2px}.table-panel .txt-section-label{padding:10px 0 6px}.table-panel .tbl-size-row{display:flex;gap:12px;margin:2px 0 8px}.tbl-size-field{display:flex;flex-direction:column;gap:5px;flex:1;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--faint)}.tbl-num{height:38px;padding:0 10px;border:1px solid var(--line);border-radius:9px;background:var(--surface);color:var(--ink);font:inherit;font-size:14px}.tbl-num:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.tbl-contents-label{margin-top:8px}.tbl-grid{display:grid;gap:1px;margin:4px 0 14px;overflow-x:auto;background:var(--line);border:1px solid var(--line);border-radius:8px}.tbl-cell{width:100%;min-width:0;height:32px;padding:0 8px;border:none;border-radius:0;background:var(--surface);color:var(--ink);font:inherit;font-size:12.5px}.tbl-cell:focus-visible{outline:none;box-shadow:inset 0 0 0 2px var(--accent);position:relative;z-index:1}.tbl-contents-head{display:flex;align-items:baseline;justify-content:space-between;padding:10px 0 4px}.tbl-contents-title{font-size:11px;font-weight:600;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em}.tbl-clear{border:none;background:none;color:var(--muted);font:inherit;font-size:12px;font-weight:600;cursor:pointer;padding:2px 4px;border-radius:6px}.tbl-clear:hover{color:var(--brand);background:var(--brand-tint)}.tbl-hint{margin:-6px 0 12px;font-size:11.5px;color:var(--muted);line-height:1.35}.tbl-import-row{margin:0 0 6px}.tbl-file{display:none}.tbl-import{display:inline-flex;align-items:center;gap:7px;width:100%;justify-content:center;padding:8px 10px;border:1px solid var(--line);border-radius:9px;background:var(--surface);color:var(--ink-soft);font:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:.12s}.tbl-import:hover{border-color:var(--accent);color:var(--ink);background:var(--wash)}.tbl-import svg{width:16px;height:16px}.tbl-styles{margin-top:8px;padding-top:12px;border-top:1px solid var(--line)}.tbl-styles-hint{margin:2px 0 6px}.tbl-style-tier{font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);margin:10px 0 5px}.tbl-style-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(46px,1fr));gap:6px}.tbl-style-tile{display:block;padding:0;line-height:0;overflow:hidden;border:1px solid var(--line);border-radius:6px;background:var(--surface);cursor:pointer;transition:.12s}.tbl-style-tile:hover{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.tbl-style-tile svg{display:block;width:100%;height:auto}.ctx-num{width:60px;height:30px;padding:0 7px;border:1px solid var(--line);border-radius:7px;background:var(--surface);color:var(--ink);font:inherit;font-size:12.5px}.ctx-num:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.ctx-select{height:30px;padding:0 6px;border:1px solid var(--line);border-radius:7px;background:var(--surface);color:var(--ink);font:inherit;font-size:12.5px;cursor:pointer}.ctx-select:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.ctx-x{color:var(--muted);font-size:12px;padding:0 1px}.ctx-txtbtn{min-width:30px;font-size:14px}.ctx-txtbtn.ctx-bold{font-weight:700}.ctx-txtbtn.ctx-italic{font-style:italic}.ctx-txtbtn.ctx-underline{text-decoration:underline}.ctx-txtbtn.ctx-strike{text-decoration:line-through}.context .font-picker{width:auto;min-width:110px;max-width:170px;height:30px}.ctx-wordart-a{font-weight:700;font-size:15px;line-height:1}.ctx-wordart-pop{position:fixed;z-index:1000;width:260px;padding:8px;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 32px #0000002e}.ctx-wordart-pop .wordart-grid{margin-bottom:0}.ctx-props{gap:6px;padding:0 10px;font-size:12px}.ctx-props svg{width:15px;height:15px}.ctx-ico{display:inline-flex;align-items:center;color:var(--ink-soft);flex:none}.ctx-ico svg{width:16px;height:16px}.ctx-pp{width:auto;padding:0 9px;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}.ctx-pp .ctx-caret{margin-left:1px}.ctx-pp-label{font-size:12px;white-space:nowrap}.ctx-pp .ctx-menu-ico svg{width:16px;height:16px}.ctx-menu-ico{display:inline-flex;align-items:center;flex:none}.ctx-menu{position:fixed;z-index:9999;min-width:204px;background:var(--surface);border:1px solid var(--line);border-radius:10px;box-shadow:0 8px 32px #0000002e,0 2px 8px #0000001a;padding:6px;display:flex;flex-direction:column;gap:1px;max-height:80vh;overflow-y:auto}.ctx-menu-label{font-size:11px;color:var(--ink-soft);padding:5px 8px 2px}.ctx-menu-sep{height:1px;background:var(--line);margin:4px 2px}.ctx-menu-item{display:flex;align-items:center;gap:9px;width:100%;padding:6px 8px;border:none;background:none;cursor:pointer;border-radius:7px;color:var(--ink);font:inherit;font-size:13px;text-align:left}.ctx-menu-item:hover,.ctx-menu-item.ctx-open{background:var(--bg)}.ctx-menu-item .ctx-menu-ico svg{width:16px;height:16px}.ctx-menu-text{flex:1}.ctx-menu-arrow{color:var(--ink-soft);display:inline-flex;flex:none}.ctx-menu-arrow svg{width:17px;height:17px;transform:rotate(-90deg)}.ctx-swatch-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:3px;padding:2px 8px 4px}.ctx-swatch{width:100%;aspect-ratio:1;border-radius:3px;border:1px solid rgba(0,0,0,.18);cursor:pointer;padding:0}.ctx-swatch:hover{outline:2px solid var(--accent);outline-offset:1px}.ctx-effect-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:8px}.ctx-effect-grid .shape-style-cell{width:100%;aspect-ratio:1}.ctx-shapestyles-fly{width:224px}.ctx-shapestyles-fly .shape-styles-grid:last-child{margin-bottom:0}.preset-trigger--compact{width:auto;min-width:0;height:30px;display:inline-flex;align-items:center;gap:5px;padding:0 8px}.preset-trigger--compact .preset-trigger-ico{display:inline-flex;width:16px;height:16px;color:var(--ink-soft)}.preset-trigger--compact .preset-trigger-ico svg{width:16px;height:16px}.preset-trigger--compact .preset-trigger-caret{font-size:10px;color:var(--muted)}.color-popover--inline{position:static;z-index:auto;width:250px;padding:2px;background:none;border:none;box-shadow:none}.color-popover--inline .mini-swatch{width:100%;height:auto;aspect-ratio:1;justify-self:stretch}.ctx-color-dot{display:block;width:14px;height:14px;border-radius:4px;border:1px solid rgba(0,0,0,.2)}.ctx-field{display:flex;flex-direction:column;gap:7px;padding:7px 10px;min-width:212px}.ctx-field-label{font-size:11px;font-weight:600;color:var(--ink-soft)}.ctx-field .slider-field{width:100%}.ctx-dash-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}.ctx-dash-tile{width:100%;height:26px;padding:0;color:var(--ink);display:grid;place-items:center;cursor:pointer;border:1px solid var(--line);border-radius:var(--r-xs);background:var(--surface);transition:border-color .12s,background .12s,box-shadow .12s}.ctx-dash-tile svg{width:38px;height:12px;display:block}.ctx-dash-tile:hover{border-color:var(--brand-tint-2);background:var(--wash)}.ctx-dash-tile.selected{border-color:var(--brand);box-shadow:inset 0 0 0 1px var(--brand)}.ctx-effects{display:flex;flex-direction:column;gap:7px;padding:8px 10px;min-width:248px}.ctx-effects-head{display:flex;align-items:center;gap:0}.ctx-effects-head .ctx-menu-ico{color:var(--ink-soft)}.ctx-effects-title{flex:1;font-size:12px;font-weight:700;color:var(--ink)}.ctx-field-row{display:flex;align-items:center;gap:10px}.ctx-field-row>.ctx-field-label{width:62px;flex:none}.ctx-field-row .slider-field{flex:1;min-width:0}.ctx-field-row .color-swatch{flex:1;height:30px;border-radius:var(--r-sm)}.ctx-effects .ctx-effect-grid{grid-template-columns:repeat(6,1fr);gap:6px;padding:0}.palette-brand{display:inline-flex;align-items:center;gap:4px}.palette-brand:empty{display:none}.palette-brand-sep{width:1px;align-self:stretch;margin:2px 4px;background:var(--line);flex:none}.brand-panel{display:flex;flex-direction:column;gap:14px;padding:14px 12px;box-sizing:border-box}.brand-intro{margin:0;font-size:12px;color:var(--muted);line-height:1.45}.brand-section{display:flex;flex-direction:column;gap:10px;padding:14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--sh-sm)}.brand-section-label{font-family:var(--display);font-size:13px;font-weight:700;color:var(--ink);letter-spacing:-.01em}.brand-chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.brand-empty{font-size:12px;color:var(--faint);font-style:italic;grid-column:1 / -1}.brand-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 5px 3px 3px;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--wash);transition:border-color .12s,box-shadow .12s}.brand-chip:hover{border-color:var(--brand-tint-2);box-shadow:var(--sh-sm)}.brand-chip-sw{width:20px;height:20px;border-radius:50%;border:1px solid rgba(0,0,0,.12)}.brand-chip-font{font-size:13px;padding:0 4px;color:var(--ink);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.brand-color-chip{cursor:pointer}.brand-chip-hex{font-size:12px;color:var(--ink-soft);letter-spacing:.02em;font-variant-numeric:tabular-nums}.brand-chip-del{width:16px;height:16px;line-height:1;border:none;border-radius:50%;background:transparent;color:var(--muted);cursor:pointer;font-size:14px;display:grid;place-items:center;flex:none;transition:background .12s,color .12s}.brand-chip-del:hover{background:var(--brand-tint-2);color:var(--brand-ink)}.brand-add-row{display:flex;align-items:center;gap:8px}.brand-add-row .color-swatch,.brand-add-row .font-picker{flex:1;min-width:0;height:34px}.brand-add-row .color-swatch{width:auto;border-radius:var(--r-sm)}.brand-add{flex:none;width:34px;height:34px;padding:0;cursor:pointer;display:grid;place-items:center;border:none;border-radius:var(--r-sm);background:var(--brand);color:#fff;transition:background .12s}.brand-add:hover{background:var(--brand-strong)}.brand-add:active{background:var(--brand-press)}.brand-add svg{width:18px;height:18px}.brand-logos{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.brand-logo-tile{position:relative;aspect-ratio:1;overflow:hidden;cursor:pointer;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--wash);transition:border-color .12s,box-shadow .12s}.brand-logo-tile:hover{border-color:var(--brand-tint-2);box-shadow:var(--sh-sm)}.brand-logo-tile img{width:100%;height:100%;object-fit:contain;display:block;padding:6px}.brand-logo-del{position:absolute;top:3px;right:3px;width:18px;height:18px;border:none;border-radius:50%;background:#0000008c;color:#fff;cursor:pointer;font-size:13px;line-height:1;display:grid;place-items:center;opacity:0;transition:opacity .12s}.brand-logo-tile:hover .brand-logo-del{opacity:1}.brand-logo-add{aspect-ratio:1;display:grid;place-items:center;cursor:pointer;border:1.5px dashed var(--line);border-radius:var(--r-sm);background:var(--wash);color:var(--muted);transition:border-color .12s,color .12s,background .12s}.brand-logo-add:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-tint)}.brand-logo-add svg{width:22px;height:22px}.auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:var(--canvas-bg, #f0f0f0)}.auth-card{background:var(--surface, #fff);border:1px solid var(--border, #e0e0e0);border-radius:14px;padding:2.5rem 2.75rem;width:100%;max-width:400px;box-shadow:0 8px 40px #0000001f}.auth-logo{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1.1rem;margin-bottom:1.75rem;color:var(--ink, #111)}.auth-title{font-size:1.5rem;font-weight:700;margin:0 0 1.25rem;color:var(--ink, #111)}.auth-err{color:var(--red, #e53e3e);min-height:1.25em;font-size:.875rem;margin:0 0 .5rem;font-weight:500}.auth-form{display:flex;flex-direction:column;gap:.875rem}.auth-form label{display:flex;flex-direction:column;gap:.35rem;font-size:.875rem;font-weight:500;color:var(--ink-soft, #555)}.auth-form input{border:1.5px solid var(--border, #ddd);border-radius:8px;padding:.6rem .8rem;font-size:1rem;color:var(--ink, #111);background:var(--input-bg, #fff);outline:none;transition:border-color .15s}.auth-form input:focus{border-color:var(--brand, #4f46e5);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand, #4f46e5) 15%,transparent)}.auth-submit{margin-top:.375rem;padding:.7rem 1rem;background:var(--brand, #4f46e5);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s}.auth-submit:hover:not(:disabled){opacity:.88}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-switch{text-align:center;margin:1.125rem 0 0;font-size:.875rem;color:var(--ink-soft, #666)}.auth-switch button{background:none;border:none;color:var(--brand, #4f46e5);cursor:pointer;font-size:inherit;padding:0;font-weight:500;text-decoration:underline}.auth-switch button:hover{opacity:.8}.auth-oauth{display:flex;flex-direction:column;gap:.6rem;margin-bottom:.25rem}.auth-oauth-btn{display:flex;align-items:center;gap:.65rem;padding:.6rem 1rem;border:1.5px solid var(--border, #ddd);border-radius:8px;background:var(--surface, #fff);color:var(--ink, #111);font-size:.9rem;font-weight:500;text-decoration:none;cursor:pointer;transition:background .12s,border-color .12s}.auth-oauth-btn:hover{background:var(--canvas-bg, #f5f5f5);border-color:var(--ink-soft, #aaa)}.auth-oauth-btn svg{flex-shrink:0}.auth-divider{display:flex;align-items:center;gap:.75rem;margin:1rem 0 .75rem;color:var(--ink-soft, #888);font-size:.8rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border, #e0e0e0)}
