*{box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}button{font-family:inherit}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#1a1a1a}::-webkit-scrollbar-thumb{background:#4a4a4a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#5a5a5a}:root{--anthracite-dark: #1a1a1a;--anthracite: #2d2d2d;--anthracite-light: #3d3d3d;--anthracite-lighter: #4a4a4a;--yellow: #FFD000;--yellow-hover: #E6BC00;--yellow-light: rgba(255, 208, 0, .1);--white: #ffffff;--gray-light: #e5e5e5;--gray: #888888;--text-primary: #ffffff;--text-secondary: #b0b0b0;--error: #ff4444;--success: #4ade80;--warning: #fbbf24}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--anthracite-dark);color:var(--text-primary)}.header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--anthracite);border-bottom:1px solid var(--anthracite-light)}.logo{display:flex;align-items:center;gap:.75rem}.logo h1{font-size:1.25rem;font-weight:600;color:var(--white);margin:0;letter-spacing:-.5px}.dataset-overview{display:flex;align-items:center;gap:1.5rem}.file-name{font-size:.875rem;color:var(--text-secondary);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:.375rem .75rem;background:var(--anthracite-light);border-radius:4px}.overview-stats{display:flex;gap:1.5rem}.stat{display:flex;flex-direction:column;align-items:flex-end}.stat-value{font-size:1.25rem;font-weight:600;color:var(--yellow)}.stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.reset-button{padding:.5rem 1rem;background:transparent;border:1px solid var(--anthracite-lighter);color:var(--text-secondary);border-radius:4px;cursor:pointer;font-size:.875rem;transition:all .2s}.reset-button:hover{border-color:var(--yellow);color:var(--yellow)}.upload-container{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem}.upload-zone{width:100%;max-width:500px;padding:3rem;border:2px dashed var(--anthracite-lighter);border-radius:8px;text-align:center;cursor:pointer;transition:all .2s;background:var(--anthracite)}.upload-zone:hover,.upload-zone.dragging{border-color:var(--yellow);background:var(--yellow-light)}.upload-icon{color:var(--yellow);margin-bottom:1rem}.upload-text{font-size:1rem;color:var(--text-primary);margin-bottom:.5rem}.upload-hint{font-size:.875rem;color:var(--text-secondary)}.upload-zone.has-error{border-color:var(--error)}.upload-error{font-size:.875rem;color:var(--error);margin-top:.5rem}.explorer{flex:1;display:flex;overflow:hidden}.column-list{width:260px;background:var(--anthracite);border-right:1px solid var(--anthracite-light);display:flex;flex-direction:column;overflow:hidden}.column-list-title{padding:1rem 1.25rem;margin:0;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);border-bottom:1px solid var(--anthracite-light)}.column-items{list-style:none;padding:0;margin:0;overflow-y:auto;flex:1}.column-item{width:100%;padding:.75rem 1.25rem;background:transparent;border:none;text-align:left;color:var(--text-primary);cursor:pointer;font-size:.875rem;transition:all .15s;border-left:3px solid transparent;display:flex;align-items:center;gap:.625rem}.column-item:hover{background:var(--anthracite-light)}.column-item.selected{background:var(--yellow-light);border-left-color:var(--yellow);color:var(--yellow)}.column-type-icon{width:20px;height:20px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:600;flex-shrink:0}.column-type-icon.numeric{background:#64c8ff26;color:#64c8ff}.column-type-icon.text{background:#c896ff26;color:#c896ff}.column-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.column-detail{flex:1;padding:2rem;overflow-y:auto}.column-detail.empty{display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.detail-title{font-size:1.5rem;font-weight:600;margin:0 0 1rem;color:var(--yellow)}.quality-banner{margin-bottom:1.5rem;padding:.875rem 1rem;border-radius:6px;background:var(--anthracite)}.quality-banner.good{border-left:3px solid var(--success)}.quality-banner.warning{border-left:3px solid var(--warning)}.quality-banner.critical{border-left:3px solid var(--error)}.quality-bar{height:6px;background:var(--anthracite-light);border-radius:3px;overflow:hidden;margin-bottom:.5rem}.quality-fill{height:100%;border-radius:3px;transition:width .3s}.quality-banner.good .quality-fill{background:var(--success)}.quality-banner.warning .quality-fill{background:var(--warning)}.quality-banner.critical .quality-fill{background:var(--error)}.quality-message{font-size:.8125rem;color:var(--text-secondary)}.detail-section{margin-bottom:2rem}.detail-section h4{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin:0 0 1rem}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.detail-item{background:var(--anthracite);padding:1rem;border-radius:6px}.detail-label{display:block;font-size:.75rem;color:var(--text-secondary);margin-bottom:.25rem}.detail-value{font-size:1.125rem;font-weight:500;color:var(--text-primary)}.detail-percent{font-size:.875rem;color:var(--text-secondary);margin-left:.25rem}.type-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.type-badge.numeric{background:#64c8ff26;color:#64c8ff}.type-badge.text{background:#c896ff26;color:#c896ff}.simple-chart{background:var(--anthracite);padding:1rem 1rem .5rem;border-radius:6px}.chart-tooltip{height:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;margin-bottom:.5rem;opacity:0;transition:opacity .15s}.chart-tooltip.visible{opacity:1}.tooltip-range{font-size:.875rem;font-weight:500;color:var(--yellow)}.tooltip-count{font-size:.75rem;color:var(--text-secondary)}.chart-wrapper{margin-top:1.5rem;width:100%}.chart-inner{display:flex;gap:.5rem}.chart-y-axis{display:flex;flex-direction:column;justify-content:space-between;padding:0 .25rem;min-width:30px;text-align:right}.y-tick{font-size:.625rem;color:var(--text-secondary);line-height:1}.chart-area{flex:1;position:relative;height:140px}.chart-grid{position:absolute;inset:0;pointer-events:none}.grid-line{position:absolute;left:0;right:0;height:1px;background:var(--anthracite-lighter);opacity:.5}.chart-bars{display:flex;align-items:flex-end;height:100%;gap:3px;position:relative;z-index:1}.chart-bar{flex:1;background:var(--yellow);border-radius:2px 2px 0 0;min-height:2px;cursor:pointer;transition:all .15s;position:relative}.chart-bar:hover,.chart-bar.hovered{background:var(--yellow-hover);box-shadow:0 0 8px #ffd00066}.bar-label{position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:.6875rem;font-weight:600;color:var(--yellow);white-space:nowrap}.chart-x-axis{display:flex;justify-content:space-between;padding:.5rem 0 0 38px;font-size:.6875rem;color:var(--text-secondary)}.chart-x-axis span:nth-child(2){color:var(--gray)}.frequency-list{list-style:none;padding:0;margin:0}.frequency-item{display:flex;align-items:center;gap:1rem;padding:.5rem 0;border-bottom:1px solid var(--anthracite-light)}.frequency-item:last-child{border-bottom:none}.freq-value{width:150px;font-size:.875rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.freq-bar-container{flex:1;height:8px;background:var(--anthracite-light);border-radius:4px;overflow:hidden}.freq-bar{display:block;height:100%;background:var(--yellow);border-radius:4px}.freq-count{width:60px;text-align:right;font-size:.875rem;color:var(--text-secondary)}.error-message{padding:1rem 2rem;background:#ff44441a;color:var(--error);text-align:center}.footer{padding:1rem 2rem;text-align:center;font-size:.75rem;color:var(--text-secondary);border-top:1px solid var(--anthracite-light)}.footer-dot{margin:0 .5rem;color:var(--yellow)}
