:root{--bg: #0b0c0e;--surface: #111316;--surface2: #181b20;--surface3: #1e2229;--border: #2a2e38;--border2: #353a47;--accent: #00e5a0;--accent2: #00b87d;--accent-dim: rgba(0, 229, 160, .12);--accent-glow: rgba(0, 229, 160, .25);--text: #e8eaf0;--text2: #8c92a4;--text3: #555d6e;--danger: #ff4d6a;--danger-dim: rgba(255, 77, 106, .12);--warning: #ffb83f;--warning-dim: rgba(255, 184, 63, .12);--success: #00e5a0;--radius: 6px;--radius2: 10px;--font-display: "Syne", sans-serif;--font-mono: "JetBrains Mono", monospace;--transition: .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased}body{background:var(--bg);color:var(--text);font-family:var(--font-mono);line-height:1.6;min-height:100vh}.app{display:flex;flex-direction:column;min-height:100vh}.header{display:flex;align-items:center;justify-content:space-between;padding:18px 40px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:100}.header-logo{display:flex;align-items:center;gap:12px}.header-logo-mark{width:32px;height:32px;background:var(--accent);border-radius:4px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:16px;color:var(--bg)}.header-title{font-family:var(--font-display);font-size:18px;font-weight:700;letter-spacing:-.3px;color:var(--text)}.header-subtitle{font-size:11px;color:var(--text3);letter-spacing:.08em;text-transform:uppercase}.main{flex:1;padding:40px;max-width:1400px;margin:0 auto;width:100%}.section-label{font-family:var(--font-display);font-size:11px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:20px;display:flex;align-items:center;gap:8px}.section-label:after{content:"";flex:1;height:1px;background:var(--border)}.upload-zone{border:2px dashed var(--border2);border-radius:var(--radius2);padding:60px 40px;text-align:center;cursor:pointer;transition:border-color var(--transition),background var(--transition);background:var(--surface);position:relative;overflow:hidden}.upload-zone:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 100%,var(--accent-dim) 0%,transparent 70%);opacity:0;transition:opacity .3s}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent)}.upload-zone:hover:before,.upload-zone.drag-over:before{opacity:1}.upload-icon{width:56px;height:56px;margin:0 auto 20px;border:2px solid var(--border2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text2);transition:border-color var(--transition),color var(--transition)}.upload-zone:hover .upload-icon,.upload-zone.drag-over .upload-icon{border-color:var(--accent);color:var(--accent)}.upload-heading{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--text);margin-bottom:8px}.upload-sub{color:var(--text2);font-size:13px;margin-bottom:24px}.upload-sub span{color:var(--accent)}.file-input{display:none}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius);font-family:var(--font-mono);font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all var(--transition);text-decoration:none;white-space:nowrap}.btn-primary{background:var(--accent);color:var(--bg);border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent2);border-color:var(--accent2);box-shadow:0 0 20px var(--accent-glow)}.btn-ghost{background:transparent;color:var(--text2);border-color:var(--border2)}.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--border2);background:var(--surface3)}.btn-danger{background:var(--danger-dim);color:var(--danger);border-color:var(--danger)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-sm{padding:6px 12px;font-size:12px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:500}.badge-success{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(0,229,160,.3)}.badge-danger{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(255,77,106,.3)}.badge-type{background:var(--surface3);color:var(--text3);border:1px solid var(--border);font-family:var(--font-mono);font-size:10px}.alert{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:var(--radius);font-size:13px;border:1px solid}.alert-success{background:var(--accent-dim);border-color:#00e5a04d;color:var(--accent)}.alert-error{background:var(--danger-dim);border-color:#ff4d6a4d;color:var(--danger)}.alert-warning{background:var(--warning-dim);border-color:#ffb83f4d;color:var(--warning)}.file-preview{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);margin-top:16px}.file-preview-info{display:flex;align-items:center;gap:12px}.file-icon{width:36px;height:36px;background:var(--accent-dim);border:1px solid rgba(0,229,160,.3);border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:12px;font-weight:700}.file-name{font-size:13px;color:var(--text);font-weight:500}.file-meta{font-size:11px;color:var(--text3);margin-top:2px}.table-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;flex-wrap:wrap}.table-toolbar-left{display:flex;align-items:center;gap:12px;flex:1;min-width:200px}.search-wrap{position:relative;flex:1;max-width:360px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text3);pointer-events:none}.search-input{width:100%;padding:9px 12px 9px 36px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-mono);font-size:13px;transition:border-color var(--transition);outline:none}.search-input:focus{border-color:var(--accent)}.search-input::placeholder{color:var(--text3)}.page-size-select{padding:9px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-mono);font-size:13px;cursor:pointer;outline:none}.table-stats{font-size:12px;color:var(--text3);white-space:nowrap}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius2);background:var(--surface)}table{width:100%;border-collapse:collapse;font-size:13px}thead{background:var(--surface2);border-bottom:1px solid var(--border)}th{padding:12px 16px;text-align:left;font-family:var(--font-display);font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text2);white-space:nowrap;-webkit-user-select:none;user-select:none;cursor:pointer;transition:color var(--transition),background var(--transition)}th:hover{color:var(--text);background:var(--surface3)}th.sorted{color:var(--accent)}.sort-indicator{display:inline-flex;flex-direction:column;gap:1px;margin-left:6px;vertical-align:middle}tbody tr{border-bottom:1px solid var(--border);transition:background var(--transition)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--surface2)}td{padding:11px 16px;color:var(--text);max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}td.null-cell{color:var(--text3);font-style:italic}td.bool-true{color:var(--accent)}td.bool-false{color:var(--danger)}.pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:20px;flex-wrap:wrap}.page-btn{min-width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text2);font-family:var(--font-mono);font-size:13px;cursor:pointer;transition:all var(--transition);padding:0 10px}.page-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.page-btn.active{background:var(--accent);border-color:var(--accent);color:var(--bg);font-weight:700}.page-btn:disabled{opacity:.3;cursor:not-allowed}.page-ellipsis{color:var(--text3);padding:0 4px}.history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}.history-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);padding:18px;cursor:pointer;transition:border-color var(--transition),background var(--transition)}.history-card:hover{border-color:var(--accent);background:var(--surface2)}.history-card.active-card{border-color:var(--accent);background:var(--accent-dim)}.history-filename{font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--text);margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.history-table-name{font-size:11px;color:var(--text3);font-family:var(--font-mono)}.spinner-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;gap:16px;color:var(--text3);font-size:13px}.spinner{width:36px;height:36px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.progress-wrap{margin-top:20px}.progress-label{display:flex;justify-content:space-between;font-size:12px;color:var(--text2);margin-bottom:8px}.progress-bar{height:4px;background:var(--surface3);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease;box-shadow:0 0 8px var(--accent-glow)}.empty-state{text-align:center;padding:60px 40px;color:var(--text3)}.empty-state-icon{font-size:40px;margin-bottom:16px;opacity:.4}.empty-state h3{font-family:var(--font-display);font-size:16px;color:var(--text2);margin-bottom:8px}.empty-state p{font-size:13px}.schema-preview{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.schema-col{display:flex;align-items:center;gap:6px;padding:5px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:20px;font-size:12px}.schema-col-name{color:var(--text);font-family:var(--font-mono)}.divider{height:1px;background:var(--border);margin:32px 0}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);padding:24px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:28px}.tab{padding:10px 20px;font-family:var(--font-mono);font-size:13px;color:var(--text3);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition);margin-bottom:-1px;background:none;border-top:none;border-left:none;border-right:none}.tab:hover{color:var(--text)}.tab.active-tab{color:var(--accent);border-bottom-color:var(--accent)}.type-text{color:#7eb6ff}.type-integer{color:#ff9f7e}.type-numeric{color:#ffce7e}.type-boolean{color:#a0e5a0}.type-date{color:#d4a0ff}.type-timestamp{color:#ff9fd4}@media (max-width: 768px){.header{padding:14px 20px}.main{padding:24px 16px}.table-toolbar{flex-direction:column;align-items:stretch}.search-wrap{max-width:100%}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:999}.modal-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);padding:24px;box-shadow:0 0 40px #0009;animation:modalFade .2s ease;width:90%;max-width:320px}.modal-card-lg{max-width:500px}.modal-title{font-family:var(--font-display);font-size:16px;font-weight:700;margin-bottom:12px;color:var(--text)}.modal-text{font-size:13px;color:var(--text2);margin-bottom:20px;line-height:1.5}.modal-highlight{display:block;margin-top:6px;color:var(--accent);font-family:var(--font-mono);font-size:12px;word-break:break-all}.modal-actions{display:flex;justify-content:flex-end;gap:10px}@keyframes modalFade{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
