*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=dark]{--bg:#0f1117;--surface:#1a1d27;--surface-hover:#22253a;--border:#2a2d3a;--text:#e4e4e7;--text-muted:#9ca3af;--accent:#818cf8;--chart-grid:#ffffff0a;--chart-divider:#ffffff1f;--chart-tick:#ffffff52;--chart-axis:#ffffff7a;--chart-bubble-text:#fff;--chart-quad-qw:#34d3990f;--chart-quad-sp:#facc150d;--chart-quad-fi:#9ca3af0a;--chart-quad-rc:#f871710f;--chart-label-qw:#34d39947;--chart-label-sp:#facc1540;--chart-label-fi:#9ca3af38;--chart-label-rc:#f8717147;--tooltip-bg:#23263aee;--tooltip-text:#fff;--overlay-bg:#000000a6}[data-theme=light]{--bg:#f5f6fa;--surface:#fff;--surface-hover:#eef0f6;--border:#d4d7e0;--text:#1a1d27;--text-muted:#5f6577;--accent:#6366f1;--chart-grid:#0000000d;--chart-divider:#0000001f;--chart-tick:#0006;--chart-axis:#0000008c;--chart-bubble-text:#fff;--chart-quad-qw:#10b98114;--chart-quad-sp:#eab30812;--chart-quad-fi:#6b72800f;--chart-quad-rc:#ef444412;--chart-label-qw:#10b98159;--chart-label-sp:#b482004d;--chart-label-fi:#6b728047;--chart-label-rc:#ef444459;--tooltip-bg:#fffe;--tooltip-text:#1a1d27;--overlay-bg:#00000059}html,body{width:100%;overflow-x:hidden}body{background:var(--bg);color:var(--text);min-height:100vh;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;transition:background .2s,color .2s}.app-shell{min-height:100vh;display:flex}.app-nav-wrap{flex-shrink:0;height:100vh;position:sticky;top:0}.app-nav{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;width:220px;height:100%;padding:.75rem 0;transition:width .2s;display:flex;overflow:hidden}.app-nav.collapsed{width:52px}.app-nav-toggle{z-index:10;background:var(--surface);border:1px solid var(--border);width:24px;height:24px;color:var(--text-muted);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:background .12s,color .12s,box-shadow .12s;display:flex;position:absolute;top:18px;right:-12px;box-shadow:0 1px 3px #00000026}.app-nav-toggle:hover{background:var(--surface-hover);color:var(--text);box-shadow:0 2px 6px #00000040}.app-nav-brand{border-bottom:1px solid var(--border);color:var(--accent);justify-content:center;align-items:center;margin-bottom:.75rem;padding:.75rem 0 1rem;display:flex}.app-nav-items{flex:1;padding:0 .5rem;list-style:none}.app-nav-item{color:var(--text-muted);cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:.6rem;padding:.55rem .75rem;font-size:.82rem;font-weight:500;transition:background .12s,color .12s;display:flex}.app-nav-item:hover{background:var(--surface-hover);color:var(--text)}.app-nav-item.active{background:var(--surface-hover);color:var(--text);font-weight:600}.app-nav-item svg{opacity:.7;flex-shrink:0}.app-nav-item.active svg{opacity:1;color:var(--accent)}.app-nav-label{opacity:1;transition:opacity .15s;overflow:hidden}.app-nav.collapsed .app-nav-label{opacity:0;width:0}.app-nav.collapsed .app-nav-item{justify-content:center;padding:.55rem}.app-nav-footer{border-top:1px solid var(--border);margin-top:auto;padding:.75rem 1rem .25rem}.app-nav.collapsed .app-nav-footer{justify-content:center;padding:.75rem .25rem .25rem;display:flex}.app-nav.collapsed .theme-toggle{gap:0;padding:.45rem}.app-nav.collapsed .theme-toggle-label{display:none}.app-main{flex:1;min-width:0;padding:1.5rem}header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1rem;margin:0 0 1.5rem;display:flex}header h1{letter-spacing:-.02em;font-size:1.75rem;font-weight:700}header p{color:var(--text-muted);margin-top:.25rem;font-size:.9rem}.pivot-toggle{background:var(--surface);border:1px solid var(--border);border-radius:8px;flex-shrink:0;display:flex;overflow:hidden}.pivot-btn{color:var(--text-muted);cursor:pointer;letter-spacing:.02em;background:0 0;border:none;padding:.5rem 1.1rem;font-family:inherit;font-size:.8rem;font-weight:500;transition:all .2s}.pivot-btn:hover{background:var(--surface-hover)}.pivot-btn.active{background:var(--accent);color:#fff}.chart-container{background:var(--surface);border:1px solid var(--border);border-radius:12px;min-width:0;display:flex;position:relative}.chart-main{flex:1;min-width:0;padding:1rem;position:relative}.chart-sidebar{border-left:1px solid var(--border);flex-shrink:0;width:280px;min-height:0;display:flex}@media (max-width:860px){.chart-container{flex-direction:column}.chart-sidebar{border-left:none;border-top:1px solid var(--border);width:100%;max-height:300px}}.chart-container canvas{width:100%;display:block}.chart-canvas-wrap{position:relative}.chart-overlay{pointer-events:auto;position:absolute;inset:0}.axis-label{color:var(--chart-axis);-webkit-user-select:none;user-select:none;flex-direction:column;align-items:center;gap:.4rem;font-size:.8rem;font-weight:600;display:flex}.axis-label-effort{justify-content:center;padding:.4rem 0 0}.axis-label-value{white-space:nowrap;position:absolute;top:50%;left:.5rem;transform:translateY(-50%)}.axis-help-trigger{color:var(--text-muted);opacity:.5;cursor:help;align-items:center;transition:opacity .15s,color .15s;display:inline-flex;position:relative}.axis-help-trigger:hover{opacity:1;color:var(--accent)}.axis-help-popover{background:var(--surface);border:1px solid var(--border);z-index:60;white-space:normal;border-radius:10px;width:340px;padding:.75rem .9rem;animation:.12s ease-out menuFadeIn;position:absolute;box-shadow:0 8px 28px #0000004d}.axis-help-popover-up{bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.axis-help-popover-down{top:calc(100% + 8px);left:0}.axis-help-popover-right{top:50%;left:calc(100% + 8px);transform:translateY(-50%)}.axis-help-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.5rem;font-size:.75rem;font-weight:700}.axis-help-table{border-collapse:collapse;width:100%;color:var(--text);font-size:.76rem;line-height:1.45}.axis-help-table td{vertical-align:top;border-bottom:1px solid var(--border);padding:.3rem .4rem}.axis-help-table tr:last-child td{border-bottom:none}.axis-help-level{color:var(--accent);text-align:center;font-variant-numeric:tabular-nums;width:1.6em;font-weight:700}.chart-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.chart-title{color:var(--text);letter-spacing:-.01em;text-align:center;flex:1;font-size:1.15rem;font-weight:600}.chart-menu{position:relative}.chart-menu-trigger{color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;padding:.2rem .5rem;font-size:1.25rem;line-height:1;transition:background .15s,color .15s,border-color .15s}.chart-menu-trigger:hover{background:var(--surface-hover);color:var(--text);border-color:var(--border)}.chart-menu-dropdown{background:var(--surface);border:1px solid var(--border);z-index:50;border-radius:8px;min-width:160px;padding:4px;animation:.12s ease-out menuFadeIn;position:absolute;top:calc(100% + 4px);right:0;box-shadow:0 8px 24px #00000040}@keyframes menuFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.chart-menu-dropdown button{width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:5px;align-items:center;gap:.5rem;padding:.5rem .65rem;font-size:.82rem;transition:background .12s;display:flex}.chart-menu-dropdown button:hover{background:var(--surface-hover)}.chart-menu-dropdown button svg{opacity:.7;flex-shrink:0}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.25rem}.legend-card{background:0 0;border:none;border-radius:0;flex-direction:column;flex:1;width:100%;min-height:0;padding:1rem;display:flex;overflow:hidden}.card h2{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.75rem;font-size:.75rem}.legend-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.legend-header h2{margin-bottom:0}.legend-actions{gap:.35rem;display:flex}.legend-action-btn{color:var(--text-muted);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:4px;padding:.2rem .5rem;font-family:inherit;font-size:.68rem;font-weight:500;transition:all .15s}.legend-action-btn:hover:not(:disabled){color:var(--text);border-color:var(--text-muted)}.legend-action-btn:disabled{opacity:.3;cursor:default}.legend-item{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;padding:.4rem 0;font-size:.85rem;transition:opacity .2s;display:flex}.legend-item.dimmed{opacity:.25}.legend-swatch{border-radius:3px;flex-shrink:0;width:12px;height:12px}.legend-count{color:var(--text-muted);font-variant-numeric:tabular-nums;margin-left:auto;font-size:.72rem}.legend-usecases{flex-direction:column;flex:1;gap:.6rem;min-height:0;display:flex;overflow-y:auto}.legend-uc-group.dimmed{opacity:.25}.legend-uc-theme{-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;padding:.3rem 0;font-size:.82rem;font-weight:600;display:flex}.legend-uc-theme-name{cursor:pointer;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.legend-collapse-btn{width:18px;height:18px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:transform .15s,color .12s;display:flex;transform:rotate(90deg)}.legend-collapse-btn.collapsed{transform:rotate(0)}.legend-collapse-btn:hover{color:var(--text);background:var(--surface-hover)}.legend-uc-list{margin:0;padding:0 0 0 1.25rem;list-style:none}.legend-uc-item{color:var(--text);cursor:pointer;align-items:baseline;gap:.4rem;min-width:0;padding:.2rem .35rem;font-size:.78rem;line-height:1.35;transition:background .1s;display:flex}.legend-uc-id{color:var(--text-muted);font-variant-numeric:tabular-nums;flex-shrink:0;min-width:1.8em;font-size:.68rem;font-weight:600}.legend-uc-name{white-space:nowrap;text-overflow:ellipsis;min-width:0;overflow:hidden}.legend-uc-item:hover,.legend-uc-item.highlighted{background:var(--surface-hover);border-radius:4px}.legend-uc-item.highlighted .legend-uc-id,.legend-uc-item.highlighted .legend-uc-name{color:var(--accent)}.detail-card{display:none}.detail-card.active{margin-top:1.5rem;display:block}.detail-name{margin-bottom:.5rem;font-size:.95rem;font-weight:600}.detail-row{justify-content:space-between;padding:.25rem 0;font-size:.85rem;display:flex}.detail-label{color:var(--text-muted)}.tooltip{pointer-events:none;background:var(--tooltip-bg);color:var(--text);border:1px solid var(--border);z-index:100;border-radius:8px;max-width:300px;padding:.75rem 1rem;font-size:.8rem;line-height:1.5;position:fixed;box-shadow:0 8px 24px #00000040}.tooltip strong{color:var(--tooltip-text);font-size:.85rem}.tooltip-tag{color:#fff;border-radius:4px;margin-top:.3rem;padding:.1rem .45rem;font-size:.68rem;display:inline-block}.header-controls{flex-shrink:0;align-items:flex-end;gap:.75rem;display:flex}.file-upload-wrapper{flex-direction:column;align-items:flex-end;gap:.35rem;display:flex}.file-upload-zone{background:var(--surface);border:1.5px dashed var(--border);cursor:pointer;color:var(--text-muted);white-space:nowrap;border-radius:8px;align-items:center;gap:.5rem;padding:.45rem .9rem;font-size:.78rem;transition:all .2s;display:flex}.file-upload-zone:hover,.file-upload-zone.dragging{border-color:var(--accent);background:var(--surface-hover);color:var(--text)}.file-upload-icon{font-size:1rem;line-height:1}.file-upload-reset{color:var(--accent);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:0;font-family:inherit;font-size:.7rem;text-decoration:underline}.file-upload-reset:hover{color:var(--text)}.detecting-banner{background:var(--surface);border:1px solid var(--accent);color:var(--text);border-radius:8px;align-items:center;gap:.6rem;margin-bottom:1rem;padding:.7rem 1rem;font-size:.85rem;display:flex}.detecting-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.column-mapper-overlay{z-index:200;background:var(--overlay-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.column-mapper{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:90vw;max-width:560px;max-height:90vh;padding:2rem;overflow-y:auto}.column-mapper h2{margin-bottom:.35rem;font-size:1.15rem;font-weight:700}.column-mapper-desc{color:var(--text-muted);margin-bottom:1.25rem;font-size:.82rem;line-height:1.5}.column-mapper-error{color:#f87171;background:#f8717114;border:1px solid #f8717133;border-radius:6px;margin-bottom:1rem;padding:.5rem .75rem;font-size:.78rem;line-height:1.5}.mapper-fields{flex-direction:column;gap:.8rem;margin-bottom:1.5rem;display:flex}.mapper-field-row{justify-content:space-between;align-items:center;gap:1rem;display:flex}.mapper-field-row label{flex-direction:column;min-width:0;display:flex}.mapper-field-name{font-size:.85rem;font-weight:600}.mapper-required{color:#f87171;margin-left:2px}.mapper-field-desc{color:var(--text-muted);font-size:.7rem}.mapper-field-row select{background:var(--bg);width:200px;color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:6px;flex-shrink:0;padding:.4rem .6rem;font-family:inherit;font-size:.8rem}.mapper-field-row select:focus{border-color:var(--accent);outline:none}.mapper-preview{margin-bottom:1.25rem}.mapper-preview h3{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.5rem;font-size:.75rem}.mapper-table-wrap{border:1px solid var(--border);border-radius:8px;overflow-x:auto}.mapper-table-wrap table{border-collapse:collapse;width:100%;font-size:.78rem}.mapper-table-wrap th,.mapper-table-wrap td{text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:.4rem .7rem}.mapper-table-wrap th{background:var(--surface-hover);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;font-weight:600}.mapper-table-wrap tr:last-child td{border-bottom:none}.mapper-actions{justify-content:flex-end;gap:.6rem;display:flex}.mapper-btn{cursor:pointer;border:1px solid var(--border);border-radius:8px;padding:.5rem 1.2rem;font-family:inherit;font-size:.82rem;font-weight:500;transition:all .15s}.mapper-btn.secondary{color:var(--text-muted);background:0 0}.mapper-btn.secondary:hover{color:var(--text);border-color:var(--text-muted)}.mapper-btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.mapper-btn.primary:hover:not(:disabled){filter:brightness(1.15)}.mapper-btn.primary:disabled{opacity:.35;cursor:default}.theme-toggle{color:var(--text-muted);background:var(--surface);border:1px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:.35rem;padding:.45rem .75rem;font-family:inherit;font-size:.78rem;font-weight:500;transition:all .2s;display:flex}.theme-toggle:hover{color:var(--text);border-color:var(--text-muted);background:var(--surface-hover)}.theme-toggle-icon{font-size:.9rem;line-height:1}.theme-toggle-label{letter-spacing:.02em}.edit-modal-overlay{z-index:200;background:var(--overlay-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);justify-content:center;align-items:center;animation:.12s ease-out menuFadeIn;display:flex;position:fixed;inset:0}.edit-modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:90vw;max-width:380px;padding:1.75rem 2rem;box-shadow:0 12px 40px #00000059}.edit-modal-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.edit-modal-header h2{font-size:1.05rem;font-weight:700}.edit-modal-close{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;padding:0;transition:all .12s;display:flex}.edit-modal-close:hover{background:var(--surface-hover);color:var(--text);border-color:var(--border)}.edit-modal-name{color:var(--text);margin-bottom:1.25rem;font-size:.9rem;font-weight:600;line-height:1.4}.edit-modal-fields{flex-direction:column;gap:.85rem;margin-bottom:1.5rem;display:flex}.edit-modal-actions{justify-content:flex-end;gap:.6rem;display:flex}.stepper-row{justify-content:space-between;align-items:center;display:flex}.stepper-label{color:var(--text);font-size:.85rem;font-weight:600}.stepper-controls{border:1px solid var(--border);border-radius:8px;align-items:center;gap:0;display:flex;overflow:hidden}.stepper-btn{background:var(--surface);width:36px;height:36px;color:var(--text);cursor:pointer;border:none;justify-content:center;align-items:center;padding:0;transition:background .12s,color .12s;display:flex}.stepper-btn:hover:not(:disabled){background:var(--surface-hover);color:var(--accent)}.stepper-btn:disabled{opacity:.25;cursor:default}.stepper-value{font-variant-numeric:tabular-nums;width:40px;height:36px;color:var(--accent);background:var(--bg);border-left:1px solid var(--border);border-right:1px solid var(--border);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.loading{height:300px;color:var(--text-muted);justify-content:center;align-items:center;font-size:.9rem;display:flex}
