*{box-sizing:border-box;margin:0;padding:0}body{color:#1a1a1a;background:#fafafa;min-height:100vh;font-family:system-ui,sans-serif}.app{max-width:1100px;margin:0 auto;padding:2rem 1.5rem}header{margin-bottom:2rem}header h1{margin-bottom:.3rem;font-size:1.6rem;font-weight:600}header p{color:#666;font-size:.9rem}.input-section{margin-bottom:1.5rem}.input-row{gap:8px;margin-bottom:.5rem;display:flex}input[type=text]{background:#fff;border:1px solid #ddd;border-radius:8px;outline:none;flex:1;padding:9px 12px;font-family:system-ui;font-size:15px}input[type=text]:focus{border-color:#534ab7}input[type=text].has-error{border-color:#e24b4a}button{color:#fff;cursor:pointer;background:#1a1a1a;border:none;border-radius:8px;padding:9px 18px;font-size:14px}button:hover{background:#333}.error{color:#e24b4a;margin-bottom:.5rem;font-size:13px}.chips{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:.5rem;display:flex}.chips-label{color:#888;font-size:12px}.chip{color:#555;cursor:pointer;background:0 0;border:1px solid #ddd;border-radius:99px;padding:3px 10px;font-size:12px}.chip:hover{color:#1a1a1a;background:#f0f0f0}.supported{color:#999;font-size:12px}.stats-bar{flex-wrap:wrap;gap:8px;margin-bottom:1.5rem;display:flex}.stat{background:#fff;border:1px solid #eee;border-radius:10px;flex-direction:column;flex:140px;gap:4px;padding:10px 14px;display:flex}.stat-label{color:#888;white-space:nowrap;font-size:11px}.stat-val{color:#1a1a1a;font-size:22px;font-weight:600}.stat-val-sm{color:#444;font-size:12px;font-weight:500;line-height:1.4}.tables-row{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.hash-table-wrap{background:#fff;border:1px solid #eee;border-radius:12px;overflow:hidden}.hash-table-wrap h3{padding:14px 16px 0;font-size:15px;font-weight:600}.table-subtitle{color:#888;border-bottom:1px solid #f0f0f0;padding:4px 16px 12px;font-size:12px}table{border-collapse:collapse;width:100%;font-size:13px}th{text-align:left;color:#666;background:#f5f5f5;border-bottom:1px solid #eee;padding:8px 12px;font-size:12px;font-weight:500}td{vertical-align:middle;border-bottom:1px solid #f9f9f9;padding:7px 12px}.slot-index{color:#888;width:40px;font-weight:600}.slot-hash{color:#bbb;width:40px;font-family:monospace}.empty-slot td{background:#fafafa}.filled-slot td{background:#fff}.collision-slot td{background:#fffbf0}.empty-label{color:#ccc}.word-chip{color:#534ab7;background:#eeedfe;border-radius:99px;margin:1px 2px;padding:2px 8px;font-size:12px;display:inline-block}.arrow{color:#bbb;font-size:11px}
