@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";
:root{--bg-primary:#0a0e1a;--bg-card:#ffffff08;--bg-card-hover:#ffffff14;--accent:#d4a843;--accent-glow:#d4a8434d;--text-primary:#f0f0f5;--text-secondary:#8a8fa8;--border:#ffffff14;--radius:12px;--glass-blur:16px;--cat-arts:#d4a843;--cat-society:#43b5a0;--cat-science:#7c6cf0}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;margin:0;font-family:Inter,sans-serif;overflow-x:hidden}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}.glass-panel{background:var(--bg-card);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--border);border-radius:var(--radius)}.layout{max-width:1440px;margin:0 auto;padding:0 2rem}.navbar{justify-content:space-between;align-items:center;padding:1.25rem 0;display:flex}.logo{letter-spacing:-.5px;font-size:1.5rem;font-weight:700}.logo span{color:var(--accent)}.nav-links{align-items:center;gap:2rem;display:flex}.nav-links a{color:var(--text-secondary);font-weight:500;transition:color .2s}.nav-links a:hover,.nav-links a.active{color:var(--text-primary)}.btn-signin{color:var(--text-primary);padding:.5rem 1.25rem;font-weight:500;transition:all .2s}.btn-signin:hover{background:var(--bg-card-hover);box-shadow:0 0 15px var(--accent-glow);border-color:#ffffff26}.tagline{text-align:center;color:var(--text-secondary);letter-spacing:.2px;margin-top:1.5rem;margin-bottom:1.5rem;font-size:1rem}.search-container{margin:1.5rem 0;position:relative}.search-input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-primary);outline:none;padding:1rem 1rem 1rem 3rem;font-size:1rem;transition:all .3s}.search-input::placeholder{color:var(--text-secondary)}.search-input:focus{border-color:var(--accent);background:#ffffff0d;box-shadow:0 0 20px #d4a84326}.search-icon{color:var(--text-secondary);position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.main-content{gap:2rem;min-height:60vh;padding-bottom:6rem;display:flex}.filter-panel{align-self:flex-start;width:280px;min-width:280px;max-height:calc(100vh - 2rem);padding:1.5rem;position:sticky;top:1rem;overflow-y:auto}.filter-group{margin-bottom:1.75rem}.filter-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem;font-size:.8rem;font-weight:600;display:block}.filter-select{width:100%;color:var(--text-primary);border:1px solid var(--border);appearance:none;background:var(--bg-card);border-radius:8px;padding:.65rem .75rem;font-family:inherit;font-size:.875rem}.foundation-group{margin-bottom:1.25rem}.subcategory-row{flex-wrap:wrap;gap:.4rem;margin-top:.4rem;display:flex}.filter-chip{color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:20px;padding:.45rem .9rem;font-size:.75rem;font-weight:500;transition:all .2s}.filter-chip:hover{background:#ffffff0d}.chip-arts{border-color:#d4a8434d}.chip-arts.active{color:var(--cat-arts);border-color:var(--cat-arts);box-shadow:0 0 10px var(--accent-glow);background:#d4a84326}.chip-arts-sub{border-style:dashed;border-color:#d4a84340;padding:.3rem .7rem;font-size:.7rem}.chip-arts-sub:hover{border-color:#d4a84399}.chip-arts-sub.active{color:var(--cat-arts);border-style:solid;border-color:var(--cat-arts);background:#d4a84333}.chip-society{border-color:#43b5a04d}.chip-society.active{color:var(--cat-society);border-color:var(--cat-society);background:#43b5a026;box-shadow:0 0 10px #43b5a04d}.chip-society-sub{border-style:dashed;border-color:#43b5a040;padding:.3rem .7rem;font-size:.7rem}.chip-society-sub:hover{border-color:#43b5a099}.chip-society-sub.active{color:var(--cat-society);border-style:solid;border-color:var(--cat-society);background:#43b5a033}.chip-science{border-color:#7c6cf04d}.chip-science.active{color:var(--cat-science);border-color:var(--cat-science);background:#7c6cf026;box-shadow:0 0 10px #7c6cf04d}.chip-science-sub{border-style:dashed;border-color:#7c6cf040;padding:.3rem .7rem;font-size:.7rem}.chip-science-sub:hover{border-color:#7c6cf099}.chip-science-sub.active{color:var(--cat-science);border-style:solid;border-color:var(--cat-science);background:#7c6cf033}.days-row{gap:.4rem;display:flex}.day-circle{border:1px solid var(--border);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;transition:all .2s;display:flex}.day-circle:hover,.day-circle.active{border-color:var(--accent);color:var(--accent);background:#d4a8431a}.time-row{flex-wrap:wrap;gap:.4rem;display:flex}.time-pill{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:20px;padding:.4rem .9rem;font-size:.8rem;transition:all .2s}.time-pill:hover,.time-pill.active{border-color:var(--accent);color:var(--accent);background:#d4a8431a}.clear-btn{color:var(--accent);margin-top:.5rem;font-size:.8rem;text-decoration:underline}.conflict-toggle{border:1px solid var(--border);cursor:pointer;text-align:left;background:#ffffff05;border-radius:10px;align-items:flex-start;gap:.6rem;padding:.7rem .85rem;transition:all .2s;display:flex}.conflict-toggle:hover{background:#ffffff0a}.conflict-toggle.active{background:#ef44440f;border-color:#ef44444d}.conflict-checkbox{border:2px solid var(--border);border-radius:4px;justify-content:center;align-items:center;width:18px;min-width:18px;height:18px;margin-top:1px;transition:all .2s;display:flex}.conflict-checkbox.checked{background:#ef4444;border-color:#ef4444}.conflict-checkbox svg{color:#fff}.conflict-toggle-text{color:var(--text-secondary);font-size:.75rem;line-height:1.4}.conflict-prompt{flex-direction:column;gap:.6rem;display:flex}.conflict-prompt-text{color:var(--text-secondary);font-size:.75rem;line-height:1.4}.conflict-prompt-btn{text-align:center;color:var(--accent);border:1px solid #d4a84340;border-radius:8px;padding:.55rem .85rem;font-size:.8rem;font-weight:500;transition:all .2s;display:inline-block}.conflict-prompt-btn:hover{background:#d4a84314;border-color:#d4a84366}.schedule-page{max-width:700px;margin:0 auto;padding:1.5rem 0 4rem}.schedule-title{margin-bottom:.35rem;font-size:1.75rem;font-weight:800}.schedule-subtitle{color:var(--text-secondary);margin-bottom:2rem;font-size:.9rem}.schedule-search-wrapper{margin-bottom:2rem;position:relative}.schedule-search-container{position:relative}.schedule-search-icon{color:var(--text-secondary);position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.schedule-search-input{background:var(--bg-card);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:12px;outline:none;padding:.9rem 1rem .9rem 2.75rem;font-family:inherit;font-size:.9rem;transition:border-color .2s}.schedule-search-input::placeholder{color:var(--text-secondary)}.schedule-search-input:focus{border-color:var(--accent)}.schedule-search-spinner{color:var(--text-secondary);font-size:.75rem;position:absolute;top:50%;right:1rem;transform:translateY(-50%)}.schedule-dropdown{z-index:50;border:1px solid var(--border);background:#111728;border-radius:12px;max-height:320px;margin-top:.4rem;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.schedule-dropdown-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.schedule-dropdown-item:last-child{border-bottom:none}.schedule-dropdown-info{flex-direction:column;gap:.1rem;min-width:0;display:flex}.schedule-dropdown-code{color:var(--accent);font-size:.8rem;font-weight:600}.schedule-dropdown-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.schedule-dropdown-time{color:var(--text-secondary);font-size:.7rem}.schedule-dropdown-btn{border:1px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;padding:.4rem .8rem;font-size:.75rem;font-weight:600;transition:all .2s}.schedule-dropdown-btn:hover{background:#d4a84314}.schedule-dropdown-btn.added{color:#f87171;border-color:#ef444466}.schedule-dropdown-btn.added:hover{background:#ef444414}.schedule-classes{margin-top:.5rem}.schedule-section-title{align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1rem;font-weight:700;display:flex}.schedule-count{background:var(--accent);color:var(--bg-primary);border-radius:20px;padding:.15rem .5rem;font-size:.7rem;font-weight:700}.schedule-empty{text-align:center;color:var(--text-secondary);padding:2.5rem 1rem;font-size:.9rem}.schedule-empty p+p{margin-top:.3rem;font-size:.8rem}.schedule-class-list{flex-direction:column;gap:.75rem;display:flex}.schedule-class-card{justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.schedule-class-info{flex-direction:column;gap:.15rem;min-width:0;display:flex}.schedule-class-code{color:var(--accent);font-size:.85rem;font-weight:600}.schedule-class-name{color:var(--text-primary);font-size:.85rem}.schedule-class-meta{color:var(--text-secondary);gap:.35rem;font-size:.75rem;display:flex}.schedule-class-instructor{color:var(--text-secondary);opacity:.7;font-size:.7rem}.schedule-remove-btn{color:#f87171;cursor:pointer;background:0 0;border:1px solid #ef444440;border-radius:8px;flex-shrink:0;padding:.4rem .85rem;font-size:.75rem;font-weight:500;transition:all .2s}.schedule-remove-btn:hover{background:#ef444414}.schedule-save-note{text-align:center;color:var(--text-secondary);opacity:.6;margin-top:2rem;font-size:.75rem}.grid-wrapper{flex-direction:column;flex:1;gap:1rem;display:flex}.sort-bar{gap:.5rem;display:flex}.sort-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:20px;align-items:center;gap:.4rem;padding:.4rem .85rem;font-size:.75rem;font-weight:500;transition:all .2s;display:flex}.sort-btn:hover{border-color:var(--accent);color:var(--text-primary)}.sort-btn.active{border-color:var(--accent);color:var(--accent);background:#d4a84326}.course-grid{flex:1;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));align-content:start;gap:1.25rem;display:grid}.show-all-hint{text-align:center;color:var(--text-secondary);opacity:.5;margin-top:-.5rem;padding:0 1rem .5rem;font-size:.75rem}.course-card{flex-direction:column;gap:.75rem;padding:1.25rem;transition:all .3s;display:flex;position:relative}.course-card:hover{border-color:#d4a84340;transform:translateY(-2px);box-shadow:0 0 25px #d4a8431a}.card-header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.card-code{color:var(--accent);letter-spacing:.3px;font-size:.85rem;font-weight:600}.card-badges{flex-wrap:wrap;gap:.4rem;display:flex}.badge{white-space:nowrap;border-radius:10px;padding:.2rem .55rem;font-size:.6rem;font-weight:500}.badge-arts{color:var(--cat-arts);background:#d4a84326;border:1px solid #d4a8434d}.badge-society{color:var(--cat-society);background:#43b5a026;border:1px solid #43b5a04d}.badge-science{color:var(--cat-science);background:#7c6cf026;border:1px solid #7c6cf04d}.badge-default{color:var(--text-secondary);border:1px solid var(--border);background:#ffffff14}.badge-cat{color:var(--text-secondary);border:1px dotted var(--border);border-radius:10px;padding:.2rem .55rem;font-size:.6rem}.card-title{font-size:1.05rem;font-weight:600;line-height:1.3}.card-meta{flex-direction:column;gap:.5rem;display:flex}.card-meta-row{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.8rem;display:flex}.card-meta-row svg{flex-shrink:0}.card-meta-text{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.card-actions{border-top:1px solid var(--border);gap:.75rem;margin-top:auto;padding-top:.75rem;display:flex}.card-save-btn{color:var(--text-primary);flex:1;padding:.6rem;font-size:.85rem;font-weight:500;transition:all .2s}.card-save-btn:hover{background:var(--bg-card-hover);box-shadow:0 0 10px var(--accent-glow)}.card-save-btn.added{color:#4ade80;cursor:default;background:#4ade8026;border-color:#4ade80;justify-content:center;align-items:center;gap:.3rem;display:flex}.card-save-btn.added:hover{box-shadow:none}.card-toast{color:#0a0f1a;white-space:nowrap;z-index:10;background:#4ade80;border-radius:20px;align-items:center;gap:.3rem;padding:.35rem .75rem;font-size:.7rem;font-weight:600;animation:.3s toastPop,.4s 1.6s forwards toastFade;display:flex;position:absolute;top:.75rem;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #4ade804d}@keyframes toastPop{0%{opacity:0;transform:translate(-50%)translateY(-8px)scale(.9)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}@keyframes toastFade{to{opacity:0;transform:translate(-50%)translateY(-8px)}}.card-enroll-link{color:var(--accent);align-items:center;gap:.3rem;padding:.6rem .75rem;font-size:.85rem;font-weight:500;transition:opacity .2s;display:flex}.card-enroll-link:hover{opacity:.8}.section-tag{color:var(--text-secondary);margin-left:.25rem;font-size:.65rem}.card-section-type{color:var(--text-secondary);border:1px solid var(--border);background:#ffffff0d;border-radius:6px;padding:.15rem .5rem;font-size:.7rem}.card-grades{border-top:1px solid var(--border);margin-top:.25rem;padding-top:.6rem}.card-grades-header{justify-content:space-between;align-items:center;margin-bottom:.4rem;display:flex}.card-grades-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-size:.65rem;font-weight:600}.card-grades-pct-a{color:#4ade80;font-size:.75rem;font-weight:700}.card-grades-bar{border-radius:4px;gap:1px;height:8px;margin-bottom:.35rem;display:flex;overflow:hidden}.grade-seg{min-width:2px;transition:opacity .2s}.grade-seg:hover{opacity:.8}.grade-a{background:#4ade80}.grade-b{background:#60a5fa}.grade-c{background:#fbbf24}.grade-d{background:#f97316}.grade-f{background:#ef4444}.card-grades-legend{flex-wrap:wrap;gap:.6rem;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:.2rem;font-size:.6rem;display:flex}.legend-dot{border-radius:50%;width:6px;height:6px;display:inline-block}.modal-overlay{z-index:500;background:#000000a6;animation:.2s fadeIn;position:fixed;inset:0}.modal-container{z-index:510;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-panel{border:1px solid var(--border);background:#111728;border-radius:20px;flex-direction:column;width:100%;max-width:520px;max-height:80vh;animation:.3s cubic-bezier(.32,.72,0,1) slideUp;display:flex;overflow:hidden}.modal-header{padding:1.75rem 1.75rem 0}.modal-scroll-area{flex:1;padding:1.25rem 1.75rem .5rem;overflow-y:auto}.modal-actions{border-top:1px solid var(--border);background:#111728;padding:1rem 1.75rem 1.5rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:flex-start;padding:1.75rem 1.75rem 1rem;display:flex}.modal-title{font-size:1.15rem;font-weight:700}.modal-subtitle{color:var(--text-secondary);margin-top:.25rem;font-size:.8rem}.modal-close-btn{color:var(--text-secondary);padding:.25rem;transition:color .2s}.modal-close-btn:hover{color:var(--text-primary)}.modal-lecture-summary{color:var(--accent);background:#d4a84314;border:1px solid #d4a84333;border-radius:10px;align-items:center;gap:.5rem;margin-bottom:1.25rem;padding:.6rem .9rem;font-size:.8rem;display:flex}.modal-section-group{margin-bottom:1rem}.modal-section-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.8rem;font-weight:600;display:flex}.modal-section-count{color:var(--text-secondary);opacity:.6;font-size:.7rem;font-weight:400}.modal-section-list{flex-direction:column;gap:.5rem;display:flex}.modal-section-option{text-align:left;border:1px solid var(--border);cursor:pointer;background:#ffffff05;border-radius:10px;padding:.85rem 1rem;transition:all .2s;position:relative}.modal-section-option:hover{background:#ffffff0d;border-color:#ffffff26}.modal-section-option.selected{border-color:var(--accent);background:#d4a84314;box-shadow:0 0 12px #d4a84326}.modal-option-top{justify-content:space-between;align-items:center;margin-bottom:.35rem;display:flex}.modal-option-section{color:var(--text-primary);font-size:.85rem;font-weight:600}.modal-option-days{color:var(--accent);font-size:.8rem;font-weight:500}.modal-option-bottom{justify-content:space-between;align-items:center;display:flex}.modal-option-time{color:var(--text-secondary);align-items:center;gap:.35rem;font-size:.75rem;display:flex}.modal-option-instructor{color:var(--text-secondary);font-size:.75rem}.modal-option-location{color:var(--text-secondary);opacity:.7;align-items:center;gap:.35rem;margin-top:.3rem;font-size:.7rem;display:flex}.modal-option-check{color:var(--accent);position:absolute;top:.6rem;right:.6rem}.modal-actions{border-top:1px solid var(--border);background:#111728;gap:.75rem;padding:1rem 1.75rem 1.5rem;display:flex}.modal-skip-btn{color:var(--text-primary);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff26;border-radius:10px;flex:1;padding:.75rem;font-size:.85rem;font-weight:500;transition:all .2s}.modal-skip-btn:hover{background:#ffffff1a;border-color:#ffffff40}.modal-confirm-btn{color:var(--bg-primary);background:var(--accent);border-radius:10px;flex:1;padding:.75rem;font-size:.85rem;font-weight:600;transition:opacity .2s}.modal-confirm-btn:disabled{opacity:.4;cursor:not-allowed}.modal-confirm-btn:not(:disabled):hover{opacity:.9}.mobile-filter-btn{z-index:100;color:var(--bg-primary);background:var(--accent);border-radius:50px;padding:.85rem 1.5rem;font-size:.9rem;font-weight:600;transition:transform .2s,box-shadow .2s;display:none;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 4px 20px #d4a84366}.mobile-filter-btn:hover{transform:scale(1.05)}.mobile-filter-btn svg{vertical-align:middle;margin-right:.4rem}.drawer-overlay{z-index:200;opacity:0;background:#0009;transition:opacity .3s;display:none;position:fixed;inset:0}.drawer-overlay.open{opacity:1;display:block}.filter-drawer{z-index:300;background:#111728;border-top-left-radius:24px;border-top-right-radius:24px;max-height:80vh;padding:1.5rem;transition:transform .35s cubic-bezier(.32,.72,0,1);display:none;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;transform:translateY(100%)}.filter-drawer.open{display:block;transform:translateY(0)}.drawer-handle{background:#fff3;border-radius:2px;width:40px;height:4px;margin:0 auto 1.25rem}.drawer-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.drawer-title{font-size:1.1rem;font-weight:700}.drawer-close{color:var(--text-secondary);padding:.4rem .8rem;font-size:.85rem}.drawer-apply-btn{background:var(--accent);width:100%;color:var(--bg-primary);border-radius:var(--radius);margin-top:1.5rem;padding:.9rem;font-size:.95rem;font-weight:700;transition:opacity .2s}.drawer-apply-btn:hover{opacity:.9}.state-message{text-align:center;color:var(--text-secondary);grid-column:1/-1;padding:3rem 1rem}.state-message p{margin-top:.5rem;font-size:.9rem}.class-search{gap:.75rem;margin-bottom:1.5rem;display:flex}.class-search-field{flex:1;position:relative}.class-search-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:.4rem;font-size:.7rem;font-weight:600;display:block}.class-search-input{background:var(--bg-card);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:10px;outline:none;padding:.75rem .85rem;font-family:inherit;font-size:.85rem;transition:border-color .2s}.class-search-input::placeholder{color:var(--text-secondary)}.class-search-input:focus{border-color:var(--accent)}.class-search-input:disabled{opacity:.4;cursor:not-allowed}.class-search-dropdown{z-index:50;border:1px solid var(--border);background:#111728;border-radius:10px;max-height:250px;margin-top:.3rem;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.class-search-dropdown-item{text-align:left;border-bottom:1px solid var(--border);cursor:pointer;width:100%;color:var(--text-primary);flex-direction:column;gap:.1rem;padding:.6rem .85rem;font-size:.8rem;transition:background .15s;display:flex}.class-search-dropdown-item:last-child{border-bottom:none}.class-search-dropdown-item:hover{background:#ffffff0d}.class-search-dropdown-item.selected{color:var(--accent);background:#d4a84314}.class-search-item-code{color:var(--accent);font-size:.8rem;font-weight:600}.class-search-item-name{color:var(--text-secondary);font-size:.7rem}.lecture-picker{margin-bottom:2rem}.lecture-picker-title{color:var(--text-primary);margin-bottom:.75rem;font-size:.85rem;font-weight:700}.lecture-picker-list{flex-direction:column;gap:.6rem;display:flex}.lecture-picker-item{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;gap:.75rem;padding:.85rem 1rem;transition:border-color .2s;display:flex}.lecture-picker-item:hover{border-color:#ffffff26}.lecture-picker-info{flex-direction:column;gap:.1rem;display:flex}.lecture-picker-section{color:var(--text-primary);font-size:.8rem;font-weight:600}.lecture-picker-time{color:var(--accent);font-size:.75rem}.lecture-picker-instructor{color:var(--text-secondary);font-size:.7rem}@media (max-width:868px){.layout{padding:0 1rem;overflow-x:hidden}.filter-panel{display:none}.mobile-filter-btn{align-items:center;display:flex}.filter-drawer{display:block}.nav-links{gap:1rem}.nav-links a{font-size:.85rem}.btn-signin{padding:.4rem 1rem;font-size:.85rem}.logo{font-size:1.25rem}.search-container{margin:1rem 0}.search-input{padding:.85rem .85rem .85rem 2.75rem;font-size:.9rem}.course-grid{grid-template-columns:1fr;gap:1rem}.course-card{overflow:hidden}.card-title{word-break:break-word;font-size:1rem}.card-code{word-break:break-word;white-space:normal;font-size:.8rem}.main-content{padding-bottom:5rem}.schedule-page{padding:1.5rem .5rem 4rem}.schedule-title{font-size:1.5rem}.schedule-subtitle{margin-bottom:1.5rem;font-size:.85rem}.schedule-search-input{font-size:.85rem}.schedule-class-list{gap:1rem}.schedule-class-card{padding:1.1rem 1rem}.schedule-section-title{margin-top:.5rem;margin-bottom:1.25rem}.class-search{flex-direction:column}.class-search-input{font-size:.85rem}}@media (max-width:480px){.layout{padding:0 .75rem}.navbar{padding:1rem 0}.logo{font-size:1.1rem}.nav-links{gap:.5rem}.nav-links a{font-size:.8rem}.btn-signin{padding:.3rem .65rem;font-size:.75rem}.course-card{padding:1rem}.card-code{font-size:.75rem}.card-badges{gap:.3rem}.badge,.badge-cat{font-size:.55rem}.card-meta-text{font-size:.75rem}.schedule-page{padding:1.25rem .25rem 4rem}.schedule-title{margin-bottom:.25rem;font-size:1.35rem}.schedule-subtitle{margin-bottom:1.25rem;font-size:.8rem}.schedule-search-input{padding:.8rem .8rem .8rem 2.5rem;font-size:.8rem}.schedule-class-card{padding:1rem .85rem}.schedule-class-code,.schedule-class-name{font-size:.8rem}.schedule-class-meta{font-size:.7rem}.schedule-remove-btn{padding:.35rem .7rem;font-size:.7rem}.schedule-save-note{font-size:.7rem}}.timetable-container{border:1px solid var(--border);background:#11172899;border-radius:12px;margin:1.5rem 0;overflow:hidden}.timetable{min-width:600px;overflow-x:auto}.tt-header{border-bottom:2px solid var(--border);background:#d4a84314;display:flex}.tt-time-col{flex-shrink:0;width:60px;min-width:60px}.tt-day-col{text-align:center;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);border-left:1px solid var(--border);flex:1;padding:.6rem .25rem;font-size:.75rem;font-weight:700}.tt-body{display:flex;position:relative}.tt-time-labels{flex-shrink:0;width:60px;min-width:60px;position:relative}.tt-time-label{color:var(--text-secondary);font-size:.65rem;font-weight:500;position:absolute;right:8px;transform:translateY(-50%)}.tt-columns{flex:1;display:flex;position:relative}.tt-column{border-left:1px solid var(--border);flex:1;position:relative}.tt-grid-line{border-top:1px solid #ffffff0a;height:0;position:absolute;left:0;right:0}.tt-block{cursor:default;z-index:1;border-radius:6px;flex-direction:column;gap:1px;padding:.25rem .4rem;transition:transform .15s,box-shadow .15s;display:flex;position:absolute;left:2px;right:2px;overflow:hidden}.tt-block:hover{z-index:5;transform:scale(1.02);box-shadow:0 4px 16px #0000004d}.tt-block-code{font-size:.65rem;font-weight:700;line-height:1.2}.tt-block-section{color:var(--text-secondary);font-size:.55rem}.tt-block-location{color:var(--text-secondary);opacity:.7;text-overflow:ellipsis;white-space:nowrap;font-size:.5rem;overflow:hidden}.timetable-container{-webkit-overflow-scrolling:touch;overflow-x:auto}@media (max-width:768px){.tt-time-col,.tt-time-labels{width:45px;min-width:45px}.tt-time-label{font-size:.55rem}.tt-day-col{padding:.4rem .15rem;font-size:.6rem}.tt-block-code{font-size:.55rem}.tt-block-section{font-size:.5rem}.tt-block-location{display:none}}
