:root{--primary-color: #2563eb;--secondary-color: #1e40af;--background-color: #f8fafc;--text-color: #1e293b;--border-color: #e2e8f0}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:var(--background-color);color:var(--text-color);line-height:1.5}.app{max-width:1200px;margin:0 auto;padding:2rem}.header{text-align:center;margin-bottom:3rem}.header h1{font-size:2.5rem;color:var(--primary-color);margin-bottom:.5rem}.header p{font-size:1.1rem;color:var(--text-color);opacity:.8}.main-content{display:grid;gap:2rem}.input-section{background:#fff;padding:1.5rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a}.input-section h2{margin-bottom:1rem;color:var(--primary-color)}.input-area{width:100%;min-height:200px;padding:1rem;border:1px solid var(--border-color);border-radius:.375rem;font-family:monospace;font-size:.875rem;resize:vertical}.input-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.input-header h2{margin:0}.clear-button{background-color:var(--primary-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.875rem;transition:background-color .2s}.clear-button:hover{background-color:var(--secondary-color)}.warning-message{background-color:#fef3c7;color:#92400e;padding:.75rem;border-radius:.375rem;margin-bottom:1rem;font-size:.875rem;display:flex;align-items:center;gap:.5rem}.error-message{background-color:#fee2e2;color:#b91c1c;padding:.75rem;border-radius:.375rem;margin-bottom:1rem;font-size:.875rem;display:flex;align-items:center;gap:.5rem}.visualization-section{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}.graph-container{grid-column:1;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;height:600px}.cycle-list{grid-column:2;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:16px;overflow-y:auto;height:600px;display:flex;flex-direction:column}.cycle-list-header{margin-bottom:16px}.cycle-list h3{margin:0 0 12px;color:#333;font-size:1.2rem}.search-controls{display:flex;gap:8px;margin-bottom:12px}.search-input{flex:1;padding:8px 12px;border:1px solid #e0e0e0;border-radius:4px;font-size:.9rem;outline:none;transition:border-color .2s}.search-input:focus{border-color:#2b7ce9}.sort-select{padding:8px 12px;border:1px solid #e0e0e0;border-radius:4px;font-size:.9rem;background-color:#fff;outline:none;cursor:pointer;transition:border-color .2s}.sort-select:focus{border-color:#2b7ce9}.cycle-list-container{flex:1;display:flex;flex-direction:column;gap:12px;overflow-y:auto}.cycle-item{padding:12px;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s ease}.cycle-item:hover{background-color:#f5f5f5;border-color:#2b7ce9}.cycle-item.selected{background-color:#e3f2fd;border-color:#2b7ce9}.cycle-item-header{display:flex;justify-content:space-between;margin-bottom:8px}.cycle-index{font-weight:600;color:#333}.cycle-length{color:#666;font-size:.9rem}.cycle-path{color:#666;font-size:.9rem;margin-bottom:4px;word-break:break-all}.cycle-file{color:#999;font-size:.8rem;font-family:monospace}.no-results{text-align:center;color:#666;padding:20px;font-style:italic}.canvas-section{background:#fff;padding:1.5rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.canvas-section h2{margin-bottom:1rem;color:var(--primary-color)}.graph-wrapper{position:relative;width:100%;height:600px;min-height:400px;max-height:800px;overflow:hidden;background:#fff;border-radius:.375rem;box-shadow:0 1px 3px #0000001a;resize:vertical;padding-bottom:10px;display:flex;flex-direction:column}.vis-network{width:100%!important;height:100%!important;overflow:hidden!important}.resize-handle{position:absolute;bottom:0;left:0;right:0;height:10px;cursor:ns-resize;background:linear-gradient(to bottom,transparent,rgba(0,0,0,.1));z-index:10}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#fffc;color:var(--text-color);font-size:1.1rem;z-index:10}.graph-wrapper .error-message{position:absolute;top:0;left:0;right:0;padding:1rem;background-color:#fee2e2;color:#b91c1c;font-size:.875rem;z-index:10}.details-container{grid-column:1 / -1;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:16px;margin-top:20px}.demo-section{background:#fff;padding:1.5rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a}.footer{text-align:center;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border-color);color:var(--text-color);opacity:.7}.zoom-controls{position:absolute;top:10px;right:10px;display:flex;gap:5px;z-index:10}.zoom-controls button{background:#fff;border:1px solid var(--border-color);border-radius:4px;padding:5px 10px;cursor:pointer;font-size:14px;color:var(--text-color);box-shadow:0 1px 3px #0000001a;transition:all .2s}.zoom-controls button:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}@media (max-width: 768px){.visualization-section{grid-template-columns:1fr}.app{padding:1rem}}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
