:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-card: rgba(18, 18, 26, .8);--bg-glass: rgba(255, 255, 255, .03);--bg-glass-hover: rgba(255, 255, 255, .06);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--accent-primary: #6366f1;--accent-secondary: #8b5cf6;--accent-gradient: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--success: #10b981;--warning: #f59e0b;--error: #ef4444;--border-subtle: rgba(255, 255, 255, .06);--border-accent: rgba(99, 102, 241, .3);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 30px rgba(99, 102, 241, .15);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--sidebar-width: 380px;--gradient-1: rgba(99, 102, 241, .08);--gradient-2: rgba(139, 92, 246, .06)}[data-theme=light]{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-card: rgba(255, 255, 255, .9);--bg-glass: rgba(0, 0, 0, .03);--bg-glass-hover: rgba(0, 0, 0, .06);--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--border-subtle: rgba(0, 0, 0, .1);--border-accent: rgba(99, 102, 241, .4);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px rgba(99, 102, 241, .1);--gradient-1: rgba(99, 102, 241, .05);--gradient-2: rgba(139, 92, 246, .05)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{height:100%;display:flex;flex-direction:column;background:radial-gradient(ellipse at top left,var(--gradient-1) 0%,transparent 50%),radial-gradient(ellipse at bottom right,var(--gradient-2) 0%,transparent 50%),var(--bg-primary)}.app-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);background:var(--bg-glass);border-bottom:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header-left{display:flex;align-items:center;gap:var(--space-6)}.logo{display:flex;align-items:center;gap:var(--space-3);color:var(--accent-primary)}.logo h1{font-size:1.5rem;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tagline{color:var(--text-muted);font-size:.875rem}.preview-toggle{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.preview-toggle:hover{background:var(--bg-glass-hover);border-color:var(--border-accent)}.app-content{flex:1;overflow:hidden}.upload-section{height:100%;display:flex;align-items:center;justify-content:center;padding:var(--space-6)}.upload-card{max-width:600px;width:100%;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-10);box-shadow:var(--shadow-lg),var(--shadow-glow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.upload-header{text-align:center;margin-bottom:var(--space-8)}.upload-header svg{color:var(--accent-primary);margin-bottom:var(--space-4)}.upload-header h2{font-size:1.75rem;font-weight:700;margin-bottom:var(--space-2)}.upload-header p{color:var(--text-secondary)}.features-preview{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--border-subtle)}.feature{display:flex;align-items:center;gap:var(--space-3);color:var(--text-secondary);font-size:.875rem}.feature-icon{font-size:1.25rem}.file-upload-container{width:100%}.file-upload-zone{position:relative;border:2px dashed var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-8);text-align:center;cursor:pointer;transition:all var(--transition-normal);background:var(--bg-glass)}.file-upload-zone:hover{border-color:var(--accent-primary);background:var(--bg-glass-hover)}.file-upload-zone.dragging{border-color:var(--accent-primary);background:#6366f114;transform:scale(1.01)}.file-upload-zone.loaded{border-style:solid;border-color:var(--success)}.file-upload-zone.error{border-color:var(--error)}.upload-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.upload-content h3{font-size:1.125rem;font-weight:600}.upload-content p{color:var(--text-secondary)}.upload-content .hint{font-size:.75rem;color:var(--text-muted)}.upload-icon{color:var(--accent-primary);transition:transform var(--transition-normal)}.upload-icon.bouncing{animation:bounce .5s ease infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.upload-content.loaded{color:var(--success)}.success-icon{width:40px;height:40px;background:var(--success);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.file-icon{color:var(--text-primary)}.file-name{font-weight:600;color:var(--text-primary);font-size:.8rem;word-break:break-word;overflow-wrap:break-word;max-width:100%;line-height:1.3;text-align:center;padding:0 var(--space-2)}.upload-error{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-4);padding:var(--space-3) var(--space-4);background:#ef44441a;border-radius:var(--radius-md);color:var(--error);font-size:.875rem}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-subtle);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard{display:flex;height:100%;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-subtle);overflow-y:auto;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-4)}.sidebar-section{background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-4)}.sidebar-section .file-upload-zone{padding:var(--space-4)}.library-selector{display:flex;flex-direction:column;gap:var(--space-3)}.selector-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}.library-buttons{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-2)}.library-button{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-3) var(--space-2);background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.library-button:hover{background:var(--bg-glass-hover);border-color:var(--border-accent)}.library-button.active{background:#6366f126;border-color:var(--accent-primary);color:var(--text-primary)}.library-icon{font-size:1.25rem}.library-name{font-size:.625rem;font-weight:500}.chart-type-selector{display:flex;flex-direction:column;gap:var(--space-3)}.chart-type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2)}.chart-type-button{position:relative;display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-3) var(--space-2);background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.chart-type-button:hover{background:var(--bg-glass-hover);border-color:var(--border-accent)}.chart-type-button.active{background:#6366f126;border-color:var(--accent-primary);color:var(--text-primary)}.chart-type-button.recommended{border-color:#10b9814d}.chart-type-icon{display:flex;align-items:center;justify-content:center}.chart-type-name{font-size:.625rem;font-weight:500;text-align:center}.recommendation-badge{position:absolute;top:-4px;right:-4px;width:16px;height:16px;background:var(--success);border-radius:50%;font-size:.625rem;display:flex;align-items:center;justify-content:center;color:#fff}.recommendation-hint{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-3);background:#10b98114;border-radius:var(--radius-md);font-size:.75rem;color:var(--success);line-height:1.4}.recommendation-star{flex-shrink:0}.metric-controls{display:flex;flex-direction:column;gap:var(--space-5)}.control-group{display:flex;flex-direction:column;gap:var(--space-2)}.control-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}.control-select{width:100%;padding:var(--space-3);background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.control-select:focus{outline:none;border-color:var(--accent-primary)}.control-select option{background:var(--bg-secondary);color:var(--text-primary)}.control-hint{font-size:.75rem;color:var(--text-muted)}.metric-chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.metric-chip{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.8125rem;cursor:pointer;transition:all var(--transition-fast)}.metric-chip:hover{background:var(--bg-glass-hover);border-color:var(--border-accent)}.metric-chip.selected{background:#6366f126;border-color:var(--accent-primary);color:var(--text-primary)}.chip-remove{opacity:.6;transition:opacity var(--transition-fast)}.metric-chip:hover .chip-remove{opacity:1}.aggregation-buttons{display:flex;gap:var(--space-2)}.agg-button{flex:1;padding:var(--space-2);background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.6875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.agg-button:hover{background:var(--bg-glass-hover);border-color:var(--border-accent)}.agg-button.active{background:#6366f126;border-color:var(--accent-primary);color:var(--text-primary)}.data-preview{display:flex;flex-direction:column;gap:var(--space-3)}.preview-header{display:flex;align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:.875rem}.preview-title{font-weight:600;color:var(--text-primary)}.preview-stats{margin-left:auto;font-size:.75rem;color:var(--text-muted)}.column-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.column-tag{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:.6875rem}.column-tag.numeric{border-color:#6366f14d}.column-tag.categorical{border-color:#10b9814d}.column-tag.date{border-color:#f59e0b4d}.tag-name{color:var(--text-primary);font-weight:500}.tag-type{color:var(--text-muted)}.tag-metric{background:var(--accent-primary);color:#fff;padding:0 4px;border-radius:3px;font-size:.625rem;text-transform:uppercase}.preview-table-container{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.preview-table{width:100%;border-collapse:collapse;font-size:.75rem}.preview-table th{text-align:left;padding:var(--space-2) var(--space-3);background:var(--bg-glass);border-bottom:1px solid var(--border-subtle);font-weight:600;color:var(--text-secondary);white-space:nowrap}.th-content{display:flex;align-items:center;gap:var(--space-2)}.preview-table td{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-subtle);white-space:nowrap}.preview-table tr:last-child td{border-bottom:none}.null-value{color:var(--text-muted);font-style:italic}.preview-more{padding:var(--space-2) var(--space-3);text-align:center;font-size:.75rem;color:var(--text-muted);background:var(--bg-glass)}.chart-area{flex:1;display:flex;flex-direction:column;padding:var(--space-6);overflow:hidden}.chart-header{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-2);margin-bottom:var(--space-4)}.chart-header h2{font-size:1.25rem;font-weight:600}.chart-badges{display:flex;gap:var(--space-2)}.badge{padding:2px 8px;background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:9999px;font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;line-height:1}.badge.library{border-color:var(--accent-primary);color:var(--accent-primary)}.badge.type{border-color:var(--accent-secondary);color:var(--accent-secondary)}.badge.metrics{border-color:var(--success);color:var(--success)}.chart-wrapper{flex:1;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-md);overflow:hidden}.chart-container{width:100%;height:100%}.d3-container{position:relative}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media(max-width:1200px){:root{--sidebar-width: 320px}.library-buttons,.chart-type-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.dashboard{flex-direction:column}.sidebar{width:100%;max-height:40vh;border-right:none;border-bottom:1px solid var(--border-subtle)}.chart-area{flex:1;min-height:50vh}}
