:root{--vm-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235b6b7a' stroke-width='2'%3E%3Cpath d='M5 20V10l7-7 7 7v10H5z' /%3E%3C/svg%3E");--bg:#ffffff;--bg-alt:#f6f8fa;--text:#0b1220;--muted:#5b6b7a;--primary:#094660;--primary-faded:#0946601a;--primary-contrast:#ffffff;--border:#e2e8f0;--danger:#b00020;--danger-close:#740217;--ok:#1e7e34;--shadow:0 2px 10px rgba(0,0,0,0.06);--node-key:#0b6bcb;--type-string:#0a7f5a;--type-number:#8a7561;--type-boolean:#7a2cbf;--type-null:#8f8f8f;--col-left:1fr;--col-right:1fr;--moon-bg:#4e3818;--page-color-transition:background .2s ease,color .2s ease}html[data-theme=dark]{--bg:#0f141a;--bg-alt:#121a23;--text:#e6edf3;--muted:#9fb0c0;--primary:#1d4d63;--primary-faded:#1d4d631a;--primary-contrast:#ffffff;--border:#1f2a36;--danger:#ff6666;--danger-close:#ce5454;--ok:#4dd07e;--shadow:0 2px 12px rgba(0,0,0,0.4);--node-key:#66b0ff;--type-string:#7dd3a9;--type-number:#ffad66;--type-boolean:#c69cff;--type-null:#b6c2cd;--moon-bg:#7c8494}html[data-theme=dark],html[data-theme=dark] *{scrollbar-color:#3a4756 #0f141a}html[data-theme=dark] ::-webkit-scrollbar{width:12px;height:12px}html[data-theme=dark] ::-webkit-scrollbar-track{background:#0f141a}html[data-theme=dark] ::-webkit-scrollbar-thumb{background-color:#3a4756;border-radius:8px;border:2px solid #0f141a}html[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background-color:#516378}*{box-sizing:border-box}body,html{height:100%}body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";background:var(--bg);color:var(--text);overflow:hidden}.app-header{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg);border-bottom:1px solid var(--border);backdrop-filter:blur(8px)}.brand{display:flex;align-items:center;gap:10px}.brand .logo{border-radius:6px}.logo-dark{display:none}html[data-theme=dark] .logo-light{display:none}html[data-theme=dark] .logo-dark{display:inline-block}.brand h1{font-size:18px;margin:0}.brand .tag{color:var(--muted);font-size:12px}.actions{display:flex;gap:8px;align-items:center}.install-modal{position:fixed;bottom:20px;right:20px;z-index:1000;max-width:320px;animation:slideInUp .3s ease-out}.install-modal-content{background:var(--bg);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:16px;position:relative}.spacing-dot{margin:0 8px;color:var(--border)}.bmc-btn{display:inline-block;padding:2px 6px;border-radius:6px;background:var(--primary);font-weight:400;font-size:small;text-decoration:none;color:var(--primary-contrast);opacity:.6}.bmc-btn:hover{opacity:1}.install-modal-close{position:absolute;top:8px;right:8px;background:0 0;border:none;font-size:18px;color:var(--muted);cursor:pointer;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s ease}.install-modal-close:hover{background:var(--bg-alt);color:var(--text)}.install-modal-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding-right:24px}.install-modal-icon{position:relative;width:20px;height:20px}.install-icon-light{display:inline-block}.install-icon-dark{display:none}html[data-theme=dark] .install-icon-light{display:none}html[data-theme=dark] .install-icon-dark{display:inline-block}.install-modal-title{font-size:16px;font-weight:600;color:var(--text)}.install-modal-description{font-size:14px;color:var(--muted);margin-bottom:16px;line-height:1.4}.install-modal-buttons{display:flex;gap:8px;justify-content:flex-end}.install-modal-not-now{background:0 0;color:var(--text);border-color:var(--border);font-size:14px;padding:8px 16px}.install-modal-not-now:hover{background:var(--bg-alt)}.install-modal-install{background:var(--primary);color:var(--primary-contrast);border-color:var(--primary);font-size:14px;padding:8px 16px}.install-modal-install:hover{filter:brightness(.95)}@keyframes slideInUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width:480px){.install-modal{bottom:16px;right:16px;left:16px;max-width:none}}.about-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-out}.about-modal-content{background:var(--bg);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);max-width:500px;width:90%;max-height:80vh;overflow-y:auto;position:relative;animation:slideInDown .3s ease-out}.about-modal-close{position:absolute;top:12px;right:12px;background:0 0;border:none;font-size:20px;color:var(--muted);cursor:pointer;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s ease}.about-modal-close:hover{background:var(--bg-alt);color:var(--text)}.about-modal-header{display:flex;align-items:center;gap:12px;padding:20px 20px 0 20px;margin-bottom:16px}.about-modal-icon{position:relative;width:24px;height:24px}.about-icon-light{display:inline-block}.about-icon-dark{display:none}html[data-theme=dark] .about-icon-light{display:none}html[data-theme=dark] .about-icon-dark{display:inline-block}.about-modal-title{font-size:20px;font-weight:600;color:var(--text)}.about-modal-body{padding:0 20px 20px 20px;line-height:1.6}.about-modal-body p{margin:0 0 16px 0;color:var(--text)}.about-modal-body strong{color:var(--primary)}.about-modal-body p:last-child{margin-bottom:0}.about-modal-footer{display:flex;justify-content:center;opacity:.7;border-top:1px solid var(--primary-faded)}.about-modal-close-btn{background:var(--primary);color:var(--primary-contrast);border-color:var(--primary);padding:8px 16px}.about-modal-close-btn:hover{filter:brightness(.95)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideInDown{from{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.shortcuts-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-out}.shortcuts-modal-content{background:var(--bg);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);max-width:600px;width:90%;max-height:80vh;overflow-y:auto;position:relative;animation:slideInDown .3s ease-out}.shortcuts-modal-close{position:absolute;top:12px;right:12px;background:0 0;border:none;font-size:20px;color:var(--muted);cursor:pointer;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s ease}.shortcuts-modal-close:hover{background:var(--bg-alt);color:var(--text)}.shortcuts-modal-header{display:flex;align-items:center;gap:12px;padding:20px 20px 0 20px;margin-bottom:16px}.shortcuts-modal-icon{position:relative;width:24px;height:24px}.shortcuts-icon-light{display:inline-block}.shortcuts-icon-dark{display:none}html[data-theme=dark] .shortcuts-icon-light{display:none}html[data-theme=dark] .shortcuts-icon-dark{display:inline-block}.shortcuts-modal-title{font-size:20px;font-weight:600;color:var(--text)}.shortcuts-modal-body{padding:0 20px 20px 20px}.shortcuts-section{margin-bottom:24px}.shortcuts-section:last-child{margin-bottom:0}.shortcuts-section h3{margin:0 0 12px 0;font-size:16px;font-weight:600;color:var(--primary);border-bottom:1px solid var(--border);padding-bottom:8px}.shortcut-item{display:flex;align-items:center;gap:16px;margin-bottom:8px;padding:8px 0}.shortcut-item:last-child{margin-bottom:0}.shortcut-key{background:var(--bg-alt);border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;font-weight:600;color:var(--text);min-width:80px;text-align:center;white-space:nowrap}.shortcut-description{color:var(--text);font-size:14px;flex:1}.btn{appearance:none;border:1px solid var(--primary);background:var(--primary);color:var(--primary-contrast);padding:8px 12px;border-radius:8px;cursor:pointer;font-weight:600}.btn:hover{filter:brightness(.95)}.btn:active{transform:translateY(1px)}.btn.ghost{background:0 0;color:var(--text);border-color:var(--border)}.btn.ghost:hover{background:var(--bg-alt)}.layout{display:grid;grid-template-columns:var(--col-left,1fr) 20px var(--col-right,1fr);gap:0;padding:16px;height:calc(100% - 119px);position:relative}@media (max-width:900px){.layout{grid-template-columns:1fr}.splitter{display:none}}.mobile-tabs{display:none;position:fixed;bottom:0;left:0;right:0;z-index:10;background:var(--bg);border-top:1px solid var(--border);padding:8px 16px;margin:0}.mobile-tab{display:flex;align-items:center;gap:8px;padding:12px 16px;background:0 0;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;color:var(--muted);transition:all .2s ease;flex:1;justify-content:center}.mobile-tab:hover{background:var(--bg-alt);color:var(--text)}.mobile-tab.active{background:var(--primary);color:var(--primary-contrast)}.tab-icon{font-size:16px;display:flex;align-items:center;justify-content:center}.tab-icon svg{width:16px;height:16px;color:inherit}.tab-label{font-size:14px}@media (max-width:900px){.mobile-tabs{display:flex;gap:8px}.layout{grid-template-columns:1fr;gap:0;padding:0 0 80px 0;height:calc(100% - 119px)}.splitter{display:none!important}.input-panel,.output-panel{display:none;border-radius:0;border:none;box-shadow:none;height:calc(100vh - 130px)}.layout.show-input .input-panel{display:block}.layout.show-result .output-panel{display:block}.panel-header h2{display:none}.panel-header{padding:6px 8px;border-bottom:none;min-height:40px;display:flex;align-items:center}.toolbar .btn{font-size:11px;padding:4px 6px;min-width:auto;border-radius:6px}.toolbar{gap:3px;padding:0 8px;height:32px;display:flex;align-items:center}.output-panel .toolbar .btn{font-size:10px;padding:3px 5px}.output-panel .toolbar select{font-size:10px;padding:3px 5px;padding-right:20px}.editor-wrap{height:calc(100% - 52px)!important;border-radius:0}.result-grid{height:100%;border-radius:0;display:grid;grid-template-columns:1fr}.tree{border-right:none;padding:12px;overflow:auto;height:calc(100vh - 130px)}.pretty-wrap{height:calc(100vh - 182px)!important;overflow:auto!important}.pretty{padding:12px;min-height:auto;width:calc(100% - 50px);white-space:-moz-pre-wrap;white-space:-o-pre-wrap;word-wrap:break-word;white-space:pre-wrap!important}.app-footer{display:none}.layout{height:calc(100vh - 60px);padding-bottom:80px}.tips{display:none}.line-numbers{min-width:50px!important}}.panel{background:var(--bg);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);overflow:hidden}.splitter{width:12px;cursor:col-resize;margin:0 4px;position:relative;display:flex;align-items:center;justify-content:center;background:var(--bg-alt);border-radius:4px;transition:background-color .2s ease;height:100%;min-height:400px}.splitter:hover{background:var(--border)}.splitter::before{content:'⋮⋮';display:block;color:var(--muted);font-size:12px;line-height:1;letter-spacing:-2px;transform:rotate(90deg);user-select:none;position:relative;left:1px}.splitter:hover::before{color:var(--text)}.percentage-overlay{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 16px;box-shadow:var(--shadow);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:14px;font-weight:600;color:var(--text);z-index:1000;pointer-events:none;display:none}.percentage-overlay.show{display:block}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid var(--border)}.panel-header h2{margin:0;font-size:16px}.toolbar{display:flex;gap:8px;flex-wrap:wrap}.editor-wrap{position:relative;height:calc(100% - 85px);display:flex}.line-numbers{background:var(--bg-alt);border-right:1px solid var(--border);padding:12px 8px 12px 12px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:14px;line-height:1.5;color:var(--muted);text-align:right;user-select:none;min-width:40px;white-space:pre;overflow:hidden}#jsonInput{flex:1;min-height:260px;height:100%;resize:none;padding:12px;background:var(--bg);color:var(--text);border:none;border-bottom:1px solid var(--border);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:14px;line-height:1.5;outline:0!important}.input-panel:has(#jsonInput:focus),.output-panel:has(.pretty-wrap:focus),.output-panel:has(.tree:focus){outline:2px solid var(--primary);outline-offset:0}.tips{color:var(--muted);font-size:12px;padding:8px 12px}#errorBanner{padding:10px 32px 10px 12px;color:var(--primary-contrast);background:var(--danger);position:absolute;bottom:0}#errorClose{float:right;padding:2px 8px 4px;position:absolute;right:8px;top:50%;transform:translateY(-50%);border:1px solid var(--danger-close)}.hidden{display:none}.result-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;height:calc(100% - 54px)}.result-grid.view-tree{grid-template-columns:1fr}.result-grid.view-raw{grid-template-columns:1fr}@media (max-width:1200px){.result-grid{grid-template-columns:1fr;height:auto}}.tree{padding:12px;border-right:1px solid var(--border);overflow:auto}.pretty-wrap{display:flex;height:100%;overflow:auto}.pretty{margin:0;padding:12px;min-height:200px;flex:1;white-space:pre;overflow:visible;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:14px;line-height:1.5}#prettyLineNumbers{padding:12px 8px 12px 12px;background:var(--bg-alt);border-right:1px solid var(--border);height:fit-content!important}.view-raw #jsonTree{display:none}.view-raw .pretty-wrap{display:flex}.view-tree #jsonTree{display:block}.view-tree .pretty-wrap{display:none}.node{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;line-height:1.6}.node .line{display:flex;align-items:center;gap:6px}.toggle{width:18px;height:18px;border-radius:4px;border:1px solid var(--border);background:var(--bg-alt);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;user-select:none}.toggle:hover{background:var(--bg)}.toggle::after{content:'▸';font-size:12px;color:var(--muted)}.node.expanded>.line>.toggle::after{content:'▾'}.key{color:var(--node-key);font-weight:600}.type-badge{font-size:11px;padding:1px 6px;border-radius:10px;border:1px solid var(--border);color:var(--muted)}.value.string{color:var(--type-string)}.value.number{color:var(--type-number)}.value.boolean{color:var(--type-boolean)}.value.null{color:var(--type-null)}.children{margin-left:8px;border-left:1px dashed var(--border);padding-left:8px}.node:not(.expanded)>.children{display:none}.app-footer{padding:16px;color:var(--muted);display:flex;gap:10px;justify-content:space-between;border-top:1px solid var(--border);position:relative}.app-footer .middle{position:absolute;left:50%;transform:translateX(-50%)}#viewMode{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding:8px 40px 8px 34px;position:relative;background-image:var(--vm-icon),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235b6b7a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat,no-repeat;background-position:10px center,right 10px center;background-size:16px,14px}html[data-theme=dark] #viewMode{background-image:var(--vm-icon),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239fb0c0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E")}#viewMode:focus{outline:2px solid var(--primary)}#viewMode[data-mode=tree]{--vm-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235b6b7a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 10h5V5'/%3E%3Cpath d='M12 10v9'/%3E%3Cpath d='M5 19h14'/%3E%3Cpath d='M17 10h-5'/%3E%3Ccircle cx='7' cy='10' r='2'/%3E%3Ccircle cx='17' cy='10' r='2'/%3E%3C/svg%3E")}#viewMode[data-mode=raw]{--vm-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235b6b7a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 4h9l3 3v13H6z'/%3E%3Cpath d='M6 9h12'/%3E%3Cpath d='M8 13h8'/%3E%3Cpath d='M8 17h8'/%3E%3C/svg%3E")}html[data-theme=dark] #viewMode[data-mode=tree]{--vm-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239fb0c0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 10h5V5'/%3E%3Cpath d='M12 10v9'/%3E%3Cpath d='M5 19h14'/%3E%3Cpath d='M17 10h-5'/%3E%3Ccircle cx='7' cy='10' r='2'/%3E%3Ccircle cx='17' cy='10' r='2'/%3E%3C/svg%3E")}html[data-theme=dark] #viewMode[data-mode=raw]{--vm-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239fb0c0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 4h9l3 3v13H6z'/%3E%3Cpath d='M6 9h12'/%3E%3Cpath d='M8 13h8'/%3E%3Cpath d='M8 17h8'/%3E%3C/svg%3E")}.theme-toggle{background:0 0;border:none;cursor:pointer;padding:8px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background-color .2s ease}.theme-toggle:hover{background:var(--bg-alt)}.theme-icon{width:20px;height:20px;transition:transform .3s ease;color:var(--text)}.theme-icon.sun{transform:rotate(0)}.theme-icon.moon{transform:rotate(180deg)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,1px,1px);white-space:nowrap;border:0}#darkmode{padding:.3em .5em;cursor:pointer;width:40px;height:40px;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.darkmode_icon{position:absolute;width:20px;height:20px;border-radius:10px;background:var(--moon-bg);transform-origin:center center;transition:transform .75s ease-in-out,var(--page-color-transition)}.darkmode_icon::after{position:absolute;content:'';width:16px;height:16px;left:8px;bottom:4px;border-radius:10px;background:var(--bg);transform-origin:center center;transition:transform .5s ease,left .25s ease,bottom .25s ease,var(--page-color-transition)}.darkmode_icon .ray{position:absolute;left:7px;top:7px;width:6px;height:6px;border-radius:6px;background:var(--moon-bg);transform-origin:center;transition:transform .5s ease-in-out,var(--page-color-transition)}.ray:nth-child(1){transform:rotate(45deg) translateX(0)}.ray:nth-child(2){transform:rotate(90deg) translateX(0)}.ray:nth-child(3){transform:rotate(135deg) translateX(0)}.ray:nth-child(4){transform:rotate(180deg) translateX(0)}.ray:nth-child(5){transform:rotate(225deg) translateX(0)}.ray:nth-child(6){transform:rotate(270deg) translateX(0)}.ray:nth-child(7){transform:rotate(315deg) translateX(0)}.ray:nth-child(8){transform:rotate(360deg) translateX(0)}.darkmode_icon:hover{opacity:.6}[data-theme=dark] .darkmode_icon{transform:scale(1)}[data-theme=dark] .darkmode_icon::after{left:8px;bottom:4px;transform:scale(1)}[data-theme=dark] .ray:nth-child(1){transform:rotate(45deg) translateX(0)}[data-theme=dark] .ray:nth-child(2){transform:rotate(90deg) translateX(0)}[data-theme=dark] .ray:nth-child(3){transform:rotate(135deg) translateX(0)}[data-theme=dark] .ray:nth-child(4){transform:rotate(180deg) translateX(0)}[data-theme=dark] .ray:nth-child(5){transform:rotate(225deg) translateX(0)}[data-theme=dark] .ray:nth-child(6){transform:rotate(270deg) translateX(0)}[data-theme=dark] .ray:nth-child(7){transform:rotate(315deg) translateX(0)}[data-theme=dark] .ray:nth-child(8){transform:rotate(360deg) translateX(0)}[data-theme=light] .darkmode_icon{transform:scale(.6)}[data-theme=light] .darkmode_icon::after{left:15px;bottom:8px;transform:scale(0)}[data-theme=light] .ray:nth-child(1){transform:rotate(45deg) translateX(-16px)}[data-theme=light] .ray:nth-child(2){transform:rotate(90deg) translateX(-16px)}[data-theme=light] .ray:nth-child(3){transform:rotate(135deg) translateX(-16px)}[data-theme=light] .ray:nth-child(4){transform:rotate(180deg) translateX(-16px)}[data-theme=light] .ray:nth-child(5){transform:rotate(225deg) translateX(-16px)}[data-theme=light] .ray:nth-child(6){transform:rotate(270deg) translateX(-16px)}[data-theme=light] .ray:nth-child(7){transform:rotate(315deg) translateX(-16px)}[data-theme=light] .ray:nth-child(8){transform:rotate(360deg) translateX(-16px)}