:root{--bg: #0f1117;--surface: #1a1d27;--surface2: #232635;--border: #2e3247;--text: #e4e6f0;--text-muted: #8b8fa8;--accent: #6366f1;--accent-hover: #818cf8;--success: #22c55e;--error: #ef4444;--warning: #f59e0b}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}.app{max-width:1100px;margin:0 auto;padding:20px}.header{text-align:center;padding:24px 0;border-bottom:1px solid var(--border);margin-bottom:24px}.header h1{font-size:28px;background:linear-gradient(135deg,var(--accent),#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header p{color:var(--text-muted);font-size:14px;margin-top:4px}.app-tabs{display:flex;justify-content:center;gap:8px;margin:16px 0 22px}.app-tab{padding:8px 14px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;font-size:13px;transition:all .15s}.app-tab:hover{color:var(--text);border-color:#6366f180}.app-tab.active{color:var(--text);border-color:var(--accent);background:#6366f11f}.panel{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:18px;margin-bottom:16px}.panel h3{font-size:15px;color:var(--text);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.config-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:768px){.config-grid{grid-template-columns:1fr}}.config-right{display:flex;flex-direction:column;gap:16px}.selected-target{background:var(--surface2);padding:10px 12px;border-radius:6px;margin-bottom:10px;font-size:13px;border-left:3px solid var(--accent)}.search-input{width:100%;padding:8px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px;margin-bottom:8px}.search-input:focus{outline:none;border-color:var(--accent)}.question-list{max-height:200px;overflow-y:auto;border:1px solid var(--border);border-radius:6px}.question-item{display:flex;gap:8px;align-items:center;padding:6px 10px;cursor:pointer;font-size:12px;border-bottom:1px solid var(--border);transition:background .15s}.question-item:hover{background:var(--surface2)}.question-item.active{background:#6366f126;border-left:2px solid var(--accent)}.q-id{color:var(--accent);font-weight:600;min-width:60px}.q-text{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.q-count{color:var(--text-muted);font-size:11px}.data-stats{display:flex;gap:16px;margin-top:10px;font-size:12px;color:var(--text-muted)}.option-ranker{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.option-ranker h4{font-size:13px;margin-bottom:4px}.ranker-hint{font-size:11px;color:var(--text-muted);margin-bottom:8px}.rank-list{display:flex;flex-direction:column;gap:4px}.rank-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--surface2);border-radius:6px;cursor:grab;font-size:13px;transition:background .15s,border-color .15s;border:1px solid transparent;-webkit-user-select:none;user-select:none}.rank-item:active{cursor:grabbing}.rank-item.dragging{opacity:.4}.rank-item.drag-over{border-color:var(--accent);background:#6366f11a}.rank-position{min-width:20px;text-align:center;font-weight:700;color:var(--accent);font-size:12px}.rank-handle{color:var(--text-muted);font-size:14px;line-height:1}.rank-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rank-exclude{width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text-muted);font-size:11px;cursor:pointer;transition:all .15s;flex-shrink:0}.rank-exclude:hover{border-color:var(--error);color:var(--error)}.rank-exclude.active{background:#22c55e26;border-color:var(--success);color:var(--success)}.rank-exclude.active:hover{background:#22c55e40}.rank-item.excluded{opacity:.4;cursor:default;border-style:dashed}.rank-item.excluded .rank-label{text-decoration:line-through}.composite-toggle{margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.composite-check{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--surface2);border-radius:6px;cursor:pointer;transition:all .15s;border:1px solid transparent}.composite-check.active{border-color:var(--accent);background:#6366f11a}.composite-check input{accent-color:var(--accent)}.composite-check div{display:flex;flex-direction:column}.composite-check strong{font-size:12px}.composite-check small{font-size:11px;color:var(--text-muted)}.composite-partner-label{margin-top:4px;font-size:12px;color:var(--accent)}.btn-link{background:transparent;border:none;padding:0;color:var(--accent);cursor:pointer;font:inherit}.btn-link:hover{text-decoration:underline}.rank-count{font-size:10px;color:var(--text-muted);flex-shrink:0}.encoding-options{display:flex;flex-direction:column;gap:6px}.encoding-option{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--surface2);border-radius:6px;cursor:pointer;transition:all .15s}.encoding-option.active{border-left:3px solid var(--accent);background:#6366f11a}.encoding-option.disabled{opacity:.5;cursor:not-allowed}.encoding-option input[type=radio]{accent-color:var(--accent)}.encoding-option div{display:flex;flex-direction:column}.encoding-option strong{font-size:13px}.encoding-option small{color:var(--text-muted);font-size:11px}.model-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.model-check{display:flex;align-items:center;gap:6px;padding:8px 10px;background:var(--surface2);border-radius:6px;cursor:pointer;font-size:13px;transition:all .15s;border:1px solid transparent}.model-check.checked{background:#6366f126;border-color:var(--accent)}.model-check input{accent-color:var(--accent)}.model-params{border:1px solid var(--border);border-radius:6px;margin-bottom:8px;overflow:hidden}.model-params-header{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;background:var(--surface2);transition:background .15s}.model-params-header:hover{background:#6366f114}.expand-icon{font-size:10px;color:var(--text-muted)}.optuna-toggle{margin-left:auto;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--accent);cursor:pointer}.optuna-toggle input{accent-color:var(--accent)}.params-body{padding:12px;border-top:1px solid var(--border)}.manual-params{display:grid;grid-template-columns:1fr 1fr;gap:10px}.param-row{display:flex;flex-direction:column;gap:2px}.param-row label{display:flex;justify-content:space-between;align-items:center;font-size:13px}.param-row input[type=number]{width:80px;padding:4px 8px;background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:12px;text-align:right}.param-row input[type=number]:focus{outline:none;border-color:var(--accent)}.param-row small{color:var(--text-muted);font-size:11px}.optuna-config label{display:flex;align-items:center;gap:8px;font-size:13px}.optuna-config input[type=number]{width:60px;padding:4px 8px;background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);text-align:right}.muted{color:var(--text-muted);font-size:12px}.parquet-combiner code{background:var(--surface2);padding:2px 6px;border-radius:6px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;color:var(--accent)}.combiner-controls{margin-top:10px}.combiner-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}@media(max-width:768px){.combiner-grid{grid-template-columns:1fr}}.combiner-control{display:flex;flex-direction:column;gap:6px}.combiner-label{font-size:12px;color:var(--text);font-weight:600}.combiner-sub{font-size:11px;color:var(--text-muted)}.combiner-input,.combiner-select,.file-input{width:100%;padding:8px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px}.combiner-input:focus,.combiner-select:focus,.file-input:focus{outline:none;border-color:var(--accent)}.file-list{margin-top:12px;border:1px solid var(--border);border-radius:8px;overflow:hidden}.file-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 10px;border-bottom:1px solid var(--border);background:#ffffff05}.file-row:last-child{border-bottom:none}.file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.file-size{flex-shrink:0;font-size:11px;color:var(--text-muted)}.combiner-actions{display:flex;align-items:center;gap:12px;margin-top:14px;flex-wrap:wrap}.combiner-success{font-size:12px;color:var(--success)}.combiner-error{margin-top:10px;color:var(--error);font-size:13px}.combiner-warning{margin-top:10px;padding:10px 12px;border-radius:8px;border:1px solid rgba(245,158,11,.35);background:#f59e0b14;color:var(--warning);font-size:12px}.btn-subtle{padding:6px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:12px;cursor:pointer;transition:border-color .15s,background .15s}.btn-subtle:hover{border-color:#6366f18c;background:#6366f114}.parquet-columns{margin-top:12px}.parquet-columns-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}.parquet-columns-list{max-height:280px;overflow-y:auto;border:1px solid var(--border);border-radius:8px}.parquet-col{display:flex;align-items:center;gap:8px;padding:7px 10px;border-bottom:1px solid var(--border);background:#ffffff05;font-size:12px}.parquet-col:last-child{border-bottom:none}.parquet-col.checked{background:#6366f11f}.parquet-col input[type=checkbox]{accent-color:var(--accent)}.parquet-col-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px}.parquet-col-tag{flex-shrink:0;font-size:10px;color:var(--text-muted);border:1px solid var(--border);padding:1px 8px;border-radius:999px}.parquet-col-tag.accent{color:var(--accent);border-color:#6366f173;background:#6366f114}.parquet-output{margin-top:16px;padding-top:14px;border-top:1px solid var(--border)}.parquet-output h4{font-size:13px;margin-bottom:6px}.parquet-preview{margin-top:14px}.parquet-order-list{max-height:320px;overflow-y:auto}.train-actions{text-align:center;margin:16px 0}.btn-train{padding:12px 40px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-train:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.btn-train:disabled{opacity:.5;cursor:not-allowed}.time-estimate{margin-top:8px;font-size:13px;color:var(--text-muted)}.progress-tracker{border-left:3px solid var(--accent)}.progress-tracker.error{border-left-color:var(--error)}.progress-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.progress-timing{display:flex;gap:12px;font-size:12px;margin-left:auto}.progress-elapsed{color:var(--text-muted)}.progress-eta{color:var(--accent);font-weight:500}.btn-cancel{padding:4px 12px;background:transparent;border:1px solid var(--error);color:var(--error);border-radius:4px;font-size:12px;cursor:pointer}.progress-bar-container{position:relative;height:24px;background:var(--surface2);border-radius:12px;overflow:hidden;margin-bottom:8px}.progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),#a78bfa);border-radius:12px;transition:width .3s ease}.progress-pct{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:11px;font-weight:600}.progress-message{font-size:13px;margin-bottom:8px}.progress-log{max-height:150px;overflow-y:auto;font-size:11px;font-family:SF Mono,Monaco,Consolas,monospace;color:var(--text-muted)}.log-entry{padding:2px 0}.log-entry.done{color:var(--success)}.results-meta{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px;font-size:12px;color:var(--text-muted)}.results-meta span{background:var(--surface2);padding:4px 10px;border-radius:4px}.metrics-table{margin-bottom:16px;overflow-x:auto}.metrics-table table{width:100%;border-collapse:collapse;font-size:13px}.metrics-table th{text-align:left;padding:8px 12px;background:var(--surface2);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.metrics-table th:hover{background:#6366f11a}.metrics-table td{padding:8px 12px;border-bottom:1px solid var(--border)}.metrics-table td.best{color:var(--success);font-weight:600}.model-tabs{display:flex;gap:4px;margin:16px 0 12px;border-bottom:1px solid var(--border);padding-bottom:0}.tab{padding:8px 16px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:13px;border-bottom:2px solid transparent;transition:all .15s}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.model-details{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start}@media(max-width:768px){.model-details{grid-template-columns:1fr}}.confusion-matrix,.feature-importance,.model-comparison-chart{background:var(--surface2);border-radius:8px;padding:12px}.confusion-matrix h4,.feature-importance h4,.model-comparison-chart h4{font-size:13px;margin-bottom:8px;color:var(--text-muted)}.confusion-matrix svg,.feature-importance svg,.model-comparison-chart svg{display:block;margin:0 auto}.confusion-matrix text,.feature-importance text,.model-comparison-chart text{fill:var(--text)}.error-banner{background:#ef44441a;border-color:var(--error);display:flex;justify-content:space-between;align-items:center;color:var(--error)}.error-banner button{background:transparent;border:1px solid var(--error);color:var(--error);padding:2px 8px;border-radius:4px;cursor:pointer;font-size:11px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px;color:var(--text-muted);font-size:14px}.loading-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.offline-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px 20px;text-align:center}.offline-title{font-size:36px;background:linear-gradient(135deg,var(--accent),#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:4px}.offline-subtitle{font-size:18px;color:var(--text);margin-bottom:16px}.offline-message{color:var(--text-muted);font-size:14px;line-height:1.7;margin-bottom:28px}.offline-message strong{color:var(--warning);letter-spacing:.5px}.btn-retry{padding:12px 32px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;margin-bottom:32px}.btn-retry:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.btn-retry:disabled{opacity:.6;cursor:not-allowed}.offline-help{color:var(--text-muted);font-size:12px;display:flex;flex-direction:column;align-items:center;gap:6px}.offline-help code{background:var(--surface2);padding:6px 14px;border-radius:6px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;color:var(--accent)}.offline-hint{margin-top:2px}.offline-scene{position:relative;width:320px;height:180px;margin-bottom:24px;overflow:hidden}.tunnel{position:absolute;right:30px;bottom:40px;width:60px;height:70px;background:var(--surface2);border-radius:30px 30px 0 0;border:3px solid var(--border);border-bottom:none}.tunnel-opening{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:28px;height:40px;background:var(--bg);border-radius:14px 14px 0 0}.whale{position:absolute;bottom:30px;left:0;animation:whale-ram 2.5s ease-in-out infinite}@keyframes whale-ram{0%{transform:translate(20px)}45%{transform:translate(160px)}55%{transform:translate(140px)}65%{transform:translate(160px)}75%{transform:translate(130px)}to{transform:translate(20px)}}.whale-body{position:relative;width:100px;height:56px;background:linear-gradient(180deg,#6366f1,#4f46e5);border-radius:50px 30px 30px 50px}.whale-eye{position:absolute;top:14px;right:18px;width:8px;height:8px;background:#fff;border-radius:50%}.whale-eye:after{content:"";position:absolute;top:2px;right:1px;width:4px;height:4px;background:var(--bg);border-radius:50%}.whale-mouth{position:absolute;top:28px;right:10px;width:14px;height:6px;border-bottom:2px solid rgba(255,255,255,.4);border-radius:0 0 7px 7px}.whale-fin{position:absolute;top:-12px;left:40px;width:20px;height:18px;background:#4f46e5;border-radius:0 12px 0 0;transform:skew(-15deg)}.whale-tail{position:absolute;top:8px;left:-20px;width:24px;height:24px;border-top:8px solid #4f46e5;border-left:8px solid #4f46e5;border-radius:12px 0 0;transform:rotate(-10deg)}.whale-tail:after{content:"";position:absolute;top:-8px;left:0;width:24px;height:24px;border-bottom:8px solid #4f46e5;border-left:8px solid #4f46e5;border-radius:0 0 0 12px;transform:rotate(0)}.whale-spout{position:absolute;top:-8px;right:30px;width:4px;height:0;animation:spout 2.5s ease-in-out infinite}.whale-spout:before,.whale-spout:after{content:"";position:absolute;bottom:0;width:6px;height:6px;background:#6366f166;border-radius:50%}.whale-spout:before{left:-6px;animation:spout-drop 2.5s ease-in-out infinite}.whale-spout:after{left:4px;animation:spout-drop 2.5s ease-in-out infinite .15s}@keyframes spout{0%,40%{height:0;opacity:0}60%{height:20px;opacity:1}80%{height:24px;opacity:.6}to{height:0;opacity:0}}@keyframes spout-drop{0%,40%{transform:translateY(0);opacity:0}55%{transform:translateY(-16px);opacity:1}75%{transform:translateY(-22px);opacity:.5}to{transform:translateY(0);opacity:0}}.output-preview{margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.output-preview h4{font-size:14px;margin-bottom:12px;color:var(--text)}.output-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:12px}.output-actions{display:flex;gap:10px;align-items:center}.btn-download{padding:6px 14px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:12px;cursor:pointer;transition:background .15s}.btn-download:hover{background:var(--accent-hover)}.output-loading,.output-empty,.output-error{padding:24px;text-align:center;color:var(--text-muted);font-size:13px}.output-error{color:var(--error);background:#ef44441a;border-radius:6px}.column-selector{position:relative}.column-selector-trigger{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:12px;cursor:pointer;transition:border-color .15s}.column-selector-trigger:hover{border-color:var(--accent)}.column-selector-dropdown{position:absolute;top:100%;right:0;margin-top:4px;min-width:280px;max-width:360px;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #0006;z-index:100;overflow:hidden}.column-limit-warning{padding:8px 12px;background:#f59e0b1a;color:var(--warning);font-size:11px;border-bottom:1px solid var(--border)}.column-group{border-bottom:1px solid var(--border)}.column-group:last-child{border-bottom:none}.column-group-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--surface2);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.column-group-actions{display:flex;gap:6px}.column-group-actions button{padding:2px 6px;background:transparent;border:1px solid var(--border);border-radius:3px;color:var(--text-muted);font-size:10px;cursor:pointer;transition:all .15s}.column-group-actions button:hover{border-color:var(--accent);color:var(--accent)}.column-list{padding:6px}.column-list.scrollable{max-height:200px;overflow-y:auto}.column-item{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:12px;transition:background .15s}.column-item:hover{background:var(--surface2)}.column-item.checked{background:#6366f11a}.column-item input{accent-color:var(--accent)}.column-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.column-tag{padding:1px 5px;border-radius:3px;font-size:9px;font-weight:600;text-transform:uppercase}.column-tag.prediction{background:#6366f133;color:var(--accent)}.data-table-wrapper{overflow-x:auto;border:1px solid var(--border);border-radius:6px}.data-table{width:100%;border-collapse:collapse;font-size:12px;white-space:nowrap}.data-table th{position:sticky;top:0;background:var(--surface2);padding:8px 12px;text-align:left;font-weight:600;border-bottom:1px solid var(--border);max-width:150px;overflow:hidden;text-overflow:ellipsis}.data-table td{padding:6px 12px;border-bottom:1px solid var(--border);max-width:150px;overflow:hidden;text-overflow:ellipsis}.data-table td.prediction{color:var(--accent);font-family:SF Mono,Monaco,Consolas,monospace}.data-table tr:hover td{background:var(--surface2)}.data-table-empty{padding:24px;text-align:center;color:var(--text-muted);font-size:13px}.output-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding-top:12px;border-top:1px solid var(--border);font-size:12px}.row-info{color:var(--text-muted)}.page-controls{display:flex;align-items:center;gap:10px}.page-controls button{padding:4px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:12px;cursor:pointer;transition:all .15s}.page-controls button:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.page-controls button:disabled{opacity:.4;cursor:not-allowed}
