:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:start;min-width:320px;min-height:100vh}.container{width:100%;max-width:1200px;margin:0 auto;padding:1rem 1rem 0}header{margin-bottom:1rem;text-align:center}header h1{font-size:2.5rem;margin-bottom:1rem;background:linear-gradient(90deg,#646cff,#a855f7);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.input-group{display:flex;gap:1rem;justify-content:center;margin-bottom:1rem}input[type=text]{padding:.75rem;width:300px;border-radius:6px;border:1px solid #30363d;background:#0d1117;color:#fff;font-size:1rem}button{padding:.75rem 1.5rem;border-radius:6px;border:1px solid transparent;background-color:#646cff;font-weight:600;cursor:pointer;transition:border-color .25s}button:hover{background-color:#535bf2}.status{margin-top:1rem;padding:.5rem;border-radius:4px;background:#1a1a1a;color:#888}.status.error{color:#ff6b6b;background:#ff6b6b1a}.card{background:#1a1a1a;border-radius:8px;padding:1rem;margin-bottom:1rem;box-shadow:0 4px 6px #0000004d}.card:last-child{margin-bottom:0}.card h2{margin-top:0;font-size:1.5rem;color:#e6edf3;border-bottom:1px solid #30363d;padding-bottom:.5rem;margin-bottom:1rem}textarea{width:100%;min-height:120px;padding:1rem;background:#0d1117;border:1px solid #30363d;border-radius:6px;color:#e6edf3;font-family:inherit;font-size:1rem;resize:vertical}.hint{color:#8b949e;font-size:.9rem;margin-bottom:1rem}.visualization-grid{display:flex;flex-direction:column;gap:2rem}.visualization-grid>*{flex:1;min-width:0}.text-viewer{font-family:Courier New,Courier,monospace;line-height:1.6;font-size:1.1rem;white-space:pre-wrap;word-break:break-all;padding:1rem;background:#0d1117;border-radius:6px;border:1px solid #30363d;min-height:100px;max-height:600px;overflow-y:auto;overscroll-behavior:contain}.char{transition:background-color .1s;cursor:default;position:relative}.char.active{background-color:#646cff66;color:#fff;border-radius:2px}[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;bottom:120%;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:4px 8px;border-radius:4px;font-size:.75rem;white-space:nowrap;pointer-events:none;z-index:100;box-shadow:0 2px 4px #00000080;border:1px solid #444}.token-display{display:flex;flex-wrap:wrap;align-content:flex-start;gap:.5rem;padding:1rem;background:#0d1117;border-radius:6px;border:1px solid #30363d;min-height:100px;max-height:600px;overflow-y:auto;overscroll-behavior:contain}.token-chip{display:inline-flex;align-items:center;justify-content:center;padding:.25rem .5rem;background:#21262d;border:1px solid #30363d;border-radius:4px;font-family:Courier New,monospace;font-size:.9rem;color:#c9d1d9;cursor:pointer;transition:all .2s;position:relative}.token-chip.active,.token-chip.highlighted{background:#646cff;color:#fff;border-color:#646cff;transform:translateY(-1px);box-shadow:0 2px 4px #0003}@media(min-width:768px){.visualization-grid{flex-direction:row}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
