@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";.lp{color:#fff;background:var(--bg-primary);font-family:var(--font-sans,"Inter", sans-serif);-webkit-font-smoothing:antialiased;min-height:100vh}.lp a{color:inherit;text-decoration:none}.lp-nav{z-index:50;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0f172ab8;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:16px 40px;display:flex;position:sticky;top:0}.lp-nav .pp-word{font-size:20px}.lp-navlinks{gap:28px;display:flex}.lp-navlinks a{color:var(--text-secondary);font-size:14px;font-weight:500;transition:color .15s}.lp-navlinks a:hover{color:#fff}.lp-btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 18px;font-family:inherit;font-size:14px;font-weight:600;transition:all .18s;display:inline-flex}.lp-btn-violet{background:var(--gradient-brand);color:#fff;box-shadow:0 4px 16px #4f46e566}.lp-btn-violet:hover{transform:translateY(-1px);box-shadow:0 6px 22px #4f46e58c}.lp-btn-ghost{color:#fff;background:0 0;border:1px solid #ffffff2e}.lp-btn-ghost:hover{background:#ffffff0f}.lp-hero{background:radial-gradient(120% 90% at 78% -5%, #211c5e 0%, #211c5e00 55%), var(--bg-primary);padding:88px 40px 96px;position:relative;overflow:hidden}.lp-hero-inner{grid-template-columns:1.05fr .95fr;align-items:center;gap:40px;max-width:1140px;margin:0 auto;display:grid}.lp-eyebrow{text-transform:uppercase;letter-spacing:1.5px;color:var(--brand-violet-bright);align-items:center;gap:8px;margin-bottom:22px;font-size:12px;font-weight:600;display:inline-flex}.lp-eyebrow .dot{background:var(--brand-violet-bright);width:7px;height:7px;box-shadow:0 0 10px var(--brand-violet-bright);border-radius:50%}.lp-hero h1{letter-spacing:-.03em;margin:0 0 22px;font-size:56px;font-weight:800;line-height:1.05}.lp-hero h1 .grad{background:linear-gradient(100deg, var(--brand-violet-bright), var(--brand-cyan));color:#0000;-webkit-background-clip:text;background-clip:text}.lp-lede{color:var(--text-secondary);max-width:480px;margin:0 0 32px;font-size:18px;line-height:1.6}.lp-cta{align-items:center;gap:14px;display:flex}.lp-art{justify-content:center;display:flex}.lp-art svg{filter:drop-shadow(0 30px 60px #4f46e573);width:100%;max-width:360px}.lp-meta{gap:34px;margin-top:44px;display:flex}.lp-meta .stat{font-size:26px;font-weight:800}.lp-meta .stat span{color:var(--text-muted);letter-spacing:.3px;margin-top:3px;font-size:12px;font-weight:500;display:block}.lp-features{background:var(--bg-secondary);border-top:1px solid #ffffff0d;padding:76px 40px}.lp-features-inner{max-width:1140px;margin:0 auto}.lp-sec-head{text-align:center;margin-bottom:48px}.lp-sec-head h2{letter-spacing:-.02em;margin:0 0 12px;font-size:34px;font-weight:800}.lp-sec-head p{color:var(--text-secondary);margin:0;font-size:16px}.lp-grid3{grid-template-columns:repeat(3,1fr);gap:22px;display:grid}.lp-fcard{background:var(--bg-primary);border:1px solid var(--border);border-radius:16px;padding:28px;transition:border-color .2s,transform .2s}.lp-fcard:hover{border-color:var(--brand-violet);transform:translateY(-3px)}.lp-ficon{width:46px;height:46px;color:var(--brand-violet-bright);background:#6c63ff24;border-radius:12px;justify-content:center;align-items:center;margin-bottom:18px;display:flex}.lp-fcard h3{margin:0 0 8px;font-size:18px;font-weight:700}.lp-fcard p{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.6}.lp-ctaband{text-align:center;background:radial-gradient(80% 140% at 50% 0%, #211c5e 0%, var(--bg-primary) 60%);padding:80px 40px}.lp-ctaband h2{letter-spacing:-.02em;margin:0 0 16px;font-size:38px;font-weight:800}.lp-ctaband p{color:var(--text-secondary);max-width:460px;margin:0 auto 30px;font-size:17px}.lp-footer{border-top:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:40px;display:flex}.lp-footer .copy{color:var(--text-muted);font-size:13px}.lp-footer a.gh{color:var(--text-secondary);font-size:13px;transition:color .15s}.lp-footer a.gh:hover{color:var(--brand-violet-bright)}@media (width<=820px){.lp-hero-inner{grid-template-columns:1fr}.lp-art{order:-1}.lp-grid3{grid-template-columns:1fr}.lp-navlinks{display:none}.lp-hero h1{font-size:42px}}@media (prefers-reduced-motion:reduce){.lp-btn,.lp-fcard{transition:none}}.lp-navbrand{align-items:center;display:flex}.lp-footer{flex-wrap:wrap;gap:20px}.lp-footlinks{flex-wrap:wrap;gap:20px;display:flex}.lp-footlinks a{color:var(--text-secondary);font-size:13px;transition:color .15s}.lp-footlinks a:hover{color:var(--brand-violet-bright)}.lp-page{max-width:860px;margin:0 auto;padding:64px 40px 88px}.lp-page>h1{letter-spacing:-.02em;margin:0 0 14px;font-size:40px;font-weight:800}.lp-page .intro{color:var(--text-secondary);max-width:620px;margin:0 0 40px;font-size:18px;line-height:1.6}.lp-eyebrow.page{margin-bottom:16px}.lp-prose{color:var(--text-secondary);font-size:15px;line-height:1.7}.lp-prose h2{color:#fff;margin:32px 0 10px;font-size:20px}.lp-prose p{margin:0 0 14px}.lp-prose ul{margin:0 0 14px;padding-left:20px}.lp-prose li{margin-bottom:6px}.lp-prose strong{color:var(--text-primary)}.lp-prose a{color:var(--brand-violet-bright)}.lp-note{color:#fcd34d;background:#f59e0b1a;border:1px solid #f59e0b59;border-radius:10px;margin:24px 0;padding:12px 14px;font-size:13px}.lp-steps{flex-direction:column;gap:16px;display:flex}.lp-step{background:var(--bg-secondary);border:1px solid var(--border);border-radius:14px;align-items:flex-start;gap:18px;padding:20px 22px;display:flex}.lp-step .num{background:var(--gradient-brand);color:#fff;border-radius:10px;flex:none;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;font-weight:800;display:flex;box-shadow:0 4px 14px #4f46e559}.lp-step h3{color:#fff;margin:4px 0 6px;font-size:17px}.lp-step p{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.6}.lp-feat-grid{grid-template-columns:repeat(2,1fr);gap:18px;display:grid}.lp-feat{background:var(--bg-secondary);border:1px solid var(--border);border-radius:14px;padding:22px;transition:border-color .2s}.lp-feat:hover{border-color:var(--brand-violet)}.lp-feat h3{color:#fff;margin:0 0 8px;font-size:16px}.lp-feat p{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.6}.lp-price-card{text-align:center;background:var(--bg-secondary);border:1px solid var(--brand-violet);border-radius:18px;max-width:540px;margin:8px auto 0;padding:44px 36px;box-shadow:0 20px 50px #4f46e52e}.lp-price-card .tag{text-transform:uppercase;letter-spacing:1.5px;color:var(--brand-violet-bright);margin-bottom:14px;font-size:12px;font-weight:600;display:inline-block}.lp-price-card h2{margin:0 0 12px;font-size:28px}.lp-price-card p{color:var(--text-secondary);margin:0 0 26px;line-height:1.6}.lp-price-list{text-align:left;gap:10px;max-width:360px;margin:0 auto 28px;display:grid}.lp-price-list div{color:var(--text-secondary);align-items:center;gap:10px;font-size:14px;display:flex}.lp-price-list svg{color:var(--brand-violet-bright);flex:none}.lp-contact-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;max-width:560px;padding:28px}.lp-contact-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 0;display:flex}.lp-contact-row:last-child{border-bottom:none}.lp-contact-row .lbl{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);flex:none;width:110px;font-size:12px}.lp-contact-row .val{color:var(--text-primary)}.lp-contact-row .pending{color:var(--text-muted);font-style:italic}.lp-faq{flex-direction:column;gap:12px;display:flex}.lp-faq details{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:2px 18px}.lp-faq summary{cursor:pointer;color:#fff;justify-content:space-between;align-items:center;padding:15px 0;font-weight:600;list-style:none;display:flex}.lp-faq summary::-webkit-details-marker{display:none}.lp-faq summary:after{content:"+";color:var(--brand-violet-bright);font-size:18px;font-weight:700}.lp-faq details[open] summary:after{content:"−"}.lp-faq details p{color:var(--text-secondary);margin:0 0 15px;font-size:14px;line-height:1.6}@media (width<=820px){.lp-feat-grid{grid-template-columns:1fr}.lp-page>h1{font-size:32px}}:root{--brand-violet:#6c63ff;--brand-violet-deep:#4f46e5;--brand-violet-bright:#8b85ff;--brand-violet-tint:#e9e7ff;--brand-cyan:#6c63ff;--brand-ink:#08060d;--gradient-brand:linear-gradient(135deg, var(--brand-violet), var(--brand-violet-deep));--brand-glow:#6c63ff59}html.web-scroll,html.web-scroll body,html.web-scroll #root{height:auto;overflow:auto}.pp-lockup{align-items:center;gap:10px;display:flex}.pp-lockup--stacked{flex-direction:column;gap:10px}.pp-word{letter-spacing:-.02em;color:#fff;font-size:22px;font-weight:800}.pp-word .pile{color:var(--brand-violet-bright)}.auth-screen{background:radial-gradient(120% 80% at 50% -10%, #211c5e 0%, #211c5e00 55%), var(--bg-primary);min-height:100vh;color:var(--text-primary);place-items:center;padding:24px;display:grid}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:380px;padding:32px 28px;box-shadow:0 20px 50px #0006,0 0 0 1px #6c63ff14}.auth-brand{justify-content:center;margin-bottom:20px;display:flex}.auth-card h1{text-align:center;margin:0 0 4px;font-size:22px}.auth-card .sub{color:var(--text-secondary);text-align:center;margin:0 0 24px;font-size:14px}.auth-field{margin-bottom:16px}.auth-field label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;display:block}.auth-field input,.auth-field select{box-sizing:border-box;background:var(--bg-primary);border:1px solid var(--border-light);width:100%;color:var(--text-primary);border-radius:8px;padding:10px 12px;font-size:14px;transition:border-color .18s,box-shadow .18s}.auth-field input:focus,.auth-field select:focus{border-color:var(--brand-violet);box-shadow:0 0 0 3px var(--brand-glow);outline:none}.auth-btn{background:var(--gradient-brand);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;padding:11px;font-size:15px;font-weight:600;transition:transform .18s,box-shadow .18s,opacity .18s;box-shadow:0 4px 16px #4f46e566}.auth-btn:hover{transform:translateY(-1px);box-shadow:0 6px 22px #4f46e58c}.auth-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-error{color:#fca5a5;background:#ef44441f;border:1px solid #ef444466;border-radius:8px;margin-bottom:16px;padding:10px 12px;font-size:13px}.auth-note{color:var(--text-primary);background:#6c63ff1a;border:1px solid #6c63ff59;border-radius:8px;margin-bottom:16px;padding:10px 12px;font-size:13px}.web-chrome{z-index:1000;color:var(--text-secondary);align-items:center;gap:10px;font-size:13px;display:flex;position:fixed;top:6px;right:12px}.web-chrome a,.web-chrome button{color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:4px 10px;font-size:12px;text-decoration:none;transition:color .15s,border-color .15s}.web-chrome a:hover,.web-chrome button:hover{color:var(--brand-violet-bright);border-color:var(--brand-violet)}.admin-wrap{background:radial-gradient(90% 50% at 100% 0%, #211c5e80 0%, #211c5e00 45%), var(--bg-primary);min-height:100vh;color:var(--text-primary);box-sizing:border-box;padding:32px}.admin-wrap .head{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.admin-wrap .head h1{font-size:24px}.admin-table{border-collapse:collapse;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;width:100%;overflow:hidden}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--border);padding:10px 14px;font-size:14px}.admin-table th{color:var(--text-secondary);background:var(--bg-secondary);font-weight:600}.admin-table tr:last-child td{border-bottom:none}.pill{border-radius:999px;padding:2px 8px;font-size:12px;display:inline-block}.pill.admin{color:var(--brand-violet-bright);background:#6c63ff2e}.pill.user{background:var(--bg-tertiary);color:var(--text-secondary)}.pill.off{color:#fca5a5;background:#ef444426}.admin-act{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:6px;margin-right:6px;padding:4px 8px;font-size:12px;transition:color .15s,border-color .15s}.admin-act:hover{color:var(--text-primary);border-color:var(--border-light)}.admin-act.danger:hover{color:#fca5a5;border-color:#ef444480}.admin-create{flex-wrap:wrap;align-items:flex-end;gap:10px;margin-bottom:20px;display:flex}.cred-box{background:#6c63ff1a;border:1px solid #6c63ff66;border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;padding:14px 16px;display:flex}.cred-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);margin-bottom:4px;font-size:12px}.cred-line{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.cred-email{color:var(--text-primary);font-weight:600}.cred-pw{background:var(--bg-primary);border:1px solid var(--border-light);font-family:var(--font-mono,ui-monospace, monospace);color:var(--brand-violet-bright);letter-spacing:.5px;border-radius:6px;padding:4px 10px;font-size:15px}.cred-hint{color:var(--text-muted);margin-top:6px;font-size:12px}.cred-actions{align-items:center;gap:8px;display:flex}.admin-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px;display:flex}.admin-toolbar input,.admin-toolbar select{background:var(--bg-primary);border:1px solid var(--border-light);color:var(--text-primary);border-radius:8px;padding:8px 12px;font-size:13px}.admin-toolbar input:focus,.admin-toolbar select:focus{border-color:var(--brand-violet);box-shadow:0 0 0 3px var(--brand-glow);outline:none}.admin-search{min-width:220px}.admin-count{color:var(--text-muted);margin-left:auto;font-size:13px}.admin-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.admin-table th.sortable:hover{color:var(--brand-violet-bright)}.role-select{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;border-radius:6px;padding:3px 6px;font-size:12px}.role-select:focus{border-color:var(--brand-violet);outline:none}.pro-toggle{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:999px;padding:3px 12px;font-size:12px;transition:color .15s,border-color .15s,background .15s}.pro-toggle:hover{color:var(--text-primary);border-color:var(--border-light)}.pro-toggle--on{border-color:var(--brand-violet);color:var(--brand-violet-bright);background:#6c63ff2e;font-weight:600}.account-page{max-width:640px;min-height:100vh;color:var(--text-primary);margin:0 auto;padding:40px 24px 80px}.account-head{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.account-head h1{font-size:24px}.account-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;margin-bottom:18px;padding:22px 24px}.account-card h2{margin:0 0 14px;font-size:16px}.account-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:16px;padding:11px 0;display:flex}.account-row:last-child{border-bottom:none}.account-row .lbl{color:var(--text-secondary);font-size:13px}:root{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--bg-card:#1e293b;--bg-hover:#334155;--accent:#6c63ff;--accent-hover:#4f46e5;--accent-glow:#6c63ff4d;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#8b9bb4;--border:#334155;--border-light:#475569;--radius:12px;--radius-sm:8px;--radius-lg:16px;--shadow:0 4px 6px -1px #0000004d, 0 2px 4px -2px #0003;--shadow-lg:0 10px 15px -3px #0006, 0 4px 6px -4px #0000004d;--transition:.2s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.titlebar{background:var(--bg-secondary);border-bottom:1px solid var(--border);-webkit-app-region:drag;flex-shrink:0;justify-content:space-between;align-items:center;height:40px;padding:0 12px;display:flex}.titlebar-left{align-items:center;gap:10px;display:flex}.titlebar-logo{width:22px;height:22px;color:var(--accent)}.titlebar-title{color:var(--text-secondary);letter-spacing:.5px;font-size:13px;font-weight:600}.titlebar-controls{-webkit-app-region:no-drag;gap:2px;display:flex}.titlebar-btn{width:36px;height:28px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;display:flex}.titlebar-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.titlebar-btn.close:hover{background:var(--danger);color:#fff}.app-layout{height:calc(100vh - 40px);display:flex}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:280px;display:flex}.sidebar-header{border-bottom:1px solid var(--border);padding:20px}.sidebar-header h2{text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:12px;font-size:14px;font-weight:700}.open-pdf-btn{background:linear-gradient(135deg, var(--accent), #6366f1);color:#fff;border-radius:var(--radius-sm);cursor:pointer;width:100%;transition:all var(--transition);box-shadow:0 2px 8px var(--accent-glow);border:none;justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:600;display:flex}.open-pdf-btn:hover{box-shadow:0 4px 16px var(--accent-glow);transform:translateY(-1px)}.open-pdf-btn:active{transform:translateY(0)}.sidebar-files{flex:1;padding:12px;overflow-y:auto}.file-item{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);align-items:center;gap:10px;margin-bottom:4px;padding:10px 12px;display:flex}.file-item:hover{background:var(--bg-hover)}.file-item.active{background:#6c63ff26;border:1px solid #6c63ff4d}.file-item-icon{color:var(--danger);flex-shrink:0}.file-item-info{flex:1;min-width:0}.file-item-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.file-item-size{color:var(--text-muted);margin-top:2px;font-size:11px}.file-item-remove{opacity:0;color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:4px;padding:4px}.file-item:hover .file-item-remove,.file-item:focus-within .file-item-remove,.file-item-remove:focus-visible{opacity:1}.file-item-remove:hover{color:var(--danger);background:#ef44441a}.main-content{flex-direction:column;flex:1;min-width:0;display:flex}.toolbar{background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;padding:12px 20px;display:flex}.toolbar-group{background:var(--bg-primary);border-radius:var(--radius-sm);align-items:center;gap:4px;padding:2px;display:flex}.toolbar-btn{color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:6px 10px;display:flex}.toolbar-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.toolbar-btn.active{background:var(--accent);color:#fff}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.toolbar-btn:disabled:hover{color:var(--text-secondary);background:0 0}.toolbar-separator{background:var(--border);width:1px;height:24px}.page-info{color:var(--text-secondary);text-align:center;min-width:100px;font-size:13px;font-weight:500}.zoom-display{color:var(--text-muted);text-align:center;min-width:50px;font-size:12px;font-weight:500}.toolbar-spacer{flex:1}.extract-btn{background:linear-gradient(135deg, var(--success), #059669);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);border:none;align-items:center;gap:6px;padding:8px 18px;font-size:13px;font-weight:600;display:flex;box-shadow:0 2px 8px #10b9814d}.extract-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b98166}.extract-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.status-banner{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;font-size:13px;display:flex}.status-banner--error{color:#fecaca;background:#ef44441f;border-bottom-color:#ef444459}.status-banner--empty{color:#fde68a;background:#f59e0b1f;border-bottom-color:#f59e0b59}.status-banner-close{color:inherit;cursor:pointer;opacity:.7;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:14px;line-height:1}.status-banner-close:hover{opacity:1;background:#ffffff1a}.content-area{flex:1;display:flex;overflow:hidden}.pdf-viewer{background:var(--bg-primary);flex-direction:column;flex:1;align-items:flex-start;gap:16px;padding:24px;display:flex;overflow:auto}.pdf-page-wrapper{border-radius:var(--radius);box-shadow:var(--shadow-lg);background:#fff;flex-shrink:0;position:relative;overflow:visible}.pdf-page-wrapper canvas{display:block}.empty-state{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.empty-icon{border:2px dashed var(--border);background:linear-gradient(135deg,#6c63ff1a,#6366f11a);border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;margin-bottom:24px;display:flex}.empty-icon svg{width:48px;height:48px;color:var(--accent)}.empty-state h2{color:var(--text-primary);margin-bottom:8px;font-size:22px;font-weight:700}.empty-state p{color:var(--text-muted);max-width:400px;font-size:14px;line-height:1.6}.empty-state .open-pdf-btn{width:auto;margin-top:24px;padding:14px 28px;font-size:15px}.data-panel{background:var(--bg-secondary);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;width:380px;display:flex}.data-panel-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.data-panel-header h3{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-size:14px;font-weight:700}.data-panel-tabs{border-bottom:1px solid var(--border);padding:0 12px;display:flex}.data-panel-tab{color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 16px;font-size:13px;font-weight:500}.data-panel-tab:hover{color:var(--text-secondary)}.data-panel-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.data-panel-content{flex:1;padding:16px;overflow-y:auto}.pile-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);margin-bottom:12px;padding:16px}.pile-card:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-glow)}.pile-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.pile-card-id{color:var(--accent);font-size:15px;font-weight:700}.pile-card-status{text-transform:uppercase;letter-spacing:.5px;border-radius:12px;padding:3px 10px;font-size:11px;font-weight:600}.pile-card-status.complete{color:var(--success);background:#10b98126}.pile-card-status.partial{color:var(--warning);background:#f59e0b26}.pile-card-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.pile-field{flex-direction:column;gap:2px;display:flex}.pile-field-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:10px;font-weight:600}.pile-field-value{color:var(--text-primary);font-size:13px;font-weight:500}.summary-section{margin-bottom:20px}.summary-section h4{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:12px;font-size:12px;font-weight:700}.summary-stats{grid-template-columns:1fr 1fr;gap:10px;display:grid}.stat-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;padding:14px}.stat-value{color:var(--accent);font-size:24px;font-weight:800;line-height:1}.stat-label{color:var(--text-muted);margin-top:4px;font-size:11px;font-weight:500}.text-content{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;max-height:100%;padding:16px;font-size:13px;line-height:1.7}.text-content .diag-section{border-radius:var(--radius);border:1px solid #334155;margin-bottom:12px;overflow:hidden}.text-content .diag-title{color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;background:#1e293b;border-bottom:1px solid #334155;padding:6px 12px;font-size:11px;font-weight:600}.text-content .diag-content{background:var(--bg-primary);color:#64748b;white-space:pre-wrap;word-break:break-all;max-height:260px;margin:0;padding:10px 12px;font-family:Cascadia Code,Fira Code,monospace;font-size:11px;line-height:1.6;overflow-y:auto}.loading-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172acc;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-secondary);margin-top:16px;font-size:14px;font-weight:500}.export-btn{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:500;display:flex}.export-btn:hover{border-color:var(--accent);color:var(--accent)}.export-btn+.export-btn{margin-left:8px}.search-box{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);transition:all var(--transition);align-items:center;gap:8px;padding:6px 12px;display:flex}.search-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.search-box input{color:var(--text-primary);background:0 0;border:none;outline:none;width:200px;font-family:inherit;font-size:13px}.search-box input::placeholder{color:var(--text-muted)}.search-box svg{color:var(--text-muted);flex-shrink:0}.no-data{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;display:flex}.no-data svg{color:var(--text-muted);margin-bottom:12px}.no-data p{color:var(--text-muted);font-size:13px;line-height:1.5}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.pile-card{animation:.3s ease-out fadeIn}.pile-number-badge{background:var(--bg-primary);border:1px solid var(--border);min-width:36px;height:28px;color:var(--text-primary);cursor:default;transition:all var(--transition);border-radius:6px;justify-content:center;align-items:center;padding:0 8px;font-size:12px;font-weight:600;display:inline-flex}.pile-number-badge:hover{border-color:var(--accent);color:var(--accent);background:#6c63ff1a}.pile-number-badge.selected{border-color:var(--accent);background:var(--accent);color:#fff;box-shadow:0 0 0 3px var(--accent-glow)}.pile-card.selected{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.pile-highlight-marker{pointer-events:none;z-index:10;position:absolute;transform:translate(-50%,-50%)}.pile-category-marker{pointer-events:none;z-index:8;flex-direction:column;align-items:center;display:flex;position:absolute;transform:translate(-50%,-50%)}.pile-category-dot{background:#fbbf24d9;border:2px solid #f59e0b;border-radius:50%;width:18px;height:18px;animation:2s ease-in-out infinite category-pulse;box-shadow:0 0 6px #f59e0b99}@keyframes category-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.75;transform:scale(1.25)}}.category-header{cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition);margin:-4px -6px;padding:4px 6px}.category-header:hover{background:#6c63ff12}.category-header--active{background:#f59e0b1f;border-left:3px solid #f59e0b;padding-left:8px}.category-header--active h4 span:first-child{color:#f59e0b}.pile-highlight-ring{border:3px solid var(--accent);width:64px;height:64px;box-shadow:0 0 16px var(--accent-glow), inset 0 0 10px var(--accent-glow);border-radius:50%;animation:1.5s ease-in-out infinite pile-pulse}.pile-highlight-label{background:var(--accent);color:#fff;white-space:nowrap;border-radius:4px;padding:3px 10px;font-size:13px;font-weight:700;position:absolute;top:-28px;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #0000004d}@keyframes pile-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}.pdf-page-wrapper--add-mode,.pdf-page-wrapper--category-mode{cursor:crosshair}.add-pile-overlay{cursor:crosshair;z-index:20;border-radius:var(--radius);background:#6c63ff0d;border:2px dashed #6c63ff66;position:absolute;inset:0}.category-area-overlay{z-index:22;cursor:crosshair;border-radius:var(--radius);background:#10b9810a;border:2px dashed #10b98159;position:absolute;inset:0}.category-area-selection-preview{pointer-events:none;background:#10b98138;border:2px solid #10b981f2;position:absolute;box-shadow:inset 0 0 0 1px #0f172a66}.pdf-page-wrapper--symbol-mode{cursor:crosshair}.symbol-select-overlay{z-index:25;cursor:crosshair;border-radius:var(--radius);background:#0ea5e90a;border:1px dashed #0ea5e959;position:absolute;inset:0}.symbol-selection-preview{background:#0ea5e92e;border:2px dashed #0ea5e9;position:absolute}.symbol-template-box{z-index:30;pointer-events:none;background:#f59e0b24;border:2px dashed #f59e0b;position:absolute}.symbol-match-box{z-index:21;cursor:pointer;transition:all var(--transition);background:#10b9811f;border:2px solid #10b981;padding:0;position:absolute}.symbol-match-box:hover{background:#10b98133}.symbol-match-box.removed{opacity:.7;background:#ef444426;border-color:#ef4444}.symbol-match-score{color:#fff;background:#0f172a;border-radius:3px;padding:1px 4px;font-size:10px;font-weight:700;position:absolute;top:-18px;left:0}.add-pile-btn{background:var(--bg-primary);border:1px dashed var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);align-items:center;gap:6px;padding:8px 12px;font-size:13px;font-weight:500;display:flex}.add-pile-btn:hover{border-color:var(--accent);color:var(--accent);background:#6c63ff0d}.add-pile-btn--active{border-color:var(--accent);color:var(--accent);background:#6c63ff1a;animation:2s ease-in-out infinite add-pile-pulse}@keyframes add-pile-pulse{0%,to{box-shadow:0 0 #6c63ff4d}50%{box-shadow:0 0 0 4px #6c63ff1a}}.add-cat-form{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:7px;margin-top:8px;padding:12px;display:flex}.add-cat-row{flex-direction:column;gap:3px;display:flex}.add-cat-row label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;font-size:11px;font-weight:600}.add-cat-row input{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);transition:border-color var(--transition);outline:none;padding:5px 8px;font-family:inherit;font-size:13px}.add-cat-row input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}.pile-relocate-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;z-index:20;border:none;border-radius:4px;padding:1px 8px;font-size:13px;font-weight:700;line-height:1.6;position:absolute;bottom:-22px;left:50%;transform:translate(-50%);box-shadow:0 2px 6px #0006}.pile-relocate-btn:hover{background:var(--accent-hover,#0062b1)}.pile-relocate-popup{background:var(--surface-2,#1e2535);border:1px solid var(--border,#2d3652);z-index:100;white-space:nowrap;border-radius:6px;min-width:120px;margin-top:26px;padding:4px 0;position:absolute;top:100%;left:50%;transform:translate(-50%);box-shadow:0 6px 24px #0000008c}.pile-relocate-title{color:var(--text-secondary,#8892aa);text-transform:uppercase;letter-spacing:.5px;padding:4px 10px 2px;font-size:10px;font-weight:600}.pile-relocate-item{cursor:pointer;width:100%;color:var(--text-primary,#e0e6f0);text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:5px 10px;font-size:12px;display:flex}.pile-relocate-item:hover,.pile-relocate-item.focused{background:var(--surface-3,#252d43);outline:none}.pile-relocate-item--danger{color:#ff8d8d}.pile-relocate-item--danger:hover,.pile-relocate-item--danger.focused{color:#ffb3b3;background:#ff636324}.pile-relocate-code{font-weight:700}.pile-relocate-afm{color:var(--text-secondary,#8892aa);font-size:10px}.correction-dropdown{z-index:100;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;min-width:120px;margin-top:4px;padding:6px;position:absolute;top:100%;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #0006}.correction-dropdown-title{color:var(--text-secondary);border-bottom:1px solid var(--border);margin-bottom:4px;padding:4px 8px 6px;font-size:10px}.correction-dropdown-item{width:100%;color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:space-between;align-items:center;gap:8px;padding:6px 10px;font-size:12px;font-weight:600;transition:background .15s;display:flex}.correction-dropdown-item:hover{background:var(--accent);color:#fff}.correction-dropdown-item--danger{color:#ff8d8d}.correction-dropdown-item--danger:hover{color:#ffb3b3;background:#ff636324}.correction-dropdown-item:hover span{color:#ffffffb3!important}.correction-select{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;border-radius:4px;outline:none;padding:2px 4px;font-size:10px;font-weight:600;transition:border-color .15s}.correction-select:hover,.correction-select:focus{border-color:var(--accent)}.correction-clear-btn{border:1px solid var(--warning);color:var(--warning);cursor:pointer;background:0 0;border-radius:4px;padding:3px 10px;font-size:11px;transition:all .15s}.correction-clear-btn:hover{background:var(--warning);color:#fff}.category-delete-btn{cursor:pointer;opacity:.55;color:var(--text-secondary);background:0 0;border:none;border-radius:4px;align-items:center;padding:3px 5px;font-size:13px;line-height:1;transition:opacity .15s,background .15s,color .15s;display:flex}.category-delete-btn:hover{opacity:1;color:#ef4444;background:#ef444426}.search-overlay{z-index:1000;background:0 0;position:fixed;inset:0}.search-popup{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius);width:380px;position:absolute;top:60px;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 8px 32px #00000059}.search-input-row{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:10px 12px;display:flex}.search-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-size:14px}.search-input::placeholder{color:var(--text-secondary)}.search-close-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:14px;line-height:1}.search-close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.search-results{max-height:280px;overflow-y:auto}.search-result-item{cursor:pointer;align-items:center;gap:10px;padding:8px 14px;transition:background .1s;display:flex}.search-result-item:hover,.search-result-item.focused{background:var(--bg-secondary)}.search-result-code{color:var(--accent);text-align:center;background:#6c63ff1a;border-radius:4px;min-width:32px;padding:2px 6px;font-size:11px;font-weight:700}.search-result-num{color:var(--text-primary);flex:1;font-size:13px;font-weight:600}.search-result-page{color:var(--text-secondary);font-size:11px}.search-no-results{text-align:center;color:var(--text-secondary);padding:14px;font-size:13px}.search-highlight{color:inherit;background:#f59e0b66;border-radius:2px;padding:0 1px}.search-target-marker{pointer-events:none;z-index:10;border:3px solid #f59e0b;border-radius:50%;width:48px;height:48px;animation:2s ease-out forwards search-flash;position:absolute;transform:translate(-50%,-50%)}@keyframes search-flash{0%{opacity:1;transform:translate(-50%,-50%)scale(.5)}30%{opacity:1;transform:translate(-50%,-50%)scale(1.2)}to{opacity:0;transform:translate(-50%,-50%)scale(1.8)}}.confirm-dialog-overlay{z-index:9999;background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-dialog{background:var(--bg-secondary,#1e2233);border:1px solid var(--border,#2a3050);border-radius:12px;min-width:300px;max-width:400px;padding:24px 28px;box-shadow:0 12px 40px #00000080}.confirm-dialog-title{color:var(--text-primary);margin:0 0 8px;font-size:16px;font-weight:700}.confirm-dialog-body{color:var(--text-secondary);margin:0 0 20px;font-size:13px}.confirm-dialog-actions{justify-content:flex-end;gap:10px;display:flex}.confirm-dialog-cancel{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;border-radius:6px;padding:7px 16px;font-size:13px}.confirm-dialog-cancel:hover{background:var(--bg-hover,#2a3050)}.confirm-dialog-confirm{color:#fff;cursor:pointer;background:#c0392b;border:none;border-radius:6px;padding:7px 16px;font-size:13px;font-weight:600}.confirm-dialog-confirm:hover{background:#e74c3c}
