:root{--bg:#f5f2ea;--bg-2:#ede9dd;--bg-3:#e3dec9;--card:#ffffff;--card-2:#fbf9f3;--ink:#1a1815;--ink-2:#45413a;--ink-3:#847f72;--ink-4:#b5af9e;--ink-5:#d6d0bd;--line:#e8e3d3;--line-soft:#f0ebdb;--accent:#4a6fa5;--accent-hover:#3b5c8d;--accent-soft:#e2eaf3;--accent-2:#d77550;--danger:#c93d3d;--success:#4a9d6c;--shadow-xs:0 1px 2px rgba(40,35,25,0.04);--shadow-sm:0 2px 8px rgba(40,35,25,0.06);--shadow-md:0 6px 22px rgba(40,35,25,0.07),0 1px 3px rgba(40,35,25,0.04);--shadow-lg:0 18px 48px rgba(40,35,25,0.12),0 4px 12px rgba(40,35,25,0.06);--shadow-modal:0 30px 80px rgba(20,18,12,0.22),0 6px 18px rgba(20,18,12,0.08);--r-xs:4px;--r-sm:8px;--r:12px;--r-lg:18px;--r-xl:24px;--ease:cubic-bezier(0.16,1,0.3,1);--ease-out:cubic-bezier(0.22,1,0.36,1)}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%}body{background:var(--bg);color:var(--ink);font-family:Manrope,-apple-system,BlinkMacSystemFont,Hiragino Kaku Gothic ProN,Yu Gothic,sans-serif;font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;background-image:radial-gradient(at 6% 0,rgba(74,111,165,.045) 0,transparent 38%),radial-gradient(at 96% 100%,rgba(215,117,80,.04) 0,transparent 42%);background-attachment:fixed;overflow-x:hidden}::selection{background:var(--accent-soft);color:var(--ink)}button{font-family:inherit}header.app-header{padding:22px 32px 14px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.brand{display:flex;align-items:baseline;gap:12px}.brand .mark{font-family:"Instrument Serif",serif;font-size:36px;font-weight:400;letter-spacing:-.02em;line-height:1}.brand .mark em{color:var(--accent);font-style:italic}.brand .tag{color:var(--ink-3);font-size:12px;letter-spacing:.02em;font-family:JetBrains Mono,monospace}.brand .tag:before{content:"//";margin-right:6px;color:var(--ink-4)}.header-actions{display:flex;gap:6px;align-items:center}.app{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);grid-gap:22px;gap:22px;padding:0 32px 80px;max-width:1440px;margin:0 auto;align-items:start}@media (max-width:980px){.app{grid-template-columns:1fr;gap:16px;padding:0 14px 100px}header.app-header{padding:18px 16px 10px}.brand .mark{font-size:30px}.brand .tag{display:none}}.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-xs)}.panel-head{padding:18px 22px 14px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;justify-content:space-between;gap:12px}.panel-head .head-text{flex:1 1;min-width:0}.panel-head .ttl{font-size:10.5px;color:var(--ink-3);letter-spacing:.14em;text-transform:uppercase;font-weight:700;font-family:JetBrains Mono,monospace}.panel-head .sub{font-size:17px;color:var(--ink);font-weight:600;margin-top:4px;letter-spacing:-.01em}.panel-body{padding:18px 22px}.mobile-tabs{display:none;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:4px;margin:0 14px 12px;position:-webkit-sticky;position:sticky;top:8px;z-index:30;box-shadow:var(--shadow-md)}.mobile-tabs button{flex:1 1;background:transparent;border:none;font-size:13px;color:var(--ink-2);padding:10px 14px;border-radius:999px;cursor:pointer;font-weight:600;transition:all .2s var(--ease)}.mobile-tabs button.active{background:var(--ink);color:#fff}.mini-preview,.mini-reopen{display:none}@media (max-width:980px){body:has(.app[data-tab=controls]) .mini-preview,body:has(.app[data-tab=controls]) .mini-reopen{display:flex}}.mini-preview{position:fixed;right:14px;bottom:calc(14px + env(safe-area-inset-bottom));background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);z-index:60;padding:6px;cursor:pointer;align-items:center;justify-content:center;overflow:visible;transition:transform .18s var(--ease),box-shadow .18s var(--ease);-webkit-tap-highlight-color:transparent;animation:miniIn .32s var(--ease-out)}.mini-preview:active{transform:scale(.97)}@keyframes miniIn{0%{opacity:0;transform:translateY(8px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.mini-frame{width:152px;height:120px;border-radius:10px;overflow:hidden;background:var(--bg-2);display:flex;align-items:center;justify-content:center;pointer-events:none}.mini-frame>div{transition:transform .2s var(--ease)}.mini-close{position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;border:2px solid var(--card);padding:0;display:inline-flex;justify-content:center;z-index:1;box-shadow:var(--shadow-sm)}.mini-close,.mini-reopen{background:var(--ink);color:#fff;cursor:pointer;align-items:center}.mini-reopen{position:fixed;right:14px;bottom:calc(14px + env(safe-area-inset-bottom));z-index:60;border:none;border-radius:999px;padding:10px 14px;font-family:inherit;font-size:12px;font-weight:600;gap:6px;box-shadow:var(--shadow-lg);animation:miniIn .28s var(--ease-out)}.mini-reopen:active{transform:scale(.96)}body:has(.picker-overlay.show) .mini-preview,body:has(.picker-overlay.show) .mini-reopen,body:has(.png-overlay.show) .mini-preview,body:has(.png-overlay.show) .mini-reopen{display:none!important}@media (max-width:980px){.mobile-tabs{display:flex}.app{display:block}.app>.panel-group{margin-bottom:14px}.app[data-tab=controls] .preview-col,.app[data-tab=preview] .controls-col{display:none}.preview-col{position:static}.preview-stage{min-height:220px;padding:10px 10px 14px}.preview-actions{padding:10px 12px;gap:6px}.preview-actions .btn{font-size:13px;padding:9px 12px;min-height:40px;flex:1 1;justify-content:center}.preview-actions .btn.primary{flex:1 1 100%;order:-1;font-size:14px;padding:11px 14px}.field-input,.field-label-input,.field-textarea,.picker-search{font-size:16px}}.style-panel{margin-bottom:14px}.style-rows{gap:16px}.style-row,.style-rows{display:flex;flex-direction:column}.style-row{gap:8px}.row-label{font-size:10.5px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.12em;font-weight:700;font-family:JetBrains Mono,monospace;display:flex;align-items:center;justify-content:space-between;gap:8px}.row-label .row-hint{text-transform:none;letter-spacing:0;color:var(--ink-3);font-weight:500;font-size:11px;font-family:Manrope,sans-serif}.templates{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:6px;gap:6px;background:var(--bg);padding:4px;border-radius:var(--r);border:1px solid var(--line-soft)}.tpl-card{background:transparent;border:1px solid transparent;border-radius:var(--r-sm);padding:10px 8px 9px;cursor:pointer;text-align:center;transition:all .2s var(--ease);color:var(--ink-2);position:relative}.tpl-card:hover{color:var(--ink)}.tpl-card.active{background:var(--card);border-color:var(--line);color:var(--ink);box-shadow:var(--shadow-xs)}.tpl-card .tpl-name{font-weight:700;font-size:13px;margin-bottom:1px;letter-spacing:-.01em}.tpl-card .tpl-desc{font-family:JetBrains Mono,monospace;font-size:9.5px;color:var(--ink-3);font-weight:500}.tpl-card.active .tpl-desc{color:var(--accent)}.pills{display:flex;flex-wrap:wrap;gap:6px}.pill{background:var(--bg);border:1px solid var(--line-soft);color:var(--ink-2);font-family:inherit;font-size:12px;padding:7px 12px;border-radius:999px;cursor:pointer;transition:all .18s var(--ease);font-weight:600;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.pill:hover{background:var(--bg-2);border-color:var(--line);color:var(--ink)}.pill.active{background:var(--ink);color:#fff;border-color:var(--ink)}.pill .pill-ratio{font-family:JetBrains Mono,monospace;font-size:10px;opacity:.6;font-weight:500}.pill.active .pill-ratio{opacity:.75}.pill .lang-dot,.pill .theme-dot{width:10px;height:10px;border-radius:50%;box-shadow:inset 0 0 0 1px rgba(0,0,0,.12);flex-shrink:0}.bg-swatches{display:flex;flex-wrap:wrap;gap:8px}.swatch{width:28px;height:28px;border-radius:50%;cursor:pointer;border:2px solid var(--card);box-shadow:0 0 0 1px var(--line);transition:all .18s var(--ease)}.swatch:hover{transform:scale(1.12)}.swatch.active{box-shadow:0 0 0 2px var(--accent),0 0 0 4px var(--card);transform:scale(1.05)}.btn{background:var(--card);color:var(--ink);border:1px solid var(--line);font-family:inherit;font-size:12.5px;padding:7px 13px;border-radius:var(--r-sm);cursor:pointer;transition:all .15s var(--ease);font-weight:600;display:inline-flex;align-items:center;gap:6px;line-height:1}.btn:hover{background:var(--bg);border-color:var(--ink-4)}.btn:active{transform:translateY(1px)}.btn.primary{background:var(--ink);color:#fff;border-color:var(--ink)}.btn.primary:hover{background:#000;border-color:#000}.btn.accent{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.accent:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn.subtle{background:transparent;border-color:transparent;color:var(--ink-2)}.btn.subtle:hover{background:var(--bg-2);color:var(--ink)}.btn.danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.btn.small{font-size:11.5px;padding:5px 10px}.btn .ico{opacity:.75;font-size:13px}.fields-panel{overflow:visible}.fields-panel .panel-head .head-meta{display:flex;align-items:center;gap:8px}.field-count{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--ink-3);padding:3px 9px;background:var(--bg);border-radius:999px;border:1px solid var(--line-soft);font-weight:600;letter-spacing:.02em}.fields-body{padding:14px 16px 18px;background:var(--card-2)}.fields-list{display:flex;flex-direction:column;gap:8px;position:relative}.fields-empty{text-align:center;padding:28px 20px;color:var(--ink-3);font-size:13px;background:var(--card);border:1.5px dashed var(--ink-5);border-radius:var(--r)}.fields-empty .empty-title{font-family:"Instrument Serif",serif;font-size:22px;color:var(--ink);margin-bottom:4px;font-style:italic}.fields-empty .empty-sub{color:var(--ink-3);margin-bottom:14px}.field-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);display:grid;grid-template-columns:22px 1fr auto;align-items:stretch;transition:box-shadow .18s var(--ease),border-color .18s var(--ease),transform .18s var(--ease),opacity .2s;position:relative}.field-card:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.field-card.dragging{opacity:.45;cursor:-webkit-grabbing;cursor:grabbing}.field-card.drag-over-top{box-shadow:0 -2px 0 var(--accent)}.field-card.drag-over-bot{box-shadow:0 2px 0 var(--accent)}.field-card.enter{animation:fieldEnter .32s var(--ease-out)}.field-card.leave{animation:fieldLeave .22s var(--ease-out) forwards}@keyframes fieldEnter{0%{opacity:0;transform:translateY(-6px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes fieldLeave{to{opacity:0;transform:translateX(-12px) scale(.97)}}.field-drag{display:flex;align-items:center;justify-content:center;cursor:-webkit-grab;cursor:grab;color:var(--ink-4);border-right:1px solid var(--line-soft);-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none;border-radius:var(--r) 0 0 var(--r);transition:color .15s,background .15s}.field-drag:hover{color:var(--ink-2);background:var(--bg)}.field-drag:active{cursor:-webkit-grabbing;cursor:grabbing}.field-drag svg{width:10px;height:16px}.field-body{padding:10px 12px 12px;min-width:0}.field-header{display:flex;align-items:baseline;gap:8px;margin-bottom:6px;min-width:0}.field-label{font-size:12.5px;color:var(--ink);font-weight:600;flex-shrink:0;max-width:60%}.field-key,.field-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.field-key{font-family:JetBrains Mono,monospace;font-size:10.5px;color:var(--ink-3);font-weight:500;flex:1 1;min-width:0}.field-key .type-chip{margin-left:4px;padding:1px 5px;background:var(--bg-2);border-radius:4px;font-size:9.5px;color:var(--ink-3);text-transform:lowercase}.field-hint{font-size:11px;color:var(--ink-3);margin-top:6px;font-family:JetBrains Mono,monospace;line-height:1.4}.field-input,.field-textarea{width:100%;background:transparent;border:none;color:var(--ink);font-family:inherit;font-size:13.5px;padding:2px 0;outline:none;resize:none;line-height:1.5}.field-textarea{min-height:1.5em}.field-input::placeholder,.field-textarea::placeholder{color:var(--ink-4)}.field-card.is-custom .field-label-input{background:transparent;border:none;color:var(--ink);font-weight:600;font-size:12.5px;padding:0;outline:none;border-bottom:1px dashed var(--ink-4);width:100%;transition:border-color .15s;flex:1 1;min-width:0}.field-card.is-custom .field-label-input:focus{border-bottom-color:var(--accent)}.field-card.is-custom .field-label-input::placeholder{color:var(--ink-4);font-weight:500}.field-actions{display:flex;flex-direction:column;border-left:1px solid var(--line-soft)}.field-actions button{flex:1 1;background:transparent;border:none;color:var(--ink-4);cursor:pointer;padding:0 12px;font-size:12px;transition:all .15s;display:flex;align-items:center;justify-content:center;min-width:36px}.field-actions button:hover{background:var(--bg);color:var(--ink)}.field-actions button.remove:hover{background:var(--danger);color:#fff}.field-actions button:disabled{opacity:.3;cursor:not-allowed}.field-actions button+button{border-top:1px solid var(--line-soft)}.field-actions svg{width:12px;height:12px}.add-field-btn{width:100%;background:var(--card);border:1.5px dashed var(--accent);color:var(--accent);font-family:inherit;font-size:13.5px;padding:14px;border-radius:var(--r);cursor:pointer;transition:all .2s var(--ease);font-weight:600;margin-top:10px;display:flex;align-items:center;justify-content:center;gap:8px}.add-field-btn:hover{background:var(--accent);color:#fff;border-style:solid;transform:translateY(-1px);box-shadow:0 6px 16px rgba(74,111,165,.25)}.add-field-btn .plus{font-size:16px;line-height:1;display:inline-flex;width:18px;height:18px;border-radius:50%;align-items:center;justify-content:center;background:var(--accent-soft);color:var(--accent);transition:all .2s var(--ease)}.add-field-btn:hover .plus{background:rgba(255,255,255,.2);color:#fff}.picker-overlay{position:fixed;inset:0;background:rgba(20,18,12,.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:100;opacity:0;pointer-events:none;transition:opacity .25s var(--ease);display:flex;align-items:center;justify-content:center;padding:24px}.picker-overlay.show{opacity:1;pointer-events:auto}.picker{background:var(--card);width:100%;max-width:540px;max-height:calc(100vh - 48px);border-radius:var(--r-lg);box-shadow:var(--shadow-modal);display:flex;flex-direction:column;overflow:hidden;transform:translateY(16px) scale(.97);transition:transform .32s var(--ease-out)}.picker-overlay.show .picker{transform:translateY(0) scale(1)}.picker-head{padding:18px 22px 14px;display:flex;align-items:flex-start;justify-content:space-between;border-bottom:1px solid var(--line-soft);flex-shrink:0}.picker-head .h-text{display:flex;flex-direction:column;gap:2px}.picker-head .h-title{font-family:"Instrument Serif",serif;font-style:italic;font-size:24px;line-height:1.1;letter-spacing:-.01em;color:var(--ink)}.picker-head .h-sub{color:var(--ink-3);font-size:12px;font-family:JetBrains Mono,monospace}.picker-close{background:var(--bg);border:1px solid var(--line);color:var(--ink-2);width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.picker-close:hover{background:var(--ink);color:#fff;border-color:var(--ink)}.picker-search-wrap{padding:14px 22px 8px;position:relative;flex-shrink:0}.picker-search{width:100%;background:var(--bg);border:1px solid var(--line);color:var(--ink);font-family:inherit;font-size:14.5px;padding:11px 14px 11px 38px;border-radius:var(--r);outline:none;transition:all .15s}.picker-search:focus{background:var(--card);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.picker-search::placeholder{color:var(--ink-4)}.picker-search-icon{position:absolute;left:36px;top:50%;transform:translateY(-50%);color:var(--ink-4);pointer-events:none;display:inline-flex;align-items:center;justify-content:center}.picker-cats{flex-shrink:0;padding:4px 22px 12px;display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 16px,#000 calc(100% - 16px),transparent);mask-image:linear-gradient(90deg,transparent 0,#000 16px,#000 calc(100% - 16px),transparent)}.picker-cats::-webkit-scrollbar{display:none}.cat-chip{background:var(--card);border:1px solid var(--line);color:var(--ink-2);font-size:12px;padding:7px 13px;border-radius:999px;cursor:pointer;transition:all .15s var(--ease);font-weight:600;white-space:nowrap;display:inline-flex;align-items:center;gap:6px;flex-shrink:0;min-height:32px;line-height:1.2}.cat-chip .ci{font-size:13px;opacity:.85}.cat-chip:hover{background:var(--bg);color:var(--ink);border-color:var(--ink-4);transform:translateY(-1px)}.cat-chip.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 8px rgba(74,111,165,.28)}.cat-chip.active .ci{opacity:1}.cat-chip .chip-x{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:-4px;margin-left:2px;border-radius:50%;background:rgba(255,255,255,.25);font-size:12px;line-height:1;font-weight:600}.cat-chip.active:hover{background:var(--accent-hover);border-color:var(--accent-hover)}@media (max-width:600px){.cat-chip{font-size:13px;padding:9px 14px;min-height:38px}}.picker-list{flex:1 1;overflow-y:auto;padding:4px 14px 14px;-webkit-overflow-scrolling:touch}.picker-section{margin-top:10px}.picker-section:first-child{margin-top:4px}.picker-section-title{font-family:JetBrains Mono,monospace;font-size:10.5px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.12em;font-weight:700;padding:8px 8px 6px;display:flex;align-items:center;gap:8px}.picker-section-title .pst-line{flex:1 1;height:1px;background:var(--line-soft)}.picker-item{width:100%;background:transparent;border:none;border-radius:var(--r-sm);padding:10px 12px;cursor:pointer;display:flex;align-items:center;gap:12px;text-align:left;transition:all .15s;color:var(--ink)}.picker-item:hover{background:var(--bg)}.picker-item:focus-visible{background:var(--bg);outline:2px solid var(--accent);outline-offset:-2px}.picker-item.added,.picker-item:disabled{opacity:.5;cursor:default;color:var(--ink-3)}.picker-item.added:hover{background:transparent}.picker-item .pi-icon{width:30px;height:30px;border-radius:var(--r-sm);background:var(--bg-2);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.picker-item .pi-text{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:1px}.picker-item .pi-label{font-size:14px;font-weight:600;color:var(--ink);line-height:1.3}.picker-item.added .pi-label{color:var(--ink-3)}.picker-item .pi-key{font-family:JetBrains Mono,monospace;font-size:10.5px;color:var(--ink-3)}.picker-item .pi-status{font-size:11px;color:var(--ink-3);flex-shrink:0;display:flex;align-items:center;gap:4px}.picker-item.added .pi-status{color:var(--success);font-weight:600}.picker-item .pi-arrow{font-size:16px;color:var(--ink-4);flex-shrink:0;transition:transform .15s}.picker-item:hover .pi-arrow{color:var(--accent);transform:translateX(3px)}.picker-item.custom-tile{background:var(--accent-soft);border:1px dashed var(--accent);margin-bottom:10px}.picker-item.custom-tile:hover{background:var(--accent);color:#fff}.picker-item.custom-tile .pi-icon{background:var(--card);color:var(--accent);font-weight:700}.picker-item.custom-tile:hover .pi-icon{background:rgba(255,255,255,.2);color:#fff}.picker-item.custom-tile:hover .pi-arrow,.picker-item.custom-tile:hover .pi-key,.picker-item.custom-tile:hover .pi-label{color:#fff}.picker-empty{text-align:center;padding:32px 16px;color:var(--ink-3);font-size:13px}.picker-empty .pe-title{font-family:"Instrument Serif",serif;font-size:20px;color:var(--ink);margin-bottom:4px;font-style:italic}.picker-foot{border-top:1px solid var(--line-soft);padding:12px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--card-2);flex-shrink:0}.picker-foot-info{font-family:JetBrains Mono,monospace;font-size:11.5px;color:var(--ink-3);font-weight:600}.picker-foot .btn.primary{min-height:40px;padding:9px 22px}.confirm-overlay{position:fixed;inset:0;background:rgba(20,18,12,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:120;opacity:0;pointer-events:none;transition:opacity .25s var(--ease);display:flex;align-items:center;justify-content:center;padding:24px}.confirm-overlay.show{opacity:1;pointer-events:auto}.confirm-dialog{background:var(--card);width:100%;max-width:380px;border-radius:var(--r-lg);box-shadow:var(--shadow-modal);padding:22px 22px 16px;transform:translateY(12px) scale(.97);transition:transform .32s var(--ease-out);display:flex;flex-direction:column;gap:8px}.confirm-overlay.show .confirm-dialog{transform:translateY(0) scale(1)}.confirm-title{font-family:"Instrument Serif",serif;font-style:italic;font-size:22px;color:var(--ink);line-height:1.2}.confirm-body{font-size:13.5px;color:var(--ink-2);line-height:1.55;margin-bottom:8px}.confirm-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:6px}.confirm-actions .btn{min-height:40px;padding:9px 16px}.btn.danger-fill{background:var(--danger);border-color:var(--danger);color:#fff}.btn.danger-fill:hover{background:#b13434;border-color:#b13434}.png-overlay{position:fixed;inset:0;background:rgba(20,18,12,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:110;opacity:0;pointer-events:none;transition:opacity .25s var(--ease);display:flex;align-items:center;justify-content:center;padding:24px}.png-overlay.show{opacity:1;pointer-events:auto}.png-sheet{background:var(--card);width:100%;max-width:640px;max-height:calc(100vh - 48px);border-radius:var(--r-lg);box-shadow:var(--shadow-modal);display:flex;flex-direction:column;overflow:hidden;transform:translateY(16px) scale(.97);transition:transform .32s var(--ease-out)}.png-overlay.show .png-sheet{transform:translateY(0) scale(1)}.png-head{padding:16px 20px 12px;display:flex;align-items:flex-start;gap:12px;border-bottom:1px solid var(--line-soft);flex-shrink:0}.png-head-text{flex:1 1;min-width:0}.png-title{font-family:"Instrument Serif",serif;font-style:italic;font-size:22px;line-height:1.1;color:var(--ink);margin-bottom:4px}.png-hint{font-size:12.5px;color:var(--ink-3);line-height:1.4}.png-hint-mobile{display:none}.png-hint-desktop{display:inline}.png-preview{flex:1 1;overflow:auto;padding:18px;display:flex;align-items:center;justify-content:center;background:var(--card-2);-webkit-overflow-scrolling:touch}.png-img{max-width:100%;max-height:60vh;height:auto;border-radius:var(--r);box-shadow:var(--shadow-md);display:block;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-touch-callout:default}.png-actions{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--line-soft);flex-shrink:0;background:var(--card)}.png-actions .btn{min-height:40px;padding:9px 16px}.png-actions .png-dl{flex:1 1;justify-content:center}@media (max-width:600px){.png-overlay{padding:0;align-items:flex-end}.png-sheet{max-width:100%;max-height:94vh;border-radius:var(--r-lg) var(--r-lg) 0 0;transform:translateY(40px)}.png-overlay.show .png-sheet{transform:translateY(0)}.png-sheet:before{content:"";display:block;width:42px;height:4px;background:var(--ink-5);border-radius:999px;margin:8px auto 0;flex-shrink:0}.png-hint-mobile{display:inline}.png-hint-desktop{display:none}.png-img{max-height:56vh}.picker-overlay{padding:0;align-items:flex-end}.picker{max-width:100%;max-height:92vh;border-radius:var(--r-lg) var(--r-lg) 0 0;transform:translateY(40px)}.picker-overlay.show .picker{transform:translateY(0)}.picker-head{padding:14px 18px 10px}.picker-search-wrap{padding:8px 18px}.picker-search-icon{left:32px}.picker-search{padding:13px 14px 13px 38px;font-size:16px}.picker-cats{padding:4px 18px 12px}.picker-list{padding:4px 10px 24px}.picker-item{padding:12px 10px;min-height:56px}.picker-item .pi-icon{width:34px;height:34px;font-size:16px}.picker-item .pi-label{font-size:15px}.picker:before{content:"";display:block;width:42px;height:4px;background:var(--ink-5);border-radius:999px;margin:8px auto 0;flex-shrink:0}}.preview-col{position:-webkit-sticky;position:sticky;top:16px}.preview-stage{padding:14px 14px 18px;transition:background .4s var(--ease);background:var(--card-2);min-height:280px;display:flex;align-items:flex-start;justify-content:center;overflow:hidden;position:relative}.scale-wrap{transition:transform .3s var(--ease);margin:0 auto}.preview-actions{display:flex;gap:8px;padding:10px 14px;border-bottom:1px solid var(--line-soft);flex-wrap:wrap;background:var(--card);align-items:center}.preview-actions .btn{min-height:36px}.export-frame{display:flex;align-items:center;justify-content:center;box-sizing:border-box;overflow:hidden;transition:background .4s var(--ease)}.export-frame.auto{width:640px;padding:32px 28px;border-radius:18px}.export-frame.square{width:1080px;height:1080px;padding:36px 40px;flex-direction:column;gap:20px}.export-frame.post{width:1200px;height:675px;padding:28px 36px;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.7fr);grid-gap:32px;gap:32px;align-items:stretch}.export-frame.wide{width:1500px;height:500px;padding:24px 36px;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.55fr);grid-gap:36px;gap:36px;align-items:stretch}.export-frame.post .bigtext,.export-frame.wide .bigtext{justify-content:center;justify-self:center;align-items:flex-start;height:100%;width:max-content;max-width:100%}.export-frame.square .json-card,.export-frame.square .term-window,.export-frame.square .vsc{max-width:100%;width:100%;min-height:720px;display:flex;flex-direction:column}.export-frame.square .json-body,.export-frame.square .term-body,.export-frame.square .vsc-body{flex:1 1}.export-frame.post .json-card,.export-frame.post .term-window,.export-frame.post .vsc{max-width:100%;width:100%;min-height:540px;display:flex;flex-direction:column}.export-frame.post .json-body,.export-frame.post .term-body,.export-frame.post .vsc-body{flex:1 1}.export-frame.wide .json-card,.export-frame.wide .term-window,.export-frame.wide .vsc{max-width:100%;width:100%;min-height:410px;display:flex;flex-direction:column}.export-frame.wide .json-body,.export-frame.wide .term-body,.export-frame.wide .vsc-body{flex:1 1}.export-frame.square .term-body{font-size:22px;line-height:1.85;padding:32px 38px 38px}.export-frame.square .json-body{font-size:22px;line-height:1.85;padding:30px 38px}.export-frame.square .vsc-body{font-size:22px;line-height:1.85;padding:28px 32px 36px}.export-frame.square .json-card-bar{font-size:17px;padding:18px 28px}.export-frame.square .json-card-foot{font-size:14px;padding:16px 28px}.export-frame.square .term-bar{padding:16px 22px;gap:8px}.export-frame.square .term-bar .dot{width:16px;height:16px}.export-frame.square .term-bar .title{font-size:15px}.export-frame.square .term-footer{font-size:13px;margin-top:18px}.export-frame.square .vsc-bar{padding:12px 16px}.export-frame.square .vsc-bar .dot{width:16px;height:16px}.export-frame.square .vsc-bar .title{font-size:14px}.export-frame.square .vsc-tab{padding:11px 20px;font-size:15px}.export-frame.square .json-body .ln:before{width:30px;margin-right:12px}.export-frame.square .vsc-body .vsc-ln:before{width:32px;margin-right:12px}.export-frame.post .term-body{font-size:17px;line-height:1.85;padding:22px 28px 28px}.export-frame.post .json-body{font-size:17px;line-height:1.85;padding:22px 28px}.export-frame.post .vsc-body{font-size:17px;line-height:1.85;padding:20px 24px 26px}.export-frame.post .json-card-bar{font-size:14px;padding:13px 22px}.export-frame.post .json-card-foot{font-size:12px;padding:12px 22px}.export-frame.post .term-bar{padding:12px 16px}.export-frame.post .term-bar .title{font-size:13px}.export-frame.post .term-footer{font-size:11px}.export-frame.post .vsc-bar{padding:9px 14px}.export-frame.post .vsc-tab{padding:9px 16px;font-size:13px}.export-frame.wide .term-body{font-size:16px;line-height:1.75;padding:20px 26px 24px}.export-frame.wide .json-body{font-size:16px;line-height:1.75;padding:18px 26px}.export-frame.wide .vsc-body{font-size:16px;line-height:1.75;padding:18px 24px 22px}.export-frame.wide .json-card-bar{font-size:13px;padding:11px 22px}.export-frame.wide .json-card-foot{font-size:11px;padding:10px 22px}.export-frame.wide .term-bar{padding:10px 16px}.export-frame.wide .term-bar .title{font-size:12px}.export-frame.wide .vsc-bar{padding:8px 14px}.export-frame.wide .vsc-tab{padding:8px 14px;font-size:12px}.bigtext{display:flex;flex-direction:column;gap:6px;min-width:0}.bigtext .bt-name{font-family:"Instrument Serif",serif;font-weight:400;font-size:88px;line-height:.95;letter-spacing:-.02em;color:var(--frame-fg,#1a1815)}.bigtext .bt-name em{font-style:italic;color:var(--frame-accent,#7a6dcc)}.bigtext .bt-title{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;font-size:30px;color:var(--frame-fg-2,#57544d);letter-spacing:-.005em;margin-top:8px;line-height:1.15}.bigtext .bt-meta{font-family:Manrope,sans-serif;font-weight:500;font-size:17px;color:var(--frame-fg-2,#57544d);line-height:1.7;margin-top:18px}.bigtext .bt-meta .bt-row{display:flex;gap:10px;align-items:baseline}.bigtext .bt-meta .bt-key{font-size:13px;min-width:80px;letter-spacing:.06em}.bigtext .bt-mark,.bigtext .bt-meta .bt-key{font-family:JetBrains Mono,monospace;color:var(--frame-fg-3,#8a857a);text-transform:uppercase}.bigtext .bt-mark{font-size:12px;letter-spacing:.1em}.export-frame.square .bigtext{text-align:center;align-items:center}.export-frame.square .bigtext .bt-name{font-size:84px}.export-frame.square .bigtext .bt-title{font-size:28px}.export-frame.square .bigtext .bt-meta{align-items:center;margin-top:12px;font-size:16px}.export-frame.square .bigtext .bt-row{justify-content:center}.export-frame.square .bigtext .bt-key{min-width:0}.export-frame.post .bigtext .bt-name{font-size:84px;line-height:.95}.export-frame.post .bigtext .bt-title{font-size:28px}.export-frame.post .bigtext .bt-meta{font-size:15px;margin-top:16px}.export-frame.wide .bigtext .bt-name{font-size:76px;line-height:.95}.export-frame.wide .bigtext .bt-title{font-size:26px}.export-frame.wide .bigtext .bt-meta{font-size:14px;margin-top:12px;line-height:1.6}.export-frame.wide .bigtext .bt-key{font-size:11px;min-width:60px}.export-frame.dark-bg .bt-name{color:#f8f5ee}.export-frame.dark-bg .bt-title{color:#c5bfae}.export-frame.dark-bg .bt-meta{color:#b5ad9a}.export-frame.dark-bg .bt-key,.export-frame.dark-bg .bt-mark{color:#8a857a}.term-window{--tw-bg:#1a1b22;--tw-bar:#292a33;--tw-fg:#e8eaed;--tw-prompt:#28c840;--tw-cmd:#82aaff;--tw-muted:#8a8d96;--tw-title:#8a8d96;--tw-footer:#6a6c75;--tw-cursor:#e8eaed;--tw-shadow:0 20px 60px rgba(0,0,0,0.18),0 4px 12px rgba(0,0,0,0.08);width:100%;max-width:540px;background:var(--tw-bg);border-radius:12px;overflow:hidden;box-shadow:var(--tw-shadow);font-family:JetBrains Mono,monospace;flex-shrink:0}.term-bar{background:var(--tw-bar);padding:10px 14px;display:flex;align-items:center;gap:6px}.term-bar .dot{width:12px;height:12px;border-radius:50%}.term-bar .dot.r{background:#ff5f57}.term-bar .dot.y{background:#febc2e}.term-bar .dot.g{background:#28c840}.term-bar .title{flex:1 1;text-align:center;color:var(--tw-title);font-size:11px;font-weight:500}.term-body{padding:18px 20px 22px;color:var(--tw-fg);font-size:12.5px;line-height:1.85}.term-line{margin-bottom:2px}.term-prompt{color:var(--tw-prompt);margin-right:8px}.term-cmd{color:var(--tw-cmd)}.term-out{color:var(--tw-fg);padding-left:16px;word-break:break-word;white-space:pre-wrap}.term-out.muted{color:var(--tw-muted)}.term-cursor{display:inline-block;width:.55em;height:1.05em;background:var(--tw-cursor);margin-left:.3em;vertical-align:-.15em;animation:blink 1.05s steps(2) infinite}@keyframes blink{50%{opacity:0}}.term-footer{color:var(--tw-footer);font-size:10px;text-align:right;margin-top:14px}.term-window.theme-light{--tw-bg:#f8f5ee;--tw-bar:#ede4d0;--tw-fg:#1a1815;--tw-prompt:#2d7a3e;--tw-cmd:#1d4ed8;--tw-muted:#847f72;--tw-title:#847f72;--tw-footer:#b5af9e;--tw-cursor:#1a1815;--tw-shadow:0 12px 40px rgba(40,35,25,0.10),0 2px 8px rgba(40,35,25,0.04)}.term-window.theme-cream{--tw-bg:#f6efdc;--tw-bar:#ebe1c4;--tw-fg:#3d3a32;--tw-prompt:#4a7c2e;--tw-cmd:#4a6fa5;--tw-muted:#847f72;--tw-title:#847f72;--tw-footer:#a8a292;--tw-cursor:#3d3a32;--tw-shadow:0 12px 40px rgba(80,60,30,0.10),0 2px 8px rgba(80,60,30,0.04)}.json-card{--jc-bg:#ffffff;--jc-bar:#f7f5f0;--jc-fg:var(--ink);--jc-border:var(--line);--jc-line-num:var(--ink-4);--jc-meta:var(--ink-3);--jc-key:#c2410c;--jc-str:#15803d;--jc-num:#1d4ed8;--jc-bool:#7c3aed;--jc-null:var(--ink-3);--jc-punct:var(--ink-2);--jc-file-icon:var(--accent);--jc-shadow:0 12px 40px rgba(40,35,25,0.08),0 2px 8px rgba(40,35,25,0.04);width:100%;max-width:520px;background:var(--jc-bg);border-radius:14px;overflow:hidden;box-shadow:var(--jc-shadow);border:1px solid var(--jc-border);flex-shrink:0}.json-card-bar{background:var(--jc-bar);border-bottom:1px solid var(--jc-border);padding:10px 16px;font-family:JetBrains Mono,monospace;font-size:11px;color:var(--jc-meta);display:flex;align-items:center;gap:8px}.json-card-bar .file-icon{color:var(--jc-file-icon);font-weight:700}.json-card-bar .meta{margin-left:auto;color:var(--jc-line-num)}.json-body{padding:18px 20px;font-family:JetBrains Mono,monospace;font-size:12.5px;line-height:1.85;color:var(--jc-fg);overflow-x:auto}.json-body .ln{display:flex;align-items:center;white-space:pre;min-height:1.85em}.json-body .ln:before{content:attr(data-n);flex-shrink:0;width:20px;margin-right:8px;text-align:right;color:var(--jc-line-num);-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.json-body .ln-text{flex:1 1;min-width:0;line-height:1}.json-card .j-key{color:var(--jc-key)}.json-card .j-str{color:var(--jc-str)}.json-card .j-num{color:var(--jc-num)}.json-card .j-bool{color:var(--jc-bool)}.json-card .j-null{color:var(--jc-null);font-style:italic}.json-card .j-punct{color:var(--jc-punct)}.json-card-foot{border-top:1px solid var(--jc-border);padding:10px 16px;font-family:JetBrains Mono,monospace;font-size:10px;color:var(--jc-meta);display:flex;justify-content:space-between}.json-card.theme-dark{--jc-bg:#1a1b22;--jc-bar:#21222c;--jc-fg:#e8eaed;--jc-border:#2a2b35;--jc-line-num:#6a6c75;--jc-meta:#8a8d96;--jc-key:#82aaff;--jc-str:#c3e88d;--jc-num:#f78c6c;--jc-bool:#c792ea;--jc-null:#8a8d96;--jc-punct:#e8eaed;--jc-file-icon:#82aaff;--jc-shadow:0 20px 60px rgba(0,0,0,0.22),0 4px 12px rgba(0,0,0,0.08)}.json-card.theme-cream{--jc-bg:#faf6ee;--jc-bar:#f1eadb;--jc-fg:#3d3a32;--jc-border:#e3dec9;--jc-line-num:#a8a292;--jc-meta:#847f72;--jc-key:#b75428;--jc-str:#5a7d3e;--jc-num:#4a6fa5;--jc-bool:#7d4ca6;--jc-null:#847f72;--jc-punct:#3d3a32;--jc-file-icon:#4a6fa5;--jc-shadow:0 12px 40px rgba(80,60,30,0.10),0 2px 8px rgba(80,60,30,0.04)}.vsc{--vc-bg:#1e1e1e;--vc-bar:#323233;--vc-tab-bg:#1e1e1e;--vc-tab-inactive:#252526;--vc-tab-fg:#cccccc;--vc-line-num:#6a6a6a;--vc-fg:#d4d4d4;--vc-kw:#c586c0;--vc-let:#569cd6;--vc-var:#9cdcfe;--vc-key:#9cdcfe;--vc-str:#ce9178;--vc-num:#b5cea8;--vc-bool:#569cd6;--vc-punct:#d4d4d4;--vc-cm:#6a9955;--vc-shadow:0 20px 60px rgba(0,0,0,0.15),0 4px 12px rgba(0,0,0,0.08);width:100%;max-width:580px;background:var(--vc-bg);border-radius:10px;overflow:hidden;box-shadow:var(--vc-shadow);font-family:JetBrains Mono,monospace;flex-shrink:0}.vsc-bar{background:var(--vc-bar);padding:8px 12px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--vc-tab-inactive)}.vsc-bar .dot{width:12px;height:12px;border-radius:50%}.vsc-bar .dot.r{background:#ff5f57}.vsc-bar .dot.y{background:#febc2e}.vsc-bar .dot.g{background:#28c840}.vsc-bar .title{flex:1 1;text-align:center;color:var(--vc-tab-fg);font-size:11px}.vsc-tabs{background:var(--vc-tab-inactive);display:flex;border-bottom:1px solid var(--vc-bg)}.vsc-tab{padding:7px 14px;color:var(--vc-tab-fg);font-size:11.5px;background:var(--vc-tab-bg);border-right:1px solid var(--vc-tab-inactive);gap:7px}.vsc-tab,.vsc-tab .file-ico{display:inline-flex;align-items:center}.vsc-tab .file-ico{width:13px;height:13px;background:#519aba;border-radius:1px;font-size:8px;color:#fff;font-weight:700;justify-content:center}.vsc-body{padding:16px 18px 20px;font-size:12.5px;line-height:1.85;color:var(--vc-fg);overflow-x:auto}.vsc-ln{display:flex;align-items:center;white-space:pre;min-height:1.85em}.vsc-ln:before{content:attr(data-n);flex-shrink:0;width:22px;margin-right:10px;text-align:right;color:var(--vc-line-num);-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.vsc-ln-text{flex:1 1;min-width:0;line-height:1}.vsc .v-kw{color:var(--vc-kw)}.vsc .v-let{color:var(--vc-let)}.vsc .v-var{color:var(--vc-var)}.vsc .v-key{color:var(--vc-key)}.vsc .v-str{color:var(--vc-str)}.vsc .v-num{color:var(--vc-num)}.vsc .v-bool{color:var(--vc-bool)}.vsc .v-punct{color:var(--vc-punct)}.vsc .v-cm{color:var(--vc-cm);font-style:italic}.vsc.theme-light{--vc-bg:#ffffff;--vc-bar:#f3f3f3;--vc-tab-bg:#ffffff;--vc-tab-inactive:#ececec;--vc-tab-fg:#424242;--vc-line-num:#237893;--vc-fg:#000000;--vc-kw:#af00db;--vc-let:#0000ff;--vc-var:#001080;--vc-key:#001080;--vc-str:#a31515;--vc-num:#098658;--vc-bool:#0000ff;--vc-punct:#000000;--vc-cm:#008000;--vc-shadow:0 12px 40px rgba(40,35,25,0.10),0 2px 8px rgba(40,35,25,0.04)}.vsc.theme-cream{--vc-bg:#faf6ee;--vc-bar:#f1eadb;--vc-tab-bg:#faf6ee;--vc-tab-inactive:#ede4d0;--vc-tab-fg:#6e6857;--vc-line-num:#a8a292;--vc-fg:#3d3a32;--vc-kw:#b75428;--vc-let:#4a6fa5;--vc-var:#2d5d80;--vc-key:#2d5d80;--vc-str:#5a7d3e;--vc-num:#4a6fa5;--vc-bool:#7d4ca6;--vc-punct:#3d3a32;--vc-cm:#847f72;--vc-shadow:0 12px 40px rgba(80,60,30,0.10),0 2px 8px rgba(80,60,30,0.04)}.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:10px 20px;border-radius:999px;font-size:13px;font-weight:600;opacity:0;pointer-events:none;transition:all .25s var(--ease);z-index:1000;box-shadow:var(--shadow-lg)}.toast.show{transform:translateX(-50%) translateY(0);opacity:1}.toast.err{background:var(--danger)}.toast.success{background:var(--success)}footer.app-footer{text-align:center;color:var(--ink-3);font-size:11px;padding:24px 16px 36px;letter-spacing:.04em}footer .heart{color:var(--accent);font-weight:600;text-decoration:none;border-bottom:1px dotted var(--accent);padding-bottom:1px;transition:color .15s var(--ease),border-color .15s var(--ease)}footer .heart:hover{color:var(--accent-hover);border-bottom-color:var(--accent-hover);border-bottom-style:solid}footer kbd{background:var(--card);border:1px solid var(--line);border-radius:4px;padding:1px 5px;font-family:JetBrains Mono,monospace;font-size:10px;color:var(--ink-2)}.size-info{font-family:JetBrains Mono,monospace;font-size:10.5px;color:var(--ink-3);padding:3px 8px;background:var(--bg);border-radius:999px;border:1px solid var(--line-soft);font-weight:600}.style-toggle{display:none;background:transparent;border:none;cursor:pointer;color:var(--ink-3);font-size:13px;transition:transform .2s var(--ease);align-items:center;justify-content:center;padding:10px;margin:-10px;min-width:44px;min-height:44px;border-radius:999px}.style-toggle:focus-visible,.style-toggle:hover{background:var(--bg);color:var(--ink)}.style-toggle svg{width:18px;height:18px;transition:transform .2s var(--ease)}.style-panel.collapsed .style-toggle svg{transform:rotate(-90deg)}.style-panel.collapsed .panel-body{display:none}@media (max-width:980px){.style-toggle{display:inline-flex}.style-panel-head{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:rgba(74,111,165,.1)}.style-panel-head:active{background:var(--bg)}.field-input,.field-label-input,.field-textarea,.picker-search,input:not([type]),input[type=email],input[type=number],input[type=search],input[type=tel],input[type=text],input[type=url],select,textarea{font-size:16px!important}}