*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#f0f2f5;color:#1a1a2e;display:flex;flex-direction:column}#root{display:flex;flex-direction:column}.topbar{background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;padding:0 1.5rem;height:48px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;box-shadow:0 1px 3px #0003}.topbar-left{display:flex;align-items:center;gap:.6rem}.topbar-logo{width:28px;height:28px;border-radius:6px;background:linear-gradient(135deg,#4a90d9,#6c5ce7);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;color:#fff}.topbar h1{font-size:.95rem;font-weight:600;letter-spacing:.01em}.topbar h1 span{font-weight:400;opacity:.6}.env-badge{font-size:.6rem;background:#4a90d94d;padding:.15rem .55rem;border-radius:10px;font-weight:600;letter-spacing:.04em;border:1px solid rgba(74,144,217,.4)}.main{flex:1;display:flex;overflow:hidden}.left-panel{width:320px;min-width:320px;background:#fff;border-right:1px solid #e4e7ec;display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0}.panel-section{padding:1rem 1.1rem;border-bottom:1px solid #f0f1f3}.panel-section:last-child{border-bottom:none}.section-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#8892a4;margin-bottom:.55rem}.form-group{margin-bottom:.7rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:.25rem;font-weight:600;font-size:.75rem;color:#4a5568}.form-group select,.form-input{width:100%;padding:.45rem .6rem;border:1px solid #d0d5dd;border-radius:6px;font-size:.8rem;background:#fff;color:#333;transition:border-color .15s;font-family:inherit}.form-group select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center}.form-group select:focus,.form-input:focus{outline:none;border-color:#4a90d9;box-shadow:0 0 0 3px #4a90d91f}.form-input::placeholder{color:#a0a8b4}.mode-toggle{display:flex;gap:0;margin-bottom:.7rem;border:1px solid #d0d5dd;border-radius:6px;overflow:hidden}.mode-btn{flex:1;padding:.4rem 0;font-size:.75rem;font-weight:600;border:none;background:#f8f9fa;color:#6c757d;cursor:pointer;transition:all .15s;font-family:inherit}.mode-btn:first-child{border-right:1px solid #d0d5dd}.mode-btn:hover{background:#e9ecef}.mode-btn.active{background:#4a90d9;color:#fff}.drop-zone{border:2px dashed #d0d5dd;border-radius:8px;padding:1.5rem 1rem;text-align:center;cursor:pointer;transition:all .2s;color:#8892a4;font-size:.78rem}.drop-zone:hover{border-color:#4a90d9;background:#4a90d90a}.drop-zone.dragover{border-color:#4a90d9;background:#4a90d914;box-shadow:0 0 0 3px #4a90d91f}.drop-zone.has-file{border-style:solid;border-color:#4a90d9;background:#4a90d90a}.drop-icon{width:36px;height:36px;margin-bottom:.4rem;opacity:.5}.file-name{font-weight:600;color:#2d3748;font-size:.82rem}.file-meta{font-size:.7rem;color:#a0a8b4;margin-top:.2rem}.file-input{display:none}.center-panel{flex:1;display:flex;flex-direction:column;border-right:1px solid #e4e7ec;min-width:0}.preview-area{flex:1;overflow:auto;background:#f5f6f8}.preview-area img{max-width:100%;height:auto}.btn-parse{width:100%;padding:.6rem;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;background:linear-gradient(135deg,#4a90d9,#357abd);color:#fff;transition:all .2s;box-shadow:0 1px 3px #4a90d94d}.btn-parse:hover:not(:disabled){background:linear-gradient(135deg,#357abd,#2b68a8);box-shadow:0 2px 6px #4a90d966;transform:translateY(-1px)}.btn-parse:active:not(:disabled){transform:translateY(0)}.btn-parse:disabled{background:#d0d5dd;color:#9aa5b4;cursor:not-allowed;box-shadow:none}.btn-get-token{width:100%;padding:.5rem;border:1px solid #4a90d9;border-radius:6px;font-size:.82rem;font-weight:600;cursor:pointer;background:transparent;color:#4a90d9;transition:all .2s}.btn-get-token:hover:not(:disabled){background:#4a90d9;color:#fff}.btn-get-token:disabled{opacity:.5;cursor:not-allowed}.token-status{font-size:.78rem;margin:6px 0 0;padding:0}.token-status.ok{color:#3ecf8e}.token-status.error{color:#e05c5c}.right-panel{flex:1;display:flex;flex-direction:column;min-width:0}.panel-toolbar{display:flex;align-items:center;justify-content:space-between;padding:0 .9rem;height:38px;background:#fff;border-bottom:1px solid #e4e7ec;flex-shrink:0}.panel-toolbar h3{font-size:.75rem;color:#4a5568;font-weight:600;letter-spacing:.01em}.tg{display:flex;align-items:center;gap:.3rem}.tb{padding:.2rem .5rem;font-size:.7rem;background:#f0f2f5;border:1px solid #d0d5dd;border-radius:4px;cursor:pointer;font-weight:500;transition:all .15s;color:#4a5568}.tb:hover{background:#e4e7ec;border-color:#c0c5cc}.tb.active{background:#4a90d9;color:#fff;border-color:#357abd;box-shadow:0 1px 2px #4a90d933}.tb:disabled{opacity:.35;cursor:not-allowed}.tb-sep{width:1px;height:16px;background:#e4e7ec;flex-shrink:0}.pipe-badge{font-size:.6rem;font-weight:700;padding:.1rem .4rem;border-radius:10px;letter-spacing:.02em}.pipe-ok{background:#d4edda;color:#155724}.pipe-err{background:#f8d7da;color:#721c24}.pipe-warn{background:#fff3cd;color:#856404}.results-area{flex:1;overflow:auto;background:#fff}.placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#9aa5b4;font-size:.82rem;text-align:center;padding:2rem;gap:.6rem}.placeholder svg{opacity:.3}.rv{padding:.7rem .9rem}.rv-section{margin-bottom:1px}.rv-top{border-bottom:1px solid #f5f6f8;padding-bottom:.35rem;margin-bottom:.35rem}.rv-header{display:flex;align-items:center;gap:.4rem;cursor:pointer;padding:.28rem .45rem;border-radius:5px;font-size:.78rem;transition:background .1s}.rv-header:hover{background:#f0f4f8}.rv-arrow{font-size:.55rem;width:12px;text-align:center;transition:transform .15s;display:inline-block;color:#a0aec0}.rv-section.collapsed .rv-arrow{transform:rotate(-90deg)}.rv-skey{font-weight:600;color:#2d3748}.rv-empty-tag{font-size:.6rem;background:#edf2f7;color:#a0aec0;padding:.05rem .35rem;border-radius:8px}.rv-count{font-size:.65rem;color:#a0aec0}.rv-body{padding-left:1rem}.rv-row{display:flex;padding:.25rem .45rem;border-radius:4px;font-size:.78rem;gap:.8rem}.rv-row:hover{background:#f7fafc}.rv-key{min-width:140px;max-width:180px;color:#718096;font-weight:500;flex-shrink:0;word-break:break-word}.rv-val{flex:1;word-break:break-word}.rv-null{color:#cbd5e0;font-style:italic}.rv-str{color:#2d3748}.rv-num{color:#3182ce;font-weight:500}.rv-bool{color:#38a169;font-weight:600}.json-view{color:#cdd6f4;padding:1rem;margin:0;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.75rem;line-height:1.6;white-space:pre-wrap;word-break:break-word;background:#1e1e2e;min-height:100%}.status-bar{flex-shrink:0;padding:0 1.2rem;height:32px;font-size:.75rem;border-top:1px solid #e4e7ec;background:#fff;display:flex;align-items:center;justify-content:space-between}.status-msg{display:flex;align-items:center;gap:.4rem;color:#8892a4}.status-msg.loading{color:#4a90d9}.status-msg.error{color:#e53e3e}.status-msg.success{color:#38a169}.status-msg.warning{color:#d69e2e}.spinner{display:inline-block;width:12px;height:12px;border:2px solid #4a90d9;border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.status-time{color:#a0a8b4;font-size:.72rem;font-variant-numeric:tabular-nums}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#c0c5cc;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#a0a8b4}
