@font-face{font-family:SF Pro Display;src:url(/assets/SF-Pro-Display-Regular-2nqpBkwV.otf) format("opentype");font-weight:400;font-style:normal}.header{display:flex;align-items:center;justify-content:center;gap:2rem;padding:1.5rem 0 2.5rem}.header-logo{height:60px;width:auto;display:block}.header-title{font-size:2rem;margin:0;line-height:1;color:#334155}@media(max-width:768px){.header{flex-direction:column;gap:1rem;padding:1rem 0}.header-logo{height:60px}.header-title{font-size:1.75rem;text-align:center}}:root{--bg-color: #f8fafc;--surface-color: #ffffff;--primary-color: #334155;--primary-glow: rgba(51, 65, 85, .05);--secondary-color: #64748b;--text-main: #0f172a;--text-dim: #64748b;--border-color: #e2e8f0;--glass-bg: #ffffff}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-color)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}*{box-sizing:border-box;margin:0;padding:0}body,input,button{font-family:SF Pro Display,-apple-system,sans-serif}html,body{height:100%;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);min-height:100dvh}#root{display:flex;flex-direction:column;padding:1rem 2rem;max-width:1400px;margin:0 auto;height:100vh;box-sizing:border-box;position:relative;--grid-header-font: .875rem;--grid-cell-font: .8rem;--grid-time-width: 70px;--session-code-font: .85rem;--session-group-font: .72rem;--session-weeks-font: .65rem;--grid-row-height: minmax(0, 1fr)}@media(max-width:768px){#root{padding:0 1rem;height:auto;min-height:100dvh;max-width:100%;display:flex;flex-direction:column;--grid-header-font: .7rem;--grid-cell-font: .6rem;--grid-time-width: 42px;--session-code-font: .7rem;--session-group-font: .6rem;--session-weeks-font: .55rem;--grid-row-height: 1fr}}.panel{background:var(--surface-color);border:1px solid var(--border-color);border-radius:.5rem;padding:1rem;display:flex;flex-direction:column;min-height:0}.swipe-hint,.tap-hint{display:none}@media(max-width:768px){.swipe-hint,.tap-hint{display:inline}}h1{font-size:1.875rem;font-weight:700;margin-bottom:2rem;color:var(--text-main)}.layout{display:grid;grid-template-columns:320px 1fr;gap:2rem;width:100%;flex:1;min-height:0;overflow:hidden}.panel-subjects{flex:1}.subjects-list{flex:1;overflow-y:auto;border:1px solid var(--border-color);border-radius:.375rem;background:var(--bg-color)}.schedule-section{display:flex;flex-direction:column;gap:1rem;flex:1;min-height:0}.desktop-hint{display:flex;align-items:center;gap:.5rem;font-size:.75rem;opacity:.6;color:var(--text-dim)}@media(max-width:1024px){.desktop-hint{display:none}.layout{display:flex;flex-direction:column;gap:1rem;width:100%}.layout-sidebar{display:contents}#root{height:auto;max-width:100%;padding:0 1rem}.panel-priority{order:1}.panel-selected{order:2}.panel-overlapping{order:3}.schedule-section{order:4;height:94dvh!important;min-height:94dvh!important;max-height:94dvh!important;flex-shrink:0;display:flex;flex-direction:column;gap:.75rem;padding:.5rem;margin:0;box-sizing:border-box}.panel-subjects{order:5}.subjects-list{max-height:200px;overflow-y:auto;flex:1;border:1px solid var(--border-color);border-radius:.375rem;background:var(--bg-color)}}.layout-sidebar{display:flex;flex-direction:column;gap:1rem;height:100%;min-height:0;z-index:10;position:relative}.controls-row{display:flex;gap:.75rem;flex-shrink:0;width:100%}.controls-row .panel{padding:.75rem .5rem;min-width:0}.controls-row h2{margin-bottom:.5rem!important;font-size:.75rem!important}@media(max-width:1024px){.controls-row{flex-direction:column}.controls-row .panel{flex:none!important}.controls-row h2{font-size:.9rem!important}}.swipe-hint{display:none;font-size:.75rem;color:var(--text-dim);opacity:.6;font-style:italic;margin-left:.75rem}@media(max-width:1024px){.swipe-hint{display:inline-block}}.btn-toggle{padding:.5rem .1rem;background:transparent;border:1px solid var(--border-color);color:var(--text-dim);cursor:pointer;transition:all .2s;font-weight:500;flex:1;text-align:center;font-size:.65rem!important;letter-spacing:-.02em}.btn-toggle:first-child{border-radius:.5rem 0 0 .5rem}.btn-toggle:last-child{border-radius:0 .5rem .5rem 0}.btn-toggle.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}@media(max-width:1024px){.btn-toggle{font-size:.9rem!important;padding:.4rem .2rem}}.selected-list-container{overflow-y:auto;min-height:0;display:flex;flex-direction:column;gap:.4rem;padding-right:4px}.selected-item{display:flex;justify-content:space-between;align-items:center;padding:.35rem .6rem;border-radius:.375rem;margin-bottom:.3rem;transition:all .2s;border:1px solid var(--border-color);background:var(--surface-color);position:relative;font-size:.8rem}.selected-item-name{flex:1;cursor:pointer;transition:all .2s}.selected-item-name:hover{text-decoration:line-through;color:#ef4444}.selected-item-groups-btn{padding:.25rem .5rem;border-radius:4px;background:#f1f5f9;color:#475569;font-size:.75rem;cursor:pointer;border:1px solid var(--border-color);transition:all .2s;margin-left:.5rem;white-space:nowrap;font-weight:500}.selected-item-groups-btn:hover{border-color:var(--border-color);background:var(--surface-color)}.groups-popover{position:fixed;background:#1e293b;border:1px solid #334155;border-radius:.5rem;box-shadow:0 10px 15px -3px #0003;padding:.75rem;z-index:2000;min-width:130px;display:flex;flex-direction:column;gap:.25rem;pointer-events:none}.groups-popover-item{font-size:.75rem;color:#f8fafc;padding:.2rem .4rem;border-bottom:1px solid #334155}.groups-popover-item:last-child{border-bottom:none}.grid-container{overflow:auto;border-radius:.5rem;border:1px solid var(--border-color);max-width:100%;width:100%;background-color:var(--surface-color);transition:background-color .2s ease-in-out;flex:1;min-height:0;z-index:1;position:relative}.nav-panel{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:.5rem 1.25rem}@media(max-width:768px){.nav-panel{flex-direction:column;gap:1rem;padding:1rem}}.nav-panel{position:relative}@media(max-width:768px){.hide-mobile{display:none!important}}@keyframes scheduleFadeIn{0%{opacity:0}to{opacity:1}}.animate-subject-fade{animation:scheduleFadeIn .1s ease-out forwards}.schedule-block{transition:opacity .1s ease-in-out;line-height:1.2}.schedule-block span{display:inline-block}@media(max-width:480px){.schedule-block{padding:.1rem .2rem!important}.schedule-block span:first-child{font-size:.65rem!important}.schedule-block span:last-child{font-size:.55rem!important}}.warn-bg{background-color:#f8717126!important}.github-link{position:absolute;top:1.5rem;right:2rem;display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--surface-color);border:1px solid var(--border-color);border-radius:50%;color:var(--primary-color);transition:all .2s;box-shadow:0 1px 3px #0000000d;z-index:1000}.github-link:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a;color:var(--primary-color);background:var(--bg-color)}@media(max-width:1024px){.github-link{top:1rem;right:1rem;width:36px;height:36px}}.footer-disclaimer{text-align:center;padding:1.25rem 1rem .25rem;font-size:.72rem;color:var(--text-dim);font-style:italic;opacity:.6;max-width:700px;margin:0 auto;line-height:1.4}.footer-disclaimer strong{color:var(--secondary-color);font-style:normal;font-weight:700}@media(max-width:768px){.footer-disclaimer{font-size:.65rem;padding:.75rem 1rem 1.25rem;opacity:.5}}
