*{box-sizing:border-box}html,body,#root{height:100%;margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:#eaf7f1;color:#1f2937}.app{display:grid;grid-template-rows:auto 1fr auto;height:100%}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 16px;border-bottom:1px solid #e5e7eb;background:#fff}.topbar h1{font-size:18px;margin:0;color:#111827}.controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap;row-gap:8px}.file input[type=file]{display:none}.file span{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;background:#eef2ff;color:#1f2937;cursor:pointer}.multiselect{display:flex;align-items:center;gap:6px}.multiselect select{min-width:200px;background:#fff;color:#1f2937;border:1px solid #d1d5db;border-radius:6px}.multiselect .col-filter{height:32px;padding:4px 8px;border:1px solid #d1d5db;background:#fff;color:#1f2937;border-radius:6px;width:200px}.multiselect .col-actions{display:flex;flex-direction:column;gap:4px}button{padding:8px 12px;border-radius:6px;border:1px solid #d1d5db;background:#e0e7ff;color:#111827;cursor:pointer}button:disabled{opacity:.5;cursor:not-allowed}.filtering{display:flex;align-items:center;gap:10px}.filtering label{display:inline-flex;align-items:center;gap:6px;font-size:12px}.filtering input,.filtering select{background:#fff;color:#1f2937;border:1px solid #d1d5db;border-radius:6px;padding:4px 8px}.content{display:grid;grid-template-columns:1fr;height:100%}.viz-layout{display:grid;grid-template-columns:1fr 300px;gap:8px;padding:10px}.chart-wrap{width:100%;height:100%;overflow:hidden;background:#fff;border:1px solid #e5e7eb;border-radius:8px}svg{width:100%;height:100%}.panel{border:1px solid #e5e7eb;border-radius:8px;padding:10px;background:#fff;color:#1f2937}.panel h3{margin-top:0}.panel ul{margin:6px 0;padding-left:18px}.empty{padding:24px;color:#444}.hint{color:#666;font-size:12px}.footer{padding:8px 16px;border-top:1px solid #e5e7eb;background:#fff;font-size:12px;color:#6b7280}.col-title{font-size:12px;fill:#1f2937}.wedge-label{font-size:10px;fill:#111827}.arc{fill:#f3f4f6;stroke:#e5e7eb}.wedge{cursor:pointer}.viz-with-controls{display:grid;grid-template-rows:1fr auto;gap:8px}.binning{border:1px solid #e5e7eb;border-radius:8px;background:#fff;padding:8px;max-height:240px;overflow:auto}.binning h3{margin:0 0 6px;font-size:14px;color:#111827}.bin-row{display:grid;grid-template-columns:1fr auto auto auto;align-items:center;gap:8px;padding:6px 0;border-bottom:1px dashed #e5e7eb}.bin-row:last-child{border-bottom:none}.bin-col-name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#111827}.bin-type{font-size:12px;color:#6b7280}.binning label{display:inline-flex;align-items:center;gap:6px;font-size:12px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000040;display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:#fff;color:#111827;border:1px solid #e5e7eb;border-radius:10px;width:min(100%,1000px);max-height:80vh;display:grid;grid-template-rows:auto auto 1fr;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 12px;border-bottom:1px solid #e5e7eb}.modal-sub{padding:6px 12px;color:#374151;border-bottom:1px solid #f3f4f6}.table-wrap{overflow:auto}.table-wrap table{width:100%;border-collapse:collapse;font-size:12px}.table-wrap th,.table-wrap td{border:1px solid #e5e7eb;padding:6px 8px;text-align:left}.note{padding:6px 12px;color:#6b7280}
