body{font-family:sans-serif;margin:0;padding:0;background-color:#f9f9f9;display:flex;flex-direction:column;height:100vh}#header{padding:15px 20px;background:#fff;border-bottom:1px solid #ccc;display:flex;justify-content:space-between;align-items:center}h1{margin:0;font-size:24px}#main{display:flex;flex:1;overflow:hidden}#sidebar{width:320px;min-width:250px;max-width:600px;background:#fff;display:flex;flex-direction:column;flex-shrink:0}#resizer{width:5px;background:#ccc;cursor:col-resize;transition:background .2s;z-index:10;flex-shrink:0}#resizer:hover,#resizer:active{background:#999}.sidebar-section{padding:20px;border-bottom:1px solid #eee}#chart-container{flex:1;position:relative;background-color:#fafafa}#chart{width:100%;height:100%}#search-container{position:relative}#course-search{width:100%;padding:10px;box-sizing:border-box;border:1px solid #ccc;border-radius:4px;font-size:14px}#search-results{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #ccc;border-top:none;max-height:250px;overflow-y:auto;z-index:1000;display:none;box-shadow:0 4px 6px #0000001a}.search-result-item{padding:10px;cursor:pointer;border-bottom:1px solid #eee;font-size:13px}.search-result-item:hover{background:#f0f0f0}#studied-list{flex:.6;overflow-y:auto;padding:20px;background:#fdfdfd}#target-section{flex:1.4;display:flex;flex-direction:column;padding:20px;border-top:1px solid #ccc;background:#fff;overflow:hidden}#target-search-container{position:relative}#target-search{width:100%;padding:10px;box-sizing:border-box;border:1px solid #ccc;border-radius:4px;font-size:14px}#target-search-results{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #ccc;border-top:none;max-height:200px;overflow-y:auto;z-index:1000;display:none;box-shadow:0 4px 6px #0000001a}#target-prereq-display{flex:1;overflow-y:auto;margin-top:15px;font-size:13px}.prereq-node{margin-left:12px;border-left:2px solid #eee;padding-left:10px;margin-top:6px}.status-studied{color:#2e7d32;font-weight:700}.status-unstudied{color:#c62828}.logic-label{font-weight:700;color:#555;font-size:12px;background:#eee;padding:2px 6px;border-radius:4px;display:inline-block;margin-bottom:4px;transition:background .3s,color .3s}.logic-met{background:#4caf50;color:#fff}.studied-item{display:flex;justify-content:space-between;align-items:center;padding:10px;background:#fff;border:1px solid #ddd;margin-bottom:8px;border-radius:4px;font-size:14px;box-shadow:0 1px 3px #0000000d}.remove-btn{color:#e53935;cursor:pointer;font-weight:700;padding:0 5px}.remove-btn:hover{color:#b71c1c}.node circle{stroke:#fff;stroke-width:2px;transition:fill .3s,stroke .3s}.node text{font-size:12px}.link{fill:none;stroke:#999;stroke-opacity:.6;stroke-width:1.5px}.tooltip{position:absolute;text-align:center;padding:10px;font:13px sans-serif;background:#000c;color:#fff;border:0px;border-radius:4px;pointer-events:none;opacity:0;z-index:100;max-width:250px}.legend{font-size:14px}.legend-item{display:inline-flex;align-items:center;margin-left:15px}.legend-color{width:16px;height:16px;border-radius:50%;margin-right:6px}
