:root{--ink: #1c1f26;--panel: #ffffff;--bg: #e8e6df;--line: #c9c5b8;--accent: #c2402b;--accent-dim: #e7c7c0;--grid: #d4d0c4;--mono: ui-monospace, "SF Mono", "Cascadia Code", "Roboto Mono", Menlo, monospace;--sans: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--ok: #2e7d4f;--warn: #b8860b}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}#root{display:flex;flex-direction:column}body{font-family:var(--sans);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.45}header{display:flex;align-items:baseline;gap:14px;padding:14px 20px;border-bottom:2px solid var(--ink);background:var(--panel);flex-shrink:0}header h1{font-size:16px;margin:0;letter-spacing:-.01em;font-weight:650}header .sub{font-family:var(--mono);font-size:11.5px;color:#6b6759}header .badge{margin-left:auto;font-family:var(--mono);font-size:11px;background:var(--ink);color:#fff;padding:3px 9px;border-radius:2px}.wrap{display:grid;grid-template-columns:360px 1fr;flex:1 1 auto;min-height:0;overflow:hidden}@media (max-width: 880px){.wrap{grid-template-columns:1fr;height:auto;overflow:auto}.stage{height:auto;overflow:visible}.preview-card{flex:0 0 auto}.preview-body{min-height:320px}.sbpl-card{max-height:none}}.controls{border-right:1px solid var(--line);background:var(--panel);overflow-y:auto;padding:16px;display:flex;flex-direction:column}.editor-section{display:flex;flex-direction:column;flex:1 1 auto;min-height:200px}.editor-section .code-editor{flex:1 1 auto}.controls h2{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#8a8678;margin:18px 0 8px;font-weight:600}.controls h2:first-child{margin-top:0}.row{display:flex;gap:10px;margin-bottom:10px}.field{flex:1;display:flex;flex-direction:column;gap:3px}.field label{font-size:11px;color:#6b6759;font-family:var(--mono)}input[type=number],input[type=text],input[type=password],select{font-family:var(--mono);font-size:13px;border:1px solid var(--line);border-radius:3px;padding:6px 8px;background:#fbfaf6;color:var(--ink);width:100%}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:var(--accent)}textarea{width:100%;min-height:120px;font-family:var(--mono);font-size:12px;line-height:1.5;border:1px solid var(--line);border-radius:3px;padding:10px;background:#fbfaf6;color:var(--ink);resize:vertical;-moz-tab-size:2;tab-size:2}.code-editor{position:relative;border:1px solid var(--line);border-radius:3px;background:#fbfaf6;overflow:hidden;flex:1 1 auto;min-height:120px}.code-editor:focus-within{outline:2px solid var(--accent);outline-offset:-1px;border-color:var(--accent)}.code-editor pre,.code-editor textarea{margin:0;font:12px/16px var(--mono);padding:10px;tab-size:2;-moz-tab-size:2;white-space:pre-wrap;overflow-wrap:break-word;word-break:normal;box-sizing:border-box;border:0;letter-spacing:0}.code-editor pre code{font:inherit;padding:0;margin:0;white-space:inherit;word-break:inherit;overflow-wrap:inherit;display:block;transform-origin:0 0;will-change:transform}.code-editor pre{position:absolute;top:0;right:0;bottom:0;left:0;margin:0;overflow:hidden;pointer-events:none;color:var(--ink);background:transparent}.code-editor textarea{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;resize:none;background:transparent;color:transparent;caret-color:var(--ink);outline:none;overflow-y:scroll;scrollbar-width:none}.code-editor textarea::-webkit-scrollbar{width:0;height:0}.code-editor textarea::selection{background:#c2402b38}.tok-key{color:#2e6f9e}.tok-str{color:#2e7d4f}.tok-num{color:#b5651d}.tok-bool{color:#c2402b;font-weight:600}.tok-null{color:#8a8678;font-style:italic}.tok-punct{color:#8a8678}.hint{font-family:var(--mono);font-size:10.5px;color:#948f80;margin-top:4px}.err{font-family:var(--mono);font-size:11px;color:var(--accent);background:var(--accent-dim);border-radius:3px;padding:6px 8px;margin-top:6px;white-space:pre-wrap}.stage{overflow:hidden;padding:18px;display:flex;flex-direction:column;gap:18px;min-height:0}.card{background:var(--panel);border:1px solid var(--line);border-radius:4px}.preview-card{flex:1 1 auto;min-height:0;display:flex;flex-direction:column}.preview-body{flex:1 1 auto;min-height:0;overflow:auto;display:flex;align-items:center;justify-content:center}.sbpl-card{flex:0 0 auto;display:flex;flex-direction:column;max-height:42vh}.sbpl-head{cursor:pointer;-webkit-user-select:none;user-select:none}.sbpl-body{overflow:auto}.sbpl-card.min .sbpl-body{display:none}.sbpl-card.min{max-height:none}.card-head{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--line)}.card-head h3{margin:0;font-size:12px;text-transform:uppercase;letter-spacing:.06em;font-weight:650;color:#4a4738}.card-head .meta{margin-left:auto;font-family:var(--mono);font-size:11px;color:#8a8678}.card-body{padding:14px}#previewWrap,#cleanWrap{position:relative;box-shadow:0 2px 8px #00000014;overflow:hidden}#previewWrap{margin:0 auto;cursor:zoom-in}.el{position:absolute;display:flex;align-items:center;white-space:nowrap}.el.text{font-family:var(--mono);color:#000;line-height:1}.el.dm{image-rendering:pixelated}.el.dm canvas{display:block}.el.box{border:1px solid #000;background:transparent;align-items:stretch}.el.text.center{justify-content:center;text-align:center}.el.text.right{justify-content:flex-end;text-align:right}.el-label{position:absolute;top:-14px;left:0;font-family:var(--mono);font-size:9px;color:var(--accent);background:#fff;padding:0 2px;pointer-events:none}pre.out{margin:0;font-family:var(--mono);font-size:12px;line-height:1.55;white-space:pre-wrap;word-break:break-all;max-height:320px;overflow-y:auto;color:#2b2f3a}pre.out .esc{color:var(--accent);font-weight:600}pre.out .gs{color:var(--ok);font-weight:600}.btnrow{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px;justify-content:flex-end}.menu{position:relative;display:inline-block}.menu-list,.ctx-menu{position:absolute;z-index:60;min-width:150px;background:var(--panel);border:1px solid var(--line);border-radius:4px;box-shadow:0 6px 20px #1c1f262e;padding:4px;display:none}.menu-list{bottom:calc(100% + 4px);right:0}.ctx-menu{position:fixed}.menu.open .menu-list,.ctx-menu.open{display:block}.icon-btn{display:inline-flex;align-items:center;justify-content:center;padding:7px;line-height:0}.icon-btn svg{display:block}.menu-item{display:block;width:100%;text-align:left;font-family:var(--sans);font-size:13px;font-weight:500;background:transparent;color:var(--ink);border:0;border-radius:3px;padding:7px 10px;cursor:pointer}.menu-item:hover{background:#f0eee6}button{font-family:var(--sans);font-size:13px;font-weight:550;border:1px solid var(--ink);background:var(--ink);color:#fff;padding:7px 14px;border-radius:3px;cursor:pointer}button.ghost{background:#fff;color:var(--ink)}button:hover{opacity:.88}button:active{transform:translateY(1px)}button:disabled{opacity:.45;cursor:not-allowed;transform:none}.legend{font-family:var(--mono);font-size:10.5px;color:#8a8678;margin-top:8px}.legend .esc{color:var(--accent)}.legend .gs{color:var(--ok)}.copied{color:var(--ok);font-family:var(--mono);font-size:11px;align-self:center}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:24px;background:#1c1f26b8;opacity:0;visibility:hidden;transition:opacity .22s ease,visibility 0s linear .22s}.modal.open{opacity:1;visibility:visible;transition:opacity .22s ease}.modal-panel{background:#fff;border-radius:6px;max-width:95vw;max-height:95vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 12px 40px #0006;transform:scale(.985);transition:transform .22s ease}.modal.open .modal-panel{transform:scale(1)}.modal-head{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--line)}.modal-head h3{margin:0;font-size:13px;text-transform:uppercase;letter-spacing:.05em}.modal-head .meta{font-family:var(--mono);font-size:11px;color:#8a8678}.modal-stage{padding:24px;background:#dad7cf;display:flex;align-items:center;justify-content:center;overflow:auto}#cleanWrap{background:#fff;box-shadow:0 1px 6px #00000026}.password-screen{flex:1 1 auto;display:flex;align-items:center;justify-content:center;background:var(--bg)}.password-panel{background:var(--panel);border:1px solid var(--line);border-radius:4px;padding:16px;width:320px;display:flex;flex-direction:column}.password-panel h2{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#8a8678;margin:0 0 8px;font-weight:600}.password-panel .btnrow{margin-top:12px}#printHost{position:absolute;left:-99999px;top:0}#printHost .el{position:absolute;display:flex;align-items:center;white-space:nowrap}@media print{body>*:not(#printHost){display:none!important}#printHost{position:absolute;left:0!important;top:0!important;display:block!important}#printHost .label-page{position:absolute;left:0;top:0;margin:0;padding:0;background:#fff;overflow:hidden;page-break-after:avoid}#printHost #printPageInner{position:absolute;left:0;top:0;margin:0!important}html,body{margin:0!important;padding:0!important;background:#fff!important}}
