*{box-sizing:border-box}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--text: #07150d;--background: #f5fbf7;--primary: #45be78;--secondary: #9dcedd;--accent: #70a3cd}body{margin:0;min-width:320px;min-height:100vh;background:var(--background);color:var(--text)}#root{min-height:100vh}.app-container{min-height:100vh;display:flex;flex-direction:column;background:var(--background)}.app-header{background:#fff;padding:2rem;text-align:center;box-shadow:0 2px 10px #0000001a}.app-header h1{margin:0 0 .5rem;font-size:2.5rem;color:var(--primary)}.app-header p{margin:0;color:var(--text);opacity:.7;font-size:1.1rem}.app-main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:2rem;display:flex;flex-direction:column;gap:2rem}.section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000001a}.section h2{margin:0 0 1.5rem;font-size:1.5rem;color:var(--text);border-bottom:2px solid var(--primary);padding-bottom:.5rem}.upload-container{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.upload-actions{display:flex;gap:.5rem;align-items:center}.file-input{display:none}.file-label{flex:1;min-width:200px;padding:.75rem 1rem;border:2px dashed var(--accent);border-radius:8px;background:var(--background);color:var(--accent);cursor:pointer;text-align:center;transition:all .3s ease;font-weight:500}.file-label:hover{background:var(--secondary);border-color:var(--primary);color:var(--primary)}.upload-button,.execute-button{padding:.75rem 2rem;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease;box-shadow:0 2px 4px #45be784d}.upload-button:hover,.execute-button:hover{transform:translateY(-2px);box-shadow:0 4px 8px #45be7866;background:#3aa866}.upload-button:active,.execute-button:active{transform:translateY(0)}.upload-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.cancel-button{padding:.75rem 1.5rem;background:#dc3545;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease;box-shadow:0 2px 4px #dc35454d}.cancel-button:hover{transform:translateY(-2px);box-shadow:0 4px 8px #dc354566;background:#c82333}.cancel-button:active{transform:translateY(0)}.progress-container{margin-top:1.5rem;display:flex;align-items:center;gap:1rem}.progress-bar{flex:1;height:24px;background:var(--background);border-radius:12px;overflow:hidden;border:2px solid var(--secondary)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));transition:width .3s ease;border-radius:10px}.progress-text{font-weight:600;color:var(--text);min-width:50px;text-align:right}.preview-pane{margin-top:2rem;padding:1.5rem;background:var(--background);border-radius:8px;border:2px solid var(--secondary)}.preview-pane h3{margin:0 0 1.5rem;font-size:1.5rem;color:var(--text);border-bottom:2px solid var(--primary);padding-bottom:.5rem}.preview-pane h4{margin:1.5rem 0 1rem;font-size:1.2rem;color:var(--text)}.preview-notice{padding:.75rem 1rem;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;color:#856404;margin-bottom:1rem;font-size:.9rem}.preview-warning{padding:1.5rem;text-align:center;background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#721c24;margin-top:1rem}.preview-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.info-item{padding:.75rem;background:#fff;border-radius:6px;border:1px solid var(--secondary);color:var(--text)}.info-item strong{display:block;margin-bottom:.25rem;color:var(--primary)}.preview-columns{margin-bottom:1.5rem}.columns-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.column-tag{padding:.5rem 1rem;background:var(--primary);color:#fff;border-radius:20px;font-size:.9rem;font-weight:500}.preview-table-container{margin-top:1.5rem}.preview-table-wrapper{overflow-x:auto;max-height:500px;overflow-y:auto;border:1px solid var(--secondary);border-radius:8px;margin-top:.5rem}.preview-table{width:100%;border-collapse:collapse;background:#fff;font-size:.85rem}.preview-table thead{position:sticky;top:0;background:var(--accent);color:#fff;z-index:10}.preview-table th{padding:.75rem;text-align:left;font-weight:600;border-right:1px solid rgba(255,255,255,.2)}.preview-table th:last-child{border-right:none}.preview-table td{padding:.5rem .75rem;border-bottom:1px solid var(--background);border-right:1px solid var(--background);color:var(--text)}.preview-table td:last-child{border-right:none}.preview-table tbody tr:hover{background:var(--background)}.preview-table tbody tr:last-child td{border-bottom:none}.query-textarea{width:100%;padding:1rem;border:2px solid var(--secondary);border-radius:8px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.95rem;resize:vertical;transition:border-color .3s ease;margin-bottom:1rem;color:var(--text);background:var(--background)}.query-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #70a3cd1a}.execute-button{width:100%}.error-message{padding:1rem;background:#fee;border:2px solid #fcc;border-radius:8px;color:#c33;margin-bottom:1rem}.empty-placeholder{padding:3rem 2rem;text-align:center;color:var(--text);opacity:.6;border:2px dashed var(--secondary);border-radius:8px;background:var(--background)}.empty-placeholder p{margin:.5rem 0;font-size:1.1rem}.placeholder-hint{font-size:.9rem!important;color:var(--text);opacity:.5}.results-table-container{overflow-x:auto;border-radius:8px;border:1px solid var(--secondary)}.results-table{width:100%;border-collapse:collapse;background:#fff}.results-table thead{background:var(--primary);color:#fff}.results-table th{padding:1rem;text-align:left;font-weight:600;font-size:.95rem}.results-table td{padding:.75rem 1rem;border-bottom:1px solid var(--background);font-size:.9rem;color:var(--text)}.results-table tbody tr:hover{background:var(--background)}.results-table tbody tr:last-child td{border-bottom:none}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.query-time{font-size:.9rem;color:var(--text);opacity:.7;font-weight:400}.results-info{margin-bottom:1rem;padding:.75rem;background:var(--background);border-radius:6px;font-size:.9rem;color:var(--text);display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.results-info-left{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.results-pagination{color:var(--text);opacity:.6}.pagination-controls{margin-top:1rem;text-align:center}.load-more-button{padding:.75rem 2rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease;box-shadow:0 2px 4px #70a3cd4d}.load-more-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #70a3cd66;background:#5a8fb8}.load-more-button:disabled{opacity:.6;cursor:not-allowed}.export-button{padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease;box-shadow:0 2px 4px #70a3cd4d;font-family:Chiron GoRound TC,sans-serif;font-weight:700;white-space:nowrap}.export-button:hover{transform:translateY(-2px);box-shadow:0 4px 8px #70a3cd66;background:#5a8fb8}.export-button:active{transform:translateY(0)}.query-help{margin-bottom:1rem;padding:1rem;background:var(--background);border-radius:8px;border:1px solid var(--secondary)}.query-help p{margin:0 0 .5rem;color:var(--text);font-size:.95rem}.query-help code{background:#fff;padding:.2rem .4rem;border-radius:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9rem;color:var(--primary);font-weight:600}.query-examples{margin-top:.75rem}.query-examples summary{cursor:pointer;color:var(--accent);font-weight:500;font-size:.9rem;-webkit-user-select:none;user-select:none}.query-examples summary:hover{color:var(--primary)}.examples-list{margin-top:.5rem;display:flex;flex-direction:column;gap:.5rem}.example-query{padding:.5rem 1rem;background:#fff;border:1px solid var(--secondary);border-radius:6px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.85rem;text-align:left;cursor:pointer;transition:all .2s ease;color:var(--text)}.example-query:hover{background:var(--background);border-color:var(--accent);color:var(--primary)}@media(max-width:768px){.app-header h1{font-size:2rem}.app-main{padding:1rem}.section{padding:1.5rem}.upload-container{flex-direction:column}.file-label,.upload-button{width:100%}.upload-actions{width:100%;flex-direction:column}.upload-button,.cancel-button{width:100%}.preview-info{grid-template-columns:1fr}.preview-table-wrapper{max-height:400px}.preview-table{font-size:.75rem}.preview-table th,.preview-table td{padding:.5rem}}
