.login-screen{display:flex;align-items:center;justify-content:center;height:100%;background:var(--color-bg-primary)}.login-card{width:100%;max-width:400px;padding:48px 40px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:16px;box-shadow:var(--shadow-lg);text-align:center}.login-logo{margin-bottom:32px}.login-logo h1{font-size:24px;font-weight:700;color:var(--color-text-primary);margin-top:12px}.login-subtitle{font-size:13px;color:var(--color-text-muted);margin-top:4px}.login-form{display:flex;flex-direction:column;gap:12px;text-align:left}.login-form .input-group{display:flex;flex-direction:column;gap:6px}.login-form label{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.login-form input{width:100%;padding:10px 14px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);font-size:14px;font-family:var(--font-sans);transition:border-color var(--transition-fast)}.login-form input:focus{outline:none;border-color:var(--color-accent-blue);box-shadow:0 0 0 3px var(--color-focus-ring)}.login-form input::placeholder{color:var(--color-text-muted)}.login-hint{font-size:12px;color:var(--color-text-muted)}.login-error{font-size:13px;color:#f87171;padding:8px 12px;background:#f871711a;border:1px solid rgba(248,113,113,.2);border-radius:6px}.btn{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast)}.btn-primary{background:var(--color-accent-blue);color:var(--color-bg-primary)}.btn-primary:hover:not(:disabled){background:#5ccbfa}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--color-accent-cyan);border:1px solid var(--color-accent-cyan)}.btn-secondary:hover{background:#06b6d41a}.btn-ghost{background:transparent;color:var(--color-text-secondary);padding:6px 12px}.btn-ghost:hover{color:var(--color-text-primary);background:#ffffff0d}.btn-sm{padding:6px 12px;font-size:12px}.login-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--color-text-muted);font-size:12px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.login-footer{margin-top:24px;font-size:12px;color:var(--color-text-muted)}.login-footer a{color:var(--color-accent-cyan);text-decoration:none}.login-footer a:hover{text-decoration:underline}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#080f1ee6;z-index:100;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.loading-card{text-align:center}.loading-spinner{position:relative;display:inline-flex;align-items:center;justify-content:center}.loading-progress-ring{transform:rotate(-90deg);transform-origin:center;transition:stroke-dasharray .3s ease}.loading-percent{position:absolute;font-size:11px;font-weight:600;color:var(--color-text-primary);font-variant-numeric:tabular-nums}.loading-message{margin-top:16px;font-size:13px;color:var(--color-text-secondary)}.loading-error{margin-top:16px;font-size:13px;color:var(--color-accent-red)}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);height:100%;display:flex;flex-direction:column;background:var(--color-bg-secondary);border-right:1px solid var(--color-border);overflow:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 0}.sidebar-header h2{font-size:14px;font-weight:600;color:var(--color-text-primary)}.sidebar-count{font-size:11px;color:var(--color-text-muted);background:var(--color-bg-surface);padding:2px 8px;border-radius:10px}.sidebar-search{padding:12px 16px}.sidebar-search input{width:100%;padding:8px 12px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-primary);font-size:13px;font-family:var(--font-sans)}.sidebar-search input:focus{outline:none;border-color:var(--color-accent-blue)}.sidebar-search input::placeholder{color:var(--color-text-muted)}.sidebar-list{flex:1;overflow-y:auto;padding:0 8px 8px}.sidebar-empty{padding:16px;text-align:center;color:var(--color-text-muted);font-size:13px}.table-list-item{display:block;width:100%;text-align:left;padding:8px 10px;border:none;background:transparent;border-radius:6px;cursor:pointer;transition:background var(--transition-fast);font-family:var(--font-sans)}.table-list-item:hover{background:var(--color-bg-surface)}.table-list-item.selected{background:var(--color-bg-elevated);border-left:2px solid var(--color-accent-blue)}.table-list-item-name{font-size:13px;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-list-item-meta{display:flex;justify-content:space-between;margin-top:2px}.table-list-item-tech{font-size:11px;color:var(--color-text-muted);font-family:var(--font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-list-item-fields{font-size:11px;color:var(--color-text-muted);flex-shrink:0;margin-left:8px}.canvas-container{position:relative;flex:1;overflow:hidden;cursor:grab;background:var(--color-canvas-bg)}.canvas-container canvas{display:block}.detail-panel{width:var(--detail-panel-width);min-width:var(--detail-panel-width);height:100%;display:flex;flex-direction:column;background:var(--color-bg-secondary);border-left:1px solid var(--color-border);overflow:hidden;animation:slideInRight .25s ease}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.detail-panel-header{display:flex;align-items:flex-start;justify-content:space-between;padding:16px;border-bottom:1px solid var(--color-border)}.detail-panel-header h2{font-size:16px;font-weight:600;color:var(--color-text-primary);margin-bottom:4px}.detail-panel-name{font-size:12px;color:var(--color-text-muted);font-family:var(--font-mono)}.detail-panel-meta{display:flex;flex-wrap:wrap;gap:6px;padding:12px 16px;border-bottom:1px solid var(--color-border)}.badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500}.badge-default{background:var(--color-bg-surface);color:var(--color-text-secondary)}.badge-accent{background:#38bdf826;color:var(--color-accent-blue)}.badge-warning{background:#f59e0b26;color:var(--color-accent-amber)}.badge-success{background:#22c55e26;color:var(--color-accent-green)}.detail-panel-body{flex:1;overflow-y:auto;padding:16px}.detail-panel-body section{margin-bottom:20px}.detail-panel-body h3{font-size:13px;font-weight:600;color:var(--color-text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.detail-panel-body h4{font-size:12px;font-weight:500;color:var(--color-text-secondary);margin-bottom:6px}.field-list{overflow-x:auto}.field-list table{width:100%;border-collapse:collapse;font-size:12px}.field-list th{text-align:left;padding:4px 8px;color:var(--color-text-muted);font-weight:500;font-size:11px;border-bottom:1px solid var(--color-border)}.field-list td{padding:6px 8px;border-bottom:1px solid rgba(30,48,80,.3);vertical-align:top}.field-label{color:var(--color-text-primary);display:block}.field-name{font-size:10px;color:var(--color-text-muted);font-family:var(--font-mono)}.field-type{font-size:11px;color:var(--color-accent-cyan);font-family:var(--font-mono)}.field-badges{display:flex;flex-wrap:wrap;gap:4px}.relationship-list ul{list-style:none;padding:0}.relationship-list li{padding:4px 0;font-size:12px;color:var(--color-text-secondary)}.relationship-list code{font-family:var(--font-mono);font-size:11px;color:var(--color-accent-blue)}.child-tables-list{list-style:none;padding:0}.child-tables-list li{padding:3px 0}.child-tables-list code{font-size:12px;font-family:var(--font-mono);color:var(--color-text-secondary)}.app-layout{display:flex;flex-direction:column;height:100%;width:100%;overflow:hidden}.app-topbar{height:var(--topbar-height);display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);flex-shrink:0;z-index:10}.app-brand{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--color-text-primary)}.app-body{display:flex;flex:1;overflow:hidden}.connection-status{display:flex;align-items:center;gap:8px;font-size:12px}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-disconnected{background:var(--color-text-muted)}.status-connecting{background:var(--color-accent-amber);animation:pulse 1s ease infinite}.status-connected{background:var(--color-accent-green)}.status-error{background:var(--color-accent-red)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.status-label{color:var(--color-text-secondary);font-family:var(--font-mono)}:root{--color-bg-primary: #0A1628;--color-bg-secondary: #111D33;--color-bg-surface: #162240;--color-bg-elevated: #1C2D50;--color-text-primary: #E8ECF2;--color-text-secondary: #8899B0;--color-text-muted: #556680;--color-accent-blue: #38BDF8;--color-accent-cyan: #06B6D4;--color-accent-indigo: #6366F1;--color-accent-green: #22C55E;--color-accent-amber: #F59E0B;--color-accent-red: #EF4444;--color-border: #1E3050;--color-border-hover: #2A4060;--color-focus-ring: rgba(56, 189, 248, .4);--color-canvas-bg: #080F1E;--color-canvas-grid: rgba(56, 189, 248, .04);--color-node-bg: #141E35;--color-node-border: #1E3050;--color-node-header: #1A2744;--color-node-hover: #38BDF8;--color-node-selected: #06B6D4;--color-edge-inheritance: #6366F1;--color-edge-reference: #38BDF8;--sidebar-width: 280px;--detail-panel-width: 360px;--topbar-height: 48px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:var(--font-sans);background:var(--color-bg-primary);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::selection{background:#38bdf84d;color:var(--color-text-primary)}:focus-visible{outline:2px solid var(--color-accent-blue);outline-offset:2px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-hover)}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
