:root{--bg:#f5f6fb;--surface:#fff;--surface-2:#fbfcfe;--ink:#0f1222;--muted:#5a6178;--faint:#8a90a6;--line:#e8eaf3;--line-2:#d6daea;--brand:#5b5bf5;--brand-ink:#3f3fcb;--brand-2:#8b5cf6;--grad:linear-gradient(135deg,#6366f1,#8b5cf6);--grad-text:linear-gradient(120deg,#4f46e5,#9333ea 60%,#06b6d4);--accent:#06b6d4;--good:#16a34a;--warn:#c2410c;--danger:#dc2626;--tintbg:#eef0ff;--tintline:#d9dcff;--sh-1:0 1px 2px rgba(16,18,34,.06),0 1px 3px rgba(16,18,34,.05);--sh-2:0 10px 30px -12px rgba(40,40,120,.28);--sh-3:0 18px 50px -20px rgba(40,40,120,.4);--mono:"JetBrains Mono",ui-monospace,monospace;--disp:"Space Grotesk",system-ui,sans-serif;--body:"Inter",system-ui,sans-serif}*{box-sizing:border-box}body,html{margin:0;padding:0}body{background:var(--bg);color:var(--ink);font-family:var(--body);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;min-height:100vh;background-image:radial-gradient(1100px 460px at 80% -8%,rgba(139,92,246,.12),transparent 60%),radial-gradient(900px 420px at 0 0,rgba(99,102,241,.1),transparent 55%);background-attachment:fixed}a{color:var(--brand);text-decoration:none}.wrap{max-width:1140px;margin:0 auto;padding:0 22px}header.bar{position:-webkit-sticky;position:sticky;top:0;z-index:30;background:rgba(245,246,251,.82);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}.bar .wrap{justify-content:space-between;gap:14px;height:64px}.bar .wrap,.brand{display:flex;align-items:center}.brand{gap:11px;font-family:var(--disp);font-weight:700;font-size:19px;letter-spacing:-.02em;color:var(--ink)}.glyph{width:30px;height:30px;border-radius:9px;background:var(--grad);position:relative;box-shadow:var(--sh-2)}.glyph:after{content:"";position:absolute;inset:8px 7px auto 7px;height:2.4px;border-radius:2px;background:#fff;box-shadow:0 5px 0 hsla(0,0%,100%,.85),0 10px 0 hsla(0,0%,100%,.7)}.bar-right{display:flex;align-items:center;gap:12px}.ondevice{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:12px;color:var(--brand-ink);background:var(--tintbg);border:1px solid var(--tintline);padding:6px 11px;border-radius:999px}.dot{width:7px;height:7px;border-radius:50%;background:var(--good);box-shadow:0 0 0 3px rgba(22,163,74,.18);animation:pulse 2.4s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.langsel{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--line-2);border-radius:10px;padding:5px 8px;color:var(--muted);box-shadow:var(--sh-1);transition:border-color .15s}.langsel:focus-within{border-color:var(--brand)}.langsel select{border:0;background:none;font-family:var(--body);font-size:13.5px;color:var(--ink);cursor:pointer;outline:none}.hero{padding:72px 0 26px;position:relative}.hero h1{font-family:var(--disp);font-weight:700;letter-spacing:-.03em;line-height:1.02;margin:0;font-size:clamp(36px,6.2vw,62px)}.hero h1 .grad{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}.hero p{max-width:580px;color:var(--muted);font-size:17px;margin:20px 0 0}.stats{display:flex;gap:34px;margin-top:32px;flex-wrap:wrap}.stat .n{font-family:var(--mono);font-size:27px;font-weight:500;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}.stat .l{font-size:12.5px;color:var(--faint);text-transform:uppercase;letter-spacing:.09em}.vals{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:16px;gap:16px;margin:18px 0 4px}.val{border:1px solid var(--line);border-radius:14px;background:var(--surface);padding:18px 20px;box-shadow:var(--sh-1);transition:transform .18s,box-shadow .18s}.val:hover{transform:translateY(-3px);box-shadow:var(--sh-2)}.val h3{font-family:var(--disp);font-size:15.5px;margin:0 0 5px;letter-spacing:-.01em}.val p{margin:0;color:var(--muted);font-size:13.5px}.ticon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:11px;color:var(--c,#6366f1);background:color-mix(in srgb,var(--c,#6366f1) 14%,#fff);border:1px solid color-mix(in srgb,var(--c,#6366f1) 22%,#fff);flex:none}.ticon.sm{width:30px;height:30px;border-radius:9px}.tgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));grid-gap:16px;gap:16px;padding:10px 0 12px}.grouphead{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin:28px 0 4px}.card{display:flex;gap:14px;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:var(--sh-1);transition:transform .18s,box-shadow .18s,border-color .18s;color:var(--ink)}.card:hover{transform:translateY(-4px);box-shadow:var(--sh-3);border-color:var(--tintline)}.card .cbody{min-width:0}.card h3{font-family:var(--disp);font-weight:700;font-size:17px;margin:2px 0 6px;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}.card p{margin:0;color:var(--muted);font-size:13.5px}.card.soon{opacity:.65}.tag{font-family:var(--mono);font-size:10px;border-radius:6px;padding:2px 6px;font-weight:500;letter-spacing:.04em}.tag.server{background:#fff4e6;border:1px solid #ffd9a8;color:#b45309}.tag.soon{background:#f1f2f7;border:1px solid var(--line-2);color:var(--faint)}.app{display:grid;grid-template-columns:262px 1fr;grid-gap:26px;gap:26px;padding:22px 0 70px;align-items:start}nav.tools{position:-webkit-sticky;position:sticky;top:84px;background:var(--surface);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--sh-1)}.grp{padding:15px 16px 5px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}.titem{display:flex;align-items:center;gap:10px;width:100%;text-align:left;border-top:1px solid var(--line);padding:10px 15px;font-family:var(--body);font-size:14.5px;color:var(--ink);transition:background .14s}.titem:hover{background:var(--surface-2)}.titem.active{background:var(--tintbg);color:var(--brand-ink);font-weight:600;box-shadow:inset 3px 0 0 var(--brand)}.titem .nm{flex:1 1;min-width:0}.titem.soon{color:var(--faint)}.work{background:var(--surface);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--sh-1)}.whead{padding:24px 26px 18px;border-bottom:1px solid var(--line);display:flex;gap:14px;align-items:center}.whead h1{font-family:var(--disp);font-weight:700;letter-spacing:-.02em;margin:0;font-size:23px}.whead p{margin:5px 0 0;color:var(--muted);font-size:14.5px;max-width:640px}.wbody{padding:26px}.drop{border:2px dashed var(--line-2);border-radius:14px;padding:38px 20px;text-align:center;color:var(--muted);transition:border-color .18s,background .18s,transform .18s;background:var(--surface-2);cursor:pointer}.drop.hot,.drop:hover{border-color:var(--brand);background:var(--tintbg)}.drop.hot{transform:scale(1.01)}.drop strong{display:block;color:var(--ink);font-size:16px;margin-bottom:4px}.drop .hint{font-family:var(--mono);font-size:12px;margin-top:7px;color:var(--faint)}.row{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;margin-top:20px}label.fld{font-size:13px;color:var(--muted);display:flex;flex-direction:column;gap:5px;font-family:var(--mono)}input[type=number],input[type=text],select{font-family:var(--mono);font-size:14px;border:1px solid var(--line-2);border-radius:10px;padding:10px 11px;background:#fff;color:var(--ink);transition:border-color .15s,box-shadow .15s}input:focus,select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(91,91,245,.16)}input[type=range]{accent-color:var(--brand)}.btn{position:relative;font-family:var(--disp);font-weight:600;font-size:14.5px;border:0;border-radius:12px;padding:12px 20px;cursor:pointer;background:var(--grad);color:#fff;box-shadow:0 6px 16px -6px rgba(99,102,241,.6);transition:transform .16s cubic-bezier(.2,.8,.2,1),box-shadow .16s,filter .16s;overflow:hidden;isolation:isolate}.btn:before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,hsla(0,0%,100%,.35),transparent 70%);transform:translateX(-130%);transition:transform .6s;z-index:-1}.btn:hover{transform:translateY(-2px);box-shadow:0 12px 26px -8px rgba(99,102,241,.7);filter:saturate(1.08)}.btn:hover:before{transform:translateX(130%)}.btn:active{transform:translateY(0) scale(.985)}.btn:disabled{background:#c7cad9;color:#fff;box-shadow:none;cursor:not-allowed;transform:none}.btn:disabled:before{display:none}.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line-2);box-shadow:var(--sh-1)}.btn.ghost:hover{background:var(--surface-2);filter:none}.files{margin-top:18px;display:flex;flex-direction:column;gap:8px}.frow{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:11px;padding:9px 12px;background:var(--surface-2);font-family:var(--mono);font-size:13px;animation:fadein .2s ease}@keyframes fadein{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.frow .nm{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--body)}.frow .sz{color:var(--muted)}.frow .x{cursor:pointer;color:var(--faint);border:0;background:none;font-size:16px;transition:color .15s}.frow .x:hover{color:var(--danger)}.thumb{width:36px;height:36px;border-radius:8px;object-fit:cover;border:1px solid var(--line)}.out{margin-top:20px;padding:16px;border:1px solid var(--tintline);background:linear-gradient(180deg,var(--tintbg),#fff);border-radius:12px;animation:fadein .25s ease}.out .delta{color:var(--brand-ink)}.msg,.out .delta{font-family:var(--mono);font-size:13px}.msg{margin-top:14px;color:var(--muted)}.msg.err{color:var(--danger)}.soonbox{padding:30px;border:1px dashed var(--line-2);border-radius:14px;background:var(--surface-2);color:var(--muted);line-height:1.6}.soonbox b{color:var(--ink)}.content{border-top:1px solid var(--line);margin-top:6px;padding:28px 26px 30px}.content .lead{font-size:16px;color:var(--ink);max-width:700px;margin:0 0 8px}.content h2{font-family:var(--disp);font-weight:700;font-size:17px;letter-spacing:-.01em;margin:28px 0 12px}.steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;max-width:700px}.steps li{display:flex;gap:12px;align-items:flex-start;color:var(--muted);font-size:14.5px}.steps li span{flex:none;width:25px;height:25px;border-radius:8px;background:var(--grad);color:#fff;font-family:var(--mono);font-size:12px;display:flex;align-items:center;justify-content:center;margin-top:1px}.faq{margin:0;max-width:700px}.faq dt{font-weight:600;font-size:14.5px;margin-top:14px}.faq dd{margin:5px 0 0;color:var(--muted);font-size:14px}.rel{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:12px;gap:12px}.relcard{border:1px solid var(--line);border-radius:13px;padding:14px;background:var(--surface-2);transition:transform .15s,border-color .15s,box-shadow .15s;color:var(--ink)}.relcard:hover{transform:translateY(-2px);border-color:var(--tintline);box-shadow:var(--sh-1);background:#fff}.relcard strong{display:block;font-family:var(--disp);font-size:15px;margin-bottom:3px}.relcard span{color:var(--muted);font-size:12.5px}.adslot{margin:22px 0;border:1px dashed var(--line-2);border-radius:14px;background:repeating-linear-gradient(45deg,#fbfcff,#fbfcff 12px,#f5f6fb 0,#f5f6fb 24px);min-height:110px;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--faint);font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase}.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(134px,1fr));grid-gap:14px;gap:14px;margin-top:20px}.pcard{border:1px solid var(--line);border-radius:12px;background:var(--surface-2);padding:8px;display:flex;flex-direction:column;gap:6px;transition:transform .15s,box-shadow .15s}.pcard:hover{box-shadow:var(--sh-1)}.pthumb{height:150px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:8px;cursor:-webkit-grab;cursor:grab}.pthumb img{max-width:100%;max-height:100%;transition:transform .15s}.pmeta{font-family:var(--mono);font-size:11px;color:var(--ink);text-align:center}.pmeta span{color:var(--faint)}.pctrls{display:flex;justify-content:center;gap:4px}.pctrls button{border:1px solid var(--line-2);background:#fff;border-radius:7px;width:27px;height:27px;cursor:pointer;font-size:13px;color:var(--ink);padding:0;transition:background .14s,border-color .14s}.pctrls button:hover:not(:disabled){background:var(--tintbg);border-color:var(--brand)}.pctrls button:disabled{opacity:.35;cursor:not-allowed}.pcard.drag{outline:2px dashed var(--brand);outline-offset:2px;opacity:.6}.pcard.over{border-color:var(--brand);background:var(--tintbg)}footer{border-top:1px solid var(--line);background:var(--surface);margin-top:10px}.fcols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;grid-gap:28px;gap:28px;padding:40px 0 26px}.fcol h4{font-family:var(--disp);font-size:13px;letter-spacing:.02em;margin:0 0 12px;color:var(--ink)}.fcol a{display:block;color:var(--muted);font-size:13.5px;padding:4px 0;transition:color .14s}.fcol a:hover{color:var(--brand)}.fbrand{display:flex;align-items:center;gap:10px;font-family:var(--disp);font-weight:700;font-size:17px;margin-bottom:10px}.fbrand .glyph{width:26px;height:26px;border-radius:8px}.fcol.about p{color:var(--muted);font-size:13.5px;margin:0;max-width:320px}.fnote{padding:18px 0 10px;font-size:12px;line-height:1.6;max-width:900px}.fbar,.fnote{border-top:1px solid var(--line);color:var(--faint)}.fbar{padding:14px 0 26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:12.5px}.fbar .mono{font-family:var(--mono)}:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:6px}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.001ms!important;transition-duration:.001ms!important}}@media(max-width:860px){.app{grid-template-columns:1fr}nav.tools{position:static}}@media(max-width:760px){.vals{grid-template-columns:1fr}.fcols{grid-template-columns:1fr 1fr}}@media(max-width:520px){.fcols{grid-template-columns:1fr}}:root[data-theme=dark]{--bg:#0e1018;--surface:#161922;--surface-2:#1d212c;--ink:#eaecf4;--muted:#a6acc0;--faint:#7b8298;--line:#262b38;--line-2:#343a4b;--tintbg:#1b1f3a;--tintline:#343b6e;--sh-1:0 1px 2px rgba(0,0,0,.4);--sh-2:0 12px 34px -14px rgba(0,0,0,.6);--sh-3:0 20px 54px -22px rgba(0,0,0,.7)}[data-theme=dark] body{background-image:radial-gradient(1100px 460px at 80% -8%,rgba(139,92,246,.16),transparent 60%),radial-gradient(900px 420px at 0 0,rgba(99,102,241,.14),transparent 55%)}[data-theme=dark] header.bar{background:rgba(14,16,24,.8)}[data-theme=dark] input[type=number],[data-theme=dark] input[type=text],[data-theme=dark] select{background:var(--surface-2);color:var(--ink)}[data-theme=dark] .btn.ghost,[data-theme=dark] .out{background:var(--surface-2)}[data-theme=dark] .adslot{background:repeating-linear-gradient(45deg,#171a24,#171a24 12px,#1d212c 0,#1d212c 24px)}[data-theme=dark] .pthumb{background:#0b0d13}.iconbtn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;background:var(--surface);border:1px solid var(--line-2);color:var(--muted);cursor:pointer;box-shadow:var(--sh-1);transition:color .15s,border-color .15s,transform .15s}.iconbtn:hover{color:var(--brand);border-color:var(--brand);transform:translateY(-1px)}.searchbar{position:relative;margin:6px 0 2px;max-width:520px}.searchbar input{width:100%;font-family:var(--body);font-size:15px;padding:12px 14px 12px 42px;border-radius:12px;border:1px solid var(--line-2);background:var(--surface);color:var(--ink);box-shadow:var(--sh-1)}.searchbar .si{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--faint);pointer-events:none}.noresults{color:var(--muted);font-family:var(--mono);font-size:14px;padding:18px 0}.cookie{position:fixed;left:16px;right:16px;bottom:16px;z-index:50;max-width:740px;margin:0 auto;background:var(--surface);border:1px solid var(--line-2);border-radius:16px;box-shadow:var(--sh-3);padding:16px 18px;display:flex;gap:16px;align-items:center;flex-wrap:wrap;animation:fadein .3s ease}.cookie p{margin:0;flex:1 1;min-width:220px;font-size:13.5px;color:var(--muted)}.cookie p a{font-weight:500}.cookie .cbtns{display:flex;gap:10px}.cookie .cbtns .btn{padding:9px 16px;font-size:13.5px}.scrolltop{position:fixed;right:18px;bottom:18px;z-index:40;width:46px;height:46px;border-radius:50%;border:0;background:var(--grad);color:#fff;cursor:pointer;box-shadow:var(--sh-2);display:flex;align-items:center;justify-content:center;transition:transform .15s,filter .15s;animation:fadein .3s ease}.scrolltop:hover{transform:translateY(-3px);filter:saturate(1.1)}