*,:before,:after{box-sizing:border-box}:root{--bg:#f7f5f0;--bg-accent:#ebe6dc;--text:#2a2622;--text-muted:#6b645c;--output-pending-color:#a3a3a3;--font-display:system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif}html,body,#root{height:100%}body{color:var(--text);background:var(--bg);background-image:radial-gradient(ellipse 120% 80% at 50% -20%, var(--bg-accent), var(--bg) 55%);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:system-ui,-apple-system,Segoe UI,sans-serif;font-size:1.25rem;line-height:1.5}:root{--top-bar-height:4.25rem}.top-bar{z-index:200;min-height:var(--top-bar-height);box-sizing:border-box;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#f7f5f0eb;border-bottom:1px solid #2a26221f;grid-template-columns:1fr auto 1fr;align-items:center;padding:.35rem .5rem;display:grid;position:fixed;top:0;left:0;right:0}.top-bar__start{justify-self:start;display:flex}.top-bar__end{justify-self:end;width:2.75rem;height:2.75rem}.top-bar__brand{font-family:var(--font-display);letter-spacing:.02em;color:var(--text);grid-column:2;justify-self:center;margin:0;font-size:2.3rem;font-weight:600;line-height:1.1}.top-bar__menu-btn{width:2.75rem;height:2.75rem;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;margin:0;padding:0;transition:background-color .15s;display:flex}.top-bar__menu-btn:hover{background:#2a26220f}.top-bar__menu-btn:focus-visible{outline-offset:2px;outline:2px solid #aa3bff8c}.top-bar__hamburger{width:1.5rem;height:1.5rem;display:block}.top-bar__backdrop{top:var(--top-bar-height);z-index:150;cursor:pointer;background:#0003;border:none;margin:0;padding:0;position:fixed;bottom:0;left:0;right:0}.top-bar-drawer{top:var(--top-bar-height);z-index:160;background:#fffffff7;border-right:1px solid #2a26221f;flex-direction:column;width:min(320px,92vw);transition:transform .2s;display:flex;position:fixed;bottom:0;left:0;transform:translate(-100%);box-shadow:4px 0 24px #00000014}.top-bar-drawer--open{transform:translate(0)}.top-bar-drawer__inner{flex-direction:column;flex:1;gap:.85rem;padding:1rem 1rem 1.25rem;display:flex;overflow-y:auto}.top-bar-drawer__heading{letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);margin:0;font-size:.85rem;font-weight:600}.top-bar-drawer__save-row{flex-direction:column;gap:.45rem;display:flex}.top-bar-drawer__field-label{color:var(--text);font-size:.9rem}.top-bar-drawer__input{box-sizing:border-box;width:100%;font:inherit;color:var(--text);background:#fffffff2;border:2px solid #2a262233;border-radius:8px;padding:.5rem .6rem;font-size:1rem}.top-bar-drawer__input:focus{border-color:#aa3bff73;outline:none;box-shadow:0 0 0 3px #aa3bff1f}.top-bar-drawer__save-btn{font:inherit;background:var(--text);color:var(--bg);cursor:pointer;border:none;border-radius:8px;padding:.5rem .65rem;font-size:.95rem;font-weight:500}.top-bar-drawer__save-btn:hover{opacity:.92}.top-bar-drawer__error{color:#b71c1c;margin:0;font-size:.88rem}.top-bar-drawer__empty{color:var(--text-muted);margin:0;font-size:.92rem}.top-bar-drawer__list{flex-direction:column;gap:.35rem;margin:0;padding:0;list-style:none;display:flex}.top-bar-drawer__list-item{align-items:center;gap:.35rem;display:flex}.top-bar-drawer__load-btn{text-align:left;min-width:0;font:inherit;color:var(--text);cursor:pointer;text-overflow:ellipsis;white-space:nowrap;background:#f7f5f0cc;border:2px solid #2a26221f;border-radius:8px;flex:1;padding:.45rem .5rem;font-size:.95rem;overflow:hidden}.top-bar-drawer__load-btn:hover{background:#2a26220f}.top-bar-drawer__delete-btn{width:2rem;height:2rem;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;padding:0;font-size:1.35rem;line-height:1}.top-bar-drawer__delete-btn:hover{color:#b71c1c;background:#b71c1c1a}.app{min-height:100%;padding:clamp(1.5rem,5vw,3rem);padding-top:calc(var(--top-bar-height) + clamp(1.5rem, 5vw, 3rem));flex-direction:column;justify-content:center;align-items:center;gap:1.25rem;padding-bottom:calc(clamp(1.5rem,5vw,3rem) + 50vh);display:flex}.panel{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff8c;border:1px solid #2a26221f;border-radius:14px;width:min(66.6667vw,100%);padding:1.25rem 1.25rem 1.75rem;box-shadow:0 10px 30px -10px #0000000f,0 2px 6px -1px #0000000a}.textbox{word-break:normal;width:100%;height:50vh;min-height:14rem;color:var(--text);resize:none;background:#fffc;border:1px solid #2a262226;border-radius:10px;outline:none;padding:1rem 1.1rem;font-family:inherit;font-size:1rem;line-height:1.5;transition:border-color .12s,box-shadow .12s,background-color .12s;display:block}.textbox::placeholder{color:var(--text-muted);opacity:.85}.textbox:focus{background:#fffffff2;border-color:#aa3bff8c;box-shadow:0 0 0 4px #aa3bff2e}.output{--output-line-size:clamp(2rem, 5vw, 3.25rem);--output-input-border-width:1px;--output-input-inline-padding:.5em;--output-rule-half-gap:clamp(.75rem, 2.5vw, 1.125rem);width:min(66.6667vw,100%);font-family:var(--font-display);color:var(--text);text-align:left;flex-direction:column;gap:0;display:flex;position:relative}.measure-mirror-output{visibility:hidden;pointer-events:none;position:absolute;top:0;left:-9999px}.output-line{flex-direction:column;gap:0;display:flex}.output-line-body{flex-direction:column;gap:.5rem;display:flex}.output-line-text{box-sizing:border-box;font-size:var(--output-line-size);white-space:pre-wrap;word-break:normal;overflow-wrap:break-word;max-width:100%;padding-left:calc(var(--output-input-border-width) + var(--output-input-inline-padding));padding-right:calc(var(--output-input-border-width) + var(--output-input-inline-padding));font-weight:500;line-height:1.35}.output-char-match{color:var(--text)}.output-char-pending{color:var(--output-pending-color)}.output-char-mismatch{color:#c62828}.output-line-input{box-sizing:border-box;width:100%;font-family:inherit;font-size:var(--output-line-size);color:var(--text);border:var(--output-input-border-width) solid #2a26222e;padding:.35em var(--output-input-inline-padding);background:#ffffffbf;border-radius:10px;outline:none;margin:0;font-weight:500;line-height:1.35}.output-line-input:focus{border-color:#aa3bff73;box-shadow:0 0 0 3px #aa3bff26}.output-line-rule{margin:0;margin-top:var(--output-rule-half-gap);margin-bottom:var(--output-rule-half-gap);border:none;border-top:1px solid #2a262224;align-self:stretch;width:100%}
