@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&family=Inter:wght@400;500;600;700&display=swap";
:root{--font-mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;--font-ui:"Inter", ui-sans-serif, system-ui, -apple-system, sans-serif;--r-sm:6px;--r-md:8px;--r-lg:12px;--topbar-h:56px;--panel-w-l:220px;--panel-w-r:260px;--gap:14px}[data-theme=dark]{--bg:#0d0f12;--bg-elev:#14171c;--bg-elev-2:#1a1e25;--bg-canvas:#0a0c10;--line:#232934;--line-strong:#2e3543;--text:#e7eaf0;--text-muted:#8a93a3;--text-dim:#5b6373;--accent:#d4ff5e;--accent-ink:#0a0c10;--accent-soft:#d4ff5e1a;--selection:#d4ff5e2e;--shadow:0 1px 0 #ffffff08, 0 8px 24px #00000059;--grid-faint:#ffffff09}[data-theme=light]{--bg:#f4f2ed;--bg-elev:#fff;--bg-elev-2:#faf8f3;--bg-canvas:#fbfaf6;--line:#e2dfd7;--line-strong:#c9c4b7;--text:#1a1a1a;--text-muted:#6b6657;--text-dim:#9a9384;--accent:#2a6f4d;--accent-ink:#fff;--accent-soft:#2a6f4d1a;--selection:#2a6f4d2e;--shadow:0 1px 0 #fff9, 0 8px 24px #1414140f;--grid-faint:#0000000a}*{box-sizing:border-box}html,body{height:100%;margin:0;padding:0}body{font-family:var(--font-ui);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;flex-direction:column;font-size:13px;display:flex;overflow:hidden}button{font-family:inherit}.topbar{height:var(--topbar-h);background:var(--bg-elev);border-bottom:1px solid var(--line);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 18px;display:flex}.brand{color:var(--accent);align-items:center;gap:10px;display:flex}.logo{display:block}.brand-name{font-family:var(--font-mono);letter-spacing:-.01em;color:var(--text);font-size:14px;font-weight:700}.brand-tag{font-family:var(--font-mono);color:var(--text-muted);border-left:1px solid var(--line);letter-spacing:.04em;text-transform:uppercase;margin-left:4px;padding-left:10px;font-size:11px}.btn-group{align-items:center;gap:6px;display:flex}.btn{background:var(--bg-elev-2);height:32px;color:var(--text);border:1px solid var(--line);border-radius:var(--r-sm);letter-spacing:.005em;cursor:pointer;align-items:center;gap:6px;padding:0 12px;font-size:12.5px;font-weight:500;transition:background .12s,border-color .12s,transform 60ms;display:inline-flex}.btn:hover{background:var(--bg-elev);border-color:var(--line-strong)}.btn:active{transform:translateY(.5px)}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-primary{background:var(--accent);color:var(--accent-ink);border-color:#0000;font-weight:600}.btn-primary:hover{background:var(--accent);filter:brightness(1.06)}.btn-ghost{background:0 0}.btn-ghost:hover{background:var(--bg-elev-2)}.btn-danger{color:#fff;background:#c0392b;border-color:#0000;font-weight:600}.btn-danger:hover{background:#a93226;border-color:#0000}.icon-btn{width:32px;color:var(--text-muted);justify-content:center;padding:0}.icon-btn:hover{color:var(--text)}.workspace{grid-template-columns:var(--panel-w-l) 1fr var(--panel-w-r);flex:1;gap:0;min-height:0;display:grid}.panel{background:var(--bg-elev);flex-direction:column;gap:10px;padding:14px 14px 18px;display:flex;overflow-y:auto}.panel.toolbox{border-right:1px solid var(--line)}.panel.charpanel{border-left:1px solid var(--line)}.panel-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-top:4px;font-size:10.5px}.panel-label-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.panel-divider{background:var(--line);height:1px;margin:8px -14px}.tool-grid{grid-template-columns:1fr 1fr 1fr;gap:6px;display:grid}.tool-btn{color:var(--text-muted);border-radius:var(--r-sm);cursor:pointer;font-size:10.5px;font-family:var(--font-mono);letter-spacing:.03em;background:0 0;border:1px solid #0000;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;transition:background .12s,color .12s,border-color .12s;display:flex}.tool-btn:hover{background:var(--bg-elev-2);color:var(--text)}.tool-btn.active{background:var(--accent-soft);color:var(--accent);border-color:color-mix(in srgb, var(--accent) 35%, transparent)}.tool-btn span{line-height:1}.tool-btn:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.tool-btn.popover-open{border-color:color-mix(in srgb, var(--accent) 50%, transparent)}.row{align-items:center;gap:10px;display:flex}.slider{appearance:none;background:var(--line);border-radius:4px;outline:none;flex:1;height:4px}.slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent);cursor:pointer;border:2px solid var(--bg-elev);width:14px;height:14px;box-shadow:0 0 0 1px var(--line);border-radius:50%}.slider::-moz-range-thumb{background:var(--accent);cursor:pointer;border:2px solid var(--bg-elev);border-radius:50%;width:14px;height:14px}.slider-sm{flex:none;width:90px}.num-readout{font-family:var(--font-mono);color:var(--text-muted);text-align:right;min-width:22px;font-size:11.5px}.check{color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:12px;display:flex}.check input{accent-color:var(--accent)}.num-input{border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg-elev-2);width:56px;height:28px;color:var(--text);font-family:var(--font-mono);outline:none;padding:0 8px;font-size:12px}.num-input:focus{border-color:var(--accent)}.select-sm{border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg-elev-2);height:26px;color:var(--text);font-family:var(--font-mono);cursor:pointer;outline:none;padding:0 6px;font-size:11.5px}.canvas-area{background:var(--bg);flex-direction:column;min-width:0;min-height:0;display:flex}.canvas-toolbar{border-bottom:1px solid var(--line);background:var(--bg-elev);scrollbar-width:none;flex-wrap:nowrap;flex-shrink:0;align-items:center;gap:10px;height:48px;padding:0 16px;display:flex;overflow-x:auto}.canvas-toolbar::-webkit-scrollbar{display:none}.ct-group{align-items:center;gap:8px;display:flex}.ct-group.muted{color:var(--text-muted);font-family:var(--font-mono);font-size:11.5px}.ct-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:10.5px}.ct-divider{background:var(--line);width:1px;height:22px}.ct-spacer{flex:1}.ct-btn-label{align-items:center;gap:5px;display:flex}.ct-btn-label svg{flex-shrink:0}.color-swatch-label{cursor:pointer;align-items:center;display:flex;position:relative}.color-swatch{border-radius:var(--r-sm);border:1.5px solid var(--line-strong);flex-shrink:0;width:22px;height:22px;transition:border-color .15s;display:block}.color-swatch.no-color{background:repeating-linear-gradient(-45deg, var(--line-strong) 0px, var(--line-strong) 1.5px, transparent 1.5px, transparent 6px)}.color-swatch-label:hover .color-swatch{border-color:var(--accent)}.color-picker-input{opacity:0;cursor:pointer;border:none;width:100%;height:100%;padding:0;position:absolute;inset:0}.current-char{width:32px;height:32px;font-family:var(--font-mono);color:var(--accent);background:var(--accent-soft);border:1px solid color-mix(in srgb, var(--accent) 35%, transparent);border-radius:var(--r-sm);place-items:center;font-size:18px;font-weight:600;display:grid}.canvas-frame{background:radial-gradient(circle at 20% 0%, var(--accent-soft), transparent 55%), var(--bg);flex:1;align-items:stretch;min-height:0;padding:0;display:flex;position:relative;overflow:hidden}.size-overlay{background:var(--bg-elev);border:1px solid var(--line-strong);border-radius:var(--r-md);box-shadow:var(--shadow);z-index:10;opacity:.72;align-items:center;gap:8px;padding:5px 10px 5px 8px;transition:opacity .15s;display:flex;position:absolute;bottom:14px;right:14px}.size-overlay:hover,.size-overlay:focus-within{opacity:1}.size-overlay svg{color:var(--text-muted);flex-shrink:0}.size-overlay .slider{flex:none;width:82px}.size-overlay .num-readout{min-width:20px}.canvas-scroll{border-top:1px solid var(--line-strong);background:var(--bg-canvas);flex:1;width:100%;height:100%;position:relative;overflow:auto}.canvas{font-family:var(--font-mono);color:var(--text);white-space:pre;letter-spacing:0;cursor:crosshair;-webkit-user-select:none;user-select:none;z-index:1;background-image:linear-gradient(to right, var(--grid-faint) 1px, transparent 1px);background-size:var(--cell-w,9.6px) 100%;background-position:16px 0;background-repeat:repeat-x;min-width:100%;min-height:100%;margin:0;padding:14px 16px;font-size:16px;line-height:1.15;position:relative}.canvas:focus{outline:none}.overlay{pointer-events:none;z-index:2;position:absolute;top:0;left:0}.char-input-row{align-items:center;gap:10px;display:flex}.char-input{text-align:center;width:52px;height:52px;font-family:var(--font-mono);color:var(--accent);background:var(--bg-elev-2);border:1px solid var(--line);border-radius:var(--r-md);outline:none;font-size:26px;font-weight:600}.char-input:focus{border-color:var(--accent)}.hint{color:var(--text-muted);font-size:11.5px;font-family:var(--font-mono)}.char-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.char-grid.recents{grid-template-columns:repeat(7,1fr);min-height:32px}.char-cell{aspect-ratio:1;font-family:var(--font-mono);background:var(--bg-elev-2);color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;border:1px solid #0000;border-radius:4px;place-items:center;font-size:14px;transition:background .1s,border-color .1s,color .1s;display:grid}.char-cell:hover{background:var(--bg-elev);border-color:var(--line)}.char-cell.active{background:var(--accent-soft);color:var(--accent);border-color:color-mix(in srgb, var(--accent) 35%, transparent)}.brush-popover{z-index:300;background:var(--bg-elev);border:1px solid var(--line-strong);border-radius:var(--r-lg);box-shadow:var(--shadow), 0 12px 40px #0000004d;flex-direction:column;gap:10px;width:180px;padding:12px 14px 10px;animation:.14s cubic-bezier(.34,1.3,.64,1) dialog-in;display:flex;position:fixed;transform:translate(-50%)}.brush-pop-header{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:10.5px}.brush-pop-row{align-items:center;gap:8px;display:flex}.brush-pop-row .slider{flex:1}.brush-pop-sizes{justify-content:space-between;align-items:center;gap:4px;display:flex}.brush-size-dot{border-radius:var(--r-sm);cursor:pointer;background:0 0;border:1px solid #0000;flex:1;justify-content:center;align-items:center;height:28px;padding:0;transition:background .1s,border-color .1s;display:flex}.brush-size-dot:hover{background:var(--bg-elev-2);border-color:var(--line)}.brush-size-dot.active{background:var(--accent-soft);border-color:color-mix(in srgb, var(--accent) 35%, transparent)}.brush-size-dot span{color:var(--text-muted);background:currentColor;border-radius:50%;display:block}.brush-size-dot.active span{color:var(--accent)}.shape-pop-opts{grid-template-columns:1fr 1fr;gap:6px;display:grid}.shape-opt-btn{border-radius:var(--r-sm);color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.03em;cursor:pointer;background:0 0;border:1px solid #0000;flex-direction:column;align-items:center;gap:5px;padding:10px 6px;font-size:10.5px;transition:background .12s,color .12s,border-color .12s;display:flex}.shape-opt-btn:hover{background:var(--bg-elev-2);color:var(--text)}.shape-opt-btn.active{background:var(--accent-soft);color:var(--accent);border-color:color-mix(in srgb, var(--accent) 35%, transparent)}.shape-opt-btn:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.shortcut-list dl{grid-template-columns:auto 1fr;gap:4px 14px;margin:8px 0 0;font-size:11.5px;display:grid}.shortcut-list dt{font-family:var(--font-mono);color:var(--text)}.shortcut-list dd{color:var(--text-muted);margin:0}.brand-gallery-link{font-family:var(--font-mono);color:var(--text-muted);border:1px solid var(--line);border-radius:var(--r-sm);margin-left:8px;padding:2px 8px;font-size:11px;text-decoration:none;transition:color .12s,border-color .12s}.brand-gallery-link:hover{color:var(--accent);border-color:var(--accent)}.canvas-tabs{background:var(--bg-elev);border-bottom:1px solid var(--line);scrollbar-width:none;flex-shrink:0;align-items:center;gap:2px;height:36px;min-height:36px;padding:0 12px;display:flex;overflow-x:auto}.canvas-tabs::-webkit-scrollbar{display:none}.canvas-tab{border-radius:var(--r-sm) var(--r-sm) 0 0;height:26px;font-family:var(--font-mono);color:var(--text-muted);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;border-bottom:none;align-items:center;gap:5px;padding:0 10px;font-size:11.5px;transition:color .12s,background .12s;display:flex}.canvas-tab:hover{color:var(--text);background:var(--bg-elev-2)}.canvas-tab.active{color:var(--text);background:var(--bg);border-color:var(--line);position:relative}.canvas-tab.active:after{content:"";background:var(--bg);height:1px;position:absolute;bottom:-1px;left:0;right:0}.canvas-tab-close{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;padding:0 2px;font-size:14px;line-height:1;display:flex}.canvas-tab-close:hover{color:var(--text);background:var(--bg-elev-2)}.canvas-tab-add{border-radius:var(--r-sm);color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;margin-left:4px;font-size:16px;transition:color .12s,border-color .12s;display:flex}.canvas-tab-add:hover{color:var(--accent);border-color:var(--line)}.canvas-tab-rename{background:var(--bg-elev-2);border:1px solid var(--accent);color:var(--text);font-family:var(--font-mono);border-radius:3px;outline:none;width:80px;padding:1px 4px;font-size:11.5px}.canvas.no-grid{background-image:none}.mirror-btn{border:1px solid #0000;flex-direction:row;grid-column:span 3;justify-content:flex-start;gap:8px;width:100%;padding:6px 10px}.mirror-btn span{display:flex}.history-panel{border:1px solid var(--line);border-radius:var(--r-sm);background:var(--bg-elev-2);flex-direction:column;gap:2px;max-height:200px;padding:4px;display:flex;overflow-y:auto}.history-panel::-webkit-scrollbar{width:6px}.history-panel::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:6px}.history-item{cursor:pointer;font-family:var(--font-mono);color:var(--text-muted);text-align:left;background:0 0;border:1px solid #0000;border-radius:4px;align-items:center;gap:8px;padding:4px 6px;font-size:11px;transition:background .1s,color .1s;display:flex}.history-item:hover{background:var(--bg-elev);color:var(--text);border-color:var(--line)}.history-idx{color:var(--text-dim);flex-shrink:0;min-width:28px}.history-preview{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.history-empty{font-family:var(--font-mono);color:var(--text-dim);text-align:center;padding:6px;font-size:11px}.custom-palette-edit{flex-direction:column;gap:6px;display:flex}.custom-palette-add{align-items:center;gap:6px;display:flex}.custom-palette-empty{font-family:var(--font-mono);color:var(--text-dim);text-align:center;padding:8px 0;font-size:11px}.char-cell{position:relative}.char-cell-remove{background:var(--bg-elev-2);border:1px solid var(--line-strong);text-align:center;width:14px;height:14px;color:var(--text-muted);cursor:pointer;z-index:2;border-radius:50%;font-size:10px;line-height:14px;display:none;position:absolute;top:-4px;right:-4px}.char-cell:hover .char-cell-remove{display:block}.char-cell-remove:hover{color:#fff;background:#c0392b;border-color:#0000}.export-btn-wrap{position:relative}.export-dropdown{z-index:300;background:var(--bg-elev);border:1px solid var(--line-strong);border-radius:var(--r-md);box-shadow:var(--shadow), 0 8px 24px #00000040;min-width:140px;padding:4px;animation:.12s cubic-bezier(.34,1.3,.64,1) dialog-in;position:absolute;top:calc(100% + 4px);left:0}.export-dropdown-item{border-radius:var(--r-sm);width:100%;color:var(--text);font-family:var(--font-mono);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:7px 10px;font-size:12px;transition:background .1s;display:flex}.export-dropdown-item:hover{background:var(--bg-elev-2)}.resize-dialog-fields{align-items:center;gap:8px;display:flex}.resize-field-label{font-family:var(--font-mono);color:var(--text-muted);flex-direction:column;gap:4px;font-size:11px;display:flex}.resize-field-sep{font-family:var(--font-mono);color:var(--text-muted);margin-top:14px;font-size:16px}.resize-anchor-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.size-overlay-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:2px;display:flex}.size-overlay-btn:hover{color:var(--accent);background:var(--accent-soft)}.ad-slot{border:1px dashed var(--line-strong);border-radius:var(--r-sm);background:var(--bg-elev-2);flex-shrink:0;justify-content:center;align-items:center;width:100%;min-height:120px;margin-top:auto;display:flex;position:relative;overflow:hidden}.ad-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);opacity:.5;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:10px;font-weight:600}@media (max-width:880px){.ad-slot{display:none}}.toast{background:var(--bg-elev-2);color:var(--text);border:1px solid var(--line-strong);border-radius:var(--r-md);font-family:var(--font-mono);box-shadow:var(--shadow);opacity:0;pointer-events:none;z-index:100;padding:10px 16px;font-size:12px;transition:opacity .2s,transform .2s;position:fixed;bottom:24px;left:50%;transform:translate(-50%)translateY(20px)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.dialog-backdrop{z-index:200;background:#0000008c;justify-content:center;align-items:center;animation:.15s backdrop-in;display:flex;position:fixed;inset:0}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}.dialog{background:var(--bg-elev);border:1px solid var(--line-strong);border-radius:var(--r-lg);flex-direction:column;gap:16px;width:340px;max-width:calc(100vw - 32px);padding:24px 24px 20px;animation:.18s cubic-bezier(.34,1.3,.64,1) dialog-in;display:flex;box-shadow:0 24px 64px #00000073,0 1px #ffffff0a}@keyframes dialog-in{0%{opacity:0;transform:scale(.94)translateY(6px)}to{opacity:1;transform:scale(1)translateY(0)}}.dialog-icon{border-radius:var(--r-md);color:#c0392b;background:#c0392b26;flex-shrink:0;place-items:center;width:40px;height:40px;display:grid}.dialog-body{flex-direction:column;gap:6px;display:flex}.dialog-title{font-family:var(--font-ui);color:var(--text);letter-spacing:-.01em;margin:0;font-size:14px;font-weight:600}.dialog-desc{font-family:var(--font-mono);color:var(--text-muted);margin:0;font-size:11.5px;line-height:1.5}.dialog-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.canvas-scroll::-webkit-scrollbar{width:10px;height:10px}.panel::-webkit-scrollbar{width:10px;height:10px}.canvas-scroll::-webkit-scrollbar-track{background:0 0}.panel::-webkit-scrollbar-track{background:0 0}.canvas-scroll::-webkit-scrollbar-thumb{background:var(--line-strong);border:2px solid var(--bg-elev);border-radius:10px}.panel::-webkit-scrollbar-thumb{background:var(--line-strong);border:2px solid var(--bg-elev);border-radius:10px}@media (max-width:1100px){:root{--panel-w-l:180px;--panel-w-r:220px}.tool-btn{font-size:9.5px}}@media (max-width:880px){.workspace{grid-template-rows:auto 1fr auto;grid-template-columns:1fr}.brand-tag{display:none}.canvas-frame{padding:0}.panel.toolbox{border:none;border-bottom:1px solid var(--line);scrollbar-width:none;flex-flow:row;align-items:center;gap:0;height:48px;min-height:48px;max-height:48px;padding:0 10px;overflow:auto visible;-webkit-mask-image:linear-gradient(90deg,#000 0 calc(100% - 32px),#0000 100%);mask-image:linear-gradient(90deg,#000 0 calc(100% - 32px),#0000 100%)}.panel.toolbox[data-scroll-end=true]{-webkit-mask-image:none;mask-image:none}.panel.toolbox::-webkit-scrollbar{display:none}.panel.toolbox>.panel-label{display:none}.panel.toolbox>.panel-divider{flex-shrink:0;align-self:center;width:1px;height:22px;margin:0 8px}.tool-grid{flex-direction:row;flex-shrink:0;gap:2px;display:flex}.tool-btn{flex-direction:row;justify-content:center;gap:0;width:34px;height:34px;padding:0}.tool-btn span{display:none}.panel.toolbox .row{flex-wrap:nowrap;flex-shrink:0;gap:6px}.panel.toolbox .slider{flex:none;width:76px}.panel.toolbox .num-readout{min-width:16px}.panel.charpanel{border:none;border-top:1px solid var(--line);scrollbar-width:none;flex-flow:row;align-items:center;gap:0;height:52px;min-height:52px;max-height:52px;padding:0 10px;overflow:auto visible;-webkit-mask-image:linear-gradient(90deg,#000 0 calc(100% - 32px),#0000 100%);mask-image:linear-gradient(90deg,#000 0 calc(100% - 32px),#0000 100%)}.panel.charpanel[data-scroll-end=true]{-webkit-mask-image:none;mask-image:none}.panel.charpanel::-webkit-scrollbar{display:none}.panel.charpanel>.panel-label{display:none}.panel.charpanel>.panel-divider{flex-shrink:0;align-self:center;width:1px;height:26px;margin:0 8px}.shortcut-list,.panel.charpanel>.panel-divider:nth-last-child(2){display:none}.char-input-row{flex-shrink:0;gap:0}.char-input{flex-shrink:0;width:38px;height:38px;font-size:20px}.hint{display:none}.panel-label-row{flex-shrink:0;justify-content:flex-start;gap:0}.panel-label-row .panel-label{display:none}.char-grid{flex-flow:row;flex-shrink:0;gap:3px;display:flex}.char-grid.recents{min-height:auto}.char-cell{aspect-ratio:auto;flex-shrink:0;width:30px;height:30px;font-size:13px}}.vkb{display:none}@media (max-width:880px){.workspace.vkb-open{padding-bottom:4px}.vkb{z-index:300;background:var(--bg-elev);border-top:2px solid var(--line-strong);padding:6px 6px env(safe-area-inset-bottom,6px);flex-direction:column;gap:4px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -6px 28px #00000080}.vkb-top{border-bottom:1px solid var(--line-strong);align-items:center;gap:6px;padding-bottom:4px;display:flex}.vkb-tabs{gap:4px;display:flex}.vkb-tab{letter-spacing:.03em;background:var(--bg-elev-2);color:var(--text);border:1px solid var(--line-strong);cursor:pointer;border-radius:6px;padding:3px 11px;font-size:11px;font-weight:600;transition:background .12s,color .12s}.vkb-tab.active{background:var(--accent);color:var(--accent-ink);border-color:#0000}.vkb-exit-btn{color:var(--text-muted);border:1px solid var(--line-strong);cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:4px;margin-left:auto;padding:3px 9px;font-size:11px;display:flex}.vkb-rows{flex-direction:column;gap:3px;display:flex}.vkb-row{justify-content:center;gap:3px;display:flex}.vkb-controls{border-top:1px solid var(--line-strong);margin-top:1px;padding-top:4px}.vkb-key{min-width:28px;height:36px;font-size:14px;font-family:var(--font-mono);background:var(--bg-elev-2);color:var(--text);border:1px solid var(--line-strong);cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;padding:0 3px;transition:background 80ms;display:flex}.vkb-key:active,.vkb-key.active{background:var(--accent);color:var(--accent-ink);border-color:#0000}.vkb-ctrl{background:var(--bg);min-width:36px;font-size:13px}.vkb-shift{min-width:38px}.vkb-space{letter-spacing:.03em;min-width:80px;font-size:11px}.vkb-wide{min-width:46px;font-size:16px}}.gallery-page{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.gallery-content{flex:1;padding:32px 24px 48px;overflow-y:auto}.gallery-hero{text-align:center;margin-bottom:36px}.gallery-title{font-family:var(--font-mono);color:var(--accent);letter-spacing:-.02em;margin:0 0 10px;font-size:28px;font-weight:700}.gallery-subtitle{color:var(--text-muted);margin:0;font-size:13.5px}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;max-width:1100px;margin:0 auto;display:grid}.gallery-card{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--r-lg);flex-direction:column;transition:border-color .15s,box-shadow .15s;display:flex;overflow:hidden}.gallery-card:hover{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.gallery-preview{font-family:var(--font-mono);color:var(--text);background:var(--bg-canvas);white-space:pre;flex:1;min-height:140px;margin:0;padding:20px;font-size:14px;line-height:1.4;overflow:hidden}.gallery-card-footer{border-top:1px solid var(--line);justify-content:space-between;align-items:center;gap:8px;padding:10px 14px;display:flex}.gallery-card-info{flex-direction:column;gap:2px;display:flex}.gallery-card-title{font-family:var(--font-mono);color:var(--text);font-size:12.5px;font-weight:600}.gallery-card-author{font-family:var(--font-mono);color:var(--text-muted);font-size:11px}.gallery-card-actions{flex-shrink:0;gap:6px;display:flex}@media (max-width:540px){.topbar{padding:0 10px}.canvas-toolbar{gap:6px;padding:0 10px}.canvas-toolbar .ct-btn-text,.canvas-toolbar .ct-label,.ct-group.muted{display:none}.canvas-toolbar{-webkit-mask-image:linear-gradient(90deg,#000 0 calc(100% - 28px),#0000 100%);mask-image:linear-gradient(90deg,#000 0 calc(100% - 28px),#0000 100%)}}
