@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/fef07dbb0973bf53-s.3p2_lha1f2xer.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.1qq4vpdcun5oj.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/53b9e256198e5412-s.390ncx5urfkfu.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.21jp631_3pja2.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.0wgildi0cnwt9.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist", "Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5ce348bf30bf5439-s.31988l_ccedte.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.2tuy5pz7dlieh.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/6306c77e7c8268e4-s.2dbetqa9o8jxf.woff2)format("woff2");unicode-range:U+2000-2001,U+2004-2008,U+200A,U+23B8-23BD,U+2500-259F}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7d817b4c03b0c5f1-s.1uyisp29ctx0d.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.1rgnod-3esatf.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.0r6juujl39pe6.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono", "Geist Mono Fallback"}
:root{--bg:#f6f8fb;--bg-grad:radial-gradient(1200px 500px at 50% -200px, #e8f0ff 0%, #e8f0ff00 70%);--surface:#fff;--surface-2:#f1f5f9;--ink:#0b1220;--ink-soft:#334155;--muted:#64748b;--line:#e5e9f0;--line-strong:#cdd5e0;--brand:#2563eb;--brand-dark:#1d4ed8;--brand-soft:#eef4ff;--on-brand:#fff;--ok:#16a34a;--ok-soft:#f0fdf4;--ok-line:#bbf7d0;--err:#dc2626;--err-soft:#fef2f2;--err-line:#fecaca;--shadow-sm:0 1px 2px #0f172a0f;--shadow:0 6px 24px -12px #0f172a2e;--shadow-lg:0 24px 60px -24px #0f172a47;--radius:12px;--radius-lg:18px}html[data-theme=dark]{--bg:#0a0f1c;--bg-grad:radial-gradient(1200px 500px at 50% -200px, #14203a 0%, #14203a00 70%);--surface:#111a2e;--surface-2:#16223c;--ink:#eef2f9;--ink-soft:#c2ccdb;--muted:#8a97ac;--line:#22304c;--line-strong:#2d3d5c;--brand:#4f83f4;--brand-dark:#3b6fe0;--brand-soft:#16223c;--on-brand:#fff;--ok:#34d399;--ok-soft:#0f2a20;--ok-line:#1f5140;--err:#f87171;--err-soft:#2a1515;--err-line:#5b2626;--shadow-sm:0 1px 2px #0006;--shadow:0 8px 28px -14px #000000b3;--shadow-lg:0 24px 60px -24px #000000bf}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);background-image:var(--bg-grad);color:var(--ink);font-family:var(--font-geist-sans), system-ui, -apple-system, Segoe UI, Roboto, sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;background-repeat:no-repeat;min-height:100vh;line-height:1.55}a{color:inherit;text-decoration:none}::selection{background:color-mix(in srgb, var(--brand) 22%, transparent)}:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:6px}.container{max-width:940px;margin:0 auto;padding:0 20px}.site-header{z-index:20;border-bottom:1px solid var(--line);background:color-mix(in srgb, var(--surface) 80%, transparent);-webkit-backdrop-filter:saturate(1.4)blur(10px);backdrop-filter:saturate(1.4)blur(10px);position:sticky;top:0}.site-header .inner{justify-content:space-between;align-items:center;gap:16px;height:62px;display:flex}.brand{letter-spacing:-.02em;align-items:center;gap:9px;font-size:18px;font-weight:750;display:inline-flex}.brand span{color:var(--brand)}.brand-mark{background:linear-gradient(135deg, var(--brand), #60a5fa);color:#fff;width:30px;height:30px;box-shadow:var(--shadow-sm);border-radius:9px;place-items:center;display:grid}.header-right{align-items:center;gap:18px;display:flex}.nav-links{color:var(--muted);gap:18px;font-size:14px;font-weight:550;display:flex}.nav-links a:hover{color:var(--ink)}.theme-toggle{border:1px solid var(--line);background:var(--surface);width:36px;height:36px;color:var(--ink-soft);cursor:pointer;border-radius:10px;place-items:center;display:grid}.theme-toggle:hover{border-color:var(--line-strong);color:var(--ink)}.site-footer{border-top:1px solid var(--line);background:var(--surface);margin-top:72px;padding:40px 0 48px}.footer-top{flex-wrap:wrap;justify-content:space-between;gap:28px 48px;display:flex}.footer-brand{max-width:320px;color:var(--muted);font-size:14px}.footer-brand .brand{margin-bottom:8px}.footer-cols{flex-wrap:wrap;gap:40px;display:flex}.footer-col h4{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:0 0 10px;font-size:13px}.footer-col a{color:var(--ink-soft);padding:3px 0;font-size:14px;display:block}.footer-col a:hover{color:var(--brand)}.footer-note{border-top:1px solid var(--line);color:var(--muted);margin-top:28px;padding-top:20px;font-size:13px}.hero{text-align:center;padding:56px 0 28px}.eyebrow{color:var(--brand);background:var(--brand-soft);border:1px solid color-mix(in srgb, var(--brand) 22%, transparent);border-radius:999px;align-items:center;gap:7px;margin-bottom:18px;padding:5px 12px;font-size:13px;font-weight:600;display:inline-flex}.eyebrow .dot{background:var(--ok);border-radius:50%;width:7px;height:7px}.hero h1{letter-spacing:-.035em;margin:0 0 12px;font-size:clamp(30px,5vw,42px);line-height:1.08}.hero p{color:var(--muted);max-width:580px;margin:0 auto;font-size:17px}.hero-badges{color:var(--ink-soft);flex-wrap:wrap;justify-content:center;gap:10px 20px;margin-top:20px;font-size:14px;display:flex}.hero-badges span{align-items:center;gap:7px;display:inline-flex}.hero-badges svg{color:var(--brand)}.tool{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:20px}.dropzone{border:2px dashed var(--line-strong);border-radius:var(--radius);text-align:center;cursor:pointer;padding:44px 20px;transition:border-color .15s,background .15s,transform 50ms}.dropzone:hover,.dropzone.dragging{border-color:var(--brand);background:var(--brand-soft)}.dz-icon{color:var(--brand);font-size:30px;line-height:1}.dz-title{margin-top:10px;font-weight:650}.dz-sub{color:var(--muted);margin-top:4px;font-size:14px}.toolbar{flex-wrap:wrap;align-items:center;gap:18px;margin-top:18px;display:flex}.field{color:var(--muted);flex-direction:column;gap:5px;font-size:13px;display:flex}.field-inline{color:var(--ink);flex-direction:row;align-items:center;gap:8px;font-size:14px}.select,.num,.textarea{border:1px solid var(--line-strong);background:var(--surface);color:var(--ink);border-radius:9px;padding:9px 11px;font-family:inherit;font-size:14px}.select:focus,.num:focus,.textarea:focus,.pw-field:focus{border-color:var(--brand);outline:none}.num{width:96px}.textarea{resize:vertical;width:100%}.range{width:170px;accent-color:var(--brand)}.color{border:1px solid var(--line-strong);background:var(--surface);cursor:pointer;border-radius:9px;width:48px;height:36px;padding:2px}.filelist{flex-direction:column;gap:8px;margin:20px 0 0;padding:0;list-style:none;display:flex}.fileitem{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);align-items:center;gap:12px;padding:10px 12px;display:flex}.fi-thumb{background:var(--surface-2);border:1px solid var(--line);width:44px;height:44px;color:var(--muted);border-radius:8px;flex-shrink:0;place-items:center;font-size:11px;font-weight:700;display:grid;overflow:hidden}.fi-thumb img{object-fit:cover;width:100%;height:100%}.fi-main{flex-direction:column;flex:1;min-width:0;display:flex}.fi-name{white-space:nowrap;text-overflow:ellipsis;max-width:320px;font-size:14px;font-weight:550;overflow:hidden}.fi-meta{color:var(--muted);font-size:12.5px}.fi-side{flex-shrink:0;align-items:center;gap:8px;display:flex}.tag{color:var(--muted);font-size:12px}.tag-error{color:var(--err);white-space:nowrap;text-overflow:ellipsis;max-width:220px;overflow:hidden}.status-done{border-color:var(--ok-line);background:var(--ok-soft)}.status-error{border-color:var(--err-line);background:var(--err-soft)}.actions{flex-wrap:wrap;align-items:center;gap:10px;margin-top:18px;display:flex}.working-hint{color:var(--muted);font-size:13px}.btn{border:1px solid var(--line-strong);background:var(--surface);color:var(--ink);cursor:pointer;border-radius:10px;padding:9px 15px;font-size:14px;font-weight:650;transition:background .15s,border-color .15s,transform 40ms,box-shadow .15s}.btn:hover{border-color:var(--line-strong);background:var(--surface-2)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand);border-color:var(--brand);color:var(--on-brand);box-shadow:0 8px 20px -10px color-mix(in srgb, var(--brand) 70%, transparent)}.btn-primary:hover:not(:disabled){background:var(--brand-dark);border-color:var(--brand-dark)}.btn-ghost{color:var(--muted);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--surface-2);color:var(--ink)}.btn-small{padding:6px 11px;font-size:13px}.btn-active{border-color:var(--brand);color:var(--brand)}.section{margin-top:52px}.section h2{letter-spacing:-.02em;margin:0 0 4px;font-size:21px}.section-sub{color:var(--muted);margin:0 0 18px;font-size:14px}.grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;display:grid}.card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-sm);align-items:flex-start;gap:12px;padding:14px;font-size:14px;font-weight:600;transition:border-color .15s,transform 80ms,box-shadow .15s;display:flex}.card:hover{border-color:color-mix(in srgb, var(--brand) 40%, var(--line));box-shadow:var(--shadow);transform:translateY(-2px)}.card small{color:var(--muted);margin-top:3px;font-size:12.5px;font-weight:400;display:block}.card-icon{background:var(--brand-soft);width:38px;height:38px;color:var(--brand);border-radius:10px;flex-shrink:0;place-items:center;display:grid}.card-body{min-width:0}.features{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;display:grid}.feature{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-sm);padding:18px}.feature-icon{background:var(--brand-soft);width:40px;height:40px;color:var(--brand);border-radius:11px;place-items:center;margin-bottom:12px;display:grid}.feature h3{margin:0 0 4px;font-size:15px}.feature p{color:var(--muted);margin:0;font-size:14px}.crumbs{color:var(--muted);padding-top:26px;font-size:13px}.crumbs a:hover{color:var(--ink)}.page-head{align-items:flex-start;gap:16px;padding:14px 0 22px;display:flex}.page-head .card-icon{border-radius:12px;width:46px;height:46px;margin-top:2px}.page-head h1{letter-spacing:-.03em;margin:0 0 8px;font-size:clamp(26px,4vw,32px)}.page-head p{color:var(--muted);max-width:640px;margin:0}.prose h2{letter-spacing:-.02em;margin:34px 0 10px;font-size:21px}.prose h3{margin:22px 0 4px;font-size:16px}.prose p{color:var(--ink-soft)}.steps{color:var(--ink-soft);padding-left:20px}.steps li{margin:5px 0}.taglist{flex-wrap:wrap;gap:8px;display:flex}.taglist a{border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);border-radius:999px;padding:6px 13px;font-size:13px}.taglist a:hover{border-color:var(--brand);color:var(--brand)}.textarea{width:100%}.gen-qr-grid{grid-template-columns:1fr auto;align-items:start;gap:24px;display:grid}.gen-qr-preview{border:1px solid var(--line);background:#fff;border-radius:14px;justify-content:center;align-items:center;min-width:252px;min-height:252px;padding:16px;display:flex}.gen-qr-placeholder{color:var(--muted);font-size:14px}.gen-error{color:var(--err);margin:12px 0 0;font-size:14px}.pw-output{flex-wrap:wrap;gap:8px;display:flex}.pw-field{border:1px solid var(--line-strong);min-width:200px;font-size:16px;font-family:var(--font-geist-mono), ui-monospace, monospace;background:var(--surface);color:var(--ink);border-radius:10px;flex:1;padding:12px 14px}.pw-strength{align-items:baseline;gap:8px;margin-top:12px;font-size:14px;font-weight:650;display:flex}.pw-strength small{color:var(--muted);font-weight:400}.pw-strength.s-weak{color:var(--err)}.pw-strength.s-fair{color:#d97706}.pw-strength.s-strong,.pw-strength.s-vstrong{color:var(--ok)}.pw-toggles{flex-wrap:wrap;gap:14px;margin-top:16px;font-size:14px;display:flex}.fancy-list{flex-direction:column;gap:8px;margin:16px 0 0;padding:0;list-style:none;display:flex}.fancy-row{border:1px solid var(--line);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.fancy-out{text-overflow:ellipsis;white-space:nowrap;font-size:18px;overflow:hidden}.wheel-grid{grid-template-columns:300px 1fr;align-items:center;gap:24px;display:grid}.wheel-wrap{width:300px;height:300px;position:relative}.wheel{filter:drop-shadow(0 8px 20px #0f172a2e);width:300px;height:300px;display:block}.wheel-pointer{border-left:12px solid #0000;border-right:12px solid #0000;border-top:20px solid var(--ink);z-index:2;width:0;height:0;position:absolute;top:-4px;left:50%;transform:translate(-50%)}.wheel-side{flex-direction:column;gap:12px;display:flex}.btn-spin{padding:12px 18px;font-size:16px}.wheel-winner{font-size:18px}.wheel-winner strong{color:var(--brand)}.saved{color:var(--ok);font-weight:650}.hint{color:var(--muted);font-size:13px}.editor-preview{background:var(--surface-2);border:1px solid var(--line);border-radius:14px;justify-content:center;padding:12px;display:flex}.preview-canvas{max-width:100%;box-shadow:var(--shadow);border-radius:8px}.editor-toolbar{gap:8px}.crop-stage{touch-action:none;-webkit-user-select:none;user-select:none;box-shadow:var(--shadow);border-radius:8px;margin:0 auto;position:relative;overflow:hidden}.crop-canvas{cursor:crosshair;display:block}.crop-sel{border:2px solid var(--brand);pointer-events:none;position:absolute;box-shadow:0 0 0 9999px #0f172a66}.crop-sel.circle{border-radius:50%}.progress{background:var(--surface-2);border-radius:999px;height:8px;margin-top:14px;overflow:hidden}.progress-bar{background:var(--brand);height:100%;transition:width .2s}.vid-file{border:1px solid var(--line);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.vid-result{border:1px solid var(--ok-line);background:var(--ok-soft);border-radius:var(--radius);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:16px;padding:12px 14px;display:flex}@media (max-width:640px){.gen-qr-grid,.wheel-grid{grid-template-columns:1fr;justify-items:center}.nav-links{gap:14px}.page-head{flex-direction:column;gap:10px}}
