:root{--bg:#f8f9fa;--surface:#fff;--surface-alt:#f1f3f5;--sunken:#e9ecef;--text:#212529;--text2:#495057;--text3:#868e96;--border:#dee2e6;--border-s:#ced4da;--accent:#228be6;--accent-h:#1971c2;--accent-bg:#e7f5ff;--green:#2b8a3e;--green-bg:#d3f9d8;--red:#c92a2a;--red-bg:#ffe3e3;--orange:#e67700;--orange-bg:#fff4e6;--syn-string:#2b8a3e;--syn-number:#e67700;--syn-boolean:#5c7cfa;--syn-null:#868e96;--syn-key:#c92a2a;--syn-bracket:#495057;--mono:"JetBrains Mono",monospace;--sans:"DM Sans",system-ui,sans-serif;--r:8px;--r2:12px;--shadow-card:0 1px 3px rgba(0,0,0,.04),0 4px 12px rgba(0,0,0,.03);--shadow-card-hover:0 2px 8px rgba(0,0,0,.06),0 8px 24px rgba(0,0,0,.05)}.dark{--bg:#111113;--surface:#1c1c1e;--surface-alt:#232326;--sunken:#18181a;--text:#e4e4e7;--text2:#a1a1aa;--text3:#63636e;--border:#2c2c30;--border-s:#3f3f44;--accent:#4fc3f7;--accent-h:#29b6f6;--accent-bg:#1a3a4a;--green:#66bb6a;--green-bg:#1b3a1b;--red:#ef5350;--red-bg:#3a1b1b;--orange:#ffa726;--orange-bg:#3a2a1b;--syn-string:#ce9178;--syn-number:#b5cea8;--syn-boolean:#569cd6;--syn-null:gray;--syn-key:#9cdcfe;--syn-bracket:gray;--shadow-card:0 1px 3px rgba(0,0,0,.2),0 4px 12px rgba(0,0,0,.15);--shadow-card-hover:0 2px 8px rgba(0,0,0,.3),0 8px 24px rgba(0,0,0,.2)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:15px;line-height:1.6}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.wrap{margin:0 auto;max-width:1200px;padding:32px 24px 40px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);box-shadow:var(--shadow-card);overflow:hidden}.card.loading{animation:loading-stripe .8s linear infinite;background:repeating-linear-gradient(-45deg,transparent,transparent 10px,var(--surface-alt) 10px,var(--surface-alt) 20px);background-size:28px 28px;color:var(--text3);font-family:var(--mono);font-size:13px;padding:52px 32px;text-align:center}@keyframes loading-stripe{0%{background-position:0 0}to{background-position:28px 0}}.panel-label{align-items:center;background:var(--surface-alt);border-bottom:1px solid var(--border);color:var(--text3);display:flex;font-family:var(--mono);font-size:11px;font-weight:600;gap:8px;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase}.panel-label .dot{background:var(--accent);border-radius:50%;height:6px;width:6px}.toolbar{align-items:center;background:var(--surface-alt);border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:6px;padding:10px 14px}.toolbar .spacer{flex:1}.toolbar .sep{background:var(--border);height:20px;margin:0 4px;width:1px}.btn{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);cursor:pointer;display:inline-flex;font-family:var(--sans);font-size:13px;font-weight:500;gap:6px;padding:6px 14px;transition:all .15s ease;white-space:nowrap}.btn:hover{background:var(--surface-alt);border-color:var(--border-s);box-shadow:0 1px 2px #0000000a}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.btn-primary:hover{background:var(--accent-h);border-color:var(--accent-h);box-shadow:0 1px 4px #228be64d}.btn-sm{font-size:12px;padding:4px 10px}.btn-icon{align-items:center;background:transparent;border:1px solid transparent;border-radius:6px;color:var(--text2);cursor:pointer;display:inline-flex;font-size:16px;height:32px;justify-content:center;padding:0;transition:all .15s;width:32px}.btn-icon:hover{background:var(--surface);border-color:var(--border);color:var(--text)}.editor-wrap{min-height:300px;position:relative}.editor-textarea{background:transparent;border:none;color:var(--text);font-family:var(--mono);font-size:13px;line-height:1.6;min-height:300px;outline:none;padding:12px 12px 12px 52px;resize:vertical;-moz-tab-size:2;-o-tab-size:2;tab-size:2;width:100%}.editor-textarea::-moz-placeholder{color:var(--text3);opacity:.6}.editor-textarea::placeholder{color:var(--text3);opacity:.6}.line-numbers{border-right:1px solid var(--border);color:var(--text3);font-family:var(--mono);font-size:12px;left:0;line-height:1.6;opacity:.6;padding:12px 8px 12px 0;pointer-events:none;position:absolute;text-align:right;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none;width:40px}.split-panel{display:grid;grid-template-columns:1fr 1fr;min-height:400px}.split-panel>.panel{overflow:auto}.split-panel>.panel:first-child{border-right:1px solid var(--border)}.split-divider{background:var(--border);cursor:col-resize;transition:background .15s;width:4px}.split-divider:hover{background:var(--accent)}.error-banner{align-items:center;background:var(--red-bg);border-bottom:1px solid color-mix(in srgb,var(--red) 30%,transparent);color:var(--red);display:flex;font-family:var(--mono);font-size:12px;gap:8px;padding:8px 14px}.error-banner:before{content:"✖";flex-shrink:0}.success-banner{align-items:center;background:var(--green-bg);color:var(--green);display:flex;font-family:var(--mono);font-size:12px;gap:8px;padding:8px 14px}.success-banner:before{content:"✔";flex-shrink:0}.status-bar{align-items:center;background:var(--surface-alt);border-top:1px solid var(--border);color:var(--text3);display:flex;font-family:var(--mono);font-size:11px;gap:16px;padding:6px 14px}.content{margin:48px auto 0;max-width:1200px;padding:0 20px}.content h2{border-bottom:1px solid var(--border);color:var(--text);font-family:var(--mono);font-size:17px;font-weight:700;letter-spacing:-.3px;margin:48px 0 14px;padding-bottom:8px}.content h2:first-child{margin-top:0}.content p{line-height:1.7;max-width:720px}.content ol,.content p,.content ul{color:var(--text2);margin-bottom:12px}.content ol,.content ul{padding-left:24px}.content li{line-height:1.6;margin-bottom:6px}.content code{background:var(--surface-alt);border-radius:4px;font-family:var(--mono);font-size:13px;padding:2px 6px}.content code,.content pre{border:1px solid var(--border)}.content pre{background:var(--surface);border-radius:var(--r);box-shadow:var(--shadow-card);margin-bottom:16px;max-width:720px;overflow-x:auto;padding:16px}.content pre code{background:none;border:none;font-size:13px;line-height:1.6;padding:0}.steps{counter-reset:step;margin:16px 0 24px}.step{align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);display:flex;gap:16px;margin-bottom:16px;padding:12px 16px}.step:before{align-items:center;background:var(--accent-bg);border-radius:50%;color:var(--accent);content:counter(step);counter-increment:step;display:flex;flex-shrink:0;font-family:var(--mono);font-size:13px;font-weight:700;height:28px;justify-content:center;width:28px}.cmp{border:1px solid var(--border);border-collapse:separate;border-radius:var(--r);border-spacing:0;font-size:14px;margin:16px 0 24px;max-width:720px;overflow:hidden;width:100%}.cmp td,.cmp th{border-bottom:1px solid var(--border);padding:10px 14px;text-align:left}.cmp tr:last-child td{border-bottom:none}.cmp th{background:var(--surface-alt);color:var(--text3);font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.cmp td{background:var(--surface);color:var(--text2)}.cmp tr:hover td{background:var(--surface-alt)}.faq{margin:16px 0 24px;max-width:720px}.faq details{border-bottom:1px solid var(--border)}.faq summary{color:var(--text);cursor:pointer;font-size:14px;font-weight:600;list-style:none;padding:14px 0;transition:color .15s}.faq summary:hover{color:var(--accent)}.faq summary::-webkit-details-marker{display:none}.faq summary:before{align-items:center;background:var(--surface-alt);border-radius:4px;color:var(--text3);content:"+";display:inline-flex;font-family:var(--mono);font-size:13px;font-weight:400;height:22px;justify-content:center;margin-right:8px;vertical-align:middle;width:22px}.faq details[open] summary:before{background:var(--accent-bg);color:var(--accent);content:"−"}.faq details p{color:var(--text2);font-size:14px;line-height:1.7;padding:0 0 14px 30px}.tools-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));margin:16px 0 24px}.home .tools-grid{max-width:none}.tool-link{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-card);display:block;padding:14px 16px;text-decoration:none;transition:all .15s}.tool-link:hover{border-color:var(--accent);box-shadow:var(--shadow-card-hover);text-decoration:none;transform:translateY(-1px)}.tool-link strong{color:var(--text);display:block;font-family:var(--mono);font-size:13px;margin-bottom:3px}.tool-link span{color:var(--text3);font-size:12px}.app-footer{border-top:1px solid var(--border);color:var(--text3);font-family:var(--mono);font-size:11px;margin:48px auto 0;max-width:1200px;padding:24px 20px;text-align:center}.app-footer a{color:var(--accent);text-decoration:none}kbd{background:var(--surface-alt);border:1px solid var(--border);border-radius:4px;box-shadow:0 1px 0 var(--border);color:var(--text2);display:inline-block;font-size:11px;padding:2px 6px}.toast,kbd{font-family:var(--mono)}.toast{animation:toast-in .25s ease;background:var(--text);border-radius:var(--r);bottom:24px;box-shadow:0 4px 20px #0003;color:var(--bg);font-size:12px;left:50%;padding:10px 24px;position:fixed;transform:translate(-50%);z-index:9999}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.hidden{display:none!important}@media(max-width:768px){.wrap{padding:16px 12px 24px}.split-panel{grid-template-columns:1fr 1fr;min-height:250px}.editor-textarea{font-size:12px;min-height:200px}.editor-wrap{min-height:200px}.line-numbers{font-size:10px;width:30px}.editor-textarea{padding-left:38px}.toolbar{gap:4px;padding:6px 8px}.btn,.toolbar{font-size:12px}.btn{padding:5px 10px}.btn-sm{font-size:11px;padding:3px 8px}.card{border-radius:var(--r)}.panel-label,.status-bar{font-size:10px;padding:4px 10px}.content h2{font-size:15px;margin:32px 0 10px}.tools-grid{grid-template-columns:1fr}.step{padding:10px 12px}}@media(max-width:480px){.split-panel{grid-template-columns:1fr}.split-panel>.panel:first-child{border-bottom:1px solid var(--border);border-right:none}}.sidebar[data-v-9389b855]{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;left:0;overflow-x:hidden;overflow-y:auto;position:fixed;top:0;transition:transform .2s ease;width:220px;z-index:200}.sidebar-header[data-v-9389b855]{align-items:center;border-bottom:1px solid var(--border);display:flex;flex-shrink:0;justify-content:space-between;padding:14px 16px}.sidebar-brand[data-v-9389b855]{color:var(--text);font-family:var(--mono);font-size:14px;font-weight:700;text-decoration:none}.sidebar-close[data-v-9389b855]{background:none;border:none;color:var(--text3);cursor:pointer;display:none;font-size:20px;padding:0 4px}.sidebar-nav[data-v-9389b855]{flex:1;padding:8px 0}.nav-group[data-v-9389b855]{margin-bottom:4px}.nav-label[data-v-9389b855]{color:var(--text3);font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:1px;padding:12px 16px 4px;text-transform:uppercase}.nav-item[data-v-9389b855]{align-items:center;border-left:2px solid transparent;color:var(--text2);display:flex;font-family:var(--sans);font-size:13px;gap:10px;padding:6px 16px;text-decoration:none;transition:all .1s}.nav-item[data-v-9389b855]:hover{text-decoration:none}.nav-item.active[data-v-9389b855],.nav-item[data-v-9389b855]:hover{background:var(--surface-alt);color:var(--text)}.nav-item.active[data-v-9389b855]{border-left-color:var(--accent);font-weight:500}.nav-icon[data-v-9389b855]{flex-shrink:0;font-family:var(--mono);font-size:11px;font-weight:700;text-align:center;width:24px}.sidebar-footer[data-v-9389b855]{border-top:1px solid var(--border);flex-shrink:0;padding:12px 16px}.privacy-note[data-v-9389b855]{color:var(--text3);font-family:var(--mono);font-size:10px}@media(max-width:900px){.sidebar[data-v-9389b855]{box-shadow:none;transform:translate(-100%);transition:transform .2s ease}.sidebar.open[data-v-9389b855]{box-shadow:4px 0 20px #00000026;transform:translate(0)}.sidebar-close[data-v-9389b855]{display:block}}.app-layout{display:flex;min-height:100vh}.app-main{flex:1;margin-left:220px;min-width:0;transition:margin-left .2s ease}.sidebar-collapsed .app-main{margin-left:0}.sidebar-collapsed .sidebar{transform:translate(-100%)}.topbar{align-items:center;background:var(--surface);border-bottom:1px solid var(--border);display:flex;gap:10px;padding:8px 12px;position:sticky;top:0;z-index:100}.topbar-toggle{background:none;border:1px solid transparent;border-radius:6px;cursor:pointer;display:flex;flex-direction:column;gap:3px;padding:6px;transition:all .15s}.topbar-toggle:hover{background:var(--surface-alt);border-color:var(--border)}.topbar-toggle span{background:var(--text2);border-radius:1px;display:block;height:2px;width:16px}.topbar-brand{color:var(--text);font-family:var(--mono);font-size:13px;font-weight:700;text-decoration:none}.topbar-spacer{flex:1}.topbar-badge{color:var(--text3);font-family:var(--mono);font-size:10px}.sidebar-overlay{background:#0000004d;display:none;inset:0;position:fixed;z-index:150}.sidebar-overlay.visible{display:block}@media(max-width:900px){.app-main{margin-left:0!important}.sidebar-collapsed .sidebar{transform:translate(-100%)}}
