*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-body: #0f172a;--bg-card: #1e293b;--bg-input: #0f172a;--bg-hover: #334155;--border: #334155;--border-focus: #3b82f6;--text: #f8fafc;--text-2: #cbd5e1;--text-3: #94a3b8;--text-muted: #64748b;--blue: #3b82f6;--blue-hover: #2563eb;--blue-bg: rgba(59,130,246,.15);--green: #22c55e;--green-bg: rgba(34,197,94,.15);--orange: #f59e0b;--orange-bg: rgba(245,158,11,.15);--red: #ef4444;--red-bg: rgba(239,68,68,.15);--purple: #a78bfa;--purple-bg: rgba(167,139,250,.15);--cyan: #22d3ee;--str0: #ef4444;--str1: #f97316;--str2: #eab308;--str3: #84cc16;--str4: #22c55e;--font: "Inter", -apple-system, system-ui, sans-serif;--mono: "JetBrains Mono", monospace;--radius: 12px;--radius-sm: 8px}[data-theme=light]{--bg-body: #f0f2f5;--bg-card: #ffffff;--bg-input: #e8ebf0;--bg-hover: #dde1e8;--border: #cdd3dc;--border-focus: #2563eb;--text: #111827;--text-2: #374151;--text-3: #6b7280;--text-muted: #9ca3af;--blue: #2563eb;--blue-hover: #1d4ed8;--blue-bg: rgba(37,99,235,.12);--green: #16a34a;--green-bg: rgba(22,163,74,.12);--orange: #d97706;--orange-bg: rgba(217,119,6,.12);--red: #dc2626;--red-bg: rgba(220,38,38,.12);--purple: #7c3aed;--purple-bg: rgba(124,58,237,.12);--str0: #dc2626;--str1: #ea580c;--str2: #ca8a04;--str3: #65a30d;--str4: #16a34a}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:var(--font);background:var(--bg-body);color:var(--text);line-height:1.6;min-height:100vh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::selection{background:#3b82f64d}button{font-family:inherit;cursor:pointer;border:none;outline:none;background:none;color:inherit}input,textarea,select{font-family:inherit;outline:none;border:none;color:inherit}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.mono{font-family:var(--mono)!important}.hdr{position:sticky;top:0;z-index:100;background:var(--bg-card);border-bottom:1px solid var(--border)}.hdr-in{max-width:900px;margin:0 auto;padding:0 20px;height:54px;display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:2px;text-decoration:none;color:inherit;font-size:.88rem}.logo-img{width:95px;height:95px;object-fit:contain}.logo-t{font-weight:800;color:var(--text)}.logo-sep{color:var(--text-muted);margin:0 2px}.logo-sub{color:var(--text-3);font-weight:500}.hdr-r{display:flex;align-items:center;gap:6px}.lang-sel{appearance:none;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;padding:5px 10px;font-size:.72rem;font-weight:700;font-family:var(--mono);color:var(--text-3);cursor:pointer}.lang-sel:hover{border-color:var(--blue);color:var(--text)}.th-btn{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-3);transition:all .15s}.th-btn:hover{color:var(--text);background:var(--bg-hover)}[data-theme=dark] .ic-moon,[data-theme=light] .ic-sun{display:none}.tabs{position:sticky;top:54px;z-index:90;background:var(--bg-card);border-bottom:1px solid var(--border)}.tabs-in{max-width:900px;margin:0 auto;padding:0 16px;display:flex;gap:0;overflow-x:auto;scrollbar-width:none}.tabs-in::-webkit-scrollbar{display:none}.tab{display:flex;align-items:center;gap:7px;padding:11px 16px;font-size:.82rem;font-weight:600;color:var(--text-muted);white-space:nowrap;border-bottom:2px solid transparent;transition:all .15s}.tab:hover{color:var(--text-3)}.tab.on{color:var(--blue);border-bottom-color:var(--blue)}.tab svg{flex-shrink:0}.tab.on svg{stroke:var(--blue)}.wrap{max-width:900px;margin:0 auto;padding:32px 20px 80px}.pnl{display:none;animation:fadeUp .3s ease}.pnl.on{display:block}.sec-title{font-size:1.4rem;font-weight:800;margin-bottom:20px;letter-spacing:-.02em}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.card.vstack{display:flex;flex-direction:column;gap:16px}.pw-box{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius);padding:20px 20px 20px 24px;display:flex;align-items:flex-start;gap:12px;margin-bottom:8px;min-height:80px;position:relative;overflow:hidden}.pw-box:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--blue)}.pw-out{flex:1;font-family:var(--mono);font-size:1.05rem;line-height:1.8;word-break:break-all;letter-spacing:.05em;font-weight:500}.pw-ph{color:var(--text-muted);font-family:var(--font);font-style:italic;font-size:.9rem;font-weight:400}.pw-side{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-top:2px}.pw-len{font-family:var(--mono);font-size:.7rem;font-weight:700;color:var(--blue);background:var(--blue-bg);padding:3px 10px;border-radius:20px}.pw-len:empty{display:none}.cu{color:var(--blue)}.cl{color:var(--text-2)}.cn{color:var(--orange)}.cs{color:var(--green);font-weight:700}.pw-str{display:none;align-items:center;gap:12px;padding:0 4px;margin-bottom:20px}.pw-str-track{flex:1;height:4px;background:var(--bg-hover);border-radius:2px;overflow:hidden}.pw-str-fill{height:100%;border-radius:2px;transition:width .3s,background .3s}.pw-str-lbl{font-size:.75rem;font-weight:700;white-space:nowrap}.rng-group{margin-bottom:22px}.rng-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.rng-top label{font-size:.85rem;font-weight:600;color:var(--text-2)}.rng-num{width:58px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;padding:5px;font-family:var(--mono);font-size:.85rem;font-weight:700;text-align:center;color:var(--blue)}.rng-num:focus{border-color:var(--blue)}.rng{width:100%;height:6px;-webkit-appearance:none;appearance:none;background:linear-gradient(to right,var(--blue) var(--p, 50%),var(--bg-hover) var(--p, 50%));border-radius:3px;cursor:pointer}.rng::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--blue);border:3px solid var(--bg-card);box-shadow:0 0 0 2px var(--blue);cursor:grab;transition:transform .15s}.rng::-webkit-slider-thumb:hover{transform:scale(1.15)}.rng::-webkit-slider-thumb:active{cursor:grabbing}.rng::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--blue);border:3px solid var(--bg-card);box-shadow:0 0 0 2px var(--blue);cursor:grab}.rng-marks{display:flex;justify-content:space-between;margin-top:6px;font-size:.62rem;color:var(--text-muted);font-family:var(--mono)}.chk-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-bottom:22px}.chk{display:flex;align-items:center;gap:10px;font-size:.84rem;color:var(--text-2);cursor:pointer;padding:9px 10px;border-radius:8px;transition:all .15s;user-select:none}.chk:hover{background:var(--bg-hover);color:var(--text)}.chk input{display:none}.chk-box{width:18px;height:18px;border-radius:5px;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;position:relative}.chk-box:after{content:"";width:10px;height:10px;border-radius:2px;background:var(--blue);transform:scale(0);transition:transform .15s cubic-bezier(.34,1.56,.64,1)}.chk input:checked~.chk-box{border-color:var(--blue);background:var(--blue-bg)}.chk input:checked~.chk-box:after{transform:scale(1)}.sym-toggle{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;margin-bottom:8px;background:var(--bg-body);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.78rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;cursor:pointer;transition:all .15s}.sym-toggle:hover{border-color:var(--blue);color:var(--text-2)}.sym-toggle.open{border-color:var(--blue);color:var(--blue);border-bottom-left-radius:0;border-bottom-right-radius:0;margin-bottom:0}.sym-toggle-ico{flex-shrink:0}.sym-toggle.open .sym-toggle-ico{display:none}.sym-chevron{margin-left:auto;transition:transform .2s;flex-shrink:0}.sym-toggle.open .sym-chevron{transform:rotate(180deg)}.sym-custom{margin-bottom:8px;padding:14px 16px;background:var(--bg-body);border:1px solid var(--blue);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm)}.sym-row{display:flex;gap:8px;margin-bottom:10px}.sym-inp{flex:1;padding:8px 12px!important;font-size:.9rem!important;letter-spacing:.1em}.sym-reset{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);flex-shrink:0;transition:all .15s}.sym-reset:hover{color:var(--blue);border-color:var(--blue)}.sym-presets{display:flex;flex-wrap:wrap;gap:6px}.sym-pre{padding:4px 10px;border-radius:6px;font-family:var(--mono);font-size:.72rem;font-weight:600;color:var(--text-3);background:var(--bg-card);border:1px solid var(--border);transition:all .15s;letter-spacing:.04em}.sym-pre:hover{color:var(--green);border-color:var(--green);background:var(--green-bg)}.btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 16px;background:var(--blue);color:#fff;font-weight:700;font-size:.88rem;border-radius:var(--radius);transition:all .15s;box-shadow:0 2px 8px #3b82f64d}.btn:hover{background:var(--blue-hover);transform:translateY(-1px);box-shadow:0 4px 16px #3b82f666}.btn:active{transform:translateY(0)}.btn-row{display:flex;gap:10px}.btn-row .btn{flex:1}.btn-secondary{background:var(--bg-input);color:var(--text-2);border:1px solid var(--border);box-shadow:none}.btn-secondary:hover{background:var(--bg-hover);color:var(--text);border-color:var(--blue);box-shadow:none;transform:translateY(-1px)}.cpbtn{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all .15s;flex-shrink:0}.cpbtn:hover{background:var(--blue-bg);color:var(--blue)}.cpbtn.ok{color:var(--green);background:var(--green-bg)}.toast{position:fixed;top:20px;right:20px;transform:translateY(-16px);display:flex;align-items:center;gap:8px;padding:12px 20px;background:var(--bg-card);border:1px solid var(--green);border-radius:var(--radius);font-size:.84rem;font-weight:700;color:var(--green);opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.16,1,.3,1);z-index:200;box-shadow:0 8px 32px #0000004d}.toast.show{opacity:1;transform:translateY(0)}.inp{width:100%;padding:12px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.88rem;line-height:1.6;resize:vertical;transition:all .15s;color:var(--text)}.inp:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-bg)}.inp::placeholder{color:var(--text-muted)}.inp-wrap{position:relative}.inp-clr{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.inp-clr:hover{color:var(--text);background:var(--bg-hover)}.fld label{display:block;font-size:.75rem;font-weight:700;color:var(--text-3);margin-bottom:6px;text-transform:uppercase;letter-spacing:.08em}.s-res{animation:fadeUp .3s ease;margin-top:16px}.s-meter{margin-bottom:16px}.s-meter-track{height:6px;background:var(--bg-hover);border-radius:3px;overflow:hidden;margin-bottom:8px}.s-meter-fill{height:100%;border-radius:3px;transition:width .3s,background .3s;width:0%}.s-meter-lbl{font-size:1rem;font-weight:800}.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}.stat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.stat-k{font-size:.68rem;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em}.stat-v{font-size:1.2rem;font-weight:700;color:var(--text);margin-top:4px}.stat-v.small{font-size:.85rem}.stat-u{font-size:.65rem;color:var(--text-muted)}.tips{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px}.tips h4{font-size:.72rem;font-weight:700;color:var(--text-3);margin-bottom:10px;text-transform:uppercase;letter-spacing:.06em}.tips ul{list-style:none;display:flex;flex-direction:column;gap:6px}.tips li{font-size:.84rem;color:var(--text-2);padding-left:18px;position:relative}.tips li:before{content:"";position:absolute;left:2px;top:9px;width:6px;height:6px;border-radius:50%;background:var(--blue)}.btn-quick{background:var(--green);margin-bottom:12px;box-shadow:0 2px 8px #22c55e40;position:relative}.btn-quick:hover{background:#16a34a;box-shadow:0 4px 16px #22c55e59}.btn-hint{font-weight:400;font-size:.72rem;opacity:.7;margin-left:4px}.jwt-divider{display:flex;align-items:center;gap:12px;margin:8px 0 16px;font-size:.72rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.08em}.jwt-divider:before,.jwt-divider:after{content:"";flex:1;height:1px;background:var(--border)}.jwt-header-row{display:flex;gap:12px}.flex1{flex:1}.sel{width:100%;appearance:none;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-size:.88rem;font-weight:600;font-family:var(--mono);cursor:pointer;transition:all .15s;color:var(--text)}.sel:hover{border-color:var(--blue)}.sel:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-bg)}.sel-sm{padding:6px 10px;font-size:.82rem}.jwt-claims{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.jwt-claim-row{display:flex;align-items:center;border-bottom:1px solid var(--border);min-height:42px}.jwt-claim-row:last-child{border-bottom:none}.jwt-claim-key{width:60px;padding:0 12px;font-family:var(--mono);font-size:.76rem;font-weight:700;color:var(--blue);flex-shrink:0}.jwt-claim-inp{border:none!important;border-radius:0!important;background:var(--bg-input)!important;padding:10px 12px!important;font-size:.84rem!important;box-shadow:none!important}.jwt-claim-inp:focus{background:var(--blue-bg)!important}.jwt-claim-auto{font-size:.78rem;color:var(--text-muted);font-style:italic;padding:0 12px}.jwt-exp-wrap{flex:1;padding:4px 4px 4px 0}.jwt-exp-wrap .sel{border:1px solid var(--border);background:var(--bg-input);padding:6px 10px;font-size:.82rem;border-radius:6px}.jwt-secret-row{display:flex;gap:8px}.btn-sm{display:flex;align-items:center;gap:5px;padding:8px 14px;border-radius:var(--radius-sm);background:var(--bg-input);border:1px solid var(--border);font-size:.76rem;font-weight:600;color:var(--text-3);white-space:nowrap;transition:all .15s}.btn-sm:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-bg)}.jwt-out{margin-top:16px;background:var(--bg-body);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;animation:fadeUp .3s ease}.jwt-hd{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:var(--bg-card);border-bottom:1px solid var(--border);font-size:.7rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em}.jwt-tok{padding:14px 16px;font-size:.76rem;word-break:break-all;line-height:1.7;color:var(--text-2);background:var(--bg-body);border-bottom:1px solid var(--border)}.jwt-err{color:var(--red)!important}.jh{color:var(--red)}.jp{color:var(--blue)}.js{color:var(--green)}.jwt-decoded{display:grid;grid-template-columns:1fr 1fr;gap:0}.jwt-dec-section{padding:14px 16px}.jwt-dec-section:first-child{border-right:1px solid var(--border)}.jwt-dec-label{display:inline-block;font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;padding:2px 8px;border-radius:4px}.jwt-dec-section:first-child .jwt-dec-label{color:var(--red);background:var(--red-bg)}.jwt-dec-section:last-child .jwt-dec-label{color:var(--blue);background:var(--blue-bg)}.jwt-dec-json{font-family:var(--mono);font-size:.72rem;line-height:1.7;color:var(--text-2);background:var(--bg-card);border-radius:var(--radius-sm);padding:12px 14px;margin:0;white-space:pre-wrap;word-break:break-all;border:1px solid var(--border)}.jh-bg{border-left:3px solid var(--red)}.jp-bg{border-left:3px solid var(--blue)}@media(max-width:600px){.jwt-decoded{grid-template-columns:1fr}.jwt-dec-section:first-child{border-right:none;border-bottom:1px solid var(--border)}}.hash-list{display:grid;gap:8px;margin-top:16px;animation:fadeUp .3s ease}.hrow{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.hrow:hover{border-color:var(--blue)}.hrow-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.hbadge{font-family:var(--mono);font-size:.68rem;font-weight:700;color:var(--orange);background:var(--orange-bg);padding:2px 8px;border-radius:4px}.hbadge.b{color:var(--purple);background:var(--purple-bg)}.hbadge.g{color:var(--green);background:var(--green-bg)}.hbadge.p{color:var(--blue);background:var(--blue-bg)}.hval{font-size:.78rem;color:var(--text-2);word-break:break-all;line-height:1.6;display:block}.tok-list{display:grid;gap:8px;margin-top:16px}.trow{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.trow:hover{border-color:var(--blue)}.trow-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.tbadge{font-size:.7rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em}.tval{font-size:.78rem;color:var(--text-2);word-break:break-all;line-height:1.6;display:block}.trow-top .cpbtn,.hrow-top .cpbtn{width:28px;height:28px}.ft{text-align:center;padding:24px 20px;font-size:.72rem;color:var(--text-muted);border-top:1px solid var(--border)}.ft a{color:var(--text-3);text-decoration:none;font-weight:700}.ft a:hover{color:var(--blue)}@media(max-width:640px){.hdr-in{padding:0 14px}.logo-sub,.logo-sep{display:none}.wrap{padding:20px 14px 60px}.pw-out{font-size:.9rem}.chk-grid,.stat-row{grid-template-columns:1fr}.card{padding:18px}.sec-title{font-size:1.2rem}.tab{padding:10px}.tab span{display:none}.tab svg{width:20px;height:20px}}:global([data-theme=light]) .sel option,:global([data-theme=light]) .lang-sel option{background:var(--bg-card);color:var(--text)}:global([data-theme=light]) .card{box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f}:global([data-theme=light]) .inp,:global([data-theme=light]) .rng-num{border-color:var(--border)}:global([data-theme=light]) .th-btn{background:var(--bg-input);border:1px solid var(--border)}
