*{margin:0;padding:0;box-sizing:border-box}body{font-family:system-ui,-apple-system,sans-serif;min-height:100vh;background-color:#f5f5f5;color:#1a1a1a}main{max-width:1200px;margin:0 auto;padding:2rem}h1{font-size:2rem;font-weight:600;margin-bottom:2rem}h2{font-size:1.4rem;font-weight:500;margin-bottom:1rem}section{margin-bottom:2rem;background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;margin-top:.5rem;min-width:600px}th,td{text-align:left;padding:.5rem .75rem;border-bottom:1px solid #eee}th{font-weight:600;color:#555;font-size:.85rem;text-transform:uppercase}input[type=text]{padding:.5rem .75rem;border:1px solid #ccc;border-radius:4px;font-size:.95rem;width:100%;max-width:400px;margin-bottom:1rem}button{padding:.4rem 1rem;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;margin:.5rem .25rem}button:disabled{opacity:.4;cursor:default}table.dense th,table.dense td{padding:.25rem .5rem;font-size:.82rem;line-height:1.3}table.dense th{font-size:.72rem}table.dense tbody tr{cursor:pointer;transition:background-color .1s}table.dense tbody tr:hover{background-color:#f0f4ff}table.dense tbody tr.selected{background-color:#e0e8ff}.catalog-layout{display:flex;gap:1rem}.catalog-results{flex:1;min-width:0}.pagination{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;font-size:.82rem}.detail-pane{width:320px;flex-shrink:0;background:#fafbfc;border:1px solid #e0e0e0;border-radius:6px;padding:1rem;font-size:.82rem;align-self:flex-start;position:sticky;top:1rem}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.detail-header h3{margin:0;font-size:.95rem;font-weight:600}.close-btn{border:none;background:none;font-size:1rem;cursor:pointer;padding:.1rem .3rem;line-height:1;color:#666}.close-btn:hover{color:#000}.detail-grid{display:grid;grid-template-columns:auto 1fr;gap:.25rem .75rem}.detail-grid dt{font-weight:600;color:#555;white-space:nowrap}.detail-grid dd{margin:0;word-break:break-word}.detail-grid a{color:#2563eb;text-decoration:none}@media(max-width:768px){.detail-pane{position:fixed;inset:auto 0 0;width:100%;max-height:60vh;overflow-y:auto;border-radius:12px 12px 0 0;box-shadow:0 -4px 20px #00000026;z-index:100}}.detail-grid a:hover{text-decoration:underline}
