*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f8f9fa;--surface: #ffffff;--border: #dee2e6;--text: #212529;--text-muted: #6c757d;--primary: #0d6efd;--primary-hover: #0b5ed7;--danger: #dc3545;--success: #198754;--warning: #ffc107;--radius: 6px;--shadow: 0 1px 3px rgba(0,0,0,.08)}body{font-family:system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5;color:var(--text);background:var(--bg)}.layout{display:flex;flex-direction:column;min-height:100vh}.nav{background:var(--surface);border-bottom:1px solid var(--border);padding:0 1.5rem;display:flex;align-items:center;gap:1.5rem;height:48px;position:sticky;top:0;z-index:10}.nav-brand{font-weight:700;font-size:15px;color:var(--text);text-decoration:none}.nav a{color:var(--text-muted);text-decoration:none;font-size:13px}.nav a:hover,.nav a.active{color:var(--primary)}.main{flex:1;max-width:1100px;margin:0 auto;width:100%;padding:2rem 1.5rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow)}.card+.card{margin-top:1rem}.card-title{font-size:16px;font-weight:600;margin-bottom:1rem}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .9rem;border:1px solid transparent;border-radius:var(--radius);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--surface);border-color:var(--border);color:var(--text)}.btn-secondary:hover:not(:disabled){background:var(--bg)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#bb2d3b}.btn-sm{padding:.25rem .6rem;font-size:12px}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:13px;font-weight:500;margin-bottom:.35rem}.form-control{width:100%;padding:.4rem .7rem;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;background:var(--surface);color:var(--text)}.form-control:focus{outline:2px solid var(--primary);outline-offset:1px}textarea.form-control{resize:vertical;min-height:180px;font-family:monospace;font-size:12px}.dropzone{border:2px dashed var(--border);border-radius:var(--radius);padding:2.5rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.dropzone:hover,.dropzone.drag-over{border-color:var(--primary);background:#f0f4ff}.dropzone input{display:none}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}th{background:var(--bg);border-bottom:2px solid var(--border);padding:.5rem .75rem;text-align:left;font-weight:600;white-space:nowrap}td{border-bottom:1px solid var(--border);padding:.5rem .75rem}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg)}.tr-clickable{cursor:pointer}.badge{display:inline-block;padding:.15rem .5rem;border-radius:99px;font-size:11px;font-weight:600}.badge-blue{background:#dbeafe;color:#1d4ed8}.badge-green{background:#dcfce7;color:#15803d}.badge-yellow{background:#fef9c3;color:#854d0e}.badge-red{background:#fee2e2;color:#b91c1c}.badge-gray{background:#f3f4f6;color:#4b5563}.alert{padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem;font-size:13px}.alert-error{background:#fee2e2;border:1px solid #fca5a5;color:#b91c1c}.alert-success{background:#dcfce7;border:1px solid #86efac;color:#15803d}.alert-info{background:#dbeafe;border:1px solid #93c5fd;color:#1d4ed8}.alert ul{margin:.25rem 0 0 1.25rem}h1{font-size:22px;font-weight:700;margin-bottom:1rem}h2{font-size:17px;font-weight:600;margin-bottom:.75rem}h3{font-size:14px;font-weight:600;margin-bottom:.5rem}.row{display:flex;gap:1rem;flex-wrap:wrap}.col{flex:1;min-width:0}.text-muted{color:var(--text-muted)}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.gap-1{gap:.5rem}.gap-2{gap:1rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.spinner{display:inline-block;width:16px;height:16px;border:2px solid #ccc;border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.rjsf fieldset{border:none;padding:0;margin:0}.rjsf legend{font-size:14px;font-weight:600;margin-bottom:.5rem;color:var(--text)}.rjsf .field{margin-bottom:.75rem}.rjsf label{display:block;font-size:13px;font-weight:500;margin-bottom:.25rem}.rjsf input,.rjsf select,.rjsf textarea{width:100%;padding:.35rem .65rem;border:1px solid var(--border);border-radius:var(--radius);font-size:13px}.rjsf input:focus,.rjsf select:focus,.rjsf textarea:focus{outline:2px solid var(--primary);outline-offset:1px}.rjsf .btn{display:none}.rjsf .array-item{border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;margin-bottom:.5rem;background:var(--bg)}.rjsf .error-detail{color:var(--danger);font-size:12px;margin-top:.2rem}.matrix-table th{font-size:12px}.matrix-table td{font-size:12px;text-align:center}.avail-native{color:#15803d}.avail-addon{color:#b45309}.avail-marketplace{color:#6d28d9}.avail-absent{color:#9ca3af}.score-bar{display:flex;align-items:center;gap:.5rem}.score-bar-track{flex:1;height:8px;background:var(--border);border-radius:99px;overflow:hidden}.score-bar-fill{height:100%;border-radius:99px;background:var(--primary)}.filters{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center;margin-bottom:1rem}.filters select{padding:.3rem .6rem;border:1px solid var(--border);border-radius:var(--radius);font-size:13px}
