@import"https://fonts.googleapis.com/css2?family=Gaegu:wght@300;400;700&family=Roboto:wght@300;400;500;700&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#fff;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}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{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:#213333}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body,#root{height:100%;margin:0;padding:0}body{margin:0;font-family:Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;scrollbar-color:rgb(154,154,154) transparent}.App{flex-grow:1;overflow-y:auto;text-align:center;background-color:#fff;overflow-x:hidden;color:#000;flex-direction:row;height:100%;width:100%}.layout-container{display:flex;flex-direction:row;height:100vh}.header-and-content{gap:6px;margin-left:20vw;width:80vw;transition:margin-left .3s ease,width .3s ease;overflow-y:auto;overflow-x:hidden;height:100vh;position:fixed;right:0}.header-and-content.collapsed{margin-left:4.5vw;width:95.5vw}.App-header{display:flex;justify-content:space-between;align-items:center;background-color:#fff;margin:0;width:100%;padding:10px 20px;position:relative;box-sizing:border-box}.header-sidebar-expanded,.header-sidebar-collapsed{width:100%}.header-search-container{position:absolute;left:50%;transform:translate(-50%);width:425px;max-width:35%;display:flex;justify-content:center;align-items:center}.logo{display:flex;flex-direction:column;align-items:flex-start;color:#000}.logo-title{display:flex;align-items:center;color:#000}.logo-link{display:flex;align-items:center;text-decoration:none;color:#000;font-weight:600;gap:-4px}.logo-link:hover,.logo-link:hover .logo-text{color:#213333}.logo-text{font-size:1.8rem;font-weight:700;color:#333;margin:12px 0 -10px 8px;font-family:Gaegu,cursive}.logo-icon{width:40px;height:40px;object-fit:contain;margin-top:17px;margin-left:8px}.progress-row{margin-top:0;display:flex;align-items:center;gap:1vh;justify-content:center}.logo-progress{width:200px;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#e0e0e0;border-radius:20px;margin-left:5px}.logo-progress::-webkit-progress-bar{background-color:#e0e0e0;border-radius:10px}.logo-progress::-webkit-progress-value{background-color:#5cb85c;border-radius:10px}.Sign-in-out-container{margin-right:10px}.Sign-in-out-container button{border:1.5px solid #2c4444!important;border-radius:8px;padding:8px 16px;transition:all .3s ease;background-color:#fff;color:#000}.Sign-in-out-container button:hover{background-color:#213333!important;color:#fff!important}.floating-buttons-container{position:fixed;bottom:20px;right:20px;display:flex;gap:10px;z-index:999}.floating-icon{border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #0003;transition:all .2s ease;padding:8px}.floating-icon:hover{transform:scale(1.05)}.floating-icon svg{width:24px;height:24px}.floating-icon.help-icon{background-color:#f2f2f2;color:#444}.floating-icon.help-icon:hover{background-color:#e2e2e2}.floating-icon.form-icon{background-color:#f2f2f2;color:#444}.floating-icon.form-icon:hover{background-color:#e2e2e2}.disclaimer-overlay,.form-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.disclaimer-box,.form-popup-box{background-color:#fff;width:500px;max-width:90%;padding:30px;border-radius:8px;box-shadow:0 4px 12px #00000026;position:relative;text-align:center}.disclaimer-box h2,.form-popup-box h2{margin-top:0;color:#333;font-size:24px;font-weight:700;margin-bottom:20px}.disclaimer-box p,.form-popup-box p{color:#555;line-height:1.5;margin-bottom:20px}.close-disclaimer,.close-form-popup{position:absolute;top:10px;right:15px;background:none;border:none;font-size:24px;cursor:pointer;color:#777;padding:0;line-height:1;transition:color .3s ease}.close-disclaimer:hover,.close-form-popup:hover{color:#333}.form-link-button{display:inline-block;background-color:#213333;color:#fff;text-decoration:none;padding:12px 24px;border-radius:5px;font-weight:600;transition:all .3s ease}.form-link-button:hover{background-color:#0056b3;transform:translateY(-2px);text-decoration:none;color:#fff}@media (max-width: 600px){.App-header{flex-direction:column;align-items:flex-start;padding:10px 3%}.logo{font-size:18px}.floating-buttons-container{bottom:15px;right:15px;gap:8px}.floating-icon{width:35px;height:35px}.floating-icon svg{width:20px;height:20px}}.sidebar{position:fixed;top:0;left:0;height:100vh;background-color:#213333;box-shadow:0 1px 2px #0000000d;border-right:5px solid rgba(0,0,0,.1);align-items:center;transition:width .3s ease;overflow-y:auto;overflow-x:hidden;z-index:10;scrollbar-color:rgb(154,154,154) transparent}select{padding-right:1rem;min-inline-size:6px}.sidebar-expanded{width:20vw}.sidebar-collapsed{width:4.5vw;border-right:1px black solid}.header-row{padding:1rem .75rem;display:flex;align-items:center;justify-content:space-between}.header-row.collapsed{justify-content:center}.logo-title{overflow:hidden;transition:opacity .2s ease;color:#fff}.logo-title.collapsed{opacity:0;pointer-events:none;width:0;overflow:hidden;white-space:nowrap}.nav-container{height:100%;display:flex;flex-direction:column;background-color:#fff;border-right:5px solid rgba(0,0,0,.1);box-shadow:0 1px 2px #0000000d;overflow:hidden}.sidebar button{background-color:#213333;color:#fff;border:none;padding:.5rem;display:flex;align-items:center;justify-content:center}.concentration-dropdown{font-size:16px;border-radius:50px;border:1px solid #213333;width:18vw;background-color:#d6dadd;color:#000;font-family:khula,sans-serif;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23213333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding:12px 12px 10px 24px}.concentration-req-container{margin-top:1rem;padding-bottom:2rem}.concentration-category{display:flex;flex-direction:column;gap:8px;padding:.25rem 0 .25rem .5rem;background-color:#d6dadd;border:#213333 solid 3px}.concentration-row{display:flex;gap:8px;padding:.25rem 0 .25rem .5rem;flex-wrap:initial;font-weight:500}.expand-button{width:30px;height:25px;background-color:#d6dadd!important;border:none solid 2px!important;border-radius:4px;padding:0;margin:0;display:flex;justify-content:flex-start;align-items:center;cursor:pointer;color:#213333!important}.expand-button::selection{outline:none;box-shadow:none;border:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.expand-button:active{outline:none;box-shadow:none;border:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.expand-button:focus{outline:none;box-shadow:none;border:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.button-icon{fill:#213333;width:30px;height:30px;display:block;stroke-width:8px}.requirement-list{border-radius:4px;font-weight:400;line-height:1.8}.requirement-list-container{display:flex;align-items:left;justify-content:left;padding:0}.requirement_completed{color:#3a5e42d2}.progress-check{color:#d6dadd}.cannot-list{color:#ac5a5ad2}.capstone-active{background-color:#d4edda!important;border-left:3px solid #28a745!important;font-weight:600!important;color:#155724!important}.capstone-indicator{color:#28a745;font-weight:700;margin-left:8px}.capstone-active{transition:all .3s ease}.concentration-req-container .concentration-category:last-child{margin-bottom:0}.concentration-subcategory{margin-left:1.5rem;margin-top:.5rem;border-left:2px solid #213333;padding-left:.75rem}.subcategory-row{display:flex;align-items:center;gap:.5rem;padding:.25rem 0;color:#213333;font-size:.9rem;font-weight:700}.subcategory-expand{background:#213333;border:none;border-radius:8px;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:flex-start;transition:background-color .2s;width:25px;height:25px}.subcategory-expand:hover{background:#2a4444}.subcategory-expand .button-icon{width:16px;height:16px}.subcategory-courses{margin-left:.5rem;margin-top:.5rem;padding-left:0}.subcategory-courses li{padding-left:0;margin-left:0;text-indent:0;list-style-position:inside;padding-inline-start:0}.subcategory-list{margin-top:.5rem}.semester-boxes-wrapper{display:flex;flex-wrap:nowrap;overflow-x:auto;padding:20px;gap:15px;justify-content:flex-start;width:calc(100% - 40px);margin:0 auto;box-sizing:border-box}.semester-box{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;height:70vh;border-radius:8px;margin:0 8px;flex-shrink:0;scroll-snap-align:start;overflow:visible;border:1.5px #c4c7c5 solid}.semester-box.collapsed{min-height:400px}.semester-box.error{border:2px solid #ff4444!important;background-color:#00000080!important;transition:all .3s ease;position:relative}.semester-box.error:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-color:#00000080;border-radius:8px;z-index:0}.semester-box.error .semester-content{position:relative;z-index:1;background-color:#fffffff2}.semester-box.error .semester-header{position:relative;z-index:1;background-color:#2b1919f2}.semester-error-message{color:#f44;font-size:14px;padding:8px;text-align:center;background-color:#ff44441a;border-radius:4px;margin:8px;animation:fadeIn .3s ease-in;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;pointer-events:none}.semester-header{width:100%;height:60px;background-color:#213333;color:#fff;padding:0 15px;font-family:Gaegu,cursive;font-weight:400;font-size:27px;border-radius:6px 6px 0 0;border-bottom:1.5px solid #c4c7c5;display:flex;align-items:center;justify-content:space-between;box-sizing:border-box;position:relative}.semester-header span{flex:1;text-align:center}.semester-header-with-select{width:100%;height:60px;background-color:#213333;border-radius:6px 6px 0 0;border-bottom:1.5px solid #c4c7c5;display:flex;align-items:center;justify-content:space-between;padding:0 15px;box-sizing:border-box}.semester-select-full{flex:1;height:100%;background-color:transparent;color:#fff;font-family:Roboto,cursive;font-weight:400;font-size:19px;border:none;padding:0 20px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;text-align:center}.semester-select-full:focus{outline:none}.semester-menu-button{background:none;border:none;color:#fff;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s ease}.semester-menu-button:hover{background-color:#ffffff1a}.semester-menu-button:active{background-color:#fff3}.semester-content{background-color:#fff;flex:1;padding:10px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;scroll-behavior:smooth;min-width:90%;margin:10px 2px;border-radius:8px;overflow-x:visible}.semester-content::-webkit-scrollbar{width:6px}.semester-content.drag-over{background-color:#f8f8f8;border:2px dashed #aaa}.course-slot{background-color:#e0f2ff;min-height:10vh;border:1.5px solid #c4c7c5;border-radius:4px;padding:10px;display:flex;align-items:center;justify-content:flex-start;margin:5px 0;text-align:left;position:relative;overflow:visible;scrollbar-width:2px}.course-slot.filled{min-height:13vh;max-height:13vh;border:1.5px solid #c4c7c5;display:block;flex-direction:column;padding:0;word-break:break-word;overflow-wrap:break-word;overflow-y:auto;overflow-x:hidden;scrollbar-color:rgb(154,154,154) transparent;scrollbar-width:thin}.course-slot.filled::-webkit-scrollbar{width:2px}.course-slot.filled::-webkit-scrollbar-track{background:transparent}.course-slot.filled::-webkit-scrollbar-thumb{background-color:#0003;border-radius:2px}.course-slot.filled::-webkit-scrollbar-thumb:hover{background-color:#0000004d}.course-slot.filled:not(.pr-met):not(.pr-not-met){background-color:#f0d7d7}.course-slot.filled.pr-not-met{background-color:#ffcdd2!important}.course-slot.filled.pr-met{background-color:#c8e6c9!important}.course-slot.filled.manual-course{background-color:#f0f0f0!important}.course-filled{display:flex;flex-direction:column;align-items:flex-start;position:relative;padding:10px}.course-code{font-weight:700;font-size:16px;margin-bottom:4px;padding-right:15px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;text-align:left;width:100%}.course-title{font-weight:400;font-size:14px;text-align:left;width:100%}.course-footer{display:flex;justify-content:space-between;align-items:center;margin-top:8px;width:100%}.capstone-section{margin-left:auto}.capstone-label{display:flex;align-items:center;gap:6px;font-size:12px;cursor:pointer;color:#333}.capstone-label span{font-weight:500;padding-right:16px}.capstone-checkbox{position:absolute;right:5px;transform:scale(1.2);cursor:pointer;transform:scale(1.1);accent-color:#5a6268}.prereq-section{position:relative;margin-right:0}.prereq-link{background:none;border:none;color:#007bff;font-size:12px;cursor:pointer;text-decoration:underline;padding:0;font-family:inherit}.prereq-link:hover{color:#0056b3}.prereq-link:disabled{color:#6c757d;cursor:not-allowed;text-decoration:none}.add-course-button{background-color:#fff;border:1.5px solid #c4c7c5;border-radius:4px;padding:10px 15px;cursor:pointer;margin-top:auto;color:#000;font-size:18px;text-align:center}.add-course-button:hover{background-color:#f9f9f9}.delete-course-btn,.delete-manual-course-btn{position:absolute;top:4px;right:4px;width:18px;height:18px;border:none;background:none;color:#000;border-radius:0;font-size:20px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .2s ease;line-height:1;padding:0;opacity:1;transform:scale(1)}.delete-course-btn:hover{color:#a02834;transform:scale(1.2)}.delete-course-btn:active{transform:scale(.95)}.confirmation-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.confirmation-box{background:#fff;padding:28px;border-radius:12px;box-shadow:0 8px 32px #0000004d;max-width:420px;width:90%;max-height:90vh;overflow-y:auto;animation:modalFadeIn .2s ease-out}.confirmation-box h2{margin:0 0 16px;color:#333;font-size:1.4rem;font-weight:600}.confirmation-box p{margin:0 0 24px;color:#666;line-height:1.5;font-size:1rem}.confirmation-box p strong{color:#333;font-weight:600}.confirmation-buttons{display:flex;gap:12px;justify-content:flex-end}.confirm-delete-btn,.cancel-delete-btn{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:.95rem;transition:all .2s ease;min-width:80px}.confirm-delete-btn{background-color:#dc3545;color:#fff}.confirm-delete-btn:hover{background-color:#c82333;transform:translateY(-1px)}.cancel-delete-btn{background-color:#6c757d;color:#fff}.cancel-delete-btn:hover{background-color:#5a6268;transform:translateY(-1px)}.confirm-delete-btn:active,.cancel-delete-btn:active{transform:translateY(0)}.prereq-popup{position:fixed;background:#fff;border:2px solid #dee2e6;border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:1000;max-width:500px;max-height:400px;overflow:auto;animation:popupFadeIn .3s ease-out}.prereq-popup::-webkit-scrollbar{width:8px}.prereq-popup::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.prereq-popup::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.prereq-popup::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.prereq-popup-header{padding:16px 20px;border-bottom:1px solid #dee2e6;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:6px 6px 0 0;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:1001}.prereq-popup-header h4{margin:0;font-size:16px;font-weight:600;color:#343a40}.close-popup-btn{background:none;border:none;font-size:24px;cursor:pointer;padding:4px 8px;border-radius:6px;color:#6c757d;line-height:1;transition:all .2s ease}.close-popup-btn:hover{background-color:#f8d7da;color:#721c24}.prereq-popup-content{padding:20px}.no-prereqs{text-align:center;padding:24px;background:linear-gradient(135deg,#d4edda,#c3e6cb);border:2px solid #28a745;border-radius:8px;color:#155724;font-size:14px;font-weight:500;margin:0;font-style:italic}.prereq-course-box{border-radius:8px;padding:12px 16px;margin:4px;display:inline-block;min-width:100px;text-align:center;font-size:13px;font-weight:600;transition:all .3s ease;cursor:default;position:relative;overflow:hidden}.prereq-course-box:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .5s ease}.prereq-course-box:hover:before{left:100%}.prereq-course-box .course-code{font-size:14px;font-weight:700;margin-bottom:4px;letter-spacing:.5px}.prereq-course-box.satisfied{background:linear-gradient(135deg,#d4edda,#c3e6cb);border:2px solid #28a745;color:#155724;box-shadow:0 2px 8px #28a74533}.prereq-course-box.satisfied:hover{transform:translateY(-2px);box-shadow:0 4px 12px #28a7454d}.prereq-course-box.not-satisfied{background:linear-gradient(135deg,#f8d7da,#f1c2c7);border:2px solid #dc3545;color:#721c24;box-shadow:0 2px 8px #dc354533}.prereq-course-box.not-satisfied:hover{transform:translateY(-2px);box-shadow:0 4px 12px #dc35454d}.prereq-group-box{border-radius:12px;padding:16px;margin:12px 0;transition:all .3s ease;position:relative;overflow:hidden}.prereq-group-box.and-group{background:linear-gradient(135deg,#f8fff9,#f0fff4);border:2px solid #28a745;box-shadow:0 4px 16px #28a7451a}.prereq-group-box.and-group:not([data-satisfied=true]){background:linear-gradient(135deg,#fff8f8,#fff0f0);border-color:#dc3545;box-shadow:0 4px 16px #dc35451a}.prereq-group-box.or-group{background:linear-gradient(135deg,#fff9f0,#fff3e0);border:2px solid #fd7e14;box-shadow:0 4px 16px #fd7e141a}.prereq-group-box.or-group:not([data-satisfied=true]){background:linear-gradient(135deg,#fff8f8,#fff0f0);border-color:#dc3545;box-shadow:0 4px 16px #dc35451a}.group-header{text-align:center;font-weight:700;font-size:14px;margin-bottom:12px;display:flex;align-items:center;justify-content:center;gap:8px;text-transform:uppercase;letter-spacing:1px}.group-header span:first-child{background:#fffc;padding:4px 12px;border-radius:20px;font-size:12px;border:1px solid rgba(0,0,0,.1)}.group-children{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:center}.or-group .group-children{flex-direction:column;align-items:stretch}.or-group .prereq-item{display:flex;justify-content:center}.connector{font-weight:700;font-size:11px;padding:6px 12px;background:linear-gradient(135deg,#fff,#f8f9fa);border:1px solid #dee2e6;border-radius:20px;color:#495057;text-transform:uppercase;letter-spacing:1px;box-shadow:0 2px 4px #0000001a;transition:all .2s ease}.connector:hover{background:linear-gradient(135deg,#f8f9fa,#e9ecef);transform:scale(1.05)}.course-edit-fields{display:flex;flex-direction:column;gap:8px;padding:10px 30px 10px 10px;height:100%;box-sizing:border-box}.course-edit-fields input[type=text]{width:100%;padding:8px 12px;border:1.5px solid #d1d5db;border-radius:6px;background:#fff;font-size:14px;text-align:center;transition:all .2s ease;color:#374151;box-sizing:border-box}.course-edit-fields input[type=text]:focus{outline:none;border-color:#60a5fa;background:#f0f9ff}.course-edit-fields input[type=text]::placeholder{color:#9ca3af;font-weight:400}.course-edit-fields input[type=text]:first-child{font-weight:600}.course-slot.filled:has(.course-edit-fields){position:relative}.course-slot.filled:has(.course-edit-fields) .delete-course-btn{position:absolute;top:4px;right:4px;z-index:10}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes popupFadeIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.course-slot.new-course{animation:fadeIn .3s ease-out}@media (max-width: 600px){.prereq-popup{max-width:90vw;margin:10px}.group-children{flex-direction:column;align-items:stretch}.prereq-course-box{margin:4px 0;min-width:auto}.semester-boxes-wrapper{padding:15px;gap:10px}.semester-box{margin:0 4px}}body{overflow-x:hidden}.carousel-outer-wrapper{display:flex;position:relative;width:calc(100% - 60px);align-items:center;justify-content:center;margin:0 auto;padding-top:20px;box-sizing:border-box;scrollbar-color:rgb(154,154,154) transparent}.carousel-outer-wrapper.two{max-width:850px}.carousel-outer-wrapper.four{max-width:1600px}@media (max-width: 768px){.carousel-outer-wrapper{width:calc(100% - 40px);padding-top:15px}.carousel-inner-wrapper.two{width:calc(100% - 30px);max-width:550px}.carousel-inner-wrapper.four{width:calc(100% - 30px);max-width:1100px}}@media (min-width: 769px) and (max-width: 1024px){.carousel-inner-wrapper.two{width:calc(100% - 50px);max-width:650px}.carousel-inner-wrapper.four{width:calc(100% - 50px);max-width:1300px}}@media (min-width: 1441px){.carousel-outer-wrapper{width:calc(100% - 100px);padding-top:25px}.carousel-inner-wrapper.two{width:calc(100% - 80px);max-width:800px}.carousel-inner-wrapper.four{width:calc(100% - 80px);max-width:1600px}}.carousel-inner-wrapper.two{width:calc(100% - 60px);max-width:700px}.carousel-inner-wrapper.four{width:calc(100% - 60px);max-width:1400px}.carousel-inner-wrapper.two.collapsed{width:calc(100% - 40px);max-width:750px}.carousel-inner-wrapper.four.collapsed{width:calc(100% - 40px);max-width:1500px}.carousel-inner-wrapper{width:100%;overflow-x:auto;overflow-y:hidden;display:flex;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;padding:0}.add-box{display:flex;flex-direction:column;align-items:center;justify-content:center;height:70vh;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1.5px solid #c4c7c5;border-radius:8px;margin:0 8px;transition:all .3s ease;position:relative;overflow:hidden;flex-shrink:0}.add-box.expanded:hover,.add-box:hover{border-color:#c4c7c5;background:linear-gradient(135deg,#e9ecef,#dee2e6)}.carousel-inner-wrapper .add-box{flex:0 0 280px;width:280px}@media (max-width: 768px){.carousel-inner-wrapper .add-box{flex:0 0 240px;width:240px;margin:0 4px}}@media (min-width: 769px) and (max-width: 1024px){.carousel-inner-wrapper .add-box{flex:0 0 260px;width:260px;margin:0 5px}}@media (min-width: 1025px) and (max-width: 1440px){.carousel-inner-wrapper .add-box{flex:0 0 280px;width:280px;margin:0 6px}}@media (min-width: 1441px){.carousel-inner-wrapper .add-box{flex:0 0 300px;width:300px;margin:0 8px}}.add-button{display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:18px;font-weight:500;color:#000;width:100%;height:100%;background:transparent;border:none;cursor:pointer;transition:all .3s ease;text-align:center;line-height:1.4}.add-button:hover{color:#343a40;transform:scale(1.02)}.add-button:active{border:none;transform:scale(.98)}.add-button-plus{font-size:48px;font-weight:300;margin-bottom:8px;opacity:.8;transition:all .3s ease}.add-button:hover .add-button-plus{opacity:1;transform:rotate(90deg)}.carousel-track{display:flex;flex-direction:row;justify-content:flex-start;align-items:stretch;gap:0;width:max-content}.carousel-inner-wrapper .semester-box{flex:0 0 280px;width:280px;margin:0 6px}@media (max-width: 768px){.carousel-inner-wrapper .semester-box{flex:0 0 240px;width:240px;margin:0 4px}}@media (min-width: 769px) and (max-width: 1024px){.carousel-inner-wrapper .semester-box{flex:0 0 260px;width:260px;margin:0 5px}}@media (min-width: 1025px) and (max-width: 1440px){.carousel-inner-wrapper .semester-box{flex:0 0 280px;width:280px;margin:0 6px}}@media (min-width: 1441px){.carousel-inner-wrapper .semester-box{flex:0 0 300px;width:300px;margin:0 8px}}.carousel-button{position:absolute;top:50%;transform:translateY(-50%);z-index:1000;background:transparent;border:none;border-radius:100px;width:clamp(30px,3vw,45px);height:clamp(40px,6vh,55px);font-size:42px;font-weight:700;cursor:pointer;opacity:.8;display:flex;justify-content:center;align-items:center;color:#000;outline:none;box-shadow:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.carousel-button:hover{outline:none;box-shadow:none;color:gray;border:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.carousel-button::selection{outline:none;box-shadow:none;border:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.carousel-button:active{outline:none;box-shadow:none;border:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.carousel-button:focus{outline:none;box-shadow:none;border:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.carousel-button:before,.carousel-button:after{outline:none;box-shadow:none}.carousel-button.left{left:clamp(-75px,-2vw,-55px)}.carousel-button.right{right:clamp(-75px,-2vw,-55px)}@media (max-width: 768px){.carousel-button{width:30px;height:45px;font-size:42px}.carousel-button.left{left:-88px}.carousel-button.right{right:-30px}}@media (min-width: 1441px){.carousel-button{width:40px;height:55px;font-size:52px}.carousel-button.left{left:-80px}.carousel-button.right{right:-80px}}.carousel-button:disabled{opacity:.3;cursor:not-allowed}.drop-error-message{position:fixed;top:20px;left:50%;transform:translate(-50%);background-color:#f44;color:#fff;padding:10px 20px;border-radius:4px;z-index:1000;animation:fadeInOut 3s ease-in-out;box-shadow:0 2px 4px #0003}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,-20px)}10%{opacity:1;transform:translate(-50%)}90%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-20px)}}.menu-item{width:100%;height:8vh;display:flex;align-items:center;justify-content:center}.menu{background-color:#fff}.bear-tracks-container{display:flex;flex-direction:column;width:100%;padding-top:2vh;align-items:center;gap:0px;box-sizing:border-box;overflow-x:hidden;scrollbar-color:rgb(154,154,154) transparent}.bear-tracks-container.collapsed{width:100%}.searchbar-and-trash-container{position:relative;width:calc(100% - 40px);margin:16px auto;display:flex;justify-content:center;align-items:center;padding:0 20px;box-sizing:border-box}.enlarged-trash-zone{width:200px;height:120px;display:flex;justify-content:center;margin-top:20px;border-radius:9999px;overflow:hidden;background-color:#fff;align-items:center;position:relative}@keyframes wiggle{0%{transform:rotate(0) scale(1.1)}25%{transform:rotate(5deg) scale(1.1)}50%{transform:rotate(0) scale(1.1)}75%{transform:rotate(-5deg) scale(1.1)}to{transform:rotate(0) scale(1.1)}}.search-results-container{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;height:20vh;overflow-y:auto;overflow-x:hidden;padding:12px 20px;margin:0 auto;border-bottom:1px solid #e2e2e2;width:calc(100% - 40px);box-sizing:border-box}.search-course-block{background-color:#f0f0f0;color:#000;padding:10px;border:1.5px solid #c4c7c5;border-radius:8px;width:100%;height:12vh;box-sizing:border-box;display:flex;flex-direction:column;cursor:grab;overflow-y:auto;overflow-x:hidden}.search-course-block::-webkit-scrollbar{width:4px}.search-course-block::-webkit-scrollbar-track{background:transparent}.search-course-block::-webkit-scrollbar-thumb{background-color:#0003;border-radius:2px}.search-course-block::-webkit-scrollbar-thumb:hover{background-color:#0000004d}.search-course-block:hover{background-color:#d9d9d9}.course-code{font-size:1.1rem;font-weight:700;margin-bottom:2px;overflow:hidden;white-space:nowrap;min-height:2.4vh}.course-title{font-size:.9rem;word-break:break-word;overflow-wrap:break-word}.trash-hovered{background-color:#ffe0e0;border:2px solid red}.trash-hovered{animation:wiggle .3s ease-in-out infinite}@keyframes wiggle{0%{transform:rotate(0)}25%{transform:rotate(5deg)}50%{transform:rotate(0)}75%{transform:rotate(-5deg)}to{transform:rotate(0)}}.view-and-sort-container{display:flex;gap:20px;align-items:center;margin-top:20px;margin-bottom:20px}.display-view{display:flex;border:2px solid #213333;border-radius:9999px;overflow:hidden;width:120px;height:40px;background-color:#fff;align-items:center}.display-view-button{flex:1;border:none;background-color:#fff;color:#1e3a8a;font-weight:700;cursor:pointer;transition:background-color .3s,color .3s;height:100%}.display-view-button:focus{outline:none;box-shadow:none}.display-view-button.selected{background-color:#213333;color:#fff;height:100%;align-items:center}.display-view-button.unselected{background-color:#fff;color:#213333}.sort-semesters-button{padding:0 20px;height:40px;border:2px solid #213333;border-radius:9999px;background-color:#fff;color:#213333;font-weight:700;cursor:pointer;transition:all .3s ease;white-space:nowrap}.sort-semesters-button:hover{background-color:#213333;color:#fff}.sort-semesters-button:focus{outline:none}.sort-notification{position:fixed;top:100px;left:45%;background-color:#4caf50;color:#fff;padding:12px 24px;border-radius:8px;box-shadow:0 4px 6px #0000001a;z-index:1000;animation:slideIn .3s ease-out;font-weight:500}.sort-notification.already-sorted{background-color:#424242}@keyframes slideIn{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.search-bar-input{padding:8px 12px;font-size:14px;border-radius:50px;border:1px solid #2c4444;width:100%;min-width:350px;background-color:#e9ecef;color:#000;font-family:khula}.tour-container{position:fixed;top:0;left:0;right:0;bottom:0;z-index:100000;pointer-events:none}.tour-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;pointer-events:all;transition:clip-path .3s ease-out;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.tour-highlight{position:fixed;border:3px solid #4caf50;border-radius:8px;pointer-events:none;animation:pulse 2s infinite;box-shadow:0 0 0 4px #4caf504d;transition:all .3s ease-out;z-index:99999}@keyframes pulse{0%{box-shadow:0 0 0 4px #4caf504d}50%{box-shadow:0 0 0 8px #4caf501a}to{box-shadow:0 0 0 4px #4caf504d}}.tour-tooltip:before{content:none!important}.tour-tooltip{position:fixed;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;padding:24px;max-width:400px;pointer-events:all;transition:all .3s ease-out;z-index:100001}.tour-tooltip-centered{top:50%;left:50%;transform:translate(-50%,-50%);animation:fadeInCenter .3s ease-out}@keyframes fadeInCenter{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.tour-close{position:absolute;top:12px;right:12px;background:none;border:none;color:#666;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s}.tour-close:hover{background-color:#f0f0f0;color:#333}.tour-content{margin-bottom:20px}.tour-content h3{margin:0 0 12px;color:#213333;font-size:20px;font-weight:600;padding-right:30px}.tour-content p{margin:0;color:#555;line-height:1.5;font-size:15px}.tour-navigation{display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid #e0e0e0}.tour-progress{color:#888;font-size:14px;font-weight:500}.tour-buttons{display:flex;gap:10px}.tour-btn{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:4px;border:none}.tour-btn-prev{background-color:#fff;color:#666;border:1px solid #ddd}.tour-btn-prev:hover{background-color:#f5f5f5;border-color:#bbb}.tour-btn-skip{background-color:#fff;color:#888;border:1px solid transparent}.tour-btn-skip:hover{color:#555;text-decoration:underline}.tour-btn-next{background-color:#337335;color:#fff}.tour-btn-next:hover{background-color:#45a049}.tour-tooltip:before{content:"";position:absolute;width:0;height:0;border-style:solid}.tour-tooltip[data-position=top]:before{bottom:-10px;left:50%;transform:translate(-50%);border-width:10px 10px 0 10px;border-color:white transparent transparent transparent}.tour-tooltip[data-position=bottom]:before{top:-10px;left:50%;transform:translate(-50%);border-width:0 10px 10px 10px;border-color:transparent transparent white transparent}.tour-tooltip[data-position=left]:before{right:-10px;top:50%;transform:translateY(-50%);border-width:10px 0 10px 10px;border-color:transparent transparent transparent white}.tour-tooltip[data-position=right]:before{left:-10px;top:50%;transform:translateY(-50%);border-width:10px 10px 10px 0;border-color:transparent white transparent transparent}@media (max-width: 600px){.tour-tooltip{max-width:calc(100vw - 40px);margin:20px}.tour-content h3{font-size:18px}.tour-content p{font-size:14px}.tour-buttons{flex-wrap:wrap}}
