:root{--bg-0: #f3f7ef;--bg-1: #fdf9f0;--ink: #172126;--ink-soft: #4c5a61;--accent: #d94f2b;--accent-2: #115c47;--card: #ffffffea;--line: #d7ded8;--color-bg: #f3f7ef;--color-bg-elevated: #ffffff;--color-bg-card: #ffffffea;--color-bg-sidebar: #ffffffc0;--color-primary: #d94f2b;--color-primary-dark: #b54020;--color-primary-light: #ffe4dc;--color-success: #115c47;--color-success-light: #d1fae5;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-error: #ef4444;--color-error-light: #fee2e2;--color-text: #172126;--color-text-secondary: #4c5a61;--color-text-muted: #6b7b83;--color-border: #d7ded8;--color-border-light: #e8ebe9;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-md: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-lg: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--radius-sm: 8px;--radius: 12px;--radius-lg: 20px;--transition: all .2s ease}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Space Grotesk,Noto Sans SC,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--ink);background:radial-gradient(circle at 10% 0%,#f9e7d8 0%,transparent 35%),radial-gradient(circle at 100% 100%,#dbefe6 0%,transparent 30%),linear-gradient(135deg,var(--bg-0),var(--bg-1));min-height:100vh;line-height:1.6}.app{min-height:100vh;display:flex;flex-direction:column}.toast{position:fixed;top:20px;right:20px;z-index:1000;display:flex;align-items:center;gap:10px;padding:14px 20px;border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-lg);font-size:14px;font-weight:500}.toast.success{background:var(--color-success);color:#fff}.toast.error{background:var(--color-error);color:#fff}.toast.info{background:var(--card);color:var(--ink);border:1px solid var(--line)}.toast-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-weight:600;font-size:12px}.toast.success .toast-icon,.toast.error .toast-icon{background:#fff3}.toast.info .toast-icon{background:var(--color-primary-light);color:var(--color-primary)}.toast-enter-active,.toast-leave-active{transition:all .3s ease}.toast-enter-from,.toast-leave-to{opacity:0;transform:translate(100%)}.header{background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:0 24px;position:sticky;top:0;z-index:100}.header-content{max-width:1200px;margin:0 auto;height:64px;display:flex;align-items:center;justify-content:space-between}.brand{display:flex;align-items:center;gap:12px}.logo{width:40px;height:40px;background:linear-gradient(135deg,var(--accent),#f07f38);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:#fff}.logo svg{width:24px;height:24px}.brand h1{font-size:18px;font-weight:700;color:var(--ink);line-height:1.2}.subtitle{font-size:12px;color:var(--ink-soft);font-weight:500}.user-menu{display:flex;align-items:center;gap:12px}.user-info{display:flex;align-items:center;gap:10px}.avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--accent),#f07f38);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px}.email{font-size:14px;color:var(--ink-soft);font-weight:500}.btn-icon{width:36px;height:36px;border:none;background:#fff9;border:1px solid var(--line);border-radius:var(--radius);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);transition:var(--transition)}.btn-icon:hover{background:#ffffffe6;color:var(--ink);border-color:var(--accent)}.btn-icon svg{width:18px;height:18px}.main{flex:1;padding:24px}.login-view{max-width:420px;margin:0 auto;animation:fadeIn .4s ease}.card{background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.login-card{padding:32px}.card-header{text-align:center;margin-bottom:28px}.card-header h2{font-size:24px;font-weight:700;color:var(--ink);margin-bottom:6px}.card-header p{color:var(--ink-soft);font-size:14px}.form-section{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:600;color:var(--ink)}.optional{color:var(--ink-soft);font-weight:400}input{padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius);font-size:14px;font-family:inherit;transition:var(--transition);background:#fffc}input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #d94f2b26;background:#fff}input::placeholder{color:var(--ink-soft)}.btn-primary,.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:var(--transition)}.btn-primary{background:linear-gradient(135deg,var(--accent),#f07f38);color:#fff}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#c44524,#e06f30);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:#ffffffb3;color:var(--ink);border:1px solid var(--line)}.btn-secondary:hover:not(:disabled){background:#ffffffe6;border-color:var(--accent)}.btn-large{padding:14px 28px;font-size:15px;width:100%}.btn-danger{background:var(--color-error)}.btn-danger:hover:not(:disabled){background:#dc2626}button:disabled{opacity:.6;cursor:not-allowed}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.twofa-section{margin-top:20px;padding-top:20px}.divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--ink-soft);font-size:13px;font-weight:500}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--line)}.token-login{display:flex;gap:10px}.token-login input{flex:1}.error-message{margin-top:16px;padding:12px 16px;background:var(--color-error-light);color:var(--color-error);border-radius:var(--radius);font-size:13px;font-weight:500}.migration-view{max-width:1100px;margin:0 auto;animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.progress-section{background:var(--card);border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:20px;box-shadow:var(--shadow)}.progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.step-label{font-size:13px;font-weight:600;color:var(--accent);background:#ffe4dc;padding:4px 10px;border-radius:20px}.step-title{font-size:14px;font-weight:600;color:var(--ink)}.progress-bar{height:6px;background:#ffffff80;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:3px;transition:width .4s ease}.migration-grid{display:grid;grid-template-columns:1fr 340px;gap:20px}@media (max-width: 960px){.migration-grid{grid-template-columns:1fr}}.flow-section{background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow);min-height:auto}.step-card{padding:28px;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.step-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.btn-back{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--line);background:#ffffffb3;border-radius:var(--radius);font-size:13px;font-weight:500;color:var(--ink-soft);cursor:pointer;transition:var(--transition)}.btn-back:hover{background:#fffffff2;color:var(--ink);border-color:var(--accent)}.btn-back svg{width:16px;height:16px}.step-icon{width:40px;height:40px;background:#fff9;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;color:var(--ink-soft)}.step-icon.active{background:var(--accent);color:#fff}.step-card h3{font-size:22px;font-weight:700;color:var(--ink);margin-bottom:6px}.step-desc{color:var(--ink-soft);font-size:14px;margin-bottom:20px}.input-group{display:flex;gap:12px;margin-bottom:20px}.input-group input{flex:1}.input-group.compact{margin-bottom:0}.input-group.compact input{padding:10px 12px;font-size:13px}.input-group.compact button{padding:10px 16px;font-size:13px}.info-box{display:flex;gap:14px;padding:16px;background:#fff9;border-radius:var(--radius);border:1px solid var(--line)}.info-icon{font-size:20px;flex-shrink:0}.info-box p{font-size:13px;color:var(--ink);margin-bottom:4px}.info-box ul{margin:8px 0 0 16px;color:var(--ink-soft);font-size:13px}.info-box li{margin-bottom:4px}.id-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}@media (max-width: 600px){.id-cards{grid-template-columns:1fr}}.id-card{padding:14px;background:#fff9;border-radius:var(--radius);border:1px solid var(--line)}.id-label{display:block;font-size:12px;font-weight:600;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.id-value-row{display:flex;align-items:center;gap:8px}.id-value{font-family:SF Mono,Monaco,monospace;font-size:13px;color:var(--ink);background:#fffc;padding:6px 10px;border-radius:var(--radius-sm);border:1px solid var(--line);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.id-hint{display:block;font-size:11px;color:var(--ink-soft);margin-top:6px}.btn-copy{padding:6px;border:1px solid var(--line);background:#fffc;border-radius:var(--radius-sm);cursor:pointer;color:var(--ink-soft);transition:var(--transition);display:flex;align-items:center;justify-content:center}.btn-copy:hover{background:#fff;color:var(--ink);border-color:var(--accent)}.btn-copy svg{width:14px;height:14px}.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}@media (max-width: 768px){.info-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 500px){.info-grid{grid-template-columns:1fr}}.info-item{display:flex;flex-direction:column;gap:4px;padding:14px;background:#ffffffb3;border:1px solid var(--line);border-radius:var(--radius)}.info-label{font-size:12px;font-weight:600;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:15px;font-weight:600;color:var(--ink)}.precheck-card{padding:14px 16px;border-radius:var(--radius);margin-bottom:14px}.precheck-card.ok{background:var(--color-success-light);border:1px solid var(--color-success)}.precheck-card.warn{background:var(--color-warning-light);border:1px solid var(--color-warning)}.precheck-card.fail{background:var(--color-error-light);border:1px solid var(--color-error)}.precheck-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.precheck-icon{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}.precheck-card.ok .precheck-icon{background:var(--color-success);color:#fff}.precheck-card.warn .precheck-icon{background:var(--color-warning);color:#fff}.precheck-card.fail .precheck-icon{background:var(--color-error);color:#fff}.precheck-title{font-weight:700;font-size:14px}.precheck-card.ok .precheck-title{color:var(--color-success)}.precheck-card.warn .precheck-title{color:#92400e}.precheck-card.fail .precheck-title{color:var(--color-error)}.precheck-message{font-size:13px;color:var(--ink);margin-bottom:12px;line-height:1.5}.precheck-details{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.precheck-item{display:flex;justify-content:space-between;font-size:12px;padding:6px 10px;background:#fff9;border-radius:var(--radius-sm)}.precheck-item span:first-child{color:var(--ink-soft)}.precheck-item span:last-child{font-weight:600;color:var(--ink)}.warning-box{display:flex;gap:12px;padding:12px 14px;background:var(--color-warning-light);border:1px solid var(--color-warning);border-radius:var(--radius);margin-bottom:16px}.warning-icon{font-size:18px;flex-shrink:0}.warning-box p{font-size:13px;color:#92400e;line-height:1.5}.step-actions{display:flex;gap:12px;justify-content:flex-end}.step-actions .btn-secondary{padding:12px 20px;background:#fff9}.step-actions .btn-primary{padding:12px 24px}.confirm-summary{background:#fff9;border-radius:var(--radius);padding:16px 20px;margin-bottom:20px}.summary-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line)}.summary-row:last-child{border-bottom:none}.summary-row span:first-child{font-size:14px;color:var(--ink-soft)}.summary-row code,.summary-row strong{font-size:14px;color:var(--ink)}.summary-row code{font-family:SF Mono,Monaco,monospace;background:#fffc;padding:4px 8px;border-radius:var(--radius-sm);border:1px solid var(--line)}.success-card{text-align:center}.success-icon{font-size:56px;margin-bottom:16px}.success-card h3{font-size:26px}.success-details{background:#fff9;border-radius:var(--radius);padding:16px 20px;margin:20px 0;text-align:left}.success-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line)}.success-row:last-child{border-bottom:none}.success-row span:first-child{font-size:14px;color:var(--ink-soft)}.success-row code{font-family:SF Mono,Monaco,monospace;font-size:13px;background:#fffc;padding:4px 8px;border-radius:var(--radius-sm);border:1px solid var(--line)}.copy-row{display:flex;align-items:center;gap:8px}.status-badge{padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.status-badge.small{padding:2px 8px;font-size:11px}.status-badge.status-pending{background:var(--color-warning-light);color:#92400e}.status-badge.status-processing{background:#dbeafe;color:#1e40af}.status-badge.status-success{background:var(--color-success-light);color:#065f46}.status-badge.status-failed{background:var(--color-error-light);color:#991b1b}.status-badge.status-rolledback{background:#e0e7ff;color:#3730a3}.deleted-badge{color:var(--accent-2);font-weight:600;font-size:14px}.sidebar{display:flex;flex-direction:column;gap:20px}.sidebar-card{background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#ffffff80;border-bottom:1px solid var(--line);cursor:pointer}.sidebar-header h4{font-size:14px;font-weight:700;color:var(--ink)}.chevron{width:18px;height:18px;color:var(--ink-soft);transition:transform .2s ease}.chevron.open{transform:rotate(180deg)}.btn-refresh{padding:6px;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;color:var(--ink-soft);transition:var(--transition);display:flex;align-items:center;justify-content:center}.btn-refresh:hover{background:#fffc;color:var(--ink)}.btn-refresh svg{width:16px;height:16px}.btn-refresh svg.spinning{animation:spin 1s linear infinite}.sidebar-body{padding:16px}.query-tip{margin-top:10px;font-size:12px;color:var(--ink-soft)}.error-text{font-size:12px;color:var(--color-error);margin-top:8px}.empty-text{font-size:13px;color:var(--ink-soft);text-align:center;padding:20px}.query-result{margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}.result-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;font-size:13px}.result-row span:first-child{color:var(--ink-soft)}.result-row code{font-family:SF Mono,Monaco,monospace;font-size:12px;background:#fffc;padding:2px 6px;border-radius:var(--radius-sm)}.history-list{display:flex;flex-direction:column;gap:8px}.history-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#ffffff80;border-radius:var(--radius);border:1px solid var(--line);cursor:pointer;transition:var(--transition)}.history-item:hover{background:#ffffffe6;border-color:var(--accent)}.history-main{display:flex;align-items:center;gap:10px}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.status-pending{background:var(--color-warning)}.status-dot.status-processing{background:var(--accent)}.status-dot.status-success{background:var(--accent-2)}.status-dot.status-failed{background:var(--color-error)}.status-dot.status-rolledback{background:#6366f1}.history-info{display:flex;flex-direction:column;gap:2px}.history-id{font-family:SF Mono,Monaco,monospace;font-size:12px;color:var(--ink)}.history-time{font-size:11px;color:var(--ink-soft)}.history-meta{display:flex;gap:8px;align-items:center;margin:2px 0}.history-target{font-size:11px;color:var(--ink-soft);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-days{font-size:11px;color:var(--accent);font-weight:600;background:var(--color-primary-light);padding:1px 5px;border-radius:10px}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}.pagination button{padding:6px 12px;border:1px solid var(--line);background:#fffc;border-radius:var(--radius-sm);font-size:12px;font-weight:500;color:var(--ink);cursor:pointer;transition:var(--transition)}.pagination button:hover:not(:disabled){background:#fff;border-color:var(--accent)}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination span{font-size:12px;color:var(--ink-soft)}.detail-page{max-width:980px;margin:0 auto;padding:24px;background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.detail-page-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}.detail-page-header h3{font-size:24px;line-height:1.2;color:var(--ink)}.detail-id{margin-top:6px;font-family:SF Mono,Monaco,monospace;font-size:12px;color:var(--ink-soft)}.detail-loading,.detail-error{display:flex;align-items:center;gap:10px;padding:16px;border-radius:var(--radius);background:#fff9;border:1px solid var(--line)}.detail-error{justify-content:space-between;color:var(--color-error)}.detail-grid{background:#ffffffa6;border-radius:var(--radius);border:1px solid var(--line);padding:8px 16px}.detail-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}.detail-row:last-child{border-bottom:none}.detail-row span:first-child{font-size:14px;color:var(--ink-soft)}.detail-row code{font-family:SF Mono,Monaco,monospace;font-size:13px;padding:4px 8px;border-radius:var(--radius-sm);background:#fffc;border:1px solid var(--line)}.detail-row.error-line{align-items:flex-start}.detail-row.error-line span:last-child{color:var(--color-error)}@media (max-width: 768px){.detail-page{padding:16px}.detail-row{flex-direction:column;align-items:flex-start}}.footer{padding:20px;text-align:center}.footer p{font-size:13px;color:var(--ink);opacity:.7}
