:root{font-family:Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;color:#111827;background-color:#f8fafc}body,html{margin:0;padding:0;min-height:100vh;background:linear-gradient(135deg,#dbeafe,#fef3c7)}.app-shell{max-width:960px;margin:0 auto;padding:1.25rem 1rem 2.5rem;display:flex;flex-direction:column;gap:1.25rem}.hero{text-align:center;padding:1.25rem 1rem;background:rgba(255,255,255,.85);border-radius:18px;box-shadow:0 8px 30px rgba(15,23,42,.12)}.tabs{margin-top:1rem;display:inline-flex;gap:.5rem;padding:.25rem;border-radius:999px;background:rgba(15,23,42,.06)}.tabs button{border:none;background:transparent;padding:.5rem 1rem;border-radius:999px;cursor:pointer;font-weight:500;color:#374151}.tabs button.active{background:#111827;color:#f9fafb}.upload-panel{display:flex;flex-direction:column;gap:.75rem;padding:1rem .9rem;background:#fff;border-radius:18px;box-shadow:0 10px 40px rgba(15,23,42,.08)}.actions-row{display:flex;flex-direction:column;gap:.5rem}.field{display:flex;flex-direction:column;gap:.4rem}.field label{font-weight:600;font-size:.95rem}.field select,.field input[type=file]{padding:.65rem .75rem;border-radius:12px;border:1px solid #cbd5f5;font-size:.95rem}.hint{font-size:.8rem;color:#475569}button.primary{padding:.8rem 1.3rem;border-radius:999px;border:none;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;font-weight:600;cursor:pointer;transition:opacity .2s ease;width:100%}button.primary:disabled{opacity:.5;cursor:not-allowed}.progress{width:100%;height:10px;border-radius:999px;background:#e2e8f0;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(135deg,#34d399,#10b981);transition:width .2s ease}.error{color:#b91c1c}.results{padding:1rem .9rem;background:#fff;border-radius:18px;box-shadow:0 10px 40px rgba(15,23,42,.08)}.results ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.results li{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;padding:.6rem .75rem;border-radius:12px;border:1px solid #e2e8f0}.results li strong{font-size:.9rem;word-break:break-all}.results li small{font-size:.8rem;color:#6b7280;word-break:break-all}.results li.success{border-color:#86efac;background:#dcfce7}.results li.failure{border-color:#fecaca;background:#fee2e2}.reason{color:#b91c1c;font-size:.85rem}.panel{padding:1.5rem;background:#fff;border-radius:18px;box-shadow:0 10px 40px rgba(15,23,42,.08);display:flex;flex-direction:column;gap:1rem}.field.inline{flex-direction:row;align-items:center;justify-content:flex-start}.field.inline label{margin-right:.75rem}.card{padding:1rem;border-radius:12px;border:1px solid #e5e7eb;margin-top:.5rem}.card ul{list-style:none;margin:.5rem 0 0;padding:0}.card li{display:flex;justify-content:space-between;font-size:.9rem;padding:.25rem 0}.card small{color:#6b7280}.stats-table{width:100%;border-collapse:collapse;font-size:.95rem}.stats-table th,.stats-table td{padding:.5rem .75rem;border-bottom:1px solid #e5e7eb;text-align:left}.stats-table th{background:#f9fafb;font-weight:600}.records-list{display:flex;flex-direction:column;gap:1rem}.uploader-block{padding:.9rem;border-radius:14px;border:1px solid #e5e7eb}.uploader-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.thumb-grid{display:flex;flex-wrap:nowrap;gap:.6rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.thumb{width:45vw;max-width:150px;min-width:120px;display:flex;flex-direction:column;gap:.2rem;font-size:.8rem;flex-shrink:0}.thumb-image-wrapper{width:100%;aspect-ratio:1;overflow:hidden;border-radius:8px;border:1px solid #e5e7eb;background:#f9fafb;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.thumb-image-wrapper:hover{transform:scale(1.05);box-shadow:0 4px 12px rgba(0,0,0,.15)}.thumb img{width:100%;height:100%;object-fit:cover;display:block}.thumb span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.thumb small{color:#6b7280}.chip-button{border-radius:999px;border:1px solid #d1d5db;padding:.25rem .75rem;font-size:.8rem;background:#f9fafb;color:#374151}.chip-button.danger{border-color:#f97373;color:#b91c1c;background:#fef2f2}.chip-button.danger-outline{align-self:flex-start;border-color:#f97373;color:#b91c1c;background:transparent}.uploader-actions{display:flex;align-items:center;gap:.5rem}.image-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:50}.image-lightbox-inner{max-width:100%;max-height:100%;padding:.75rem;box-sizing:border-box;text-align:center;color:#e5e7eb}.image-lightbox-inner img{max-width:100%;max-height:70vh;border-radius:12px;box-shadow:0 15px 40px rgba(0,0,0,.6)}.image-lightbox-inner p{margin:.5rem 0 .25rem;font-size:.9rem;word-break:break-all}.image-lightbox-tip{font-size:.75rem;opacity:.8}@media (min-width: 768px){.app-shell{padding:2rem 1.5rem 3rem}.upload-panel{padding:1.5rem}button.primary{width:auto;align-self:flex-start}.thumb{width:150px}.results{padding:1.5rem}.results li{flex-direction:row;align-items:center;justify-content:space-between}}
