.vue-scheduler-page{--bg: #f0f2f5;--card-bg: #fff;--text: #1a1a2e;--text-secondary: #6b7280;--text-muted: #9ca3af;--border: #e5e7eb;--primary: #4f46e5;--primary-light: #818cf8;--primary-bg: #eef2ff;--success: #059669;--success-bg: #d1fae5;--danger: #dc2626;--danger-bg: #fee2e2;--warning: #d97706;--warning-bg: #fef3c7;--info: #2563eb;--info-bg: #dbeafe;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px rgba(0,0,0,.06), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 10px 25px rgba(0,0,0,.08);--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--transition: .2s ease}.vue-scheduler-page *,.vue-scheduler-page *:before,.vue-scheduler-page *:after{margin:0;padding:0;box-sizing:border-box}.vue-scheduler-page{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased}.vue-scheduler-page ::-webkit-scrollbar{width:6px;height:6px}.vue-scheduler-page ::-webkit-scrollbar-track{background:transparent}.vue-scheduler-page ::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.vue-scheduler-page ::-webkit-scrollbar-thumb:hover{background:#9ca3af}.vue-scheduler-page>header{background:linear-gradient(135deg,#4f46e5,#7c3aed,#6366f1);color:#fff;padding:20px 32px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;box-shadow:0 2px 12px #4f46e526;position:relative;z-index:10}.vue-scheduler-page>header h1{font-size:22px;font-weight:700;letter-spacing:-.3px}.header-actions{display:flex;gap:10px}.tab-btn{padding:16px 28px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:14px;font-weight:500;color:var(--text-secondary);transition:all var(--transition);position:relative;display:inline-flex;align-items:center;gap:7px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow);transition:all var(--transition);border:1px solid transparent;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius) var(--radius) 0 0}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card .label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;font-weight:600}.stat-card .value{font-size:32px;font-weight:800;margin-top:6px;letter-spacing:-.5px}.stat-card .value.green{color:var(--success)}.stat-card .value.red{color:var(--danger)}.stat-card .value.blue{color:var(--primary)}.stat-card .value.amber{color:var(--warning)}.vue-scheduler-page table{width:100%;border-collapse:collapse;font-size:13px}.vue-scheduler-page thead{background:#f8fafc}.vue-scheduler-page th{padding:12px 16px;text-align:left;font-weight:600;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border);white-space:nowrap}.vue-scheduler-page td{padding:12px 16px;border-bottom:1px solid #f3f4f6;color:var(--text);vertical-align:middle}.vue-scheduler-page tbody tr{transition:background var(--transition)}.vue-scheduler-page tbody tr:hover{background:#f8faff}.vue-scheduler-page td code{background:#f3f4f6;padding:2px 8px;border-radius:4px;font-size:12px;color:var(--primary);font-weight:500}.toggle-switch input:focus-visible+.toggle-slider{box-shadow:0 0 0 3px #05966933}.toggle-switch input:disabled+.toggle-slider{opacity:.4;cursor:not-allowed}.btn-run{padding:4px 14px;background:var(--primary-bg);color:var(--primary);border:1px solid rgba(79,70,229,.2);border-radius:16px;cursor:pointer;font-size:12px;font-weight:500;transition:all var(--transition);display:inline-flex;align-items:center;gap:3px;white-space:nowrap}.btn-run:hover{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 8px #4f46e54d;transform:translateY(-1px)}.btn-run:active{transform:translateY(0)}.badge-disabled{background:#f3f4f6;color:#6b7280}.badge-warning{background:var(--warning-bg);color:#92400e}.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px;align-items:center;padding:14px 18px;background:#fff;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.filters .btn-search{padding:9px 18px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;transition:all var(--transition);display:inline-flex;align-items:center;gap:5px}.filters .btn-search:hover{background:#4338ca;box-shadow:0 2px 8px #4f46e54d}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#b91c1c}.vue-scheduler-page code{font-family:SF Mono,Fira Code,Cascadia Code,Consolas,monospace}@media (max-width: 768px){.vue-scheduler-page>header{padding:16px 20px;flex-direction:column;align-items:flex-start}.vue-scheduler-page>header h1{font-size:18px}.header-actions{width:100%}.header-actions button{flex:1;justify-content:center}.tab-nav{padding:0 12px;overflow-x:auto}.tab-btn{padding:14px 18px;font-size:13px;white-space:nowrap}.tab-content{padding:16px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{padding:14px 16px}.stat-card .value{font-size:24px}.filters{flex-direction:column;align-items:stretch}.filters select,.filters input[type=date]{width:100%}.card-header{padding:12px 16px}th,td{padding:10px 12px;font-size:12px}.pagination{flex-direction:column;align-items:center}}.card-hint{font-size:12px;color:var(--text-muted);font-weight:400}.status-cards{padding:16px 24px;display:flex;flex-wrap:wrap;gap:14px}.vue-api-logs-page *{margin:0;padding:0;box-sizing:border-box}.vue-api-logs-page{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;padding:20px;min-height:100vh}.vue-api-logs-page .container{max-width:1400px;margin:0 auto;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.vue-api-logs-page .header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 30px}.vue-api-logs-page .header h1{font-size:24px;margin-bottom:5px}.vue-api-logs-page .header p{opacity:.9;font-size:14px}.vue-api-logs-page .filter-section{padding:20px 30px;background:#fafafa;border-bottom:1px solid #e0e0e0}.vue-api-logs-page .filter-row{display:flex;gap:15px;flex-wrap:wrap;align-items:center}.vue-api-logs-page .filter-item{display:flex;flex-direction:column;gap:5px}.vue-api-logs-page .filter-item label{font-size:12px;color:#666;font-weight:500}.vue-api-logs-page .filter-item input,.vue-api-logs-page .filter-item select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;min-width:150px}.vue-api-logs-page .btn{padding:8px 20px;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:all .3s}.vue-api-logs-page .btn-primary{background:#667eea;color:#fff}.vue-api-logs-page .btn-primary:hover{background:#5568d3}.vue-api-logs-page .btn-secondary{background:#6c757d;color:#fff}.vue-api-logs-page .btn-secondary:hover{background:#5a6268}.vue-api-logs-page .btn-danger{background:#dc3545;color:#fff}.vue-api-logs-page .btn-danger:hover{background:#c82333}.vue-api-logs-page .table-container{padding:20px 30px;overflow-x:auto}.vue-api-logs-page table{width:100%;border-collapse:collapse}.vue-api-logs-page thead{background:#f8f9fa}.vue-api-logs-page th{padding:12px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6;white-space:nowrap}.vue-api-logs-page td{padding:12px;border-bottom:1px solid #dee2e6;color:#555}.vue-api-logs-page tbody tr:hover{background:#f8f9fa}.vue-api-logs-page .status-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.vue-api-logs-page .status-success{background:#d4edda;color:#155724}.vue-api-logs-page .status-error{background:#f8d7da;color:#721c24}.vue-api-logs-page .pagination{padding:20px 30px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid #e0e0e0}.vue-api-logs-page .pagination-info{color:#666;font-size:14px}.vue-api-logs-page .pagination-controls{display:flex;gap:10px;align-items:center}.vue-api-logs-page .page-btn{padding:6px 12px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;transition:all .3s}.vue-api-logs-page .page-btn:hover:not(:disabled){background:#667eea;color:#fff;border-color:#667eea}.vue-api-logs-page .page-btn:disabled{opacity:.5;cursor:not-allowed}.vue-api-logs-page .page-btn.active{background:#667eea;color:#fff;border-color:#667eea}.vue-api-logs-page .modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000}.vue-api-logs-page .modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;max-width:900px;width:90%;max-height:80vh;overflow-y:auto;z-index:1001}.vue-api-logs-page .modal-header{padding:20px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;background:#f8f9fa}.vue-api-logs-page .modal-header h2{font-size:18px;color:#333}.vue-api-logs-page .modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.vue-api-logs-page .modal-close:hover{color:#333}.vue-api-logs-page .modal-body{padding:20px}.vue-api-logs-page .detail-section{margin-bottom:20px}.vue-api-logs-page .detail-section h3{font-size:14px;color:#667eea;margin-bottom:10px;padding-bottom:5px;border-bottom:1px solid #e0e0e0}.vue-api-logs-page .detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:15px}.vue-api-logs-page .detail-item{display:flex;flex-direction:column;gap:5px}.vue-api-logs-page .detail-label{font-size:12px;color:#666;font-weight:500}.vue-api-logs-page .detail-value{font-size:14px;color:#333;word-break:break-all}.vue-api-logs-page .code-block{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:4px;padding:15px;font-family:Courier New,monospace;font-size:13px;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word;max-height:300px;overflow-y:auto}.vue-api-logs-page .loading{text-align:center;padding:40px;color:#666}.vue-api-logs-page .error-message{background:#f8d7da;color:#721c24;padding:15px;border-radius:4px;margin:20px 30px}.vue-redis-page{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#333;min-height:100vh;background:#f7f8fc}.vue-redis-page .dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;padding:24px 32px;background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;flex-wrap:wrap;gap:16px}.vue-redis-page .dashboard-kicker{margin:0;font-size:12px;text-transform:uppercase;letter-spacing:2px;opacity:.7}.vue-redis-page .dashboard-header h1{margin:4px 0;font-size:24px;font-weight:700}.vue-redis-page .plus-badge{display:inline-block;background:#e94560;color:#fff;font-size:10px;padding:2px 8px;border-radius:10px;vertical-align:middle;margin-left:8px}.vue-redis-page .dashboard-subtitle{margin:4px 0 0;font-size:13px;opacity:.6}.vue-redis-page .quick-links{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.vue-redis-page .quick-links a{color:#ffffffbf;text-decoration:none;font-size:13px;padding:6px 14px;border:1px solid rgba(255,255,255,.2);border-radius:6px;transition:all .2s}.vue-redis-page .quick-links a:hover{background:#ffffff1a;color:#fff;border-color:#fff6}.vue-redis-page .tab-nav{display:flex;gap:0;padding:0 24px;background:#fff;border-bottom:2px solid #eee;align-items:center}.vue-redis-page .tab-btn{padding:14px 24px;border:none;background:none;font-size:14px;font-weight:500;color:#666;cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .2s}.vue-redis-page .tab-btn:hover{color:#1a1a2e}.vue-redis-page .tab-btn.active{color:#1a1a2e;border-bottom-color:#1a1a2e;font-weight:600}.vue-redis-page .btn{padding:8px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.vue-redis-page .btn:hover{opacity:.85}.vue-redis-page .btn-primary{background:#1a1a2e;color:#fff}.vue-redis-page .btn-danger{background:#e53e3e;color:#fff}.vue-redis-page .btn-sm{padding:5px 14px;font-size:12px}.vue-redis-page .btn:disabled{opacity:.5;cursor:not-allowed}.vue-redis-page .info-card{background:#fff;border-radius:10px;padding:18px 20px;box-shadow:0 2px 8px #0000000f}.vue-redis-page .info-card-label{font-size:12px;color:#888;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.vue-redis-page .info-card-value{font-size:22px;font-weight:700;color:#1a1a2e}.vue-redis-page .cat-card{background:#fff;border-radius:10px;padding:16px;box-shadow:0 2px 8px #0000000f;transition:all .2s}.vue-redis-page .cat-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.vue-redis-page .cat-name{font-size:14px;font-weight:600;color:#1a1a2e;margin-bottom:6px}.vue-redis-page .cat-count{font-size:28px;font-weight:700;color:#e94560}.vue-redis-page .cat-patterns{margin-top:8px;font-size:11px;color:#999;line-height:1.6}.vue-redis-page .cat-patterns code{display:inline-block;background:#f0f0f5;padding:1px 6px;border-radius:3px;margin:1px;font-size:11px}.vue-redis-page .table-container{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000f}.vue-redis-page .data-table th{background:#f8f9fc;padding:12px 14px;text-align:left;font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #eee;white-space:nowrap}.vue-redis-page .data-table td{padding:10px 14px;font-size:13px;border-bottom:1px solid #f0f0f0;vertical-align:middle}.vue-redis-page .data-table tr:hover{background:#fafbfc}.vue-redis-page .data-table code{background:#f5f5f8;padding:2px 6px;border-radius:3px;font-size:12px}.vue-redis-page .key-type-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;background:#e8f0fe;color:#1a56db}.vue-redis-page .toast{padding:12px 20px;border-radius:8px;font-size:14px;color:#fff;box-shadow:0 4px 12px #0003;animation:slideInRight .3s ease}.vue-redis-page .toast-success{background:#059669}.vue-redis-page .toast-error{background:#e53e3e}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.vue-redis-page .json-preview{background:#1a1a2e;color:#e2e8f0;padding:16px;border-radius:8px;font-size:13px;line-height:1.6;overflow-x:auto;white-space:pre-wrap;word-break:break-all;max-height:400px}@keyframes spin{to{transform:rotate(360deg)}}.vue-dbsync-page{--bg: #f0f2f5;--card-bg: #fff;--text: #1a1a2e;--text-secondary: #6b7280;--text-muted: #9ca3af;--border: #e5e7eb;--primary: #4f46e5;--primary-light: #818cf8;--primary-bg: #eef2ff;--success: #059669;--success-bg: #d1fae5;--danger: #dc2626;--danger-bg: #fee2e2;--warning: #d97706;--warning-bg: #fef3c7;--info: #2563eb;--info-bg: #dbeafe;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px rgba(0,0,0,.06), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 10px 25px rgba(0,0,0,.08);--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--transition: .2s ease}.vue-dbsync-page *,.vue-dbsync-page *:before,.vue-dbsync-page *:after{margin:0;padding:0;box-sizing:border-box}.vue-dbsync-page{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased}.vue-dbsync-page ::-webkit-scrollbar{width:6px;height:6px}.vue-dbsync-page ::-webkit-scrollbar-track{background:transparent}.vue-dbsync-page ::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.vue-dbsync-page ::-webkit-scrollbar-thumb:hover{background:#9ca3af}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172ab3;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .2s ease}.login-card{background:#fff;border-radius:var(--radius-lg);padding:44px 40px;text-align:center;max-width:420px;width:92%;box-shadow:var(--shadow-lg),0 0 0 1px #0000000d;animation:scaleIn .25s ease}.login-card .login-icon{font-size:52px;margin-bottom:8px;display:block}.login-card h2{font-size:24px;font-weight:700;color:var(--text);margin-bottom:6px}.login-card p{color:var(--text-secondary);font-size:14px;margin-bottom:24px}.input-group{position:relative;margin-bottom:20px}.input-group input{width:100%;padding:14px 48px 14px 18px;border:2px solid var(--border);border-radius:var(--radius);font-size:15px;outline:none;transition:all var(--transition);background:#f9fafb}.input-group input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #4f46e51a}.toggle-pwd{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:20px;padding:4px;opacity:.5;transition:opacity var(--transition)}.toggle-pwd:hover{opacity:.8}.login-btn{width:100%;padding:14px;background:linear-gradient(135deg,var(--primary),#6366f1);color:#fff;border:none;border-radius:var(--radius);font-size:16px;font-weight:600;cursor:pointer;transition:all var(--transition);box-shadow:0 4px 12px #4f46e54d}.login-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #4f46e566}.login-btn:active{transform:translateY(0)}.login-error{color:var(--danger);font-size:13px;margin-top:12px;min-height:20px;font-weight:500}.vue-dbsync-page>header{background:linear-gradient(135deg,#0891b2,#0e7490,#155e75);color:#fff;padding:20px 32px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;box-shadow:0 2px 12px #0891b226;position:relative;z-index:10}.vue-dbsync-page>header h1{font-size:22px;font-weight:700;letter-spacing:-.3px}.header-actions{display:flex;gap:10px;align-items:center}.header-actions button{padding:9px 18px;border:1px solid rgba(255,255,255,.25);background:#ffffff1f;color:#fff;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;transition:all var(--transition);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:inline-flex;align-items:center;gap:6px}.header-actions button:hover{background:#ffffff38;transform:translateY(-1px)}.arch-badge{padding:6px 14px;background:#ffffff26;border-radius:20px;font-size:12px;font-weight:500;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.2)}.tab-nav{display:flex;background:#fff;border-bottom:1px solid var(--border);padding:0 28px;position:sticky;top:0;z-index:5;box-shadow:var(--shadow-sm)}.tab-btn{padding:16px 28px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:14px;font-weight:500;color:var(--text-secondary);transition:all var(--transition);display:inline-flex;align-items:center;gap:7px}.tab-btn:hover{color:var(--primary);background:var(--primary-bg)}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.tab-content{display:none;padding:24px 28px;animation:fadeIn .2s ease}.tab-content.active{display:block}.db-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}@media (max-width: 900px){.db-grid{grid-template-columns:1fr}}.db-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);overflow:hidden}.db-card.connected{border-top:3px solid var(--success)}.db-card.disconnected{border-top:3px solid var(--danger);opacity:.7}.db-card-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;background:#fafbfc}.db-role{padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600}.db-role.master{background:#dbeafe;color:#1e40af}.db-role.backup{background:#fef3c7;color:#92400e}.db-name{font-weight:600;font-size:15px;flex:1}.db-status{font-size:12px;font-weight:500}.db-status.online{color:var(--success)}.db-status.offline{color:var(--danger)}.db-card-body{padding:16px 20px}.db-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.db-info-item{background:#f9fafb;padding:10px 14px;border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:4px}.db-info-item .label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.db-info-item .value{font-size:15px;font-weight:600;color:var(--text)}.db-list{background:#f9fafb;border-radius:var(--radius-sm);padding:12px}.db-list-title{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.db-list-item{display:flex;align-items:center;padding:6px 0;border-bottom:1px solid #f3f4f6;font-size:13px}.db-list-item:last-child{border-bottom:none}.db-list-name{flex:1;font-weight:500}.db-list-size{color:var(--text-secondary);margin-right:16px;font-size:12px}.db-list-tables{color:var(--text-muted);font-size:12px;margin-right:8px}.db-sync-btn{padding:3px 10px;background:var(--primary-bg);color:var(--primary);border:1px solid rgba(79,70,229,.2);border-radius:12px;cursor:pointer;font-size:11px;font-weight:500;transition:all var(--transition);white-space:nowrap}.db-sync-btn:hover{background:var(--primary);color:#fff;transform:translateY(-1px)}.sync-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:20px}.stat-card{background:#f9fafb;border-radius:var(--radius);padding:16px;border:1px solid var(--border)}.stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;font-weight:600;margin-bottom:6px}.stat-value{font-size:20px;font-weight:700}.stat-value.green{color:var(--success)}.stat-value.red{color:var(--danger)}.stat-value.blue{color:var(--primary)}.sync-actions{display:flex;align-items:center;gap:12px;padding:16px;background:#fff;border-radius:var(--radius);border:1px solid var(--border);margin-top:4px;flex-wrap:wrap}.btn-action{padding:10px 22px;border:none;border-radius:var(--radius);cursor:pointer;font-size:13px;font-weight:600;transition:all var(--transition);display:inline-flex;align-items:center;gap:6px}.btn-action.primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #4f46e540}.btn-action.primary:hover{background:#4338ca;transform:translateY(-1px)}.btn-action.warning{background:var(--warning);color:#fff;box-shadow:0 2px 8px #d9770640}.btn-action.warning:hover{background:#b45309;transform:translateY(-1px)}.compare-summary{padding:16px 20px;border-radius:var(--radius);display:flex;align-items:center;gap:14px;margin-bottom:20px}.compare-summary.matched{background:var(--success-bg);border:1px solid #a7f3d0}.compare-summary.mismatched{background:var(--warning-bg);border:1px solid #fcd34d}.compare-summary-icon{font-size:32px}.compare-summary-title{font-size:16px;font-weight:700}.compare-summary-desc{font-size:13px;color:var(--text-secondary);margin-top:2px}.compare-db{margin-bottom:20px}.compare-db-header{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#f9fafb;border-radius:var(--radius-sm) var(--radius-sm) 0 0;border:1px solid var(--border);border-bottom:none}.compare-db-name{font-weight:600;font-size:14px}.compare-db-status{font-size:12px;font-weight:600;padding:2px 10px;border-radius:10px}.compare-db-status.matched{background:var(--success-bg);color:#065f46}.compare-db-status.mismatched{background:var(--warning-bg);color:#92400e}.compare-db-count{margin-left:auto;font-size:12px;color:var(--text-muted)}.compare-table{width:100%;border-collapse:collapse;font-size:13px;border:1px solid var(--border);border-radius:0 0 var(--radius-sm) var(--radius-sm);overflow:hidden}.compare-table thead{background:#f8fafc}.compare-table th{padding:10px 14px;text-align:left;font-weight:600;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border)}.compare-table td{padding:10px 14px;border-bottom:1px solid #f3f4f6}.compare-table tbody tr:hover{background:#f8faff}.compare-table tbody tr.row-mismatch{background:#fff7ed}.compare-table tbody tr.row-mismatch:hover{background:#ffedd5}.btn-refresh{padding:8px 16px;background:var(--primary-bg);color:var(--primary);border:1px solid rgba(79,70,229,.2);border-radius:var(--radius-sm);cursor:pointer;font-size:12px;font-weight:500;transition:all var(--transition)}.btn-refresh:hover{background:var(--primary);color:#fff}.toggle-switch{position:relative;width:44px;height:24px;display:inline-block}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#d1d5db;border-radius:24px;cursor:pointer;transition:all .25s ease}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:all .25s ease;box-shadow:0 1px 3px #00000026}.toggle-switch input:checked+.toggle-slider{background:var(--success)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.2px;line-height:1}.badge-success{background:var(--success-bg);color:#065f46}.badge-failed{background:var(--danger-bg);color:#991b1b}.badge-running{background:var(--info-bg);color:#1e40af}.badge-aborted{background:#fef3c7;color:#92400e}.badge-auto{background:#eef2ff;color:#4338ca}.badge-manual{background:#fef3c7;color:#92400e}.vue-dbsync-page table{width:100%;border-collapse:collapse;font-size:13px}.vue-dbsync-page thead{background:#f8fafc}.vue-dbsync-page th{padding:12px 16px;text-align:left;font-weight:600;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border);white-space:nowrap}.vue-dbsync-page td{padding:12px 16px;border-bottom:1px solid #f3f4f6;color:var(--text);vertical-align:middle}.vue-dbsync-page tbody tr{transition:background var(--transition)}.vue-dbsync-page tbody tr:hover{background:#f8faff}.vue-dbsync-page td code{background:#f3f4f6;padding:2px 8px;border-radius:4px;font-size:12px;color:var(--primary);font-weight:500}.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;margin-bottom:20px;border:1px solid var(--border)}.card-header{padding:16px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:#fafbfc}.card-header h3{font-size:15px;font-weight:600;color:var(--text)}.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center;padding:14px 24px;border-bottom:1px solid var(--border)}.filters select,.filters input[type=date]{padding:9px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;outline:none;background:#f9fafb;color:var(--text);transition:all var(--transition);min-width:140px}.filters select:focus,.filters input[type=date]:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #4f46e514}.btn-search{padding:9px 18px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;transition:all var(--transition);display:inline-flex;align-items:center;gap:5px}.btn-search:hover{background:#4338ca;box-shadow:0 2px 8px #4f46e54d}.pagination{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-top:1px solid var(--border);background:#fafbfc;flex-wrap:wrap;gap:12px}.pagination-info{font-size:13px;color:var(--text-secondary)}.pagination-btns{display:flex;gap:4px}.pagination-btns button{min-width:36px;height:34px;padding:0 10px;border:1px solid var(--border);background:#fff;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);transition:all var(--transition);display:inline-flex;align-items:center;justify-content:center}.pagination-btns button:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary)}.pagination-btns button:disabled{opacity:.35;cursor:not-allowed}.pagination-btns button.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 6px #4f46e54d}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a99;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .15s ease}.modal{background:#fff;border-radius:var(--radius-lg);padding:28px 30px;max-width:440px;width:92%;box-shadow:0 25px 50px #0003;animation:scaleIn .2s ease}.modal h3{font-size:18px;font-weight:600;margin-bottom:6px;color:var(--text)}.modal p{color:var(--text-secondary);font-size:13px;line-height:1.5;margin-bottom:18px}.modal input{width:100%;padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius);font-size:14px;outline:none;margin-bottom:20px;transition:all var(--transition)}.modal input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.modal-actions button{padding:10px 22px;border:none;border-radius:var(--radius);cursor:pointer;font-size:14px;font-weight:500;transition:all var(--transition)}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #4f46e540}.btn-primary:hover{background:#4338ca;transform:translateY(-1px);box-shadow:0 4px 12px #4f46e559}.btn-cancel{background:#f3f4f6;color:var(--text);border:1px solid var(--border)}.btn-cancel:hover{background:#e5e7eb}.toast{position:fixed;top:24px;right:24px;padding:14px 24px;border-radius:var(--radius);color:#fff;font-size:14px;font-weight:500;z-index:10000;animation:slideInRight .35s cubic-bezier(.16,1,.3,1);box-shadow:0 8px 24px #0000002e;display:flex;align-items:center;gap:8px;max-width:400px}.toast-success{background:linear-gradient(135deg,#059669,#10b981)}.toast-error{background:linear-gradient(135deg,#dc2626,#ef4444)}.loading{text-align:center;padding:40px;color:var(--text-muted);font-size:14px}.error{text-align:center;padding:40px;color:var(--danger);font-size:14px}.empty{text-align:center;padding:48px 20px;color:var(--text-muted);font-size:14px}.vue-dbsync-page code{font-family:SF Mono,Fira Code,Cascadia Code,Consolas,monospace}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes slideInRight{0%{transform:translate(120%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.vue-dbsync-page>header{padding:16px 20px;flex-direction:column;align-items:flex-start}.vue-dbsync-page>header h1{font-size:18px}.header-actions{width:100%}.tab-nav{padding:0 12px;overflow-x:auto}.tab-btn{padding:14px 18px;font-size:13px;white-space:nowrap}.tab-content{padding:16px}.db-grid{grid-template-columns:1fr}.sync-stats-grid{grid-template-columns:repeat(2,1fr)}.sync-actions{flex-direction:column;align-items:stretch}.btn-action{width:100%;justify-content:center}.filters{flex-direction:column;align-items:stretch}.filters select,.filters input[type=date]{width:100%}}
