@import"https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400..700;1,400..600&family=Source+Sans+3:ital,wght@0,300..700;1,400..600&family=IBM+Plex+Mono:wght@400;500;600&display=swap";:root{--paper-0: #F8F4EC;--paper-1: #ECE7DC;--paper-2: #E1DBCE;--paper-3: #CFC8B8;--paper-4: #B5AC9A;--ink-1: #15110C;--ink-2: #261E14;--ink-3: #5A4C3A;--ink-4: #8A7C68;--ink-5: #B5A993;--line-1: #D2CABA;--line-2: #B8AE99;--line-3: #918672;--yarn-terracotta:#B85C3A;--yarn-ochre: #C69334;--yarn-moss: #5B6F3A;--yarn-dusty-blue:#6A85A0;--yarn-plum: #7A4A52;--yarn-cream: #E8D6B3;--yarn-charcoal: #2E2823;--yarn-rust: #8E3A22;--success: #5B6F3A;--success-bg: #E6E4D2;--warning: #C69334;--warning-bg: #F2E6C7;--danger: #8E3A22;--danger-bg: #F0DDD0;--info: #6A85A0;--info-bg: #DDE3E9;--bg-app: var(--paper-1);--bg-panel: var(--paper-2);--bg-canvas: var(--paper-0);--bg-recessed: var(--paper-3);--bg-overlay: rgba(21, 17, 12, .5);--fg-1: var(--ink-1);--fg-2: var(--ink-2);--fg-3: var(--ink-3);--fg-4: var(--ink-4);--fg-on-dark: var(--paper-0);--border: var(--line-2);--border-hairline:var(--line-1);--border-strong: var(--line-3);--brand: var(--ink-2);--brand-hover: var(--ink-1);--accent: var(--yarn-terracotta);--font-serif: "Lora", "EB Garamond", Georgia, "Times New Roman", serif;--font-sans: "Source Sans 3", "Source Sans Pro", system-ui, sans-serif;--font-mono: "IBM Plex Mono", "SFMono-Regular", Menlo, Consolas, monospace;--fs-12: .75rem;--fs-13: .8125rem;--fs-14: .875rem;--fs-16: 1rem;--fs-18: 1.125rem;--fs-22: 1.375rem;--fs-28: 1.75rem;--fs-36: 2.25rem;--fs-48: 3rem;--fs-64: 4rem;--lh-tight: 1.15;--lh-snug: 1.3;--lh-normal: 1.5;--lh-relaxed: 1.65;--tracking-tight: -.01em;--tracking-normal: 0;--tracking-wide: .04em;--tracking-caps: .08em;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-0: 0;--radius-1: 2px;--radius-2: 4px;--radius-pill: 999px;--bw-hairline: 1px;--bw-strong: 2px;--shadow-0: none;--shadow-1: 0 1px 2px rgba(21, 17, 12, .08), 0 1px 1px rgba(21, 17, 12, .05);--shadow-2: 0 2px 6px rgba(21, 17, 12, .1), 0 1px 2px rgba(21, 17, 12, .06);--shadow-3: 0 8px 24px rgba(21, 17, 12, .14), 0 2px 6px rgba(21, 17, 12, .08);--shadow-inset: inset 0 1px 2px rgba(21, 17, 12, .08);--ease-out: cubic-bezier(.2, .7, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--dur-fast: .12s;--dur-base: .2s;--dur-slow: .32s;--dur-sheet: .28s;--rail-width: 56px;--inspector-width: 320px;--tabbar-height: 64px;--sheet-radius: 12px}html,body{background:var(--bg-app);color:var(--fg-2);font-family:var(--font-sans);font-size:var(--fs-16);line-height:var(--lh-normal);font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,.h1{font-family:var(--font-serif);font-size:var(--fs-48);line-height:var(--lh-tight);font-weight:500;letter-spacing:var(--tracking-tight);color:var(--fg-1);margin:0}h2,.h2{font-family:var(--font-serif);font-size:var(--fs-36);line-height:var(--lh-tight);font-weight:500;letter-spacing:var(--tracking-tight);color:var(--fg-1);margin:0}h3,.h3{font-family:var(--font-serif);font-size:var(--fs-28);line-height:var(--lh-snug);font-weight:500;color:var(--fg-1);margin:0}h4,.h4{font-family:var(--font-serif);font-size:var(--fs-22);line-height:var(--lh-snug);font-weight:500;color:var(--fg-1);margin:0}.display{font-family:var(--font-serif);font-size:var(--fs-64);line-height:var(--lh-tight);font-weight:500;letter-spacing:var(--tracking-tight);color:var(--fg-1)}.body{font-family:var(--font-sans);font-size:var(--fs-16);line-height:var(--lh-relaxed);color:var(--fg-2)}.body-sm{font-family:var(--font-sans);font-size:var(--fs-14);line-height:var(--lh-normal);color:var(--fg-2)}.lead{font-family:var(--font-sans);font-size:var(--fs-18);line-height:var(--lh-relaxed);color:var(--fg-2);font-weight:400}.label{font-family:var(--font-sans);font-size:var(--fs-13);font-weight:600;color:var(--fg-2);letter-spacing:var(--tracking-normal)}.caption{font-family:var(--font-sans);font-size:var(--fs-12);line-height:var(--lh-normal);color:var(--fg-3)}.eyebrow{font-family:var(--font-sans);font-size:var(--fs-12);font-weight:600;letter-spacing:var(--tracking-caps);text-transform:uppercase;color:var(--fg-3)}.num,input[type=number],.tabular{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}code,.code{font-family:var(--font-mono);font-size:.92em;background:var(--paper-3);padding:.05em .4em;border-radius:var(--radius-1);color:var(--fg-2)}a{color:var(--ink-2);text-decoration:underline;text-decoration-color:var(--line-2);text-decoration-thickness:1px;text-underline-offset:3px;transition:text-decoration-color var(--dur-fast) var(--ease-out)}a:hover{text-decoration-color:var(--ink-2)}::selection{background:var(--yarn-cream);color:var(--ink-1)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{background:var(--bg-app);color:var(--fg-2);font-family:var(--font-sans);overflow:hidden}button{font:inherit}.kc-app{display:grid;grid-template-rows:52px 1fr;height:100vh;width:100vw;background:var(--bg-app)}.kc-app-body{display:grid;min-height:0;overflow:hidden}.kc-app-layout-right .kc-app-body{grid-template-columns:1fr 340px}.kc-app-layout-left .kc-app-body{grid-template-columns:340px 1fr}.kc-app-layout-left .kc-inspector{order:-1}.kc-app-layout-bottom .kc-app-body{grid-template-rows:1fr auto;grid-template-columns:1fr}.kc-app-layout-bottom .kc-inspector{height:320px;max-height:45vh;border-left:none;border-top:1px solid var(--line-1);overflow-y:auto}.kc-app-layout-bottom .kc-inspector .kc-section{display:inline-block;vertical-align:top;min-width:280px;max-width:320px;margin-right:var(--space-6);white-space:normal}.kc-app-layout-bottom .kc-inspector{white-space:nowrap;overflow-x:auto;overflow-y:hidden;padding:var(--space-5) var(--space-6)}.kc-app-layout-bottom .kc-section-divider{display:inline-block;width:1px;height:100%;border-top:none;border-left:1px solid var(--line-1);margin:0 var(--space-4);vertical-align:top}.kc-topbar{display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-5);background:var(--paper-2);border-bottom:1px solid var(--line-1);height:52px}.kc-topbar-brand{display:flex;align-items:center;gap:var(--space-3)}.kc-topbar-brand img{display:block}.kc-topbar-title{font-family:var(--font-serif);font-size:19px;font-weight:500;color:var(--fg-1);letter-spacing:var(--tracking-tight)}.kc-topbar-tag{font-family:var(--font-sans);font-size:10px;font-weight:600;text-transform:lowercase;letter-spacing:var(--tracking-caps);color:var(--fg-3);background:var(--paper-3);padding:2px 6px;border-radius:var(--radius-pill)}.kc-topbar-actions{display:flex;align-items:center;gap:var(--space-2)}.kc-topbar-help{background:transparent;border:none;font-family:var(--font-sans);font-size:13px;color:var(--fg-3);cursor:pointer;display:inline-flex;align-items:center;gap:5px;padding:6px 10px;border-radius:var(--radius-1);transition:background var(--dur-fast),color var(--dur-fast)}.kc-topbar-help:hover{background:var(--paper-3);color:var(--fg-2)}.kc-main{display:flex;flex-direction:column;min-width:0;min-height:0;background:var(--paper-1);overflow:hidden;position:relative}.kc-canvas-stage{display:flex;flex-direction:column;flex:1;min-height:0;position:relative}.kc-canvas-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:10px var(--space-5);border-bottom:1px solid var(--line-1);background:var(--paper-1)}.kc-canvas-toolbar-l,.kc-canvas-toolbar-r{display:flex;align-items:center;gap:var(--space-2)}.kc-canvas-divider{width:1px;height:20px;background:var(--line-1);margin:0 var(--space-2)}.kc-canvas-mode-label{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:12px;color:var(--fg-3);white-space:nowrap}.kc-canvas-mode-select{height:30px;padding:0 24px 0 10px;font-family:var(--font-sans);font-size:12px;font-weight:500;color:var(--fg-1);background-color:var(--paper-0);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 8px center;background-size:10px 10px;border:1px solid var(--line-2);border-radius:var(--radius-1);cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;transition:background-color var(--dur-fast)}.kc-canvas-mode-select:hover{background-color:var(--paper-2)}.kc-canvas-mode-select:focus{outline:none;border-color:var(--ink-2);box-shadow:0 0 0 2px #b85c3a2e}.kc-canvas-zoom{font-family:var(--font-mono);font-size:12px;color:var(--fg-3);min-width:48px;text-align:center}.kc-canvas-scroll{flex:1;overflow:auto;padding:var(--space-6);display:grid;place-items:start center;background:var(--paper-1);position:relative}.kc-canvas-busy{position:absolute;top:12px;left:12px;background:var(--paper-0);border:1px solid var(--line-2);border-radius:var(--radius-1);padding:6px 12px;font-size:12px;font-weight:600;color:var(--fg-3);z-index:5;box-shadow:var(--shadow-1)}.chart-wrap{background:var(--paper-0);border:1px solid var(--line-2);border-radius:var(--radius-2);box-shadow:var(--shadow-1);padding:var(--space-3);display:inline-block}.chart-ruler{display:flex;font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:10px;color:var(--fg-4);-webkit-user-select:none;user-select:none}.chart-ruler-top{padding-bottom:2px}.chart-ruler-left{flex-direction:column;padding-right:4px;text-align:right}.chart-ruler-cell{display:flex;align-items:center;justify-content:center;flex:0 0 auto}.chart-ruler-left .chart-ruler-cell{justify-content:flex-end;padding-right:4px}.chart-ruler-cell.is-major{color:var(--fg-2);font-weight:500}.chart-grid{border:1.5px solid var(--ink-2);background:var(--paper-0)}.chart-cell{display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-weight:500;line-height:1;-webkit-user-select:none;user-select:none}.kc-empty-wrap{display:flex;align-items:center;justify-content:center;padding:var(--space-8)}.kc-empty{flex:1;max-width:720px;display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;padding:var(--space-12) var(--space-8);border:1.5px dashed var(--line-2);border-radius:var(--radius-2);background:var(--paper-0);transition:border-color var(--dur-base),background var(--dur-base)}.kc-empty-wrap.is-drag .kc-empty{border-color:var(--ink-2);background:var(--paper-2)}.kc-empty img{width:140px;height:auto;opacity:.92}.kc-empty h2{margin:4px 0}.kc-empty .lead{color:var(--fg-3);max-width:380px;margin:0}.kc-empty .eyebrow{color:var(--fg-3)}.kc-empty-actions{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);margin-top:var(--space-4)}.kc-empty-or{color:var(--fg-4);font-size:12px;text-transform:lowercase;letter-spacing:var(--tracking-caps)}.kc-empty-samples{display:flex;gap:var(--space-3);flex-wrap:wrap;justify-content:center}.kc-empty-sample{display:flex;flex-direction:column;align-items:center;gap:6px;padding:var(--space-3) var(--space-4);background:var(--paper-0);border:1px solid var(--line-2);border-radius:var(--radius-2);font-family:var(--font-sans);font-size:13px;font-weight:500;color:var(--fg-2);cursor:pointer;transition:border-color var(--dur-fast),background var(--dur-fast)}.kc-empty-sample:hover{border-color:var(--ink-2);background:var(--paper-1)}.kc-drag-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#f8f4eceb;border:2.5px dashed var(--ink-2);display:grid;place-items:center;z-index:20;pointer-events:none}.kc-drag-overlay-card{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--ink-2)}.kc-inspector{background:var(--paper-2);border-left:1px solid var(--line-1);padding:var(--space-5) var(--space-5) var(--space-6);overflow-y:auto;min-width:0}.kc-app-layout-left .kc-inspector{border-left:none;border-right:1px solid var(--line-1)}.kc-section{margin-bottom:var(--space-4)}.kc-section:first-child{margin-top:0}.kc-section-divider{border-top:1px solid var(--line-1);margin:var(--space-4) 0}.kc-section-title{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin:0 0 var(--space-3)}.kc-section-title>span:first-child,.kc-section-title-toggle>span{font-family:var(--font-serif);font-size:20px;font-weight:500;color:var(--fg-1);letter-spacing:var(--tracking-tight)}.kc-section-title .caption{color:var(--fg-3)}.kc-section-title-toggle{display:inline-flex;align-items:center;gap:8px;background:none;border:none;padding:0;margin:0;cursor:pointer;color:inherit;text-align:left}.kc-section-title-toggle:hover{color:var(--fg-2)}.kc-section-title-toggle:focus-visible{outline:2px solid var(--accent, #888);outline-offset:2px;border-radius:2px}.kc-field{margin-bottom:var(--space-4)}.kc-field-label{display:block;font-family:var(--font-sans);font-size:12px;font-weight:600;color:var(--fg-3);text-transform:uppercase;letter-spacing:var(--tracking-caps);margin-bottom:8px}.kc-field-hint{font-family:var(--font-sans);font-size:12px;color:var(--fg-3);margin-top:6px;line-height:var(--lh-normal)}.kc-row{display:flex;align-items:center;gap:var(--space-2)}.kc-stack{display:flex;flex-direction:column;gap:4px}.kc-full{width:100%;justify-content:center}.kc-times{font-family:var(--font-serif);font-size:16px;color:var(--fg-3);padding:0 6px}.kc-grid-size{display:flex;align-items:center;gap:0}.kc-num-wrap{display:inline-flex;align-items:stretch;border:1px solid var(--line-2);border-radius:var(--radius-1);background:var(--paper-0);box-shadow:var(--shadow-inset);overflow:hidden}.kc-num-wrap:focus-within{border-color:var(--ink-2);box-shadow:0 0 0 2px #b85c3a2e,var(--shadow-inset)}.kc-num-step{background:transparent;border:none;padding:0 10px;cursor:pointer;color:var(--fg-2);font-size:16px;line-height:1;font-family:var(--font-sans);font-weight:500;transition:background var(--dur-fast)}.kc-num-step:hover{background:var(--paper-2)}.kc-num{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;font-size:14px;color:var(--ink-1);background:transparent;border:none;padding:7px 6px;outline:none;text-align:center;width:56px;-moz-appearance:textfield}.kc-num::-webkit-outer-spin-button,.kc-num::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.kc-num-suffix{font-family:var(--font-sans);font-size:12px;color:var(--fg-3);padding:0 8px;display:inline-flex;align-items:center;border-left:1px solid var(--line-1);background:var(--paper-1)}.kc-text{font-family:var(--font-sans);font-size:14px;color:var(--ink-1);background:var(--paper-0);border:1px solid var(--line-2);padding:7px 10px;border-radius:var(--radius-1);box-shadow:var(--shadow-inset);outline:none;width:100%}.kc-text:focus{border-color:var(--ink-2);box-shadow:0 0 0 2px #b85c3a2e,var(--shadow-inset)}.kc-seg{display:inline-flex;border:1px solid var(--line-2);border-radius:var(--radius-1);overflow:hidden;background:var(--paper-0);width:100%}.kc-seg button{flex:1;font-family:var(--font-sans);font-size:13px;font-weight:500;border:none;background:transparent;padding:8px 10px;color:var(--fg-2);cursor:pointer;border-right:1px solid var(--line-1);transition:background var(--dur-fast);display:inline-flex;align-items:center;justify-content:center;gap:5px;white-space:nowrap}.kc-seg button:last-child{border-right:none}.kc-seg button:hover{background:var(--paper-2)}.kc-seg button.is-on{background:var(--paper-3);color:var(--fg-1);font-weight:600}.kc-seg-sm button{padding:6px 10px;font-size:12px}.kc-slider{display:flex;flex-direction:column;gap:4px}.kc-range{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;background:var(--paper-3);border-radius:999px;outline:none;margin:8px 0 2px}.kc-range::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:999px;background:var(--ink-2);border:2px solid var(--paper-0);box-shadow:0 1px 3px #15110c40;cursor:pointer}.kc-range::-moz-range-thumb{width:16px;height:16px;border-radius:999px;background:var(--ink-2);border:2px solid var(--paper-0);cursor:pointer}.kc-slider-bounds{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--font-mono);font-size:11px;color:var(--fg-4)}.kc-slider-cur{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-weight:600;font-size:13px;color:var(--fg-1)}.kc-btn{font-family:var(--font-sans);font-size:14px;font-weight:600;cursor:pointer;border-radius:var(--radius-1);border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:background var(--dur-fast),border-color var(--dur-fast),color var(--dur-fast);white-space:nowrap}.kc-btn:disabled{opacity:.4;cursor:not-allowed}.kc-btn-md{padding:8px 14px}.kc-btn-sm{padding:6px 11px;font-size:13px}.kc-btn-lg{padding:12px 22px;font-size:15px}.kc-btn-primary{background:var(--ink-2);color:var(--paper-0);border-color:var(--ink-2)}.kc-btn-primary:hover:not(:disabled){background:var(--ink-1)}.kc-btn-secondary{background:var(--paper-0);color:var(--ink-2);border-color:var(--line-2)}.kc-btn-secondary:hover:not(:disabled){background:var(--paper-1);border-color:var(--line-3)}.kc-btn-ghost{background:transparent;color:var(--ink-2);border-color:transparent}.kc-btn-ghost:hover:not(:disabled){background:var(--paper-3)}.kc-icon-btn{width:30px;height:30px;padding:0;display:inline-grid;place-items:center;background:var(--paper-0);border:1px solid var(--line-2);color:var(--ink-2);border-radius:var(--radius-1);cursor:pointer;transition:background var(--dur-fast);flex-shrink:0}.kc-icon-btn:hover{background:var(--paper-2)}.kc-icon-btn.is-active{background:var(--paper-3);color:var(--ink-1);border-color:var(--line-3)}.kc-dropzone-mini{width:100%;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--paper-0);border:1.5px dashed var(--line-2);border-radius:var(--radius-2);cursor:pointer;color:var(--fg-2);text-align:left;transition:border-color var(--dur-fast),background var(--dur-fast)}.kc-dropzone-mini:hover{border-color:var(--ink-2);background:var(--paper-1)}.kc-dropzone-mini .body-sm{display:flex;flex-direction:column;gap:2px;line-height:1.3}.kc-dropzone-mini strong{font-family:var(--font-sans);font-size:14px;font-weight:600;color:var(--fg-1)}.kc-dropzone-mini .caption{font-size:12px;color:var(--fg-3)}.kc-sample-chips{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:8px}.kc-sample-chip{display:flex;flex-direction:column;align-items:center;gap:5px;padding:8px 6px;background:var(--paper-0);border:1px solid var(--line-1);border-radius:var(--radius-1);font-family:var(--font-sans);font-size:11px;color:var(--fg-2);cursor:pointer;transition:border-color var(--dur-fast),background var(--dur-fast)}.kc-sample-chip:hover{border-color:var(--line-3);background:var(--paper-1)}.kc-sample-chip.is-on{border-color:var(--ink-2);background:var(--paper-1)}.kc-sample-thumb{display:grid;width:32px;height:32px;background:var(--paper-2);border-radius:2px;overflow:hidden}.kc-sample-thumb span{display:block}.kc-palette-set-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.kc-palette-set{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:8px;background:var(--paper-0);border:1px solid var(--line-1);border-radius:var(--radius-1);cursor:pointer;text-align:left;transition:border-color var(--dur-fast)}.kc-palette-set:hover{border-color:var(--line-3)}.kc-palette-set.is-on{border-color:var(--ink-2);border-width:1.5px;padding:7.5px}.kc-palette-set-swatches{display:flex;gap:2px;width:100%;height:14px}.kc-palette-set-swatches>span{flex:1;border-radius:1px}.kc-palette-set-name{font-family:var(--font-sans);font-size:12px;font-weight:500;color:var(--fg-2)}.kc-palette-set.is-on .kc-palette-set-name{font-weight:600;color:var(--fg-1)}.kc-palette-list{display:flex;flex-direction:column;gap:4px}.kc-palette-row{display:grid;grid-template-columns:18px 24px 1fr;grid-template-rows:auto auto;gap:0 8px;padding:8px;background:var(--paper-0);border:1px solid var(--line-1);border-radius:var(--radius-1);align-items:center}.kc-palette-symbol{grid-row:1 / 3;font-family:var(--font-mono);font-size:16px;font-weight:600;color:var(--ink-1);text-align:center}.kc-palette-swatch{grid-row:1 / 3;width:24px;height:24px;border-radius:2px;border:1px solid rgba(21,17,12,.18)}.kc-palette-swatch.sm{width:14px;height:14px}.kc-palette-info{grid-column:3;grid-row:1;display:flex;justify-content:space-between;align-items:baseline;gap:8px}.kc-palette-name{font-family:var(--font-sans);font-size:13px;font-weight:500;color:var(--fg-1)}.kc-palette-info .caption{font-size:11px;color:var(--fg-3)}.kc-palette-bar{grid-column:3;grid-row:2;height:3px;background:var(--paper-2);border-radius:999px;overflow:hidden;margin-top:4px}.kc-palette-bar-fill{display:block;height:100%;border-radius:999px;transition:width var(--dur-base) var(--ease-out)}.kc-palette-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:8px}.kc-palette-tile{display:flex;flex-direction:column;align-items:stretch;gap:4px;padding:0}.kc-palette-tile-swatch{aspect-ratio:1 / 1;border-radius:2px;border:1px solid rgba(21,17,12,.18);display:grid;place-items:center;position:relative}.kc-palette-tile-symbol{font-family:var(--font-mono);font-size:22px;font-weight:600;mix-blend-mode:difference;color:#fff;opacity:.65}.kc-palette-tile-name{font-family:var(--font-sans);font-size:11px;font-weight:500;color:var(--fg-2)}.kc-palette-tile-meta{font-family:var(--font-mono);font-size:10px;color:var(--fg-3)}.kc-palette-auto{display:flex;flex-direction:column;gap:10px}.kc-palette-stack{display:flex;height:32px;border-radius:2px;overflow:hidden;border:1px solid rgba(21,17,12,.18)}.kc-palette-stack-seg{display:grid;place-items:center;font-family:var(--font-mono);font-size:14px;color:#ffffffbf;mix-blend-mode:normal}.kc-palette-auto-list{display:flex;flex-direction:column;gap:4px}.kc-palette-auto-row{display:grid;grid-template-columns:14px 1fr auto;align-items:center;gap:8px;padding:4px 6px;border-radius:2px}.kc-text-panel{border-top:1px solid var(--line-1);background:var(--paper-2);display:flex;flex-direction:column;max-height:38vh;min-height:200px}.kc-text-panel-head{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid var(--line-1);background:var(--paper-2)}.kc-text-panel-title{font-family:var(--font-serif);font-size:16px;font-weight:500;color:var(--fg-1);flex:1}.kc-text-panel-search{width:96px;font-family:var(--font-mono)}.kc-text-list{list-style:none;padding:0;margin:0;overflow-y:auto;flex:1}.kc-text-list li{display:grid;grid-template-columns:80px 16px 1fr;gap:12px;padding:10px 16px;border-bottom:1px solid var(--line-1);font-family:var(--font-sans);font-size:13px;line-height:1.45;color:var(--fg-2);align-items:baseline}.kc-text-list li:hover{background:var(--paper-1)}.kc-text-list-row{font-family:var(--font-sans);font-size:13px;font-weight:600;color:var(--fg-1)}.kc-text-list-row.num{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.kc-text-list-rev{color:var(--fg-4);font-size:12px}.kc-text-list-chunks{display:flex;flex-wrap:wrap;gap:4px 14px}.kc-text-list-chunk{display:inline-flex;align-items:center;gap:5px;white-space:nowrap}.kc-text-list-dot{width:10px;height:10px;border-radius:999px;border:1px solid rgba(21,17,12,.15)}.kc-section-export{display:flex;flex-direction:column;gap:8px}.kc-toast-stack{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:300;pointer-events:none}.kc-toast{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border-radius:var(--radius-1);border:1px solid;font-family:var(--font-sans);font-size:13px;font-weight:500;box-shadow:var(--shadow-2);pointer-events:auto;animation:toast-in .22s var(--ease-out)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.kc-toast-success{background:var(--success-bg);border-color:#c8cba9;color:#3f4f25}.kc-toast-success .kc-toast-dot{background:var(--success)}.kc-toast-error{background:var(--danger-bg);border-color:#d49e81;color:#7a2c15}.kc-toast-error .kc-toast-dot{background:var(--danger)}.kc-toast-dot{width:8px;height:8px;border-radius:999px}.kc-toast-x{background:transparent;border:none;cursor:pointer;color:inherit;opacity:.55;font-size:16px;line-height:1;padding:0;margin-left:4px}.kc-toast-x:hover{opacity:1}.kc-help-popover{position:fixed;top:60px;right:20px;width:340px;background:var(--paper-0);border:1px solid var(--line-2);border-radius:var(--radius-2);box-shadow:var(--shadow-3);z-index:200;padding:var(--space-4);animation:pop-in .22s var(--ease-out)}@keyframes pop-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.kc-help-popover header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.kc-help-popover h4{margin:0}.kc-help-popover ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:13px;color:var(--fg-2);line-height:1.5}.kc-help-popover li:before{content:"— ";color:var(--fg-4)}.kc-help-popover strong{color:var(--fg-1)}.kc-knit-mode{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--paper-1);display:flex;flex-direction:column;z-index:50}.kc-knit-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--line-1);background:var(--paper-2)}.kc-knit-back,.kc-knit-reset{display:inline-flex;align-items:center;gap:5px;background:transparent;border:none;cursor:pointer;font-family:var(--font-sans);font-size:14px;font-weight:600;color:var(--ink-2);padding:6px 10px;border-radius:var(--radius-1)}.kc-knit-back:hover,.kc-knit-reset:hover{background:var(--paper-3)}.kc-knit-title{font-family:var(--font-serif);font-size:18px;font-weight:500;color:var(--fg-1)}.kc-knit-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;gap:32px;max-width:800px;margin:0 auto;width:100%}.kc-knit-mini{width:100%;max-width:460px;background:var(--paper-0);border:1px solid var(--line-2);border-radius:var(--radius-2);padding:6px;box-shadow:var(--shadow-1)}.kc-knit-mini-chart{display:grid;gap:0}.kc-knit-mini-cell{aspect-ratio:1 / 1;border:.5px solid rgba(42,31,18,.06);opacity:.4}.kc-knit-mini-cell.is-current{opacity:1;outline:1.5px solid var(--ink-2);outline-offset:-1px;position:relative;z-index:1}.kc-knit-current{width:100%;max-width:700px;display:flex;flex-direction:column;gap:16px;align-items:center}.kc-knit-counter{display:flex;align-items:baseline;gap:10px}.kc-knit-counter>.num{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:30px;font-weight:500;color:var(--fg-1)}.kc-knit-counter-of{font-family:var(--font-sans);font-size:16px;color:var(--fg-3)}.kc-knit-counter-of .num{font-family:var(--font-mono);font-weight:500;color:var(--fg-2);font-size:16px}.kc-knit-rev{font-family:var(--font-serif);font-style:italic;font-size:14px;color:var(--fg-3);margin-left:4px}.kc-knit-instruction{display:flex;flex-wrap:wrap;gap:12px 18px;justify-content:center;font-family:var(--font-sans);font-size:22px;line-height:1.4;color:var(--fg-1);padding:24px 28px;background:var(--paper-0);border:1px solid var(--line-1);border-radius:var(--radius-2);width:100%}.kc-knit-chunk{display:inline-flex;align-items:center;gap:8px;white-space:nowrap}.kc-knit-chunk-dot{width:16px;height:16px;border-radius:999px;border:1px solid rgba(42,31,18,.2)}.kc-knit-chunk-num{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-weight:600;color:var(--fg-1)}.kc-knit-chunk-name{color:var(--fg-2)}.kc-knit-progress{width:100%;max-width:500px;height:4px;background:var(--paper-3);border-radius:999px;overflow:hidden}.kc-knit-progress-bar{height:100%;background:var(--ink-2);transition:width var(--dur-base) var(--ease-out)}.kc-knit-footer{display:flex;gap:12px;padding:16px 24px 24px;border-top:1px solid var(--line-1);background:var(--paper-2)}.kc-knit-nav{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-sans);font-size:16px;font-weight:600;padding:14px 22px;border-radius:var(--radius-1);cursor:pointer;border:1px solid transparent;transition:background var(--dur-fast)}.kc-knit-nav-back{background:var(--paper-0);color:var(--ink-2);border-color:var(--line-2);flex:0 0 30%}.kc-knit-nav-back:hover:not(:disabled){background:var(--paper-2)}.kc-knit-nav-next{background:var(--ink-2);color:var(--paper-0);border-color:var(--ink-2);flex:1}.kc-knit-nav-next:hover:not(:disabled){background:var(--ink-1)}.kc-knit-nav:disabled{opacity:.4;cursor:default}@media (max-width: 900px){.kc-app-layout-right .kc-app-body,.kc-app-layout-left .kc-app-body{grid-template-columns:1fr;grid-template-rows:1fr auto}.kc-inspector{border-left:none;border-top:1px solid var(--line-1);max-height:50vh}}.kc-canvas-active-swatch{display:inline-block;width:18px;height:18px;border-radius:4px;border:1px solid var(--ink-2);flex-shrink:0}
