*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.impact-dot{display:inline-block;width:8px;height:8px;border-radius:999px;margin-right:4px}.impact-dot-red{background:#ef4444;animation:blink-red 1s linear infinite}.impact-dot-yellow{background:#facc15;animation:blink-yellow 1.3s linear infinite}.impact-dot-green{background:#22c55e}@keyframes blink-red{0%,45%{opacity:1}45.01%,to{opacity:.15}}@keyframes blink-yellow{0%,45%{opacity:1}45.01%,to{opacity:.4}}.scroll-panel{scrollbar-width:thin;scrollbar-color:#4b5563 transparent}.scroll-panel::-webkit-scrollbar{width:6px}.scroll-panel::-webkit-scrollbar-track{background:transparent}.scroll-panel::-webkit-scrollbar-thumb{background-color:#4b5563;border-radius:999px;border:2px solid #020617}.scroll-panel::-webkit-scrollbar-thumb:hover{background-color:#9ca3af}.migration-view{padding:1.5rem 1.75rem}.migration-page{max-width:1100px;width:100%}.migration-header{margin-bottom:24px;text-align:left}.migration-badge{display:inline-flex;align-items:center;gap:8px;padding:4px 10px;border-radius:999px;background:#0f172ae6;border:1px solid rgba(148,163,184,.6);font-size:12px;letter-spacing:.04em;text-transform:uppercase}.migration-badge-dot{width:8px;height:8px;border-radius:999px;background:#22c55e;box-shadow:0 0 0 4px #22c55e40}.migration-title{margin:12px 0 8px;font-size:clamp(24px,3vw,30px);font-weight:650}.migration-subtitle{margin:0;font-size:14px;color:#cbd5f5}.migration-layout{margin-top:20px;background:linear-gradient(145deg,#0f172af5,#020617);border-radius:24px;padding:20px 20px 26px;box-shadow:0 18px 45px #0f172a66;border:1px solid rgba(148,163,184,.4)}.migration-phase-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}@media(max-width:900px){.migration-phase-row{grid-template-columns:1fr}}.migration-phase-card{position:relative;background:radial-gradient(circle at top left,#f9fafb,#e5e7eb);border-radius:18px;padding:16px 16px 18px;color:#111827;overflow:hidden;box-shadow:0 10px 24px #0f172a40;border:2px solid rgba(37,99,235,.5);transition:transform .25s ease,box-shadow .25s ease}.migration-phase-active{border-color:#2563ebcc}.migration-phase-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:12px}.migration-phase-title{font-size:14px;font-weight:650;text-transform:uppercase;letter-spacing:.08em;color:#4b5563;white-space:nowrap}.migration-phase-pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;background:#dbeafe;color:#2563eb;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em}.migration-phase-light{width:9px;height:9px;border-radius:999px;flex-shrink:0}.migration-phase-light--past{background:#6b7280;box-shadow:0 0 0 3px #6b728059}.migration-phase-light--today{background:#22c55e;box-shadow:0 0 0 3px #22c55e73}.migration-phase-light--transition{background:#f59e0b;box-shadow:0 0 0 3px #f59e0b80;animation:migration-pulse 1.2s ease-out infinite}@keyframes migration-pulse{0%{box-shadow:0 0 #f59e0b99}60%{box-shadow:0 0 0 8px #f59e0b00}to{box-shadow:0 0 #f59e0b00}}.migration-phase-caption{margin:0 0 8px;font-size:13px;color:#4b5563}.migration-lane{margin-top:6px;padding:10px;background:#f3f4f6;border-radius:14px;border:1px solid #e5e7eb}.migration-node-list{display:flex;flex-direction:column;gap:8px}.migration-node{display:flex;align-items:center;gap:8px;font-size:13px}.migration-node-label{flex:1;padding:6px 10px;border-radius:999px;background:#fff;border:1px solid #e5e7eb;box-shadow:0 2px 4px #94a3b840}.migration-arrow{flex-shrink:0;font-size:14px;color:#6b7280}.migration-env-tag{display:inline-flex;align-items:center;gap:6px;margin-top:10px;padding:4px 9px;border-radius:999px;background:#eef2ff;color:#4f46e5;font-size:11px;font-weight:500}.migration-env-dot{width:7px;height:7px;border-radius:999px;background:#4f46e5}.migration-timeline-connector{margin-top:18px;display:flex;align-items:center;justify-content:center;gap:12px;font-size:11px;text-transform:uppercase;letter-spacing:.15em;color:#9ca3af;opacity:.9}.migration-timeline-connector span{height:1px;width:46px;background:linear-gradient(to right,transparent,rgba(156,163,175,.9),transparent)}.migration-legend{margin-top:18px;font-size:11px;color:#9ca3af;text-align:center}.migration-legend strong{color:#e5e7eb}:root{--bg-body: #0f172a;--bg-card: #111827;--bg-header: #020617;--accent: #38bdf8;--accent-soft: rgba(56, 189, 248, .1);--text-main: #e5e7eb;--text-muted: #9ca3af;--border-subtle: #1f2937;--radius-lg: 16px;--radius-xl: 24px;--shadow-soft: 0 18px 45px rgba(15, 23, 42, .7);--bg-sidebar: var(--bg-card);--border-color: var(--border-subtle)}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--bg-body);color:var(--text-main)}#root{min-height:100vh}.sidebar-menu{list-style:none;padding:0;margin:0}.sidebar-item{margin-bottom:8px}.sidebar-link{display:block;padding:12px 16px;border-radius:999px;text-decoration:none;color:var(--text-main);transition:background-color .2s ease,color .2s ease}.sidebar-link:hover{background-color:var(--accent);color:#02111f}.ia-section{padding:2rem 1.5rem;max-width:1200px;margin:0 auto;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.ia-header h2{font-size:1.75rem;margin-bottom:.5rem}.ia-header p{color:#555;max-width:720px}.ia-diagram-wrapper{margin-top:1.5rem;padding:1rem;border-radius:1rem;background:linear-gradient(135deg,#f9fafb,#eef2ff);overflow-x:auto}.ia-diagram{display:flex;align-items:stretch;gap:1.5rem;min-width:720px}.ia-column{flex:0 0 220px;display:flex}.ia-card{background:#fff;border-radius:.75rem;box-shadow:0 8px 22px #0f172a14;padding:1rem 1.1rem;border:1px solid rgba(148,163,184,.4);display:flex;flex-direction:column;gap:.5rem}.ia-card-title{font-size:1.05rem;margin:0}.ia-card-description{margin:0;font-size:.85rem;color:#4b5563}.ia-card-list{list-style:disc;margin:0;padding-left:1.1rem;font-size:.85rem;color:#111827}.ia-card-list li+li{margin-top:.2rem}.ia-connector{align-self:center;flex:0 0 auto}.ia-arrow{font-size:2rem;line-height:1;color:#4b5563}.ia-legend{margin-top:1.5rem;font-size:.9rem}.ia-legend h4{margin-bottom:.3rem}.ia-legend ul{margin:0;padding-left:1.1rem;color:#4b5563}@media(max-width:768px){.ia-section{padding:1.5rem 1rem}.ia-diagram{min-width:600px}.ia-column{flex-basis:200px}}
