*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:#fff;color:#0f172a;font:14.5px/1.55 ui-sans-serif,system-ui,-apple-system,Segoe UI,Inter,Roboto,Helvetica,Arial}.shell{min-height:100vh;display:flex;flex-direction:column;overflow:hidden}.top{display:flex;align-items:center;justify-content:center;padding:14px 18px;margin:18px;border-radius:16px;background:#e0f2fe;border:1px solid #bae6fd;box-shadow:0 8px 20px #0ea5e940}.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.2px}.gem{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#2563eb,#6d28d9);box-shadow:0 10px 22px #2563eb40}.top-actions .chip{padding:6px 12px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;color:#0f172a}.layout{height:calc(100vh + -0px);display:grid;grid-template-columns:340px 1fr;gap:20px;padding:18px;overflow:hidden}.side,.center{min-height:0;overflow:auto}.card,.panel{padding:14px;border-radius:14px;background:#fff;border:1px solid #e5e7eb;box-shadow:0 8px 24px #0f172a0d}.card-title,.panel-title{display:flex;align-items:center;gap:8px;font-weight:700;margin-bottom:10px}.placeholder{color:#6b7280;font-style:italic}.dropzone{position:relative;padding:22px;text-align:center;border-radius:14px;background:#fff;border:2px dashed #d1d5db}.dropzone.drag{outline:3px solid rgba(99,102,241,.3)}.filepick{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.dz-icons{display:flex;justify-content:center;gap:8px;margin-bottom:8px}.dz-i{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;color:#fff}.purple{background:linear-gradient(135deg,#8b5cf6,#6d28d9)}.blue{background:linear-gradient(135deg,#60a5fa,#2563eb)}.green{background:linear-gradient(135deg,#34d399,#16a34a)}.dz-title{font-weight:800;letter-spacing:.2px}.dz-sub{color:#6b7280;margin-top:2px}.dz-hint{color:#94a3b8;font-size:12px;margin-top:6px}.row{display:flex;align-items:center;gap:10px}.file-row{justify-content:space-between;padding:10px;border-radius:10px;background:#f8fafc}.fname{max-width:190px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fmeta{color:#6b7280;font-size:12px}.ghost{background:none;border:none;color:#9ca3af;cursor:pointer}.ghost:hover,.pdf{color:#ef4444}.img{color:#10b981}.panel.warn{background:#fff7ed;border-color:#fdba74}.warn-row{color:#b45309}.panel.error{background:#fee2e2;border-color:#f87171}.paper{padding:12px}.textblock{white-space:pre-wrap;max-height:300px;overflow:auto;border-radius:10px;background:#f3f4f6;padding:12px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.center{display:grid;gap:14px;align-content:start}.center-head{display:flex;align-items:center;justify-content:space-between}.center-head h2{margin:0;font-size:18px}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:10px;cursor:pointer;font-weight:700;border:1px solid #e5e7eb;background:#fff}.btn-dark{background:#111827;color:#f9fafb;border-color:#111827}.insights{display:grid;gap:14px}.insights .card.big .panel.soft{max-height:180px;overflow:auto}.tags{display:flex;gap:8px;flex-wrap:wrap}.tag{padding:6px 10px;border-radius:999px;color:#111827;background:linear-gradient(135deg,#e0e7ff,#dbeafe);border:1px solid #c7d2fe}.tips{display:grid;gap:8px}.tip{display:flex;gap:10px;padding:10px;border-radius:10px;background:#ecfdf5;border:1px solid #a7f3d0}.bubble{width:24px;height:24px;border-radius:8px;display:grid;place-items:center;background:#bbf7d0;color:#064e3b;font-weight:800}.caption{margin:0}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;display:grid;place-items:center;background:#00000047;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.overlay-card{width:min(720px,92vw);background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 24px 80px #00000040;padding:18px}.overlay-row{display:flex;align-items:center;gap:16px}.ring{width:44px;height:44px;border-radius:50%;position:relative}.ring:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:4px solid #e5e7eb}.ring-spin{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:4px solid transparent;border-top-color:#2563eb;border-right-color:#6d28d9;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.overlay-body{flex:1;min-width:0}.overlay-title{font-weight:700;font-size:16px;color:#0f172a}.overlay-msg{color:#374151;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.overlay-bar{height:8px;margin-top:10px;border-radius:999px;background:#e5e7eb;overflow:hidden}.overlay-fill{height:100%;background:linear-gradient(90deg,#2563eb,#6d28d9)}.overlay-sub{color:#6b7280;font-size:12px;margin-top:4px}.overlay-stages{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:14px}.ov-stage{text-align:center;font-size:12px;color:#6b7280}.ov-dot{width:28px;height:28px;margin:0 auto 6px;border-radius:50%;display:grid;place-items:center;background:#f3f4f6;font-weight:700;color:#111827}.ov-dot.active{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff}.ov-dot.done{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.ov-label.on{color:#4f46e5}
