:root{font-family:Inter,Noto Sans TC,system-ui,-apple-system,sans-serif;color:#1f2937;background:#f3f4f6}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top right,#dbeafe,#f3f4f6 45%)}.page{width:100%;max-width:680px;margin:0 auto;padding:1.25rem 1rem 4rem;display:grid;gap:1rem}.hero h1{margin:.4rem 0 .25rem;font-size:clamp(1.4rem,5vw,2rem);line-height:1.3}.badge{display:inline-block;margin:0;padding:.35rem .75rem;border-radius:999px;background:#dbeafe;color:#1d4ed8;font-weight:600;font-size:.88rem}.subtitle{margin:.25rem 0 0;color:#4b5563;font-size:.9rem;line-height:1.5}.top-nav{display:flex;gap:.5rem;margin-top:.85rem;flex-wrap:wrap}.nav-item{background:#e5e7eb;color:#111827;font-size:.92rem;padding:.55rem 1rem;border-radius:10px;min-height:44px}.nav-item.active{background:#2563eb;color:#fff}.grid{display:grid;gap:1rem;grid-template-columns:1fr}@media(min-width:640px){.grid{grid-template-columns:repeat(2,1fr)}}.card{background:#fffffff2;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 6px 20px #0f172a12;padding:1rem}.card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.actions{display:flex;gap:.5rem;flex-shrink:0}button{border:none;border-radius:10px;background:#2563eb;color:#fff;font-weight:600;font-size:.92rem;padding:.6rem 1rem;min-height:44px;cursor:pointer;-webkit-tap-highlight-color:transparent}button.secondary{background:#6b7280}button:disabled{opacity:.5;cursor:not-allowed}.scanner-box{width:100%;min-height:260px;border:2px dashed #93c5fd;border-radius:14px;margin-top:.75rem;overflow:hidden;background:#f0f7ff}.scanner-video{width:100%;height:auto;display:block;border-radius:12px}.result-box{margin-top:.75rem;border-radius:12px;background:#f8fafc;padding:.75rem}.scan-status{font-weight:700}.scan-status.success{color:#15803d}.scan-status.error{color:#b91c1c}.scan-status.idle{color:#6b7280;font-weight:500}.scan-line1{margin:0;font-size:1rem;font-weight:700}.scan-line2{margin:.25rem 0 0;font-size:.95rem}.scan-line3{margin:.2rem 0 0;font-size:.82rem;color:#64748b;word-break:break-all}.scan-debug-button{margin-top:.5rem;padding:.4rem .75rem;font-size:.85rem;min-height:36px}.debug-box{margin:.6rem 0 0;padding:.65rem;background:#fff7ed;border:1px solid #fdba74;border-radius:10px;white-space:pre-wrap;word-break:break-word;font-size:.8rem}.file-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;border:2px dashed #a3a3a3;border-radius:12px;padding:1.25rem 1rem;cursor:pointer;margin-bottom:.75rem;color:#374151;font-size:.9rem;text-align:center;min-height:80px}.file-dropzone input{width:100%}.file-list{margin:0 0 .5rem;padding-left:1.1rem;color:#374151;font-size:.88rem}.result-list{display:grid;gap:.6rem;margin-top:.75rem}.upload-result{border-left:4px solid #d1d5db;padding:.6rem .75rem;border-radius:0 10px 10px 0;background:#f8fafc}.upload-result.ok{border-left-color:#16a34a}.upload-result.fail{border-left-color:#dc2626}.upload-filename{display:block;font-weight:600;font-size:.85rem;color:#374151;margin-bottom:.2rem;word-break:break-all}.filter-row{display:flex;gap:1.5rem;margin-top:.75rem;flex-wrap:wrap}.filter-col{display:flex;flex-direction:column;gap:.4rem;min-width:80px}.filter-label{font-weight:700;font-size:.82rem;color:#6b7280;letter-spacing:.03em;text-transform:uppercase}.filter-options-vertical{display:flex;flex-direction:column;gap:.3rem}.filter-checkbox{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .75rem;border-radius:8px;background:#f1f5f9;border:1px solid #e2e8f0;cursor:pointer;font-size:.92rem;font-weight:600;color:#334155;transition:background .12s,border-color .12s;min-height:36px;-webkit-tap-highlight-color:transparent}.filter-checkbox:has(input:checked){background:#dbeafe;border-color:#93c5fd;color:#1d4ed8}.filter-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:#2563eb;flex-shrink:0}.record-list{list-style:none;padding:0;margin:.75rem 0 0;display:grid;gap:.65rem}.record-item{padding:.8rem .9rem;border-radius:12px;background:#f8fafc;border:1px solid #e2e8f0;display:grid;gap:.3rem}.record-meta{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.record-tag{font-size:.75rem;font-weight:700;padding:.15rem .5rem;border-radius:999px;background:#e5e7eb;color:#374151;flex-shrink:0}.record-tag.camera{background:#dbeafe;color:#1d4ed8}.record-tag.upload{background:#fef9c3;color:#854d0e}.record-channel{font-weight:700;color:#15803d;font-size:.88rem}.record-store{font-size:.8rem;font-weight:700;color:#6b7280;background:#f1f5f9;padding:.1rem .45rem;border-radius:999px}.record-date{color:#6b7280;font-size:.82rem;margin-left:auto}.record-fields{display:flex;gap:.6rem;flex-wrap:wrap;font-size:.82rem;color:#475569}.record-uid{font-size:.8rem;color:#64748b;word-break:break-all}.record-url a{color:#1d4ed8;word-break:break-all;font-size:.8rem}.record-created{font-size:.75rem;color:#9ca3af}.record-used{opacity:.55}.record-tag.tag-used{background:#dcfce7;color:#15803d}.record-tag.tag-unused{background:#fef3c7;color:#92400e}.record-select{width:18px;height:18px;accent-color:#2563eb;flex-shrink:0;cursor:pointer}.bulk-toolbar{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-top:.75rem}.bulk-actions{display:flex;gap:.4rem;flex-wrap:wrap}.btn-sm{font-size:.82rem;padding:.35rem .7rem;min-height:34px;border-radius:8px}.btn-used{background:#16a34a}.btn-unused{background:#d97706}.btn-danger{background:#dc2626}.filter-checkbox input[type=radio]{width:16px;height:16px;accent-color:#2563eb;flex-shrink:0}.rule-table{width:100%;border-collapse:collapse;margin:.75rem 0 1rem;font-size:.9rem}.rule-table th,.rule-table td{border-bottom:1px solid #e2e8f0;padding:.55rem .4rem;text-align:left;vertical-align:middle}.rule-table th{color:#334155;font-size:.85rem}.rule-table input{border:1px solid #cbd5e1;border-radius:8px;padding:.45rem .55rem;font:inherit;font-size:.9rem;width:100%}.new-rule-row td{padding-top:.75rem}.error{margin-top:.75rem;color:#b91c1c;font-weight:600;font-size:.9rem}.success-msg{margin-top:.75rem;color:#15803d;font-weight:600;font-size:.9rem}.info-card ul{margin:.5rem 0 0;padding-left:1.1rem;font-size:.9rem;line-height:1.7}
