.app{min-height:100vh;padding:20px}.container{margin:0 auto;max-width:900px}.header{color:#fff;margin-bottom:40px;text-align:center}.logo-container{align-items:center;display:flex;gap:15px;justify-content:center}.logo{border-radius:12px;box-shadow:0 4px 12px #0003;height:60px;width:60px}.header h1{font-size:2.5rem;margin-bottom:10px;text-shadow:0 2px 10px #0000004d}.header p{font-size:1.1rem;opacity:.9}.config-group{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;padding:20px}.config-group label{color:#333;display:block;font-weight:600;margin-bottom:8px}.config-group input,.config-group select{background:#fff;border:1px solid #ddd;border-radius:8px;color:#333;font-size:1rem;padding:12px;transition:border-color .3s ease;width:100%}.config-group input:focus,.config-group select:focus{border-color:#667eea;outline:none}.main-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 20px 40px #0000001a;padding:40px}.connection-status{border-radius:10px;font-weight:500;margin-bottom:20px;padding:15px;text-align:center}.connection-status.connected{background:#d1fae5;border:1px solid #10b981;color:#047857}.connection-status.disconnected{background:#fef2f2;border:1px solid #ef4444;color:#dc2626}.test-connection-btn{background:linear-gradient(135deg,#ff9a3c,#ff4500);border:none;border-radius:4px;color:#fff;cursor:pointer;transition:background .2s ease}.test-connection-btn:hover{background:linear-gradient(135deg,#ff8a1c,#ff3500)}.test-result{font-size:.9rem;margin-top:10px;padding:8px 12px}.upload-area{border:2px dashed #667eea;border-radius:15px;cursor:pointer;margin-bottom:30px;padding:60px 20px;position:relative;text-align:center;transition:all .3s ease}.upload-area.dragover,.upload-area:hover:not(.disabled){background:#667eea0d;border-color:#764ba2;transform:translateY(-2px)}.upload-area.disabled{cursor:not-allowed;opacity:.5}.upload-icon{color:#667eea;font-size:4rem;margin-bottom:20px}.upload-text{color:#333;font-size:1.2rem;margin-bottom:10px}.upload-hint{color:#666;font-size:.9rem}.config-section{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:30px}.upload-btn{background:linear-gradient(135deg,#ff9a3c,#ff4500);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-bottom:20px;padding:15px;transition:all .3s ease;width:100%}.upload-btn:hover:not(:disabled){box-shadow:0 10px 20px #ff9a3c4d;transform:translateY(-2px)}.upload-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.file-list{margin-top:30px}.file-list h3{color:#333;margin-bottom:20px}.file-item{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;display:flex;justify-content:space-between;margin-bottom:15px;padding:20px}.file-info{flex:1 1}.file-name{color:#333;font-weight:600;margin-bottom:5px}.file-details{color:#666;font-size:.9rem}.file-actions{display:flex;gap:10px}.btn{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,#ff9a3c,#ff4500);color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#ff8a1c,#ff3500)}.btn-danger{background:linear-gradient(135deg,#ff9a3c,#ff4500);color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#ff8a1c,#ff3500)}.uploaded-files{margin-top:30px}.uploaded-files h3{color:#333;margin-bottom:20px}.uploaded-item{background:#e8f5e8;border:1px solid #28a745;border-radius:10px;margin-bottom:10px;padding:15px}.uploaded-item .file-name{color:#155724}.share-info{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;margin-top:10px;padding:15px}.share-link{background:#fff;border:1px solid #ddd;border-radius:4px;font-family:monospace;margin:5px 0;padding:8px;word-break:break-all}.link-modal{align-items:center;background:#000000b3;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.modal-content{background:#fff;border-radius:15px;max-height:80vh;max-width:600px;overflow-y:auto;padding:30px;width:90%}.modal-header{margin-bottom:20px}.modal-header h3{color:#333;margin-bottom:10px}.share-content,.share-item{margin-bottom:20px}.share-item{border:1px solid #ddd;border-radius:8px;padding:15px}.share-item h4{color:#333}.link-group,.share-item h4{margin-bottom:10px}.link-input{background:#f8f9fa;border:1px solid #ddd;border-radius:8px;font-size:1rem;margin-top:5px;padding:12px;width:100%}.expire-info{color:#666;font-size:.9rem;margin-top:10px}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.bucket-setup-guide{background:#fff3cd;border:1px solid #ffc107;border-radius:12px;margin-bottom:20px;padding:20px}.bucket-setup-guide h3,.bucket-setup-guide p{color:#856404;margin-bottom:15px}.setup-steps{margin:20px 0}.step{background:#fff;border-left:4px solid #ffc107;border-radius:8px;margin-bottom:20px;padding:15px}.step h4{color:#333}.step h4,.step p{margin-bottom:8px}.step p{color:#666}.step code{border-radius:4px;color:#e83e8c;padding:2px 6px}.sql-code,.step code{background:#f8f9fa;font-family:monospace}.sql-code{border:1px solid #e9ecef;border-radius:6px;color:#333;font-size:.9rem;margin-top:10px;overflow-x:auto;padding:15px}.note{background:#d1ecf1;border:1px solid #bee5eb;border-radius:8px;margin-top:20px;padding:15px}.note,.note strong{color:#0c5460}.quick-fix{background:#d4edda;border:1px solid #c3e6cb;border-radius:8px;margin-top:20px;padding:20px}.quick-fix h4{color:#155724;margin-bottom:10px}.quick-fix p{color:#155724;margin-bottom:15px}.copy-sql-btn{background:linear-gradient(135deg,#ff9a3c,#ff4500);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .3s ease}.copy-sql-btn:hover{background:linear-gradient(135deg,#ff8a1c,#ff3500)!important;box-shadow:0 10px 20px #ff9a3c4d;transform:translateY(-2px)}.connection-test{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;margin-bottom:20px;padding:20px}.connection-test h3{color:#333;margin-bottom:10px}.connection-test p{color:#666;margin-bottom:15px}.test-btn{background:linear-gradient(135deg,#ff9a3c,#ff4500);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:background .2s ease}.test-btn:hover:not(:disabled){background:linear-gradient(135deg,#ff8a1c,#ff3500)}.test-btn:disabled{background:#6c757d;cursor:not-allowed}.test-result{border-radius:6px;font-weight:500;margin-top:15px;padding:10px}.test-result.success{background:#d1fae5;border:1px solid #10b981;color:#047857}.test-result.error{background:#fef2f2;border:1px solid #ef4444;color:#dc2626}.notification{border-radius:8px;color:#fff;font-weight:500;max-width:350px;padding:15px 25px;position:fixed;right:20px;top:20px;transform:translateX(400px);transition:transform .3s ease;z-index:1001}.notification.success{background:#28a745}.notification.error{background:#dc3545}.notification.show{transform:translateX(0)}.file-preview{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;margin:0 auto;max-width:600px;padding:40px;text-align:center}.file-preview.expired{background:#f8f9fa;border:2px solid #dc3545}.file-header{align-items:center;display:flex;gap:20px;justify-content:center;margin-bottom:30px}.file-icon{font-size:4rem;margin-right:20px}.file-title h2{color:#333;margin-bottom:10px;word-break:break-all}.file-size{color:#666;font-size:1.1rem;margin:0}.file-details{background:#f8f9fa;border-radius:12px;margin-bottom:30px;padding:20px;text-align:left}.detail-item{border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:10px;padding:8px 0}.detail-item:last-child{border-bottom:none;margin-bottom:0}.label{color:#333;font-weight:600}.value{color:#666}.extract-code-section{margin-bottom:30px}.extract-code-section label{color:#333;display:block;font-weight:600;margin-bottom:10px}.extract-code-section input{border:2px solid #ddd;border-radius:8px;font-size:1.1rem;letter-spacing:2px;padding:12px;text-align:center;transition:border-color .3s ease;width:200px}.extract-code-section input:focus{border-color:#667eea;outline:none}.extract-code-section input.error{border-color:#dc3545}.error-message{color:#dc3545;font-size:.9rem;margin-top:8px}.download-section{margin-bottom:30px}.download-btn{background:linear-gradient(135deg,#ff9a3c,#ff4500);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:1.2rem;font-weight:600;min-width:200px;padding:15px 40px;transition:all .3s ease}.download-btn:hover:not(:disabled){box-shadow:0 10px 20px #ff9a3c4d;transform:translateY(-2px)}.download-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.file-warning{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;color:#856404;font-size:.9rem;padding:15px}.download-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:40px 20px}.download-header{color:#fff;margin-bottom:40px;text-align:center}.download-header h1{font-size:2.5rem;margin-bottom:10px;text-shadow:0 2px 10px #0000004d}.download-header p{font-size:1.1rem;opacity:.9}.loading{color:#fff;text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:40px;margin:0 auto 20px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-page{color:#fff;max-width:400px;text-align:center}.error-icon{font-size:4rem;margin-bottom:20px}.error-page h2{margin-bottom:15px}.error-page p{margin-bottom:30px;opacity:.9}.back-btn{background:linear-gradient(135deg,#ff9a3c,#ff4500);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;padding:12px 24px;transition:all .3s ease}.back-btn:hover{background:linear-gradient(135deg,#ff8a1c,#ff3500);box-shadow:0 10px 20px #ff9a3c4d;transform:translateY(-2px)}@media (max-width:768px){.config-section{grid-template-columns:1fr}.file-preview{margin:20px;padding:20px}.file-header{flex-direction:column;gap:10px}.file-icon{font-size:3rem;margin-right:0}.extract-code-section input{width:150px}.main-card{padding:20px}.header h1{font-size:2rem}.upload-area{padding:40px 20px}.modal-content{padding:20px;width:95%}.modal-actions{flex-direction:column}.btn{width:100%}}
/*# sourceMappingURL=main.6a6c72e5.css.map*/