*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--surface:#1a1d27;--surface-2:#222535;--border:#2e3248;--accent:#6c63ff;--accent-dim:#3d3880;--accent-hover:#857dff;--success:#3ecf8e;--warning:#f6a623;--danger:#e05252;--text:#e8eaf6;--text-muted:#7b82a8;--text-dim:#4a5070;--font-mono:"JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--radius:8px;--radius-lg:12px}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5}.app{grid-template:"header header""sidebar main"1fr/320px 1fr;min-height:100vh;display:grid}.header{background:var(--surface);border-bottom:1px solid var(--border);grid-area:header;align-items:center;gap:16px;height:56px;padding:0 24px;display:flex}.header-logo{align-items:center;gap:10px;display:flex}.header-logo svg{flex-shrink:0}.header-title{letter-spacing:-.3px;color:var(--text);font-size:17px;font-weight:700}.header-subtitle{color:var(--text-muted);font-size:12px}.header-sep{background:var(--border);width:1px;height:28px;margin:0 4px}.badge{background:var(--accent-dim);color:var(--accent-hover);letter-spacing:.3px;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;grid-area:sidebar;display:flex;overflow-y:auto}.sidebar-section{border-bottom:1px solid var(--border);padding:20px}.sidebar-section:last-child{border-bottom:none}.section-label{letter-spacing:.8px;text-transform:uppercase;color:var(--text-dim);margin-bottom:12px;font-size:11px;font-weight:700}.endpoint-group{flex-direction:column;gap:8px;display:flex}.input-wrapper{position:relative}.input-wrapper svg{color:var(--text-dim);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.endpoint-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);font-family:var(--font-mono);outline:none;padding:9px 10px 9px 34px;font-size:12px;transition:border-color .15s}.endpoint-input::placeholder{color:var(--text-dim)}.endpoint-input:focus{border-color:var(--accent)}.field-row{flex-direction:column;gap:4px;display:flex}.field-label{color:var(--text-muted);font-size:11px}.field-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);font-family:var(--font-mono);outline:none;padding:8px 10px;font-size:12px;transition:border-color .15s}.field-input::placeholder{color:var(--text-dim)}.field-input:focus{border-color:var(--accent)}.autocomplete,.autocomplete-input-wrap{position:relative}.autocomplete-input-wrap .field-input{padding-right:30px}.autocomplete-adornment{color:var(--text-dim);pointer-events:none;align-items:center;display:flex;position:absolute;top:50%;right:9px;transform:translateY(-50%)}.autocomplete-chevron{transition:transform .15s;display:flex}.autocomplete-chevron.flipped{transform:rotate(180deg)}.autocomplete-dropdown{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);z-index:100;max-height:220px;list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #0006}.autocomplete-option{font-size:12px;font-family:var(--font-mono);color:var(--text-muted);cursor:pointer;text-overflow:ellipsis;white-space:nowrap;padding:7px 10px;transition:background .1s,color .1s;overflow:hidden}.autocomplete-option.highlighted{background:var(--accent-dim);color:var(--text)}.autocomplete-error{color:var(--danger);margin-top:6px;font-size:11px}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:.8s linear infinite spin}.main{flex-direction:column;grid-area:main;display:flex;overflow:hidden}.tabs-bar{background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:0;padding:0 24px;display:flex;overflow-x:auto}.tab-btn{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;padding:14px 16px 12px;font-size:13px;transition:color .15s,border-color .15s;display:flex}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--accent-hover);border-bottom-color:var(--accent)}.tab-count{background:var(--surface-2);color:var(--text-muted);border-radius:10px;padding:1px 6px;font-size:11px}.tab-btn.active .tab-count{background:var(--accent-dim);color:var(--accent-hover)}.output-area{flex-direction:column;flex:1;display:flex;overflow:hidden}.output-toolbar{background:var(--surface-2);border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:10px 24px;display:flex}.output-toolbar-left{flex:1;align-items:center;gap:8px;display:flex}.output-info{color:var(--text-muted);font-size:12px;font-family:var(--font-mono)}.status-dot{background:var(--text-dim);border-radius:50%;width:7px;height:7px}.status-dot.ready{background:var(--success);box-shadow:0 0 6px var(--success)}.status-dot.loading{background:var(--warning);animation:1s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.toolbar-btn{background:var(--surface);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;border-radius:6px;align-items:center;gap:5px;padding:5px 10px;font-size:12px;transition:background .12s,color .12s,border-color .12s;display:flex}.toolbar-btn:hover{background:var(--surface-2);border-color:var(--accent);color:var(--text)}.toolbar-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent-hover)}.toolbar-btn.danger:hover{border-color:var(--danger);color:var(--danger)}.code-output{flex:1;padding:20px 24px;overflow-y:auto}.code-block{font-family:var(--font-mono);color:var(--text);white-space:pre;font-size:13px;line-height:1.7;overflow-x:auto}.t-prefix{color:#7b9ef0}.t-keyword{color:var(--accent-hover)}.t-iri{color:#3ecf8e}.t-string{color:#f6a623}.t-comment{color:var(--text-dim);font-style:italic}.t-datatype{color:#e07de0}.empty-state{color:var(--text-muted);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:48px;display:flex}.empty-icon{opacity:.25}.empty-title{color:var(--text-muted);font-size:16px;font-weight:600}.empty-desc{color:var(--text-dim);max-width:320px;font-size:13px;line-height:1.6}.predicates-list{flex:1;overflow:auto}.predicates-table{border-collapse:separate;border-spacing:0;white-space:nowrap}.predicates-table th{letter-spacing:.7px;text-transform:uppercase;color:var(--text-dim);background:var(--surface);border-bottom:1px solid var(--border);z-index:1;text-align:left;padding:9px 14px;font-size:10px;font-weight:700;position:sticky;top:0}.predicates-table th+th{border-left:1px solid var(--border)}.predicates-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:8px 14px}.predicates-table td+td{border-left:1px solid var(--border)}.predicates-table tbody tr:last-child td{border-bottom:none}.predicates-table tbody tr:hover td{background:var(--surface-2)}.predicates-table th.num,.predicates-table td.num{text-align:right;font-family:var(--font-mono);color:var(--text-muted)}.predicate-uri{font-family:var(--font-mono);color:#3ecf8e}.predicate-datatypes{gap:4px;display:flex}.datatype-badge{font-family:var(--font-mono);color:#e07de0;white-space:nowrap;background:#e07de022;border-radius:4px;flex-shrink:0;padding:2px 7px;font-size:11px}.datatype-badge.iri{color:var(--accent-hover);background:#6c63ff22}.datatype-badge.literal{color:#3ecf8e;background:#3ecf8e22}.datatype-badge.unknown{color:var(--text-dim);background:0 0}.shin-toggle{border-radius:7px;flex-shrink:0;width:24px;height:13px;transition:background .15s;display:inline-block;position:relative}.shin-toggle:after{content:"";border-radius:50%;width:9px;height:9px;transition:left .15s,background .15s;position:absolute;top:2px}.shin-toggle.off{background:var(--surface-2);border:1px solid var(--border);cursor:pointer}.shin-toggle.off:after{background:var(--text-dim);left:2px}.shin-toggle.off:hover{border-color:var(--warning)}.shin-toggle.off:hover:after{background:var(--warning)}.shin-toggle.on{background:var(--warning);cursor:pointer;border:1px solid #0000}.shin-toggle.on:after{background:#fff;left:12px}.shin-toggle.on:hover{background:var(--text-dim)}.shin-value{align-items:center;gap:5px;display:inline-flex}.datatype-badge.shin{color:var(--warning);background:#f6a62322}.datatype-badge.error{color:var(--danger);background:#e0525222}.class-picker{flex-direction:column;gap:8px;display:flex}.class-chips{flex-wrap:wrap;gap:5px;display:flex}.class-chip{background:var(--accent-dim);border-radius:20px;align-items:center;gap:5px;max-width:100%;padding:3px 8px 3px 9px;display:inline-flex}.class-chip-label{font-size:11px;font-family:var(--font-mono);color:var(--accent-hover);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.class-chip-remove{cursor:pointer;color:var(--accent-hover);opacity:.6;background:0 0;border:none;flex-shrink:0;align-items:center;padding:0;display:flex}.class-chip-remove:hover{opacity:1}.add-all-btn{border:1px dashed var(--border);border-radius:var(--radius);width:100%;color:var(--text-dim);cursor:pointer;text-align:center;background:0 0;padding:7px 10px;font-size:12px;transition:border-color .15s,color .15s}.add-all-btn:hover{border-color:var(--accent);color:var(--text)}.start-again-btn{border:1px dashed var(--border);border-radius:var(--radius);width:100%;color:var(--text-dim);cursor:pointer;text-align:center;background:0 0;padding:7px 10px;font-size:12px;transition:border-color .15s,color .15s}.start-again-btn:hover{color:#e05c5c;border-color:#e05c5c}.class-header-row td{background:var(--surface);border-bottom:1px solid var(--border);border-top:2px solid var(--border);padding:8px 14px}.class-header-row:first-child td{border-top:none}.class-row-uri{font-family:var(--font-mono);color:var(--accent-hover);margin-right:8px;font-size:12px;font-weight:600}.class-row-meta{color:var(--text-dim);margin-left:8px;font-size:11px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}
