@import url("https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=Manrope:wght@400;500;600;700;800&display=swap");:root{--ink:#17201d;--muted:#68736e;--green:#147a55;--lime:#dfff73;--line:#dce2de;--paper:#f7f8f5;--white:#fff}*{box-sizing:border-box}body{margin:0;background:var(--paper);color:var(--ink);font-family:Manrope,Arial,sans-serif}button{font:inherit}main{min-height:100vh;background:radial-gradient(circle at 85% 12%,#e9f7cb 0,transparent 24%),var(--paper)}header{height:76px;justify-content:space-between;padding:0 max(5vw,28px);border-bottom:1px solid var(--line)}.brand,header{display:flex;align-items:center}.brand{gap:11px;color:var(--ink);text-decoration:none;font-weight:800;letter-spacing:-.03em}.brand span{display:grid;place-items:center;width:34px;height:34px;background:var(--ink);color:var(--lime);border-radius:9px;font-family:DM Mono;font-size:13px}.secure{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:8px}.secure i{width:7px;height:7px;border-radius:50%;background:#25a56f;box-shadow:0 0 0 4px #d9f1e7}.hero{text-align:center;padding:70px 20px 48px}.eyebrow{font:500 11px DM Mono;letter-spacing:.2em;color:var(--green);margin-bottom:19px}.hero h1{font-size:clamp(44px,6vw,76px);line-height:.98;letter-spacing:-.065em;margin:0;font-weight:700}.hero h1 em{font-style:normal;color:var(--green)}.hero p{max-width:540px;margin:25px auto 0;color:var(--muted);font-size:16px;line-height:1.7}.workspace{width:min(650px,calc(100% - 32px));margin:0 auto 60px;display:grid;grid-gap:20px;gap:20px;transition:.3s}.workspace.has-results{width:min(1180px,calc(100% - 32px));grid-template-columns:minmax(340px,.8fr) minmax(450px,1.2fr);align-items:start}.results,.upload-panel{background:var(--white);border:1px solid var(--line);border-radius:18px;padding:25px;box-shadow:0 18px 60px rgba(26,48,39,.06)}.panel-title{display:flex;align-items:center;gap:13px;margin-bottom:22px}.panel-title>span{font:500 10px DM Mono;display:grid;place-items:center;border-radius:50%;width:29px;height:29px;background:var(--ink);color:var(--lime)}.panel-title div{display:flex;flex-direction:column;gap:3px}.panel-title b{font-size:14px}.panel-title small{font-size:11px;color:var(--muted)}.dropzone{height:285px;border:1.5px dashed #b7c2bc;border-radius:13px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;background:#fafbf9;overflow:hidden;transition:.2s}.dropzone:hover{border-color:var(--green);background:#f6fbf6}.dropzone img{width:100%;height:100%;object-fit:contain;padding:12px}.upload-icon{display:grid;place-items:center;width:52px;height:52px;border-radius:50%;background:#e9f6cf;margin-bottom:18px}.upload-icon svg{width:23px;fill:none;stroke:var(--green);stroke-width:1.8}.dropzone b{font-size:14px}.dropzone p{font-size:12px;color:var(--muted);margin:8px}.dropzone u{color:var(--green);font-weight:700;text-underline-offset:3px}.file-row{display:flex;justify-content:space-between;align-items:center;padding:12px 3px 0}.file-row div{display:flex;flex-direction:column}.file-row b{font-size:12px;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-row small{color:var(--muted);font-size:10px}.file-row button,.json-head button{border:0;background:none;color:var(--green);font-weight:700;font-size:11px;cursor:pointer}.extract{border:0;border-radius:10px;background:var(--ink);color:#fff;width:100%;height:52px;margin-top:18px;font-weight:700;cursor:pointer}.extract:hover:not(:disabled){background:var(--green)}.extract:disabled{opacity:.35;cursor:not-allowed}.privacy{text-align:center;color:#8b948f;font-size:10px;margin:12px 0 0}.error{background:#fff1ed;color:#a63d2d;border-radius:8px;padding:10px 12px;margin-top:12px;font-size:12px}.spinner{display:inline-block;width:14px;height:14px;border:2px solid #ffffff55;border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin-right:8px;vertical-align:-2px}@keyframes spin{to{transform:rotate(1turn)}}.results{padding:25px 28px}.results-head{display:flex;justify-content:space-between}.done{font-size:10px;color:var(--green);background:#e7f7ed;padding:7px 10px;border-radius:20px;height:min-content}.summary-grid{display:grid;grid-template-columns:repeat(2,1fr);border:1px solid var(--line);border-radius:12px;overflow:hidden}.summary-grid>div{padding:14px 16px;border-bottom:1px solid var(--line)}.summary-grid>div:nth-child(odd){border-right:1px solid var(--line)}.summary-grid>div:nth-last-child(-n+2){border-bottom:0}.summary-grid small{display:block;color:var(--muted);font:400 9px DM Mono;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}.summary-grid b{font-size:13px}.summary-grid b i{font-weight:400;color:#9da59f;font-size:11px}.summary-grid .total{background:#f2f9df}.summary-grid .total b{color:var(--green);font-size:17px}.items h3,.json-head h3{font-size:12px;margin:20px 0 10px}.items h3 span{font:400 9px DM Mono;background:#eef1ee;padding:3px 6px;border-radius:8px}.item{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding:10px 3px;font-size:11px}.item div{display:flex;flex-direction:column}.item small{color:var(--muted);margin-top:3px}.json-head{display:flex;align-items:center;justify-content:space-between}.json-head h3{margin-bottom:10px}.json-head button{border:1px solid var(--line);padding:6px 9px;border-radius:6px;margin-left:6px}pre{margin:0;background:#15201c;color:#d7e8de;border-radius:10px;padding:16px;max-height:280px;overflow:auto;font:10px/1.6 DM Mono}footer{border-top:1px solid var(--line);padding:22px max(5vw,28px);display:flex;justify-content:space-between;color:#8b948f;font-size:10px}@media(max-width:820px){.workspace.has-results{grid-template-columns:1fr;width:min(650px,calc(100% - 24px))}.hero{padding-top:50px}.hero h1{font-size:48px}.workspace{width:calc(100% - 24px)}}@media(max-width:500px){header{height:64px;padding:0 18px}.secure{display:none}.hero{padding:42px 18px 35px}.hero h1{font-size:40px}.hero p{font-size:14px}.results,.upload-panel{padding:18px}.dropzone{height:235px}.summary-grid{grid-template-columns:1fr}.summary-grid>div:nth-child(odd){border-right:0}.summary-grid>div:nth-last-child(2){border-bottom:1px solid var(--line)}footer{padding:18px;display:block;text-align:center}footer span:last-child{display:none}}