#App{margin:0 auto;padding:2rem;max-width:1600px}.app-header{width:100%;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);margin-bottom:2rem;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;box-sizing:border-box;max-width:100vw}.app-header h1{text-align:left;margin:0;flex:1;min-width:200px}.header-right{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.plan-manager-compact{display:flex;align-items:center}.user-info{display:flex;align-items:center;gap:1rem}.user-name{font-size:.95rem;color:#333;font-weight:500}.user-email{font-size:.9rem;color:#666}.sign-out-button{padding:.5rem 1rem;font-size:.9rem;background:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.sign-out-button:hover{background:#d32f2f}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:2rem}.loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-container h2{color:#f44336;margin-bottom:1rem}.error-container p{color:#666;font-size:1.1rem}.main-content{display:flex;flex-direction:column;gap:2rem;margin-top:2rem}.content-panels{display:flex;gap:2rem;align-items:flex-start}.left-panel{flex:1;min-width:0}.middle-panel{flex:0 0 400px;display:flex;flex-direction:column;gap:2rem}.rightmost-panel{flex:0 0 350px;display:flex;flex-direction:column}.term-timeline{text-align:left;max-width:700px;margin:0 auto}.term-timeline-container{display:flex;flex-direction:row;overflow-x:auto;padding:1rem 0;margin-top:1rem;scroll-snap-type:x mandatory}.term-box-wrapper{display:flex;align-items:center;position:relative;flex:0 0 100%;justify-content:center;scroll-snap-align:start}.term-connector{width:2rem;height:3px;background:linear-gradient(to right,#4a90e2,#6bb3ff);margin-right:1rem;position:relative}.term-connector:after{content:"";position:absolute;right:-6px;top:-4px;width:0;height:0;border-left:8px solid #6bb3ff;border-top:6px solid transparent;border-bottom:6px solid transparent}.term-box{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:1.5rem;width:100%;max-width:480px;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.term-box:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.term-header{border-bottom:2px solid #4a90e2;padding-bottom:.75rem;margin-bottom:1rem}.term-label{margin:0;font-size:1.5rem;font-weight:700;color:#4a90e2;text-align:center}.term-units{font-size:.85rem;color:#666;margin:.5rem 0 0;padding:0;font-weight:400;text-align:center;line-height:1.2}.term-content{display:flex;flex-direction:column;gap:1rem}.term-section{margin-bottom:.5rem}.term-section-any{border-top:1px dashed #ccc;padding-top:1rem;margin-top:.5rem}.term-section-title{font-size:.9rem;font-weight:600;color:#666;margin:0 0 .5rem;text-transform:uppercase;letter-spacing:.5px}.term-course-list{list-style:none;padding:0;margin:0}.term-course-item{padding:.5rem 0;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background-color .2s}.term-course-item:hover{background-color:#f5f5f5}.term-course-item:last-child{border-bottom:none}.term-course-item.term-course-any{padding-left:1rem;position:relative}.course-link{text-decoration:none;color:#333;display:flex;gap:.5rem;align-items:flex-start;transition:color .2s;pointer-events:none}.course-code{font-weight:600;color:#4a90e2;min-width:70px}.course-title{flex:1;font-size:.9rem;color:#666}.course-toggle-btn:disabled{opacity:.5;cursor:not-allowed;background-color:#ccc;color:#666}.course-toggle-btn:disabled:hover{background-color:#ccc;color:#666}.course-toggle-btn{margin-top:.5rem;padding:.25rem .75rem;font-size:.85rem;background:#4a90e2;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.course-toggle-btn:hover{background:#357abd}.term-course-item.course-selected{background:#e8f5e9;border-left:3px solid #4caf50;padding-left:.5rem}.term-course-item .selected-indicator{color:#4caf50;font-weight:700;margin-left:auto}.requirement-boxes{text-align:left}.requirement-boxes h2{margin-bottom:1.5rem;color:#333}.requirement-boxes-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}.requirement-box{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:all .2s}.requirement-box:hover{box-shadow:0 4px 12px #00000026}.requirement-box.requirement-fulfilled{border-color:#4caf50;background:linear-gradient(to bottom,#fff,#f1f8f4)}.requirement-box-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #e0e0e0}.requirement-box.requirement-fulfilled .requirement-box-header{border-bottom-color:#4caf50}.requirement-title{margin:0;font-size:1.2rem;font-weight:600;color:#333;flex:1}.requirement-status{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;flex-shrink:0}.status-pending{background:#f5f5f5;color:#999;border:2px solid #e0e0e0}.status-fulfilled{background:#4caf50;color:#fff;border:2px solid #4caf50;box-shadow:0 2px 8px #4caf504d}.status-icon{display:block}.requirement-description{font-size:.9rem;color:#666;margin:0 0 1rem;font-style:italic}.requirement-courses{margin-top:1rem}.requirement-course-list{list-style:none;padding:0;margin:0}.requirement-course-item{padding:.75rem;margin-bottom:.5rem;background:#f9f9f9;border-radius:6px;border-left:3px solid #e0e0e0;transition:all .2s;cursor:pointer}.requirement-course-item:hover{background:#f0f0f0;border-left-color:#4a90e2}.requirement-course-item.course-selected{background:#e8f5e9;border-left-color:#4caf50}.requirement-course-item.course-eligible{border-left-color:#4caf50;background:#f1f8f4}.requirement-course-item.course-not-eligible{border-left-color:#ff9800;opacity:.85}.requirement-course-item .course-link{display:flex;align-items:center;gap:.75rem;justify-content:space-between;flex:1;cursor:pointer}.selected-indicator{color:#4caf50;font-weight:700;font-size:1.1rem}.no-courses{color:#999;font-style:italic;margin:0;padding:1rem;text-align:center}.elective-item{padding:1rem;margin-bottom:1rem;background:#f9f9f9;border-radius:6px;border:1px solid #e0e0e0;border-left:3px solid #e0e0e0;transition:all .2s;cursor:pointer}.elective-item:hover{background:#f0f0f0;border-color:#4a90e2;box-shadow:0 2px 4px #0000001a}.elective-eligible{border-left-color:#4caf50!important;background:#f1f8f4}.elective-eligible:hover{background:#e8f5e9;border-color:#4caf50}.elective-not-eligible{opacity:.85;border-left-color:#ff9800!important;background:#fff8f0}.elective-not-eligible:hover{background:#fff3e0;border-color:#ff9800}.elective-main{margin-bottom:.5rem;font-weight:500;color:#333}.course-detail{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;position:sticky;top:2rem;color:#333}.course-detail h2{margin-top:0;color:#4a90e2;border-bottom:2px solid #4a90e2;padding-bottom:.75rem;margin-bottom:1rem}.course-detail h3{color:#333;margin-top:1.5rem;margin-bottom:.5rem;font-size:1.1rem}.course-detail p{margin:.5rem 0;line-height:1.6;color:#333}.course-detail ul{margin:.5rem 0;padding-left:1.5rem;color:#333}.course-detail li{margin:.25rem 0;color:#333}.course-detail strong{color:#333;font-weight:600}.course-detail a{color:#06c;text-decoration:none}.course-detail a:hover{text-decoration:underline}@media (max-width: 1200px){.main-content{flex-direction:column}.middle-panel,.rightmost-panel{flex:1;width:100%}.course-detail{position:static}}@media (max-width: 768px){.term-timeline-container{flex-direction:column}.term-connector{width:3px;height:2rem;margin-right:0;margin-bottom:1rem}.term-connector:after{right:-4px;top:auto;bottom:-6px;border-left:6px solid transparent;border-right:6px solid transparent;border-top:8px solid #6bb3ff;border-bottom:none}}.sign-in-container{display:flex;justify-content:center;align-items:center;min-height:60vh;width:100%;padding:2rem}.sign-in-card{background:#fff;border-radius:8px;padding:2.5rem;box-shadow:0 2px 8px #0000001a;color:#333;max-width:500px;width:100%;text-align:center}.sign-in-card h2{margin:0 0 1rem;font-size:1.8rem;color:#333}.sign-in-description{margin-bottom:1.5rem;color:#666;line-height:1.6}.error-message{background:#fee;color:#c33;padding:.75rem;border-radius:6px;margin-bottom:1rem;border:1px solid #fcc}.sign-in-button{width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:#4285f4;border:none;border-radius:6px;cursor:pointer;transition:background .2s,transform .1s;margin-bottom:1rem}.sign-in-button:hover:not(:disabled){background:#357ae8;transform:translateY(-1px)}.sign-in-button:active:not(:disabled){transform:translateY(0)}.sign-in-button:disabled{opacity:.6;cursor:not-allowed}.sign-in-note{font-size:.85rem;color:#999;margin:0;font-style:italic}.plan-manager{margin-bottom:0}.plan-manager-actions{display:flex;gap:.5rem;flex-wrap:wrap}.plan-button{padding:.5rem .9rem;font-size:.85rem;font-weight:500;border:none;border-radius:4px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.4rem;white-space:nowrap}.save-button{background:#4caf50;color:#fff}.save-button:hover:not(:disabled){background:#45a049;transform:translateY(-1px)}.load-button{background:#2196f3;color:#fff}.load-button:hover:not(:disabled){background:#1976d2;transform:translateY(-1px)}.plan-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.plan-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.plan-dialog{background:#fff;border-radius:12px;padding:2rem;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.plan-dialog h3{margin:0 0 1.5rem;color:#333;font-size:1.5rem}.plan-dialog input[type=text]{width:100%;padding:.75rem;font-size:1rem;border:2px solid #e0e0e0;border-radius:6px;margin-bottom:1rem;box-sizing:border-box}.plan-dialog input[type=text]:focus{outline:none;border-color:#2196f3}.plan-dialog-info{background:#f5f5f5;padding:1rem;border-radius:6px;margin-bottom:1.5rem}.plan-dialog-info p{margin:.25rem 0;color:#666;font-size:.9rem}.plan-dialog-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.plan-dialog-actions button{padding:.75rem 1.5rem;font-size:1rem;border:none;border-radius:6px;cursor:pointer;transition:all .2s}.plan-dialog-actions button:first-child{background:#e0e0e0;color:#333}.plan-dialog-actions button:first-child:hover{background:#d0d0d0}.plan-dialog-actions button:last-child{background:#2196f3;color:#fff}.plan-dialog-actions button:last-child:hover:not(:disabled){background:#1976d2}.plan-dialog-actions button:disabled{opacity:.6;cursor:not-allowed}.plan-load-dialog{max-width:600px}.plan-list{display:flex;flex-direction:column;gap:1rem;max-height:400px;overflow-y:auto;margin-bottom:1rem}.plan-item{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;padding:1rem;transition:all .2s}.plan-item:hover{border-color:#2196f3;box-shadow:0 2px 8px #0000001a}.plan-item-main{display:flex;justify-content:space-between;align-items:center;gap:1rem}.plan-item-info h4{margin:0 0 .5rem;color:#333;font-size:1.1rem}.plan-meta{margin:0;color:#666;font-size:.85rem}.plan-item-actions{display:flex;gap:.5rem;flex-shrink:0}.plan-item-button{padding:.5rem 1rem;font-size:.85rem;border:none;border-radius:4px;cursor:pointer;transition:all .2s}.plan-item-button.load{background:#2196f3;color:#fff}.plan-item-button.load:hover{background:#1976d2}.plan-item-button.edit{background:#ff9800;color:#fff}.plan-item-button.edit:hover{background:#f57c00}.plan-item-button.delete{background:#f44336;color:#fff}.plan-item-button.delete:hover{background:#d32f2f}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}html,body{margin:0;padding:0;width:100%;overflow-x:hidden}body{min-width:320px;min-height:100vh}#root{width:100%;overflow-x:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
