:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Sora,Avenir Next,Segoe UI,sans-serif;font-size:16px;line-height:1.4}*{box-sizing:border-box}html,body,#root{width:100%;min-height:100%;margin:0}.viewer-page{background:radial-gradient(circle at 10% 15%,#f8fbff 0%,#dbe6ee 42%,#b8c8d5 100%);width:100vw;height:100dvh;position:relative;overflow:hidden}.viewer-canvas{width:100%;height:100%}.perf-monitor{color:#f3f6f9;pointer-events:none;background:#10161cd6;border:1px solid #ffffff40;border-radius:10px;width:min(285px,100vw - 28px);padding:10px 12px;font-family:IBM Plex Mono,Courier New,monospace;position:absolute;top:14px;left:14px}.perf-monitor h2{letter-spacing:.05em;text-transform:uppercase;color:#d7e4ef;margin:0 0 8px;font-size:.8rem}.perf-monitor dl{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 10px;margin:0;display:grid}.perf-monitor dl div{border-bottom:1px solid #ffffff1a;margin:0;padding-bottom:4px}.perf-monitor dt{opacity:.72;margin:0;font-size:.65rem}.perf-monitor dd{color:#fff;margin:2px 0 0;font-size:.82rem}.drop-center{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;gap:8px;transition:background .15s;display:flex;position:absolute;inset:0}.drop-center.is-drag-over{background:#11222e2e}.drop-center-icon{opacity:.35;font-size:2.8rem;line-height:1;transition:opacity .15s,transform .15s}.drop-center.is-drag-over .drop-center-icon{opacity:.7;transform:translateY(-4px)}.drop-center-label{color:#142837a6;letter-spacing:.02em;margin:0;font-size:1.1rem;font-weight:600}.drop-center-hint{color:#14283761;margin:0;font-family:IBM Plex Mono,Courier New,monospace;font-size:.78rem}.drop-center-hint code{background:#14283714;border-radius:4px;padding:1px 5px}.drop-replace-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);pointer-events:none;z-index:5;background:#11222e73;place-items:center;display:grid;position:absolute;inset:0}.drop-replace-overlay p{color:#fff;letter-spacing:.03em;margin:0;font-size:1.2rem;font-weight:600}.viewer-controls{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffc2;border:1px solid #1f34422e;border-radius:10px;flex-direction:column;gap:4px;width:min(220px,100vw - 28px);padding:12px 14px;display:flex;position:absolute;top:14px;right:14px;box-shadow:0 8px 24px #14253129}.controls-model{color:#355469;word-break:break-all;margin:0;font-family:IBM Plex Mono,Courier New,monospace;font-size:.75rem}.controls-size{color:#4a7088;margin:0;font-family:IBM Plex Mono,Courier New,monospace;font-size:.72rem}.controls-status{color:#243845;margin:0;font-size:.82rem}.controls-error{color:#8c2626;margin:0;font-size:.8rem}.controls-toggle{color:#1e3644;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:7px;margin-top:6px;font-size:.8rem;font-weight:600;display:flex}.controls-toggle input{cursor:pointer;accent-color:#143242;margin:0}.btn-generate{color:#e8f3fa;cursor:pointer;letter-spacing:.02em;background:#143242e0;border:1px solid #14324247;border-radius:7px;margin-top:6px;padding:7px 12px;font-family:inherit;font-size:.82rem;font-weight:600;transition:background .12s,transform 80ms}.btn-generate:hover{background:#143242;transform:translateY(-1px)}.btn-generate:active{transform:translateY(0)}.json-panel{z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#d4e6f1;background:#0a1016f0;border-right:1px solid #ffffff14;flex-direction:column;width:min(460px,100vw);height:100dvh;font-family:IBM Plex Mono,Courier New,monospace;transition:transform .26s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;top:0;left:0;transform:translate(-100%);box-shadow:4px 0 32px #00000073}.json-panel.is-open{transform:translate(0)}.json-panel-header{border-bottom:1px solid #ffffff14;flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;display:flex}.json-panel-tabs{gap:4px;display:flex}.json-tab{color:#d4e6f18c;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:5px;padding:4px 10px;font-family:inherit;font-size:.78rem;transition:background .1s,color .1s}.json-tab.is-active{color:#e8f3fa;background:#ffffff1a;border-color:#ffffff24}.json-tab:hover:not(.is-active){background:#ffffff0d}.json-panel-actions{align-items:center;gap:6px;display:flex}.json-action-btn{color:#c8dde9;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff29;border-radius:5px;padding:4px 9px;font-family:inherit;font-size:.75rem;transition:background .1s}.json-action-btn:hover{background:#ffffff1f}.json-close-btn{color:#c8dde9;cursor:pointer;background:0 0;border:1px solid #ffffff29;border-radius:50%;place-items:center;width:28px;height:28px;font-size:.75rem;transition:background .1s;display:grid}.json-close-btn:hover{background:#ffffff1a}.json-panel-body{flex:1;padding:12px;overflow:hidden auto}.json-raw{color:#a8cfe0;white-space:pre;margin:0;font-size:.72rem;line-height:1.55;overflow-x:auto}.tree-root{font-size:.78rem}.tree-node{border-left:1px solid #ffffff14;margin-bottom:1px;padding-left:1rem}.tree-row{cursor:default;-webkit-user-select:none;user-select:none;align-items:baseline;gap:5px;padding:2px 0;display:flex}.tree-row[data-clickable=true]{cursor:pointer}.tree-arrow{color:#ffffff4d;flex-shrink:0;width:10px;font-size:.65rem}.tree-name{color:#e2eff7;font-weight:600}.tree-type{color:#b4d2e473;font-size:.68rem}.tree-meta{color:#a0c3d773;margin-bottom:2px;padding-left:15px;font-size:.66rem;line-height:1.5}@media (width<=640px){.viewer-controls{width:auto;left:14px;right:14px}.json-panel{width:100vw}}
