@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";:root{--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--bg-app: #09090b;--bg-panel: #18181b;--bg-card: #27272a;--bg-element: #3f3f46;--border-subtle: #27272a;--border-element: #3f3f46;--border-hover: #52525b;--text-main: #f4f4f5;--text-muted: #a1a1aa;--text-faint: #52525b;--accent-primary: #8b5cf6;--accent-hover: #7c3aed;--accent-dim: rgba(139, 92, 246, .1);--status-success: #10b981;--status-success-bg: rgba(16, 185, 129, .1);--status-warning: #f59e0b;--status-warning-bg: rgba(245, 158, 11, .1);--status-error: #ef4444;--status-error-bg: rgba(239, 68, 68, .1);--status-info: #06b6d4;--font-sans: "Inter", sans-serif;--font-mono: "JetBrains Mono", monospace;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--ease: cubic-bezier(.16, 1, .3, 1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg-app);color:var(--text-main);font-family:var(--font-sans);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased;overflow:hidden}#root{height:100vh;display:flex}h1,h2,h3,h4{font-weight:600;color:var(--text-main);letter-spacing:-.01em}.font-mono{font-family:var(--font-mono)}.text-xs{font-size:11px}.text-sm{font-size:12px}.text-base{font-size:13px}.app{display:flex;width:100%;height:100%}.sidebar{width:320px;background:var(--bg-panel);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;padding:var(--space-4);gap:var(--space-6);overflow-y:auto;z-index:20}.sidebar-header{padding-bottom:var(--space-4);border-bottom:1px solid var(--border-subtle)}.logo{font-size:18px;display:flex;align-items:center;gap:var(--space-2);color:var(--text-main)}.logo-icon{color:var(--accent-primary)}.subtitle{display:block;font-size:11px;color:var(--text-muted);margin-top:var(--space-1)}.panel{display:flex;flex-direction:column;gap:var(--space-3)}.panel-title{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-3)}button,input,select{font-family:inherit;font-size:13px;outline:none}input,select{background:var(--bg-app);border:1px solid var(--border-element);color:var(--text-main);border-radius:var(--radius-sm);padding:6px 10px;transition:border-color .15s var(--ease);width:100%}input:focus,select:focus{border-color:var(--accent-primary)}button{cursor:pointer;border-radius:var(--radius-md);padding:6px 12px;font-weight:500;border:1px solid transparent;transition:all .15s var(--ease);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2)}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-algo{background:var(--bg-card);border:1px solid var(--border-subtle);color:var(--text-main);width:100%;justify-content:flex-start}.btn-algo:hover:not(:disabled){border-color:var(--border-hover);background:var(--bg-element)}.btn-algo:disabled{opacity:.5;cursor:not-allowed}.btn-danger{background:transparent;border:1px solid var(--status-error);color:var(--status-error);width:100%}.btn-danger:hover{background:var(--status-error-bg)}.btn-clear{width:100%;margin-top:var(--space-2);color:var(--text-muted);font-size:11px;background:transparent;border:1px dashed var(--border-subtle)}.btn-clear:hover{color:var(--text-main);border-color:var(--border-element)}.toggle-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0}.toggle-label{font-size:12px;color:var(--text-muted)}.toggle-btn{background:var(--bg-card);border:1px solid var(--border-subtle);color:var(--text-muted)}.toggle-btn.active{background:var(--accent-dim);border-color:var(--accent-primary);color:var(--accent-primary)}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}.stat{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-3);text-align:center}.stat-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;color:var(--text-muted);display:block;margin-bottom:var(--space-1)}.stat-value{font-family:var(--font-mono);font-size:20px;font-weight:500;color:var(--text-main)}.euler-status{padding:var(--space-3);border-radius:var(--radius-md);display:flex;gap:var(--space-3);align-items:flex-start;margin-bottom:var(--space-2);font-size:12px}.euler-header{font-weight:600;margin-bottom:2px}.euler-desc{color:var(--text-main);opacity:.9}.euler-circuit{background:var(--status-success-bg);border:1px solid rgba(16,185,129,.2);color:var(--status-success)}.euler-trail{background:var(--status-warning-bg);border:1px solid rgba(245,158,11,.2);color:var(--status-warning)}.euler-none,.euler-disconnected{background:var(--status-error-bg);border:1px solid rgba(239,68,68,.2);color:var(--status-error)}.degree-info{display:flex;gap:var(--space-3);font-size:11px}.info-tag.odd{color:var(--status-error)}.info-tag.even{color:var(--status-success)}.editor-fields{display:flex;flex-direction:column;gap:var(--space-3);background:var(--bg-card);padding:var(--space-3);border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.editor-fields label{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--text-muted)}.editor-fields input{width:80px;text-align:right;font-family:var(--font-mono)}.math-panel{width:300px;background:var(--bg-panel);border-left:1px solid var(--border-subtle);padding:var(--space-4);overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-6);z-index:20}.formula-display{font-family:var(--font-mono);text-align:center;font-size:16px;color:var(--accent-primary);background:var(--bg-app);padding:var(--space-3);border-radius:var(--radius-md);border:1px solid var(--border-subtle);margin-bottom:var(--space-3)}.formula-values{display:flex;justify-content:space-between;text-align:center;padding:0 var(--space-2)}.val-box{display:flex;flex-direction:column}.val-label{font-size:10px;color:var(--text-muted);text-transform:uppercase}.val-num{font-family:var(--font-mono);font-size:14px;font-weight:600}.planarity-badge{text-align:center;padding:var(--space-2);border-radius:var(--radius-md);font-weight:500;font-size:13px}.planarity-badge.planar{background:var(--status-success-bg);color:var(--status-success)}.planarity-badge.non-planar{background:var(--status-error-bg);color:var(--status-error)}.degree-table{width:100%;border-collapse:collapse;font-size:12px}.degree-table th{text-align:left;color:var(--text-muted);font-weight:500;padding:var(--space-2);border-bottom:1px solid var(--border-subtle)}.degree-table td{padding:var(--space-2);border-bottom:1px solid var(--border-subtle);color:var(--text-main)}.degree-table tr:last-child td{border-bottom:none}.row-odd{color:var(--status-error)}.row-even{color:var(--text-muted)}.graph-canvas-container{flex:1;background:var(--bg-app);position:relative;overflow:hidden;user-select:none;-webkit-user-select:none}.graph-canvas{width:100%;height:100%;display:block}.inline-weight-input{width:52px;height:24px;background:var(--bg-panel);border:1px solid var(--accent-primary);border-radius:var(--radius-sm);color:var(--text-main);font-family:var(--font-mono);font-size:12px;text-align:center;padding:0 4px;outline:none}.canvas-hint{position:absolute;bottom:var(--space-4);left:50%;transform:translate(-50%);background:var(--bg-panel);border:1px solid var(--border-subtle);padding:var(--space-2) var(--space-4);border-radius:99px;font-size:11px;color:var(--text-faint);pointer-events:none;white-space:nowrap}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;display:flex;align-items:center;justify-content:center}.modal-content{background:var(--bg-panel);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-4);max-width:90vw;max-height:90vh;overflow:auto}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-thumb{background:var(--border-element);border-radius:3px}::-webkit-scrollbar-track{background:transparent}.algo-result{background:var(--bg-app);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);font-size:12px;color:var(--text-muted);margin-top:var(--space-1)}.algo-result strong{color:var(--text-main);font-family:var(--font-mono)}.algo-edges,.algo-path{display:block;font-family:var(--font-mono);font-size:11px;color:var(--text-faint);margin-top:2px}.dijkstra-section{display:flex;flex-direction:column;gap:var(--space-2)}.dijkstra-selectors{display:flex;gap:var(--space-2)}.dijkstra-selectors label{flex:1;display:flex;flex-direction:column;gap:2px;font-size:11px;color:var(--text-muted)}.sidebar-footer{margin-top:auto;padding-top:var(--space-4);border-top:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:var(--space-2)}.footer-text{font-size:11px;color:var(--text-faint);text-align:center}.math-note{font-size:11px;color:var(--text-muted);font-family:var(--font-mono);margin-top:var(--space-1)}.math-result{font-family:var(--font-mono);font-size:12px;padding:var(--space-1) 0;font-weight:500}.math-result.success{color:var(--status-success)}.math-result.warning{color:var(--status-warning)}.formula{font-family:var(--font-mono);font-size:16px;color:var(--accent-primary);text-align:center;padding:var(--space-2) 0}.parity-cell.odd{color:var(--status-error)}.parity-cell.even{color:var(--status-success)}.sum-note{font-family:var(--font-mono);color:var(--text-faint)}.readonly-val{font-family:var(--font-mono);color:var(--text-main)}.metrics-grid{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-1)}.metric-row{display:flex;gap:var(--space-2);justify-content:space-between}.metric-item{flex:1;display:flex;flex-direction:column;align-items:center;background:var(--bg-app);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:var(--space-2)}.metric-item.full-width{width:100%;flex-direction:row;justify-content:space-between;padding:var(--space-2) var(--space-3)}.metric-label{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:500}.metric-value{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--accent-primary);margin-top:2px}.center-list{color:var(--text-main);font-size:12px}.metric-warning{font-size:11px;color:var(--status-error);text-align:center;background:#ef44441a;padding:4px;border-radius:var(--radius-sm)}.io-row{display:flex;gap:var(--space-2)}.io-row button,.io-row .file-upload{flex:1}.file-upload{display:flex;align-items:center;justify-content:center;cursor:pointer;text-align:center;font-size:12px;padding:6px 12px}.history-controls{display:flex;gap:4px}.btn-icon{background:transparent;border:1px solid var(--border-subtle);color:var(--text-muted);width:28px;height:28px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;transition:all .2s}.btn-icon:hover:not(:disabled){background:var(--bg-element);color:var(--text-main);border-color:var(--border-element)}.btn-icon:disabled{opacity:.3;cursor:not-allowed}.toggle-group{display:flex;background:var(--bg-element);padding:2px;border-radius:var(--radius-sm);gap:2px}.toggle-group .toggle-btn{flex:1;border-radius:var(--radius-xs);padding:4px 8px}.author-link{display:block;font-size:11px;color:var(--text-faint);margin-top:4px;text-decoration:none;transition:color .2s}.author-link:hover{color:var(--accent-primary)}[data-theme=light]{--bg-app: #f4f4f5;--bg-panel: #ffffff;--bg-card: #ffffff;--bg-element: #e4e4e7;--text-main: #18181b;--text-muted: #52525b;--text-faint: #71717a;--border-subtle: #e4e4e7;--border-element: #d4d4d8;--border-hover: #a1a1aa;--accent-primary: #7c3aed;--accent-hover: #6d28d9;--accent-dim: rgba(124, 58, 237, .1);--shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1)}.boxed-group{display:flex;gap:8px;width:100%}.boxed-item{background:var(--bg-card);border:1px solid var(--border-element);border-radius:var(--radius-sm);padding:8px 12px;flex:1;display:flex;flex-direction:column;align-items:center;box-shadow:var(--shadow-sm);transition:all .2s var(--ease)}.boxed-item:hover{border-color:var(--accent-primary);transform:translateY(-1px)}.boxed-label{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600;margin-bottom:4px}.boxed-value{font-family:var(--font-mono);font-size:15px;font-weight:700;color:var(--text-main)}.boxed-value.highlight{color:var(--accent-primary)}.formula-values{gap:8px}.val-box{background:var(--bg-panel);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:8px;min-width:48px;box-shadow:var(--shadow-sm)}[data-theme=light] .val-box{background:#fafafa;border-color:var(--border-element)}.theme-toggle{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;transition:color .2s}.theme-toggle:hover{color:var(--text-main);background:var(--bg-element)}
