@font-face{font-family:Space Grotesk;src:url(/fonts/SpaceGrotesk-VariableFont_wght.woff2) format("woff2");font-weight:300 700;font-style:normal;font-display:swap}@font-face{font-family:IBM Plex Sans;src:url(/fonts/IBMPlexSans-VariableFont_wdth_wght.woff2) format("woff2");font-weight:100 700;font-stretch:85% 100%;font-style:normal;font-display:swap}@font-face{font-family:IBM Plex Mono;src:url(/fonts/IBMPlexMono-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:IBM Plex Mono;src:url(/fonts/IBMPlexMono-Medium.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}:root{--ink-300: #CCC4AF;--ink-400: #ABA28C;--orange-600: #D24811;--background: #F8F6F0;--foreground: #1B1913;--card: #FFFFFF;--card-foreground: #1B1913;--primary: #EA5816;--primary-foreground: #1B1913;--secondary: #EFEBE0;--secondary-foreground: #2B2820;--muted: #EFEBE0;--muted-foreground: #635C4D;--accent: #2B6CFF;--accent-foreground: #FFFFFF;--success: #3A8F5B;--warning: #C98A1B;--destructive: #C5412A;--border: #E2DCCC;--input: #E2DCCC;--ring: #EA5816;--tick: #CCC4AF;--layer-line: rgba(27, 25, 19, .06);--font-display: "Space Grotesk", system-ui, sans-serif;--font-sans: "IBM Plex Sans", system-ui, -apple-system, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, Menlo, monospace;--shadow-primary: 0 6px 18px -4px rgba(234,88,22,.4);--ease: cubic-bezier(.2,.6,.2,1);--dur-fast: .14s;--dur: .22s;color-scheme:light}:root[data-theme=dark]{--ink-300: #6A6450;--ink-400: #4A4534;--orange-600: #D24811;--background: #15130D;--foreground: #F1EDE2;--card: #1E1B14;--card-foreground: #F1EDE2;--primary: #F2682B;--primary-foreground: #1B1006;--secondary: #2A2619;--secondary-foreground: #E7E1D2;--muted: #262318;--muted-foreground: #A49C88;--accent: #5C8BFF;--accent-foreground: #0A1430;--success: #4FA873;--warning: #E0A434;--destructive: #DD5A40;--border: #322E22;--input: #322E22;--ring: #F2682B;--tick: #4A4534;--layer-line: rgba(241, 237, 226, .07);color-scheme:dark}*{box-sizing:border-box}html.theme-switching,html.theme-switching *,html.theme-switching *:before,html.theme-switching *:after{transition:none!important}body{margin:0;background:var(--background);color:var(--foreground);font-family:var(--font-sans);line-height:1.55;-webkit-font-smoothing:antialiased;font-feature-settings:"ss01","cv05";overflow-x:hidden}h1,h2,h3,h4{font-family:var(--font-display);color:var(--foreground);letter-spacing:-.01em;line-height:1.1;margin:0;font-weight:600}p{margin:0;color:var(--muted-foreground);line-height:1.7}a{color:var(--accent);text-decoration:none}.layer-lines{background-image:repeating-linear-gradient(0deg,var(--layer-line) 0,var(--layer-line) 1px,transparent 1px,transparent 6px)}.tech-label{font-family:var(--font-mono);font-size:.75rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted-foreground);font-weight:500}.tech-label:before{content:"// ";color:var(--primary)}.ticked{position:relative}.ticked:before,.ticked:after{content:"";position:absolute;width:7px;height:7px;pointer-events:none}.ticked:before{top:-1px;left:-1px;border-top:1.5px solid var(--tick);border-left:1.5px solid var(--tick)}.ticked:after{bottom:-1px;right:-1px;border-bottom:1.5px solid var(--tick);border-right:1.5px solid var(--tick)}header.top{position:sticky;top:0;z-index:40;background:color-mix(in srgb,var(--background) 86%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}.top-inner{max-width:900px;margin:0 auto;padding:.85rem 2rem;display:flex;align-items:center;justify-content:space-between}.brand{display:flex;align-items:baseline;gap:.55rem}.brand .m{font-family:var(--font-display);font-weight:700;font-size:1.3rem;letter-spacing:-.02em;color:var(--foreground)}.brand .sep{color:var(--border)}.brand .sub{font-family:var(--font-mono);font-size:.76rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted-foreground)}.nav{display:flex;align-items:center;gap:1.3rem}.nav a{font-family:var(--font-mono);font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted-foreground)}.nav a:hover{color:var(--foreground)}#tt{background:none;border:1px solid var(--border);border-radius:4px;cursor:pointer;color:var(--foreground);padding:.4rem;display:flex}#tt svg{width:17px;height:17px}[data-theme=dark] #sun,[data-theme=light] #moon{display:none}main.app{max-width:640px;margin:0 auto;padding:3rem 1.5rem 5rem;min-height:70vh}.intro{text-align:center;margin-bottom:2.25rem}.intro h1{font-size:2.6rem;letter-spacing:-.03em}.intro p{font-size:1.05rem;margin-top:.75rem}.intro .em{color:var(--accent);font-weight:500}.center-label{display:inline-block;margin-bottom:.8rem}.btn{font-family:var(--font-sans);font-weight:600;font-size:.9rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:4px;border:1px solid transparent;padding:.7rem 1rem;transition:background-color var(--dur-fast) var(--ease),border-color var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease),transform var(--dur-fast) var(--ease);white-space:nowrap;text-decoration:none}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn svg{width:17px;height:17px}.btn-primary{background:var(--primary);color:var(--primary-foreground);box-shadow:var(--shadow-primary)}.btn-primary:hover{background:var(--orange-600)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{filter:brightness(.95)}.btn-outline{background:transparent;color:var(--foreground);border-color:var(--input)}.btn-outline:hover{background:var(--secondary)}.btn-ghost{background:transparent;color:var(--muted-foreground)}.btn-ghost:hover{color:var(--foreground)}.btn-block{width:100%}.badge{display:inline-flex;align-items:center;gap:.3rem;font-family:var(--font-mono);font-size:.66rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;padding:.22rem .5rem;border-radius:2px}.badge svg{width:11px;height:11px}.badge-accent{background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}.badge-success{background:color-mix(in srgb,var(--success) 16%,transparent);color:var(--success)}.scanner{position:relative;border:1.5px solid var(--border);border-radius:8px;background:var(--card);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:border-color var(--dur);margin-bottom:1rem}.scanner:hover{border-color:var(--ink-300)}.scanner .lines{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.6}.idle-c{position:relative;text-align:center;padding:1.5rem}.idle-c .iconwrap{width:76px;height:76px;border-radius:8px;background:color-mix(in srgb,var(--primary) 12%,transparent);color:var(--primary);display:grid;place-content:center;margin:0 auto 1.1rem}.idle-c .iconwrap svg{width:36px;height:36px}.idle-c h3{font-size:1.3rem;margin-bottom:.4rem}.idle-c p{font-size:.85rem;max-width:240px;margin:0 auto}.idle-btns{display:flex;gap:.6rem;margin-top:1.4rem}.scanner img.preview{width:100%;height:100%;object-fit:contain;padding:1rem}.scanner video.cam{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;background:#000}.cam-guides{position:absolute;top:2rem;right:2rem;bottom:2rem;left:2rem;border:1px solid rgba(255,255,255,.25);border-radius:6px;pointer-events:none}.cam-count{position:absolute;top:.8rem;left:.8rem;background:#0009;color:#fff;font-family:var(--font-mono);font-size:.7rem;padding:.25rem .6rem;border-radius:2px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cam-close{position:absolute;top:.8rem;right:.8rem;background:#0000008c;color:#fff;border:none;border-radius:50%;width:32px;height:32px;display:grid;place-content:center;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cam-close svg{width:18px;height:18px}.cam-shutter{position:absolute;bottom:1.2rem;left:50%;transform:translate(-50%);width:60px;height:60px;border-radius:50%;border:4px solid #fff;background:#ffffff40;cursor:pointer;display:grid;place-content:center}.cam-shutter:after{content:"";width:42px;height:42px;background:#fff;border-radius:50%}.scanning-ov{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:color-mix(in srgb,var(--card) 70%,transparent)}.spinner{width:46px;height:46px;border:4px solid var(--primary);border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.scanning-ov .t{font-family:var(--font-mono);font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--primary)}.thumbs{display:flex;align-items:center;gap:.6rem}.thumbs .tw{position:relative;flex-shrink:0}.thumbs img{width:56px;height:56px;object-fit:cover;border-radius:4px;border:1px solid var(--border);display:block}.thumbs .rm{position:absolute;top:-7px;right:-7px;background:var(--destructive);color:#fff;border:none;border-radius:50%;width:18px;height:18px;display:grid;place-content:center;cursor:pointer}.thumbs .rm svg{width:11px;height:11px}.thumbs .add{width:56px;height:56px;border-radius:4px;border:1.5px dashed var(--border);background:none;color:var(--muted-foreground);display:grid;place-content:center;cursor:pointer;flex-shrink:0}.thumbs .add:hover{border-color:var(--ink-300);color:var(--foreground)}.thumbs .analyze{margin-left:auto}.steps{display:grid;gap:.75rem;margin-top:2rem}.step{display:flex;gap:.9rem;align-items:flex-start;border:1px solid var(--border);border-radius:6px;padding:1rem 1.1rem;background:var(--card)}.step .n{font-family:var(--font-mono);font-size:.72rem;color:var(--primary);padding-top:.15rem;letter-spacing:.1em;white-space:nowrap}.step .t{font-weight:600;font-size:.92rem;color:var(--foreground);margin-bottom:.15rem}.step .d{font-size:.82rem;color:var(--muted-foreground);line-height:1.5}.hist{margin-top:2.5rem}.hist-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.9rem}.hist-head .l{display:inline-flex;align-items:center;gap:.4rem}.hist-head .l svg{width:13px;height:13px}.hist-head .c{font-family:var(--font-mono);font-size:.68rem;color:var(--muted-foreground)}.hist-item{display:flex;align-items:center;gap:.9rem;border:1px solid var(--border);border-radius:6px;padding:.7rem .8rem;background:var(--card);cursor:pointer;transition:border-color var(--dur);margin-bottom:.6rem}.hist-item:hover{border-color:var(--ink-300)}.hist-item .th{width:42px;height:42px;border-radius:4px;background:var(--secondary);border:1px solid var(--border);display:grid;place-content:center;overflow:hidden;flex-shrink:0;color:var(--muted-foreground)}.hist-item .th img{width:100%;height:100%;object-fit:cover}.hist-item .th svg{width:18px;height:18px}.hist-item .info{flex:1;min-width:0}.hist-item .info h4{font-family:var(--font-sans);font-size:.92rem;font-weight:600;color:var(--foreground);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hist-item .info .meta{font-family:var(--font-mono);font-size:.68rem;color:var(--muted-foreground)}.hist-item .del{background:none;border:none;color:var(--muted-foreground);cursor:pointer;padding:.3rem;display:flex}.hist-item .del:hover{color:var(--destructive)}.hist-item .del svg{width:15px;height:15px}.hist-item .go{width:16px;height:16px;color:var(--ink-400);flex-shrink:0}.result{border:1px solid var(--border);border-radius:8px;background:var(--card);padding:1.6rem;position:relative}.back{background:none;border:none;color:var(--muted-foreground);font-size:.85rem;font-family:var(--font-sans);cursor:pointer;display:inline-flex;align-items:center;gap:.3rem;margin-bottom:1rem}.back:hover{color:var(--foreground)}.res-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.9rem;gap:1rem}.res-head .badges{display:flex;gap:.4rem;margin-bottom:.5rem;flex-wrap:wrap}.res-head h2{font-size:1.7rem;letter-spacing:-.02em}.res-head .boxic{background:var(--secondary);border-radius:6px;padding:.6rem;color:var(--muted-foreground);display:flex;flex-shrink:0}.res-head .boxic svg{width:22px;height:22px}.res-desc{font-size:.9rem;color:var(--muted-foreground);line-height:1.6;margin-bottom:1.3rem}.mat{position:relative;overflow:hidden;background:color-mix(in srgb,var(--primary) 9%,transparent);border:1px solid color-mix(in srgb,var(--primary) 22%,transparent);border-radius:6px;padding:1rem 1.1rem;margin-bottom:1.3rem}.mat .hammer{position:absolute;top:-6px;right:-2px;color:var(--primary);opacity:.12}.mat .hammer svg{width:64px;height:64px}.mat .l{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.12em;color:var(--primary);margin-bottom:.3rem}.mat .l svg{width:12px;height:12px}.mat .v{font-size:.9rem;font-weight:500;color:var(--foreground)}.qbox{background:var(--background);border:1px solid var(--border);border-radius:6px;padding:1rem 1.1rem;margin-bottom:1.3rem}.qbox .qh{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.qbox .qh .lab{font-family:var(--font-mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted-foreground)}.qbox .qh .ed{font-family:var(--font-mono);font-size:.62rem;color:var(--accent);display:inline-flex;align-items:center;gap:.25rem}.qbox .qh .ed svg{width:10px;height:10px}.qbox .qi{position:relative}.qbox input{width:100%;font-family:var(--font-mono);font-size:.85rem;color:var(--accent);background:var(--background);border:1px solid var(--input);border-radius:4px;padding:.6rem 2rem .6rem .7rem;transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}.qbox input:focus{outline:none;border-color:var(--ring);box-shadow:0 0 0 3px color-mix(in srgb,var(--ring) 22%,transparent)}.qbox .qi svg{position:absolute;right:.65rem;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--ink-400)}.ctas{display:flex;flex-direction:column;gap:.6rem}.upsell{text-align:center;border-top:1px solid var(--border);margin-top:1.3rem;padding-top:1rem}.upsell p{font-size:.78rem;color:var(--muted-foreground);margin-bottom:.3rem}.upsell a{font-size:.84rem;color:var(--accent);font-weight:600;text-decoration:underline}.alert-amber{display:flex;gap:.6rem;align-items:flex-start;margin-top:1rem;padding:.8rem .9rem;border-radius:6px;border-left:3px solid var(--warning);background:color-mix(in srgb,var(--warning) 12%,transparent)}.alert-amber svg{width:16px;height:16px;color:var(--warning);flex-shrink:0;margin-top:1px}.alert-amber p{font-size:.8rem;color:var(--foreground);line-height:1.45}.alert-error{display:flex;gap:.6rem;align-items:center;justify-content:center;margin-bottom:1.5rem;padding:.8rem .9rem;border-radius:6px;border:1px solid color-mix(in srgb,var(--destructive) 30%,transparent);background:color-mix(in srgb,var(--destructive) 10%,transparent);color:var(--destructive);font-size:.85rem;text-align:center}.alert-error .dot{width:8px;height:8px;border-radius:50%;background:currentColor;flex-shrink:0}.res-foot{border-top:1px solid var(--border);margin-top:1.5rem;padding-top:1.2rem;display:flex;justify-content:center}footer.ft{text-align:center;padding:1.5rem;font-family:var(--font-mono);font-size:.7rem;color:var(--muted-foreground)}
